de.ts 185 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471
  1. export default {
  2. // Navigation
  3. nav: {
  4. printers: 'Drucker',
  5. archives: 'Archiv',
  6. queue: 'Warteschlange',
  7. stats: 'Statistiken',
  8. profiles: 'Profile',
  9. maintenance: 'Wartung',
  10. projects: 'Projekte',
  11. inventory: 'Filament',
  12. files: 'Dateimanager',
  13. settings: 'Einstellungen',
  14. system: 'System',
  15. collapseSidebar: 'Seitenleiste einklappen',
  16. expandSidebar: 'Seitenleiste ausklappen',
  17. update: 'Update',
  18. updateAvailable: 'Update verfügbar: v{{version}}',
  19. updateAvailableBanner: 'Version {{version}} ist verfügbar!',
  20. viewUpdate: 'Update anzeigen',
  21. viewOnGithub: 'Auf GitHub ansehen',
  22. keyboardShortcuts: 'Tastaturkürzel (?)',
  23. switchToLight: 'Zum hellen Modus wechseln',
  24. switchToDark: 'Zum dunklen Modus wechseln',
  25. smartSwitches: 'Smart Switches',
  26. logout: 'Abmelden',
  27. },
  28. // Common
  29. common: {
  30. save: 'Speichern',
  31. saving: 'Speichern...',
  32. cancel: 'Abbrechen',
  33. delete: 'Löschen',
  34. edit: 'Bearbeiten',
  35. add: 'Hinzufügen',
  36. close: 'Schließen',
  37. confirm: 'Bestätigen',
  38. loading: 'Lädt...',
  39. error: 'Fehler',
  40. success: 'Erfolg',
  41. warning: 'Warnung',
  42. enabled: 'Aktiviert',
  43. disabled: 'Deaktiviert',
  44. yes: 'Ja',
  45. no: 'Nein',
  46. on: 'An',
  47. off: 'Aus',
  48. all: 'Alle',
  49. none: 'Keine',
  50. search: 'Suchen',
  51. filter: 'Filtern',
  52. sort: 'Sortieren',
  53. refresh: 'Aktualisieren',
  54. download: 'Herunterladen',
  55. upload: 'Hochladen',
  56. uploading: 'Hochladen...',
  57. uploadFailed: 'Hochladen fehlgeschlagen',
  58. actions: 'Aktionen',
  59. status: 'Status',
  60. name: 'Name',
  61. description: 'Beschreibung',
  62. date: 'Datum',
  63. time: 'Zeit',
  64. hours: 'Stunden',
  65. minutes: 'Minuten',
  66. seconds: 'Sekunden',
  67. days: 'Tage',
  68. enable: 'Aktivieren',
  69. disable: 'Deaktivieren',
  70. permissions: 'Berechtigungen',
  71. noPrinters: 'Keine Drucker konfiguriert',
  72. noData: 'Keine Daten verfügbar',
  73. linkNotFound: 'Link nicht gefunden',
  74. required: 'Erforderlich',
  75. optional: 'Optional',
  76. dismiss: 'Schließen',
  77. apply: 'Anwenden',
  78. reset: 'Zurücksetzen',
  79. export: 'Exportieren',
  80. import: 'Importieren',
  81. clear: 'Leeren',
  82. selectAll: 'Alle auswählen',
  83. deselectAll: 'Auswahl aufheben',
  84. noChange: '— Keine Änderung —',
  85. unchanged: 'Unverändert',
  86. unassigned: 'Nicht zugewiesen',
  87. unknown: 'Unbekannt',
  88. unknownError: 'Unbekannter Fehler',
  89. today: 'Heute',
  90. tomorrow: 'Morgen',
  91. asap: 'Sofort',
  92. overdue: 'Überfällig',
  93. now: 'Jetzt',
  94. collapse: 'Einklappen',
  95. expand: 'Ausklappen',
  96. viewArchive: 'Archiv anzeigen',
  97. viewInFileManager: 'Im Dateimanager anzeigen',
  98. addedBy: 'Hinzugefügt von {{username}}',
  99. prints: 'Drucke',
  100. more: '+{{count}} weitere',
  101. ascending: 'Aufsteigend',
  102. descending: 'Absteigend',
  103. printer: 'Drucker',
  104. remove: 'Entfernen',
  105. type: 'Typ',
  106. print: 'Drucken',
  107. rename: 'Umbenennen',
  108. move: 'Verschieben',
  109. create: 'Erstellen',
  110. duplicate: 'Duplizieren',
  111. left: 'Links',
  112. right: 'Rechts',
  113. },
  114. // Printers page
  115. printers: {
  116. title: 'Drucker',
  117. addPrinter: 'Drucker hinzufügen',
  118. editPrinter: 'Drucker bearbeiten',
  119. deletePrinter: 'Drucker löschen',
  120. printerName: 'Druckername',
  121. serialNumber: 'Seriennummer',
  122. ipAddress: 'IP-Adresse / Hostname',
  123. accessCode: 'Zugangscode',
  124. model: 'Modell',
  125. nozzleCount: 'Düsenanzahl',
  126. autoArchive: 'Automatische Archivierung',
  127. status: {
  128. available: 'Verfügbar',
  129. idle: 'Bereit',
  130. printing: 'Druckt',
  131. paused: 'Pausiert',
  132. offline: 'Offline',
  133. error: 'Fehler',
  134. finished: 'Fertig',
  135. unknown: 'Unbekannt',
  136. },
  137. temperatures: {
  138. nozzle: 'Düse',
  139. bed: 'Druckbett',
  140. chamber: 'Kammer',
  141. },
  142. progress: '{{percent}}% abgeschlossen',
  143. timeRemaining: 'Noch {{time}}',
  144. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen?',
  145. maintenanceOk: 'Wartung OK',
  146. maintenanceWarning: '{{count}} Warnung',
  147. maintenanceWarning_plural: '{{count}} Warnungen',
  148. maintenanceDue: '{{count}} fällig',
  149. maintenanceDue_plural: '{{count}} fällig',
  150. // Sort options
  151. sort: {
  152. name: 'Name',
  153. status: 'Status',
  154. model: 'Modell',
  155. location: 'Standort',
  156. ascending: 'Aufsteigend sortieren',
  157. descending: 'Absteigend sortieren',
  158. },
  159. // Card size
  160. cardSize: {
  161. small: 'Kleine Karten',
  162. medium: 'Mittlere Karten',
  163. large: 'Große Karten',
  164. extraLarge: 'Extra große Karten',
  165. },
  166. // Controls
  167. hideOffline: 'Offline ausblenden',
  168. nextAvailable: 'Nächster verfügbar',
  169. powerOn: 'Einschalten',
  170. offlinePrintersWithPlugs: 'Offline-Drucker mit Smart-Plugs',
  171. noPrintersConfigured: 'Noch keine Drucker konfiguriert',
  172. // Printer card
  173. readyToPrint: 'Druckbereit',
  174. external: 'Extern',
  175. extL: 'Ext-L',
  176. extR: 'Ext-R',
  177. deleteArchives: 'Druckarchive löschen',
  178. noLabel: 'Keine Bezeichnung',
  179. printPreview: 'Druckvorschau',
  180. width: 'Breite',
  181. height: 'Höhe',
  182. noObjectsFound: 'Keine Objekte gefunden',
  183. objectsLoadedOnPrintStart: 'Objekte werden beim Druckstart geladen',
  184. willBeSkipped: 'Wird übersprungen',
  185. name: 'Name',
  186. serialCannotBeChanged: 'Seriennummer kann nicht geändert werden',
  187. locationHelp: 'Dient zur Gruppierung von Druckern und zum Filtern von Warteschlangenaufträgen',
  188. // WiFi signal strength
  189. wifiSignal: {
  190. veryWeak: 'Sehr schwach',
  191. weak: 'Schwach',
  192. fair: 'Ausreichend',
  193. good: 'Gut',
  194. excellent: 'Ausgezeichnet',
  195. },
  196. // Maintenance
  197. maintenanceUpToDate: 'Alle Wartungen aktuell - Klicken zum Anzeigen',
  198. // Chamber light
  199. chamberLightOn: 'Kammerbeleuchtung einschalten',
  200. chamberLightOff: 'Kammerbeleuchtung ausschalten',
  201. // Files
  202. files: 'Dateien',
  203. browseFiles: 'Druckerdateien durchsuchen',
  204. // Smart plug
  205. autoOffAfterPrint: 'Automatisches Ausschalten nach Druck',
  206. autoOffExecuted: 'Auto-off wurde ausgeführt - Drucker einschalten zum Zurücksetzen',
  207. // HMS errors
  208. hmsErrors: 'HMS-Fehler',
  209. viewHmsErrors: '{{count}} HMS-Fehler anzeigen',
  210. // Actions
  211. resume: 'Fortsetzen',
  212. pause: 'Pausieren',
  213. stop: 'Stoppen',
  214. camera: 'Kamera',
  215. skipObject: 'Objekt überspringen',
  216. reconnect: 'Neu verbinden',
  217. mqttDebug: 'MQTT-Debug',
  218. printerInformation: 'Druckerinformationen',
  219. copyToClipboard: 'Kopieren',
  220. copied: 'Kopiert!',
  221. state: 'Zustand',
  222. wifiSignalLabel: 'WLAN-Signal',
  223. developerMode: 'Entwicklermodus',
  224. enabled: 'Aktiviert',
  225. disabled: 'Deaktiviert',
  226. addedOn: 'Hinzugefügt',
  227. sdCard: 'SD-Karte',
  228. inserted: 'Eingelegt',
  229. notInserted: 'Nicht eingelegt',
  230. totalPrintHours: 'Druckstunden',
  231. activeNozzle: 'Aktiv: {{nozzle}} Düse',
  232. nozzleRack: 'Düsenhalter',
  233. nozzleDocked: 'Angedockt',
  234. nozzleMounted: 'Montiert',
  235. nozzleActive: 'Aktiv',
  236. nozzleIdle: 'Inaktiv',
  237. nozzleDiameter: 'Durchmesser',
  238. nozzleType: 'Typ',
  239. nozzleStatus: 'Status',
  240. nozzleFilament: 'Filament',
  241. nozzleWear: 'Verschleiß',
  242. nozzleMaxTemp: 'Max Temp',
  243. nozzleSerial: 'Seriennr.',
  244. nozzleHardenedSteel: 'Gehärteter Stahl',
  245. nozzleStainlessSteel: 'Edelstahl',
  246. nozzleTungstenCarbide: 'Wolframkarbid',
  247. nozzleFlow: 'Durchfluss',
  248. nozzleHighFlow: 'High Flow',
  249. nozzleStandardFlow: 'Standard',
  250. // Firmware
  251. firmwareUpdate: 'Firmware-Update',
  252. firmwareInstructions: 'Gehen Sie auf dem Touchscreen des Druckers zu',
  253. firmwareNav: 'Navigieren Sie zu',
  254. settings: 'Einstellungen',
  255. firmware: 'Firmware',
  256. // Discovery
  257. discoverPrinters: 'Drucker entdecken',
  258. searching: 'Suche...',
  259. manualEntry: 'Manuelle Eingabe',
  260. addFromCloud: 'Aus Cloud hinzufügen',
  261. // Toast messages
  262. toast: {
  263. printerDeleted: 'Drucker gelöscht',
  264. printerAdded: 'Drucker hinzugefügt',
  265. printerUpdated: 'Drucker aktualisiert',
  266. failedToDelete: 'Drucker konnte nicht gelöscht werden',
  267. failedToAdd: 'Drucker konnte nicht hinzugefügt werden',
  268. failedToUpdate: 'Drucker konnte nicht aktualisiert werden',
  269. commandSent: 'Befehl gesendet',
  270. failedToSendCommand: 'Befehl konnte nicht gesendet werden',
  271. turnedOn: '{{name}} eingeschaltet',
  272. failedToPowerOn: '{{name}} konnte nicht eingeschaltet werden',
  273. scriptTriggered: 'Skript ausgelöst',
  274. printStopped: 'Druck gestoppt',
  275. printPaused: 'Druck pausiert',
  276. printResumed: 'Druck fortgesetzt',
  277. referenceDeleted: 'Referenz gelöscht',
  278. detectionAreaSaved: 'Erkennungsbereich gespeichert',
  279. failedToRunScript: 'Skript konnte nicht ausgeführt werden',
  280. failedToStopPrint: 'Druck konnte nicht gestoppt werden',
  281. failedToPausePrint: 'Druck konnte nicht pausiert werden',
  282. failedToResumePrint: 'Druck konnte nicht fortgesetzt werden',
  283. failedToControlChamberLight: 'Kammerbeleuchtung konnte nicht gesteuert werden',
  284. failedToUpdateSetting: 'Einstellung konnte nicht aktualisiert werden',
  285. failedToSkipObjects: 'Objekte konnten nicht übersprungen werden',
  286. failedToRereadRfid: 'RFID konnte nicht erneut gelesen werden',
  287. failedToCheckPlate: 'Platte konnte nicht überprüft werden',
  288. failedToUpdateLabel: 'Bezeichnung konnte nicht aktualisiert werden',
  289. failedToDeleteReference: 'Referenz konnte nicht gelöscht werden',
  290. failedToSaveDetectionArea: 'Erkennungsbereich konnte nicht gespeichert werden',
  291. plateCheckEnabled: 'Plattenprüfung aktiviert',
  292. plateCheckDisabled: 'Plattenprüfung deaktiviert',
  293. calibrationSaved: 'Kalibrierung gespeichert!',
  294. calibrationFailed: 'Kalibrierung fehlgeschlagen',
  295. rfidRereadInitiated: 'RFID-Neueinlesen gestartet',
  296. },
  297. // Connection status
  298. connection: {
  299. connected: 'Verbunden',
  300. offline: 'Offline',
  301. },
  302. // Queue info
  303. queue: {
  304. inQueue: '{{count}} Druck in Warteschlange',
  305. inQueue_plural: '{{count}} Drucke in Warteschlange',
  306. },
  307. // Controls section
  308. controls: 'Steuerung',
  309. // RFID
  310. rfid: {
  311. reread: 'RFID neu lesen',
  312. },
  313. // Permissions
  314. permission: {
  315. noAdd: 'Sie haben keine Berechtigung, Drucker hinzuzufügen',
  316. noEdit: 'Sie haben keine Berechtigung, Drucker zu bearbeiten',
  317. noDelete: 'Sie haben keine Berechtigung, Drucker zu löschen',
  318. noControl: 'Sie haben keine Berechtigung, Drucker zu steuern',
  319. noFiles: 'Sie haben keine Berechtigung, auf Druckerdateien zuzugreifen',
  320. noAmsRfid: 'Sie haben keine Berechtigung, AMS-RFID erneut zu lesen',
  321. noSmartPlugControl: 'Sie haben keine Berechtigung, Smart Plugs zu steuern',
  322. noCamera: 'Sie haben keine Berechtigung, Kameras anzuzeigen',
  323. },
  324. // Add/Edit modal
  325. modal: {
  326. addTitle: 'Drucker hinzufügen',
  327. editTitle: 'Drucker bearbeiten',
  328. myPrinter: 'Mein Drucker',
  329. selectModel: 'Modell auswählen...',
  330. locationGroup: 'Standort / Gruppe (optional)',
  331. locationPlaceholder: 'z.B. Werkstatt, Büro, Keller',
  332. autoArchiveLabel: 'Abgeschlossene Drucke automatisch archivieren',
  333. fromPrinterSettings: 'Aus Druckereinstellungen',
  334. modelOptional: 'Modell (optional)',
  335. saveChanges: 'Änderungen speichern',
  336. },
  337. // Skip objects
  338. skipObjects: {
  339. tooltip: 'Objekte überspringen',
  340. onlyWhilePrinting: 'Objekte überspringen (nur während des Drucks)',
  341. requiresMultiple: 'Objekte überspringen (erfordert 2+ Objekte)',
  342. title: 'Objekte überspringen',
  343. matchIdsInfo: 'IDs mit Drucker-Display abgleichen',
  344. printerShowsIds: 'Der Druckerbildschirm zeigt Objekt-IDs auf der Bauplatte',
  345. skipSelected: 'Ausgewählte überspringen',
  346. skipping: 'Überspringe...',
  347. noObjectsSelected: 'Keine Objekte ausgewählt',
  348. selectObjectsToSkip: 'Wählen Sie Objekte aus, die Sie vom aktuellen Druck überspringen möchten',
  349. skipped: 'übersprungen',
  350. objectsSkipped: 'Objekte übersprungen',
  351. activeCount: '{{count}} aktiv',
  352. waitForLayer: 'Warten Sie auf Schicht 2+ zum Überspringen von Objekten (aktuell Schicht {{layer}})',
  353. skip: 'Überspringen',
  354. confirmTitle: 'Objekt überspringen?',
  355. confirmMessage: 'Möchten Sie "{{name}}" wirklich überspringen? Dies kann nicht rückgängig gemacht werden.',
  356. },
  357. // Confirm modals
  358. confirm: {
  359. deleteTitle: 'Drucker löschen',
  360. deleteMessage: 'Möchten Sie "{{name}}" wirklich löschen? Alle Verbindungseinstellungen werden entfernt.',
  361. deleteArchivesNote: 'Der gesamte Druckverlauf für diesen Drucker wird dauerhaft gelöscht.',
  362. keepArchivesNote: 'Der Druckverlauf wird beibehalten, aber nicht mehr mit diesem Drucker verknüpft.',
  363. stopTitle: 'Druck stoppen',
  364. stopMessage: 'Möchten Sie den aktuellen Druck auf "{{name}}" wirklich stoppen? Der Druckauftrag wird abgebrochen.',
  365. stopButton: 'Druck stoppen',
  366. pauseTitle: 'Druck pausieren',
  367. pauseMessage: 'Möchten Sie den aktuellen Druck auf "{{name}}" wirklich pausieren?',
  368. pauseButton: 'Druck pausieren',
  369. resumeTitle: 'Druck fortsetzen',
  370. resumeMessage: 'Möchten Sie den Druck auf "{{name}}" fortsetzen?',
  371. resumeButton: 'Druck fortsetzen',
  372. powerOnTitle: 'Drucker einschalten',
  373. powerOnMessage: 'Möchten Sie die Stromversorgung für "{{name}}" wirklich EINSCHALTEN?',
  374. powerOnButton: 'Einschalten',
  375. powerOffTitle: 'Drucker ausschalten',
  376. powerOffMessage: 'Möchten Sie die Stromversorgung für "{{name}}" wirklich AUSSCHALTEN?',
  377. powerOffWarning: 'WARNUNG: "{{name}}" druckt gerade! Möchten Sie die Stromversorgung wirklich AUSSCHALTEN? Dies unterbricht den Druck und kann den Drucker beschädigen.',
  378. powerOffButton: 'Ausschalten',
  379. },
  380. // Discovery
  381. discovery: {
  382. title: 'Drucker entdecken',
  383. searching: 'Suche...',
  384. scanning: 'Scanne...',
  385. scanProgress: 'Scanne... {{scanned}}/{{total}}',
  386. foundPrinters: '{{count}} Drucker gefunden',
  387. noPrintersFound: 'Keine Drucker gefunden',
  388. noPrintersFoundSubnet: 'Keine Drucker im angegebenen Subnetz gefunden.',
  389. noPrintersFoundNetwork: 'Keine Drucker im Netzwerk gefunden.',
  390. allConfigured: 'Alle erkannten Drucker sind bereits konfiguriert.',
  391. alreadyAdded: 'Bereits hinzugefügt',
  392. select: 'Auswählen',
  393. manualEntry: 'Manuelle Eingabe',
  394. addFromCloud: 'Aus Cloud hinzufügen',
  395. subnetToScan: 'Zu scannendes Subnetz',
  396. dockerNote: 'Docker erkannt. Geben Sie das Subnetz Ihres Druckers in CIDR-Notation ein. Erfordert network_mode: host in docker-compose.yml.',
  397. scanSubnet: 'Subnetz nach Druckern scannen',
  398. discoverNetwork: 'Drucker im Netzwerk suchen',
  399. scanningSubnet: 'Subnetz wird nach Bambu-Druckern gescannt...',
  400. scanningNetwork: 'Netzwerk wird gescannt...',
  401. serialRequired: 'Seriennummer erforderlich',
  402. unknown: 'Unbekannt',
  403. failedToStart: 'Erkennung konnte nicht gestartet werden',
  404. },
  405. // AMS Drying
  406. drying: {
  407. start: 'Trocknung starten',
  408. stop: 'Trocknung stoppen',
  409. temperature: 'Temperatur',
  410. duration: 'Dauer',
  411. hours: 'Stunden',
  412. timeRemaining: '{{time}} verbleibend',
  413. active: 'Trocknung',
  414. notSupported: 'Trocknung nicht unterstützt',
  415. startingDrying: 'Trocknung wird gestartet...',
  416. stoppingDrying: 'Trocknung wird gestoppt...',
  417. },
  418. // Filaments section
  419. filaments: 'Filamente',
  420. // Camera
  421. openCameraOverlay: 'Kamera-Overlay öffnen',
  422. openCameraWindow: 'Kamera in neuem Fenster öffnen',
  423. // Firmware
  424. firmwareUpdateAvailable: 'Firmware-Update verfügbar: {{current}} → {{latest}}',
  425. firmwareUpToDate: 'Firmware {{version}} — Aktuell',
  426. firmwareUpdateButton: 'Update',
  427. // Plate detection
  428. plateDetection: {
  429. noPermission: 'Sie haben keine Berechtigung, Drucker zu aktualisieren',
  430. enabledClick: 'Plattenprüfung aktiviert - Klicken zum Deaktivieren',
  431. disabledClick: 'Plattenprüfung deaktiviert - Klicken zum Aktivieren',
  432. manageCalibration: 'Platten-Erkennungskalibrierung verwalten',
  433. calibrationRequired: 'Kalibrierung erforderlich',
  434. calibrationInstructions: 'Bitte stellen Sie sicher, dass die Druckplatte <strong>vollständig leer</strong> ist, und klicken Sie dann auf Kalibrieren.',
  435. calibrationDescription: 'Die Kalibrierung erfasst ein Referenzbild der leeren Platte. Zukünftige Prüfungen vergleichen mit dieser Referenz, um Objekte zu erkennen.',
  436. calibrationTip: '<strong>Tipp:</strong> Sie können bis zu 5 Kalibrierungen für verschiedene Platten speichern. Das System verwendet automatisch die beste Übereinstimmung bei der Prüfung.',
  437. plateEmpty: 'Platte erscheint leer',
  438. objectsDetected: 'Objekte auf Platte erkannt',
  439. confidence: 'Konfidenz',
  440. difference: 'Differenz',
  441. analysisPreview: 'Analysevorschau:',
  442. analysisLegend: 'Grüner Rahmen = Erkennungsbereich, Rote Überlagerung = Unterschiede zur Kalibrierung',
  443. savedReferences: 'Gespeicherte Referenzen ({{count}}/{{max}})',
  444. deleteReference: 'Referenz löschen',
  445. labelPlaceholder: 'Bezeichnung...',
  446. clickToEdit: '{{label}} - Zum Bearbeiten klicken',
  447. clickToAddLabel: 'Zum Hinzufügen einer Bezeichnung klicken',
  448. },
  449. // Fans
  450. fans: {
  451. partCooling: 'Bauteilkühlung',
  452. auxiliary: 'Hilfsventilator',
  453. chamber: 'Kammerventilator',
  454. },
  455. // HMS errors
  456. clickToViewHmsErrors: 'Klicken, um HMS-Fehler anzuzeigen',
  457. estimatedCompletion: 'Geschätzte Fertigstellungszeit',
  458. slotOptions: 'Slot-Optionen',
  459. // AMS hover popup
  460. amsPopup: {
  461. friendlyName: 'AMS-Name',
  462. friendlyNamePlaceholder: 'z. B. AMS-Anzeigename',
  463. serialNumber: 'Seriennummer',
  464. firmwareVersion: 'Firmware',
  465. save: 'Speichern',
  466. clear: 'Löschen',
  467. noEditPermission: 'Sie haben keine Berechtigung, AMS-Einheiten umzubenennen',
  468. },
  469. // Firmware modal
  470. firmwareModal: {
  471. title: 'Firmware-Update',
  472. titleUpToDate: 'Firmware-Info',
  473. currentVersion: 'Aktuell:',
  474. latestVersion: 'Neueste:',
  475. releaseNotes: 'Versionshinweise',
  476. checkingPrereqs: 'Prüfe Voraussetzungen...',
  477. sdCardReady: 'SD-Karte bereit. Klicken Sie unten, um die Firmware hochzuladen.',
  478. uploadedSuccess: 'Firmware auf SD-Karte hochgeladen!',
  479. applyInstructions: 'So wenden Sie das Update auf Ihrem Drucker an:',
  480. step1: 'Gehen Sie auf dem Touchscreen des Druckers zu <strong>Einstellungen</strong>',
  481. step2: 'Navigieren Sie zu <strong>Firmware</strong>',
  482. step3: 'Wählen Sie <strong>Update von SD-Karte</strong>',
  483. step4: 'Das Update dauert 10-20 Minuten',
  484. done: 'Fertig',
  485. starting: 'Starte...',
  486. uploadFirmware: 'Firmware hochladen',
  487. uploadFailed: 'Upload fehlgeschlagen: {{error}}',
  488. uploadedToast: 'Firmware hochgeladen! Starten Sie das Update vom Druckerbildschirm.',
  489. },
  490. accessCodePlaceholder: 'Leer lassen, um den aktuellen zu behalten',
  491. // ROI editor
  492. roi: {
  493. title: 'Erkennungsbereich (ROI)',
  494. xStart: 'X-Start',
  495. yStart: 'Y-Start',
  496. width: 'Breite',
  497. height: 'Höhe',
  498. instruction: 'Passen Sie den Erkennungsbereich an, um sich auf die Druckplatte zu konzentrieren. Der grüne Rahmen in der Vorschau zeigt den aktuellen Bereich.',
  499. },
  500. developerModeWarning: 'Der Entwickler-LAN-Modus ist nicht aktiviert auf: {{names}}. Einige Funktionen funktionieren möglicherweise nicht.',
  501. howToEnable: 'Aktivieren',
  502. incompatibleFile: 'Diese Datei wurde für {{slicedFor}} geslicet, aber dieser Drucker ist ein {{printerModel}}',
  503. dropNotPrintable: 'Nur .gcode- und .gcode.3mf-Dateien können gedruckt werden',
  504. dropToPrint: 'Zum Drucken ablegen',
  505. cannotPrint: 'Drucker beschäftigt',
  506. },
  507. // Archives page
  508. archives: {
  509. title: 'Druckarchiv',
  510. searchPlaceholder: 'Archiv durchsuchen...',
  511. filterByPrinter: 'Nach Drucker filtern',
  512. filterByStatus: 'Nach Status filtern',
  513. sortBy: 'Sortieren nach',
  514. sortNewest: 'Neueste zuerst',
  515. sortOldest: 'Älteste zuerst',
  516. sortName: 'Name',
  517. sortDuration: 'Dauer',
  518. sortLargest: 'Größte zuerst',
  519. sortSmallest: 'Kleinste zuerst',
  520. sortSize: 'Größe',
  521. noArchives: 'Keine Archive gefunden',
  522. noArchivesSearch: 'Keine Archive entsprechen Ihrer Suche',
  523. noArchivesYet: 'Noch keine Archive',
  524. loadingArchives: 'Lade Archive...',
  525. releaseToUpload: 'Loslassen zum Hochladen',
  526. showAll: 'Alle anzeigen',
  527. showFavoritesOnly: 'Nur Favoriten anzeigen',
  528. gridView: 'Rasteransicht',
  529. listView: 'Listenansicht',
  530. calendarView: 'Kalenderansicht',
  531. logView: 'Druckprotokoll',
  532. manageTags: 'Tags verwalten',
  533. showFailedPrints: 'Fehlgeschlagene Drucke anzeigen',
  534. hideFailedPrints: 'Fehlgeschlagene Drucke ausblenden',
  535. printTime: 'Druckzeit',
  536. filamentUsed: 'Verbrauchtes Filament',
  537. cost: 'Kosten',
  538. reprint: 'Drucken',
  539. preview: 'Vorschau',
  540. deleteArchive: 'Archiv löschen',
  541. deleteConfirm: 'Möchten Sie dieses Archiv wirklich löschen?',
  542. favorite: 'Favorit',
  543. unfavorite: 'Aus Favoriten entfernen',
  544. viewDetails: 'Details anzeigen',
  545. status: {
  546. completed: 'Abgeschlossen',
  547. failed: 'Fehlgeschlagen',
  548. stopped: 'Gestoppt',
  549. },
  550. toast: {
  551. source3mfAttached: 'Quell-3MF angehängt: {{filename}}',
  552. failedUploadSource3mf: 'Fehler beim Hochladen der Quell-3MF',
  553. source3mfRemoved: 'Quell-3MF entfernt',
  554. failedRemoveSource3mf: 'Fehler beim Entfernen der Quell-3MF',
  555. f3dAttached: 'F3D angehängt: {{filename}}',
  556. failedUploadF3d: 'Fehler beim Hochladen der F3D',
  557. f3dRemoved: 'F3D entfernt',
  558. failedRemoveF3d: 'Fehler beim Entfernen der F3D',
  559. timelapseAttached: 'Zeitraffer angehängt: {{filename}}',
  560. timelapseAlreadyAttached: 'Zeitraffer bereits angehängt',
  561. noMatchingTimelapse: 'Kein passender Zeitraffer gefunden',
  562. failedScanTimelapse: 'Fehler beim Suchen nach Zeitraffer',
  563. failedAttachTimelapse: 'Fehler beim Anhängen des Zeitraffers',
  564. timelapseRemoved: 'Zeitraffer entfernt',
  565. failedRemoveTimelapse: 'Fehler beim Entfernen des Zeitraffers',
  566. timelapseUploaded: 'Zeitraffer hochgeladen: {{filename}}',
  567. failedUploadTimelapse: 'Fehler beim Hochladen des Zeitraffers',
  568. archiveDeleted: 'Archiv gelöscht',
  569. failedDeleteArchive: 'Fehler beim Löschen des Archivs',
  570. addedToFavorites: 'Zu Favoriten hinzugefügt',
  571. removedFromFavorites: 'Aus Favoriten entfernt',
  572. projectUpdated: 'Projekt aktualisiert',
  573. failedUpdateProject: 'Fehler beim Aktualisieren des Projekts',
  574. linkCopied: 'Link in die Zwischenablage kopiert',
  575. failedCopyLink: 'Fehler beim Kopieren des Links',
  576. photoDeleted: 'Foto gelöscht',
  577. failedDeletePhoto: 'Fehler beim Löschen des Fotos',
  578. failedDeleteArchives: 'Fehler beim Löschen der Archive',
  579. failedUpdateFavorites: 'Fehler beim Aktualisieren der Favoriten',
  580. exportDownloaded: 'Export heruntergeladen',
  581. exportFailed: 'Export fehlgeschlagen',
  582. },
  583. menu: {
  584. print: 'Drucken',
  585. schedule: 'Planen',
  586. openInBambuStudio: 'Im Slicer öffnen',
  587. slice: 'Slicen',
  588. externalLink: 'Externer Link',
  589. viewOnMakerWorld: 'Auf MakerWorld ansehen',
  590. preview3d: '3D-Vorschau',
  591. viewTimelapse: 'Zeitraffer ansehen',
  592. scanForTimelapse: 'Nach Zeitraffer suchen',
  593. uploadTimelapse: 'Zeitraffer hochladen',
  594. removeTimelapse: 'Zeitraffer entfernen',
  595. downloadSource3mf: 'Quell-3MF herunterladen',
  596. uploadSource3mf: 'Quell-3MF hochladen',
  597. replaceSource3mf: 'Quell-3MF ersetzen',
  598. removeSource3mf: 'Quell-3MF entfernen',
  599. uploadF3d: 'F3D hochladen',
  600. replaceF3d: 'F3D ersetzen',
  601. downloadF3d: 'F3D herunterladen',
  602. removeF3d: 'F3D entfernen',
  603. download: 'Herunterladen',
  604. copyDownloadLink: 'Download-Link kopieren',
  605. qrCode: 'QR-Code',
  606. viewPhotos: 'Fotos ansehen',
  607. viewPhotosCount: 'Fotos ansehen ({{count}})',
  608. projectPage: 'Projektseite',
  609. addToFavorites: 'Zu Favoriten hinzufügen',
  610. removeFromFavorites: 'Aus Favoriten entfernen',
  611. edit: 'Bearbeiten',
  612. goToProject: 'Zum Projekt: {{name}}',
  613. addToProject: 'Zu Projekt hinzufügen',
  614. removeFromProject: 'Aus Projekt entfernen',
  615. loading: 'Laden...',
  616. noProjectsAvailable: 'Keine Projekte verfügbar',
  617. select: 'Auswählen',
  618. deselect: 'Abwählen',
  619. delete: 'Löschen',
  620. },
  621. permission: {
  622. noReprint: 'Sie haben keine Berechtigung, dieses Archiv erneut zu drucken',
  623. noAddToQueue: 'Sie haben keine Berechtigung, zur Warteschlange hinzuzufügen',
  624. noUpdateArchives: 'Sie haben keine Berechtigung, Archive zu aktualisieren',
  625. noUploadFiles: 'Sie haben keine Berechtigung, Dateien hochzuladen',
  626. noDownload: 'Sie haben keine Berechtigung, Archive herunterzuladen',
  627. noCopyLink: 'Sie haben keine Berechtigung, Download-Links zu kopieren',
  628. noDelete: 'Sie haben keine Berechtigung, dieses Archiv zu löschen',
  629. noCreate: 'Sie haben keine Berechtigung, Archive zu erstellen',
  630. },
  631. card: {
  632. previousPlate: 'Vorherige Platte',
  633. nextPlate: 'Nächste Platte',
  634. plateNumber: 'Platte {{index}}',
  635. moreOptions: 'Rechtsklick für mehr Optionen',
  636. addToFavorites: 'Zu Favoriten hinzufügen',
  637. removeFromFavorites: 'Aus Favoriten entfernen',
  638. cancelled: 'abgebrochen',
  639. failed: 'fehlgeschlagen',
  640. duplicate: 'Duplikat',
  641. duplicateTitle: 'Dieses Modell wurde bereits zuvor gedruckt',
  642. openSource3mf: 'Quell-3MF in Bambu Studio öffnen (Rechtsklick für mehr Optionen)',
  643. downloadF3d: 'Fusion 360 Designdatei herunterladen',
  644. viewTimelapse: 'Zeitraffer ansehen',
  645. viewPhoto: '1 Foto ansehen',
  646. viewPhotos: '{{count}} Fotos ansehen',
  647. openFolder: 'Ordner öffnen: {{name}}',
  648. slicedFile: 'Geslicte Datei - druckbereit',
  649. sourceFile: 'Nur Quelldatei - keine AMS-Zuordnung verfügbar',
  650. gcode: 'GCODE',
  651. source: 'QUELLE',
  652. project: 'Projekt: {{name}}',
  653. estimated: 'Geschätzt: {{time}}',
  654. actual: 'Tatsächlich: {{time}}',
  655. accuracy: 'Genauigkeit: {{percent}}%',
  656. filament: '{{weight}}g',
  657. layer: '{{count}} Schicht',
  658. layers: '{{count}} Schichten',
  659. object: '{{count}} Objekt',
  660. objects: '{{count}} Objekte',
  661. slicedFor: 'Geslict für {{model}}',
  662. uploadedBy: 'Hochgeladen von',
  663. noPermissionReprint: 'Sie haben keine Berechtigung, erneut zu drucken',
  664. noFileForReprint: 'Keine 3MF-Datei verfügbar — die Datei konnte beim Aufzeichnen des Drucks nicht vom Drucker heruntergeladen werden',
  665. noPermissionEdit: 'Sie haben keine Berechtigung, Archive zu bearbeiten',
  666. noPermissionDelete: 'Sie haben keine Berechtigung, Archive zu löschen',
  667. reprint: 'Drucken',
  668. schedulePrint: 'Druck planen',
  669. schedule: 'Planen',
  670. openInBambuStudio: 'Im Slicer öffnen',
  671. openInBambuStudioToSlice: 'Im Slicer öffnen zum Slicen',
  672. slice: 'Slicen',
  673. externalLink: 'Externer Link',
  674. makerWorld: 'MakerWorld: {{designer}}',
  675. viewProject: 'Projekt ansehen',
  676. noExternalLink: 'Kein externer Link',
  677. preview3d: '3D-Vorschau',
  678. download: 'Herunterladen',
  679. edit: 'Bearbeiten',
  680. delete: 'Löschen',
  681. },
  682. modal: {
  683. deleteArchive: 'Archiv löschen',
  684. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen? Diese Aktion kann nicht rückgängig gemacht werden.',
  685. deleteButton: 'Löschen',
  686. removeSource3mf: 'Quell-3MF entfernen',
  687. removeSource3mfConfirm: 'Möchten Sie die Quell-3MF-Datei wirklich von "{{name}}" entfernen? Die ursprüngliche Slicer-Projektdatei wird gelöscht.',
  688. removeButton: 'Entfernen',
  689. removeF3d: 'F3D entfernen',
  690. removeF3dConfirm: 'Möchten Sie die Fusion 360 Designdatei wirklich von "{{name}}" entfernen?',
  691. removeTimelapse: 'Zeitraffer entfernen',
  692. removeTimelapseConfirm: 'Möchten Sie das Zeitraffervideo wirklich von "{{name}}" entfernen?',
  693. timelapse: '{{name}} - Zeitraffer',
  694. selectTimelapse: 'Zeitraffer auswählen',
  695. selectTimelapseDesc: 'Keine automatische Übereinstimmung gefunden. Wählen Sie den Zeitraffer für diesen Druck:',
  696. deleteArchives: 'Archive löschen',
  697. deleteArchivesConfirm: 'Möchten Sie wirklich {{count}} Archiv(e) löschen? Diese Aktion kann nicht rückgängig gemacht werden.',
  698. deleteCount: '{{count}} löschen',
  699. },
  700. page: {
  701. title: 'Archive',
  702. printsCount: '{{filtered}} von {{total}} Drucken',
  703. dropFilesHere: '.3mf-Dateien hier ablegen',
  704. releaseToUpload: 'Loslassen zum Hochladen',
  705. only3mfSupported: 'Nur .3mf-Dateien werden unterstützt',
  706. close: 'Schließen',
  707. selected: '{{count}} ausgewählt',
  708. selectAll: 'Alle auswählen',
  709. tags: 'Tags',
  710. project: 'Projekt',
  711. favorite: 'Favorit',
  712. delete: 'Löschen',
  713. toggledFavorites: 'Favoriten für {{count}} Archiv(e) umgeschaltet',
  714. failedUpdateFavorites: 'Fehler beim Aktualisieren der Favoriten',
  715. archivesDeleted: '{{count}} Archiv(e) gelöscht',
  716. failedDeleteArchives: 'Fehler beim Löschen der Archive',
  717. photoDeleted: 'Foto gelöscht',
  718. failedDeletePhoto: 'Fehler beim Löschen des Fotos',
  719. },
  720. list: {
  721. name: 'Name',
  722. printer: 'Drucker',
  723. date: 'Datum',
  724. size: 'Größe',
  725. actions: 'Aktionen',
  726. hasTimelapse: 'Hat Zeitraffer',
  727. },
  728. log: {
  729. date: 'Datum',
  730. printName: 'Druckname',
  731. printer: 'Drucker',
  732. user: 'Benutzer',
  733. status: 'Status',
  734. duration: 'Dauer',
  735. filament: 'Filament',
  736. allPrinters: 'Alle Drucker',
  737. allUsers: 'Alle Benutzer',
  738. allStatuses: 'Alle Status',
  739. cancelled: 'Abgebrochen',
  740. skipped: 'Übersprungen',
  741. dateFrom: 'Von',
  742. dateTo: 'Bis',
  743. noEntries: 'Keine Druckprotokolleinträge gefunden',
  744. showing: '{{count}} von {{total}} Einträgen',
  745. rowsPerPage: 'Zeilen',
  746. page: 'Seite',
  747. prev: 'Zurück',
  748. next: 'Weiter',
  749. clearLog: 'Protokoll löschen',
  750. clearLogTitle: 'Druckprotokoll löschen',
  751. clearLogConfirm: 'Alle Druckprotokolleinträge werden dauerhaft gelöscht. Archive und Warteschlangeneinträge sind nicht betroffen. Diese Aktion kann nicht rückgängig gemacht werden. Sind Sie sicher?',
  752. clearLogButton: 'Alle löschen',
  753. cleared: '{{count}} Protokolleinträge gelöscht',
  754. clearFailed: 'Druckprotokoll konnte nicht gelöscht werden',
  755. },
  756. },
  757. // Queue page
  758. queue: {
  759. title: 'Druckwarteschlange',
  760. subtitle: 'Planen und verwalten Sie Ihre Druckaufträge',
  761. addToQueue: 'Zur Warteschlange hinzufügen',
  762. // Print modal
  763. print: 'Drucken',
  764. reprint: 'Erneut drucken',
  765. schedulePrint: 'Druck planen',
  766. editQueueItem: 'Warteschlangeneintrag bearbeiten',
  767. printToPrinters: 'Auf {{count}} Druckern drucken',
  768. queueToPrinters: 'Zu {{count}} Druckern hinzufügen',
  769. queueAllPlates: 'Alle {{count}} Platten in die Warteschlange',
  770. printQueued: 'Druck in Warteschlange',
  771. itemsQueued: '{{count}} Einträge in Warteschlange',
  772. sending: 'Wird gesendet...',
  773. sendingProgress: 'Sende {{current}}/{{total}}...',
  774. adding: 'Wird hinzugefügt...',
  775. addingProgress: 'Füge hinzu {{current}}/{{total}}...',
  776. savingProgress: 'Speichere {{current}}/{{total}}...',
  777. clearQueue: 'Warteschlange leeren',
  778. clearHistory: 'Verlauf löschen',
  779. emptyQueue: 'Warteschlange ist leer',
  780. position: 'Position',
  781. scheduledTime: 'Geplante Zeit',
  782. moveUp: 'Nach oben',
  783. moveDown: 'Nach unten',
  784. startNow: 'Jetzt starten',
  785. printingInProgress: 'Druck läuft...',
  786. viewArchive: 'Archiv anzeigen',
  787. viewInFileManager: 'Im Dateimanager anzeigen',
  788. itemCount: '{{count}} Element',
  789. itemCount_plural: '{{count}} Elemente',
  790. dragToReorder: 'Ziehen zum Neuordnen (nur Sofort)',
  791. reorderHint: 'Position betrifft nur Sofort-Elemente. Geplante Elemente werden zur festgelegten Zeit ausgeführt.',
  792. addedBy: 'Hinzugefügt von {{name}}',
  793. nextInQueue: 'Nächster in der Warteschlange',
  794. clearPlate: 'Druckplatte freigeben & Nächsten starten',
  795. clearPlateSuccess: 'Druckplatte freigegeben — bereit für nächsten Druck',
  796. plateReady: 'Druckplatte freigegeben — bereit für nächsten Druck',
  797. plateNumber: 'Platte {{index}}',
  798. // Sections
  799. sections: {
  800. currentlyPrinting: 'Aktuell druckend',
  801. queued: 'In Warteschlange',
  802. history: 'Verlauf',
  803. },
  804. // Status
  805. status: {
  806. pending: 'Ausstehend',
  807. waiting: 'Wartend',
  808. printing: 'Druckt',
  809. paused: 'Pausiert',
  810. completed: 'Abgeschlossen',
  811. failed: 'Fehlgeschlagen',
  812. skipped: 'Übersprungen',
  813. cancelled: 'Abgebrochen',
  814. },
  815. // Summary cards
  816. summary: {
  817. printing: 'Druckt',
  818. queued: 'In Warteschlange',
  819. totalTime: 'Gesamte Wartezeit',
  820. totalWeight: 'Gesamtgewicht der Warteschlange',
  821. history: 'Verlauf',
  822. },
  823. // Filters
  824. filter: {
  825. allPrinters: 'Alle Drucker',
  826. unassigned: 'Nicht zugewiesen',
  827. allStatus: 'Alle Status',
  828. allLocations: 'Alle Standorte',
  829. any: 'Beliebig',
  830. },
  831. // Sort
  832. sort: {
  833. byPosition: 'Nach Position sortieren',
  834. byName: 'Nach Name sortieren',
  835. byPrinter: 'Nach Drucker sortieren',
  836. bySchedule: 'Nach Zeitplan sortieren',
  837. byDate: 'Nach Datum sortieren',
  838. ascendingOldest: 'Aufsteigend (älteste zuerst)',
  839. descendingNewest: 'Absteigend (neueste zuerst)',
  840. },
  841. // Badges
  842. badges: {
  843. staged: 'Bereitgestellt',
  844. requiresPrevious: 'Erfordert vorherigen Erfolg',
  845. autoPowerOff: 'Automatisch ausschalten',
  846. },
  847. // Empty state
  848. empty: {
  849. title: 'Keine Drucke geplant',
  850. description: 'Planen Sie einen Druck von der Archivseite über die Option "Planen" im Kontextmenü oder ziehen Sie Dateien hierher.',
  851. },
  852. // Time
  853. time: {
  854. asap: 'Sofort',
  855. overdue: 'Überfällig',
  856. now: 'Jetzt',
  857. lessThanMinute: 'In weniger als einer Minute',
  858. inMinutes: 'In {{count}} Min',
  859. inHours: 'In {{count}} Stunden',
  860. },
  861. // Actions
  862. actions: {
  863. stopPrint: 'Druck stoppen',
  864. startPrint: 'Druck starten',
  865. requeue: 'Erneut einreihen',
  866. },
  867. // Bulk edit
  868. bulkEdit: {
  869. title: '{{count}} Element bearbeiten',
  870. title_plural: '{{count}} Elemente bearbeiten',
  871. description: 'Nur geänderte Einstellungen werden auf ausgewählte Elemente angewendet.',
  872. printer: 'Drucker',
  873. noChange: '— Keine Änderung —',
  874. queueOptions: 'Warteschlangenoptionen',
  875. staged: 'Bereitgestellt (manueller Start)',
  876. autoPowerOff: 'Nach Druck automatisch ausschalten',
  877. requirePrevious: 'Vorherigen Erfolg erfordern',
  878. printOptions: 'Druckoptionen',
  879. bedLevelling: 'Bett-Nivellierung',
  880. flowCalibration: 'Fluss-Kalibrierung',
  881. vibrationCalibration: 'Vibrations-Kalibrierung',
  882. layerInspection: 'Erste-Schicht-Prüfung',
  883. timelapse: 'Zeitraffer',
  884. useAms: 'AMS verwenden',
  885. applyChanges: 'Änderungen übernehmen',
  886. selectAll: 'Alle auswählen',
  887. deselectAll: 'Auswahl aufheben',
  888. selected: '{{count}} ausgewählt',
  889. editSelected: 'Ausgewählte bearbeiten',
  890. cancelSelected: 'Ausgewählte abbrechen',
  891. },
  892. // Confirmations
  893. confirm: {
  894. cancelTitle: 'Geplanten Druck abbrechen',
  895. cancelMessage: 'Möchten Sie "{{name}}" wirklich abbrechen?',
  896. stopTitle: 'Druck stoppen',
  897. stopMessage: 'Möchten Sie den aktuellen Druck "{{name}}" wirklich stoppen? Der Druckauftrag wird am Drucker abgebrochen.',
  898. removeTitle: 'Aus Verlauf entfernen',
  899. removeMessage: 'Möchten Sie "{{name}}" wirklich aus dem Warteschlangenverlauf entfernen?',
  900. clearHistoryTitle: 'Verlauf löschen',
  901. clearHistoryMessage: 'Möchten Sie alle {{count}} Element(e) aus dem Verlauf entfernen?',
  902. cancelButton: 'Druck abbrechen',
  903. stopButton: 'Druck stoppen',
  904. thisPrint: 'diesen Druck',
  905. thisItem: 'dieses Element',
  906. },
  907. // Toast messages
  908. toast: {
  909. cancelled: 'Warteschlangenelement abgebrochen',
  910. cancelFailed: 'Element konnte nicht abgebrochen werden',
  911. removed: 'Warteschlangenelement entfernt',
  912. removeFailed: 'Element konnte nicht entfernt werden',
  913. stopped: 'Druck gestoppt',
  914. stopFailed: 'Druck konnte nicht gestoppt werden',
  915. released: 'Druck in Warteschlange freigegeben',
  916. startFailed: 'Druck konnte nicht gestartet werden',
  917. reorderFailed: 'Warteschlange konnte nicht neu geordnet werden',
  918. historyCleared: '{{count}} Verlaufselement(e) gelöscht',
  919. clearHistoryFailed: 'Verlauf konnte nicht gelöscht werden',
  920. updateFailed: 'Elemente konnten nicht aktualisiert werden',
  921. bulkCancelled: '{{count}} Element(e) abgebrochen',
  922. bulkCancelFailed: 'Elemente konnten nicht abgebrochen werden',
  923. },
  924. // Permissions
  925. permissions: {
  926. noStopPrint: 'Sie haben keine Berechtigung, Drucke zu stoppen',
  927. noStartPrint: 'Sie haben keine Berechtigung, Drucke zu starten',
  928. noEdit: 'Sie haben keine Berechtigung, dieses Warteschlangenelement zu bearbeiten',
  929. noCancel: 'Sie haben keine Berechtigung, dieses Warteschlangenelement abzubrechen',
  930. noRequeue: 'Sie haben keine Berechtigung, Elemente erneut einzureihen',
  931. noRemove: 'Sie haben keine Berechtigung, dieses Warteschlangenelement zu entfernen',
  932. noClearHistory: 'Sie haben keine Berechtigung, den gesamten Verlauf zu löschen',
  933. noEditItems: 'Sie haben keine Berechtigung, Warteschlangenelemente zu bearbeiten',
  934. noCancelItems: 'Sie haben keine Berechtigung, Warteschlangenelemente abzubrechen',
  935. },
  936. },
  937. backgroundDispatch: {
  938. unknownFile: 'Unbekannte Datei',
  939. unknownPrinter: 'Unbekannter Drucker',
  940. startingPrints: 'Starte Drucke',
  941. progressSummary: '{{complete}}/{{total}} abgeschlossen • Geplant: {{dispatched}} • In Bearbeitung: {{processing}}',
  942. expandDetails: 'Dispatch-Details ausklappen',
  943. collapseDetails: 'Dispatch-Details einklappen',
  944. dismissToast: 'Dispatch-Hinweis schließen',
  945. cancelDispatchJob: 'Dispatch-Job abbrechen',
  946. cancel: 'Abbrechen',
  947. cancelling: 'Wird abgebrochen…',
  948. status: {
  949. dispatched: 'Geplant',
  950. processing: 'In Bearbeitung',
  951. completed: 'Abgeschlossen',
  952. failed: 'Fehlgeschlagen',
  953. cancelled: 'Abgebrochen',
  954. },
  955. toast: {
  956. cancellingUpload: 'Upload wird abgebrochen...',
  957. cancelled: 'Dispatch abgebrochen',
  958. cancelFailed: 'Dispatch konnte nicht abgebrochen werden',
  959. completeWithFailures: 'Background Dispatch abgeschlossen: {{completed}} erfolgreich, {{failed}} fehlgeschlagen',
  960. completeSuccess: 'Background Dispatch abgeschlossen: {{completed}} erfolgreich',
  961. printStartedRemaining: '{{completed}} Druck(e) gestartet, {{remaining}} weitere werden gesendet...',
  962. },
  963. },
  964. // Statistics page
  965. stats: {
  966. title: 'Dashboard',
  967. subtitle: 'Widgets zum Neuanordnen ziehen. Auf das Augensymbol klicken zum Ausblenden.',
  968. overview: 'Übersicht',
  969. totalPrints: 'Gesamtdrucke',
  970. successRate: 'Erfolgsrate',
  971. totalPrintTime: 'Gesamtdruckzeit',
  972. printTime: 'Druckzeit',
  973. totalFilament: 'Gesamtverbrauch Filament',
  974. filamentUsed: 'Filamentverbrauch',
  975. filamentCost: 'Filamentkosten',
  976. totalCost: 'Gesamtkosten',
  977. energyUsed: 'Energieverbrauch',
  978. energyCost: 'Energiekosten',
  979. averagePrintTime: 'Durchschnittliche Druckzeit',
  980. printsPerDay: 'Drucke pro Tag',
  981. byPrinter: 'Nach Drucker',
  982. printsByPrinter: 'Drucke nach Drucker',
  983. byMaterial: 'Nach Material',
  984. byMonth: 'Nach Monat',
  985. last7Days: 'Letzte 7 Tage',
  986. last30Days: 'Letzte 30 Tage',
  987. last90Days: 'Letzte 90 Tage',
  988. allTime: 'Gesamt',
  989. // Widgets
  990. quickStats: 'Schnellstatistiken',
  991. printActivity: 'Druckaktivität',
  992. filamentTypes: 'Filamenttypen',
  993. filamentTrends: 'Filamenttrends',
  994. failureAnalysis: 'Fehleranalyse',
  995. timeAccuracy: 'Zeitgenauigkeit',
  996. successful: 'Erfolgreich:',
  997. failed: 'Fehlgeschlagen:',
  998. perfectEstimate: '100% = perfekte Schätzung',
  999. noTimeAccuracyData: 'Noch keine Zeitgenauigkeitsdaten',
  1000. noFilamentData: 'Keine Filamentdaten verfügbar',
  1001. noPrinterData: 'Keine Druckerdaten verfügbar',
  1002. noPrintData: 'Keine Druckdaten verfügbar',
  1003. noPrintDataLast30Days: 'Keine Druckdaten in den letzten 30 Tagen',
  1004. failureReasons: 'Fehlerursachen',
  1005. topFailureReasons: 'Häufigste Fehlerursachen',
  1006. failedPrintsCount: '{{failed}} / {{total}} Drucke fehlgeschlagen',
  1007. lastWeekRate: 'Letzte Woche: {{rate}}%',
  1008. // Actions
  1009. resetLayout: 'Layout zurücksetzen',
  1010. recalculateCosts: 'Kosten neu berechnen',
  1011. recalculateCostsHint: 'Alle Archivkosten mit aktuellen Filamentpreisen neu berechnen',
  1012. exportStats: 'Statistiken exportieren',
  1013. exportAsCsv: 'Als CSV exportieren',
  1014. exportAsExcel: 'Als Excel exportieren',
  1015. hiddenCount: '{{count}} ausgeblendet',
  1016. // Toast
  1017. exportDownloaded: 'Export heruntergeladen',
  1018. exportFailed: 'Export fehlgeschlagen',
  1019. layoutReset: 'Layout zurückgesetzt',
  1020. recalculatedCosts: 'Kosten für {{count}} Archive neu berechnet',
  1021. recalculateFailed: 'Kosten konnten nicht neu berechnet werden',
  1022. // Loading
  1023. loadingStats: 'Statistiken werden geladen...',
  1024. // Permissions
  1025. noPermissionResetLayout: 'Sie haben keine Berechtigung, das Layout zurückzusetzen',
  1026. noPermissionRecalculate: 'Sie haben keine Berechtigung, Kosten neu zu berechnen',
  1027. noPrintDataInRange: 'Keine Druckdaten im ausgewählten Zeitraum',
  1028. periodFilament: 'Filamentverbrauch',
  1029. periodCost: 'Kosten',
  1030. avgPerPrint: 'Durchschnitt pro Druck',
  1031. usageOverTime: 'Verbrauch im Zeitverlauf',
  1032. filamentByWeight: 'Gewicht',
  1033. printDuration: 'Druckdauer',
  1034. printerUtilization: 'Druckerauslastung',
  1035. filamentSuccess: 'Erfolg nach Material',
  1036. printHabits: 'Druckgewohnheiten',
  1037. printTimeOfDay: 'Druck-Tageszeit',
  1038. colorDistribution: 'Farbverteilung',
  1039. noColorData: 'Keine Farbdaten verfügbar',
  1040. records: 'Rekorde',
  1041. longestPrint: 'Längster Druck',
  1042. heaviestPrint: 'Schwerster Druck',
  1043. mostExpensivePrint: 'Teuerster Druck',
  1044. busiestDay: 'Aktivster Tag',
  1045. successStreak: 'Erfolgsserie',
  1046. streakPrint: 'aufeinanderfolgender Druck',
  1047. streakPrints: '{{count}} aufeinanderfolgende Drucke',
  1048. printerStats: 'Druckerstatistiken',
  1049. hours: 'Stunden',
  1050. avgPrints: 'Ø Drucke',
  1051. noArchiveData: 'Keine Druckdaten verfügbar',
  1052. filamentByTime: 'Zeitverlauf',
  1053. avgWeight: 'Ø Gewicht',
  1054. avgTime: 'Ø Zeit',
  1055. filamentByPrints: 'Drucke',
  1056. timeframe: {
  1057. 'today': 'Heute',
  1058. 'this-week': 'Diese Woche',
  1059. 'this-month': 'Dieser Monat',
  1060. 'last-7': 'Letzte 7 Tage',
  1061. 'last-30': 'Letzte 30 Tage',
  1062. 'last-90': 'Letzte 90 Tage',
  1063. 'this-year': 'Dieses Jahr',
  1064. 'all-time': 'Gesamt',
  1065. 'custom': 'Benutzerdefiniert',
  1066. from: 'Von',
  1067. to: 'Bis',
  1068. },
  1069. },
  1070. // Maintenance page
  1071. maintenance: {
  1072. title: 'Wartung',
  1073. overview: 'Übersicht',
  1074. allOk: 'Alle Wartungen aktuell',
  1075. dueCount: '{{count}} Aufgabe fällig',
  1076. dueCount_plural: '{{count}} Aufgaben fällig',
  1077. warningCount: '{{count}} Warnung',
  1078. warningCount_plural: '{{count}} Warnungen',
  1079. totalPrintTime: 'Gesamtdruckzeit',
  1080. nextMaintenance: 'Nächste Wartung',
  1081. nothingDue: 'Nichts fällig',
  1082. tasks: 'Aufgaben',
  1083. lastPerformed: 'Zuletzt durchgeführt',
  1084. interval: 'Intervall',
  1085. hoursRemaining: '{{hours}}h verbleibend',
  1086. hoursOverdue: '{{hours}}h überfällig',
  1087. markDone: 'Als erledigt markieren',
  1088. performMaintenance: 'Wartung durchführen',
  1089. history: 'Verlauf',
  1090. noHistory: 'Kein Wartungsverlauf',
  1091. editPrintHours: 'Druckstunden bearbeiten',
  1092. currentHours: 'Aktuelle Stunden',
  1093. // Tabs
  1094. statusTab: 'Status',
  1095. settingsTab: 'Einstellungen',
  1096. // Status
  1097. overdueCount: '{{count}} überfällig',
  1098. dueSoonCount: '{{count}} bald fällig',
  1099. dueSoon: 'Bald fällig',
  1100. allGood: 'Alles in Ordnung',
  1101. overdueBy: 'Überfällig um {{duration}}',
  1102. dueIn: 'Fällig in {{duration}}',
  1103. timeLeft: '{{duration}} verbleibend',
  1104. // Duration formats
  1105. day: '1 Tag',
  1106. days: '{{count}} Tage',
  1107. week: '1 Woche',
  1108. weeks: '{{count}} Wochen',
  1109. month: '1 Monat',
  1110. months: '{{count}} Monate',
  1111. year: '1 Jahr',
  1112. // Settings
  1113. maintenanceTypes: 'Wartungstypen',
  1114. maintenanceTypesDescription: 'Systemtypen und Ihre benutzerdefinierten Wartungsaufgaben',
  1115. addCustomType: 'Benutzerdefinierten Typ hinzufügen',
  1116. restoreDefaults: 'Standardaufgaben wiederherstellen',
  1117. intervalType: 'Intervalltyp',
  1118. intervalValue: 'Intervall ({{type}})',
  1119. icon: 'Symbol',
  1120. documentationLink: 'Dokumentationslink (optional)',
  1121. assignToPrinters: 'Druckern zuweisen',
  1122. selectAtLeastOnePrinter: 'Wählen Sie mindestens einen Drucker',
  1123. addType: 'Typ hinzufügen',
  1124. custom: 'Benutzerdefiniert',
  1125. printHours: 'Druckstunden',
  1126. calendarDays: 'Kalendertage',
  1127. exampleName: 'z.B. HEPA-Filter ersetzen',
  1128. viewDocumentation: 'Dokumentation anzeigen',
  1129. timeBasedInterval: 'Zeitbasiertes Intervall',
  1130. // Interval overrides
  1131. intervalOverrides: 'Intervall-Überschreibungen',
  1132. intervalOverridesDescription: 'Intervalle für bestimmte Drucker anpassen',
  1133. // Printer assignment
  1134. assignedToPrinters: 'Druckern zugewiesen:',
  1135. noPrintersAssigned: 'Keine Drucker zugewiesen',
  1136. addPrinterShort: 'Hinzufügen:',
  1137. printersAssignedClick: '{{count}} Drucker zugewiesen - klicken zum Verwalten',
  1138. removeFromPrinter: 'Von diesem Drucker entfernen',
  1139. // Types
  1140. types: {
  1141. lubricateCarbonRods: 'Karbonstäbe schmieren',
  1142. lubricateRails: 'Linearschienen schmieren',
  1143. cleanNozzle: 'Düse/Hotend reinigen',
  1144. checkBelts: 'Riemenspannung prüfen',
  1145. cleanBuildPlate: 'Druckbett reinigen',
  1146. checkExtruder: 'Extruderzahnräder prüfen',
  1147. checkCooling: 'Kühlungslüfter prüfen',
  1148. generalInspection: 'Allgemeine Inspektion',
  1149. cleanCarbonRods: 'Kohlenstoffstangen reinigen',
  1150. lubricateSteelRods: 'Stahlstangen schmieren',
  1151. cleanSteelRods: 'Stahlstangen reinigen',
  1152. cleanLinearRails: 'Linearschienen reinigen',
  1153. checkPtfeTube: 'PTFE-Schlauch prüfen',
  1154. replaceHepaFilter: 'HEPA-Filter ersetzen',
  1155. replaceCarbonFilter: 'Aktivkohlefilter ersetzen',
  1156. lubricateLeftNozzleRail: 'Linke Düsenschiene schmieren',
  1157. },
  1158. // Toast
  1159. maintenanceComplete: 'Wartung als abgeschlossen markiert',
  1160. typeUpdated: 'Wartungstyp aktualisiert',
  1161. typeDeleted: 'Wartungstyp gelöscht',
  1162. defaultsRestored: '{{count}} Standardaufgabe(n) wiederhergestellt',
  1163. printHoursUpdated: 'Druckstunden aktualisiert',
  1164. printerAssigned: 'Drucker zugewiesen',
  1165. printerRemoved: 'Drucker entfernt',
  1166. // Confirmation
  1167. deleteTypeConfirm: '"{{name}}" löschen?',
  1168. deleteSystemTypeTitle: 'Standard-Wartungsaufgabe löschen?',
  1169. deleteSystemTypeMessage: 'Möchten Sie die Standard-Wartungsaufgabe "{{name}}" wirklich löschen?',
  1170. // Permissions
  1171. noPermissionUpdate: 'Sie haben keine Berechtigung, Wartungselemente zu aktualisieren',
  1172. noPermissionPerform: 'Sie haben keine Berechtigung, Wartungen durchzuführen',
  1173. noPermissionEditTypes: 'Sie haben keine Berechtigung, Wartungstypen zu bearbeiten',
  1174. noPermissionDeleteTypes: 'Sie haben keine Berechtigung, Wartungstypen zu löschen',
  1175. noPermissionEditHours: 'Sie haben keine Berechtigung, Druckstunden zu bearbeiten',
  1176. noPermissionRemovePrinter: 'Sie haben keine Berechtigung, Druckerzuweisungen zu entfernen',
  1177. noPermissionAssignPrinter: 'Sie haben keine Berechtigung, Drucker zuzuweisen',
  1178. noPermissionEditIntervals: 'Sie haben keine Berechtigung, Intervalle zu bearbeiten',
  1179. // Configure link
  1180. configureSettings: 'Wartungstypen und Intervalle konfigurieren',
  1181. },
  1182. // Settings page
  1183. settings: {
  1184. title: 'Einstellungen',
  1185. general: 'Allgemein',
  1186. // Tab names
  1187. tabs: {
  1188. general: 'Allgemein',
  1189. smartPlugs: 'Smart Plugs',
  1190. notifications: 'Benachrichtigungen',
  1191. filament: 'Filament',
  1192. network: 'Netzwerk',
  1193. apiKeys: 'API-Schlüssel',
  1194. virtualPrinter: 'Virtueller Drucker',
  1195. users: 'Authentifizierung',
  1196. backup: 'Sicherung',
  1197. emailAuth: 'E-Mail-Authentifizierung',
  1198. },
  1199. // Email settings
  1200. email: {
  1201. smtpSettings: 'SMTP-Konfiguration',
  1202. smtpHost: 'SMTP-Server',
  1203. smtpPort: 'SMTP-Port',
  1204. security: 'Sicherheit',
  1205. authentication: 'Authentifizierung',
  1206. username: 'Benutzername',
  1207. password: 'Passwort',
  1208. fromEmail: 'Absender-E-Mail',
  1209. fromName: 'Absendername',
  1210. testConnection: 'SMTP-Verbindung testen',
  1211. testRecipient: 'Test-Empfänger-E-Mail',
  1212. sendTest: 'Test-E-Mail senden',
  1213. sending: 'Wird gesendet...',
  1214. save: 'Einstellungen speichern',
  1215. saving: 'Wird gespeichert...',
  1216. advancedAuth: 'Erweiterte Authentifizierung',
  1217. advancedAuthEnabled: 'Erweiterte Authentifizierung ist aktiviert',
  1218. advancedAuthEnabledDesc: 'E-Mail-basierte Benutzerverwaltungsfunktionen sind aktiv. Neue Benutzer erhalten automatisch generierte Passwörter per E-Mail und können ihr Passwort über die Passwort vergessen Funktion zurücksetzen.',
  1219. advancedAuthDisabled: 'Erweiterte Authentifizierung ist deaktiviert',
  1220. advancedAuthDisabledDesc: 'Aktivieren Sie die erweiterte Authentifizierung, um E-Mail-basierte Funktionen für die Benutzerverwaltung zu aktivieren.',
  1221. enable: 'Aktivieren',
  1222. disable: 'Deaktivieren',
  1223. feature1: 'Passwörter werden automatisch generiert und an neue Benutzer gesendet',
  1224. feature2: 'Benutzer können sich mit Benutzername oder E-Mail anmelden',
  1225. feature3: 'Passwort vergessen Funktion ist verfügbar',
  1226. feature4: 'Administratoren können Benutzerpasswörter per E-Mail zurücksetzen',
  1227. // Error messages
  1228. errors: {
  1229. requiredFields: 'Bitte füllen Sie alle Pflichtfelder aus',
  1230. usernameRequired: 'Benutzername ist erforderlich, wenn Authentifizierung aktiviert ist',
  1231. enterTestEmail: 'Bitte geben Sie eine Test-E-Mail-Adresse ein',
  1232. smtpServerAndEmail: 'Bitte füllen Sie SMTP-Server und Absender-E-Mail aus, bevor Sie testen',
  1233. usernamePasswordRequired: 'Benutzername und Passwort sind erforderlich, wenn Authentifizierung aktiviert ist',
  1234. configureSmtpFirst: 'Bitte konfigurieren und testen Sie zuerst die SMTP-Einstellungen',
  1235. },
  1236. // Success messages
  1237. success: {
  1238. settingsSaved: 'SMTP-Einstellungen erfolgreich gespeichert',
  1239. },
  1240. // Security options
  1241. securityOptions: {
  1242. starttls: 'STARTTLS (Port 587)',
  1243. ssl: 'SSL/TLS (Port 465)',
  1244. none: 'Keine (Port 25)',
  1245. },
  1246. // Authentication options
  1247. authOptions: {
  1248. enabled: 'Aktiviert',
  1249. disabled: 'Deaktiviert',
  1250. },
  1251. },
  1252. appearance: 'Erscheinungsbild',
  1253. notifications: 'Benachrichtigungen',
  1254. smartPlugs: 'Smart Plugs',
  1255. spoolman: 'Spoolman',
  1256. updates: 'Updates',
  1257. language: 'Sprache',
  1258. languageDescription: 'Wählen Sie Ihre bevorzugte Sprache',
  1259. theme: 'Design',
  1260. themeLight: 'Hell',
  1261. themeDark: 'Dunkel',
  1262. themeSystem: 'System',
  1263. defaultView: 'Standardansicht',
  1264. defaultViewDescription: 'Seite, die beim Öffnen der App angezeigt wird',
  1265. checkForUpdates: 'Nach Updates suchen',
  1266. autoUpdate: 'Automatische Updates',
  1267. currentVersion: 'Aktuelle Version',
  1268. latestVersion: 'Neueste Version',
  1269. upToDate: 'Sie sind auf dem neuesten Stand',
  1270. updateAvailable: 'Update verfügbar',
  1271. // Notifications
  1272. notificationLanguage: 'Benachrichtigungssprache',
  1273. notificationLanguageDescription: 'Sprache für Push-Benachrichtigungen',
  1274. bedCooledThreshold: 'Bett-Abkühlung Schwellenwert',
  1275. bedCooledThresholdDescription: 'Temperatur, unter der das Bett nach einem Druck als abgekühlt gilt',
  1276. notificationProviders: 'Benachrichtigungsanbieter',
  1277. addProvider: 'Anbieter hinzufügen',
  1278. editProvider: 'Anbieter bearbeiten',
  1279. providerType: 'Anbietertyp',
  1280. testNotification: 'Testbenachrichtigung',
  1281. testSuccess: 'Testbenachrichtigung erfolgreich gesendet',
  1282. testFailed: 'Testbenachrichtigung konnte nicht gesendet werden',
  1283. quietHours: 'Ruhezeiten',
  1284. quietHoursDescription: 'Keine Störungen während dieser Zeiten',
  1285. quietHoursStart: 'Beginn',
  1286. quietHoursEnd: 'Ende',
  1287. events: {
  1288. title: 'Benachrichtigungsereignisse',
  1289. printStart: 'Druck gestartet',
  1290. printComplete: 'Druck abgeschlossen',
  1291. printFailed: 'Druck fehlgeschlagen',
  1292. printStopped: 'Druck gestoppt',
  1293. printProgress: 'Fortschrittsmeldungen',
  1294. printProgressDescription: 'Bei 25%, 50%, 75% benachrichtigen',
  1295. printerOffline: 'Drucker offline',
  1296. printerError: 'Druckerfehler',
  1297. filamentLow: 'Filament niedrig',
  1298. maintenanceDue: 'Wartung fällig',
  1299. maintenanceDueDescription: 'Benachrichtigen, wenn Wartung erforderlich',
  1300. },
  1301. // Smart Plugs
  1302. smartPlug: {
  1303. title: 'Smart Plugs',
  1304. add: 'Smart Plug hinzufügen',
  1305. edit: 'Smart Plug bearbeiten',
  1306. name: 'Name',
  1307. ipAddress: 'IP-Adresse',
  1308. linkedPrinter: 'Verknüpfter Drucker',
  1309. autoOn: 'Automatisch einschalten',
  1310. autoOnDescription: 'Einschalten beim Druckstart',
  1311. autoOff: 'Automatisch ausschalten',
  1312. autoOffDescription: 'Ausschalten nach Druckende',
  1313. offDelay: 'Ausschaltverzögerung',
  1314. offDelayMinutes: 'Minuten nach Druck',
  1315. offDelayTemp: 'Wenn Düse unter Temperatur',
  1316. currentState: 'Aktueller Status',
  1317. turnOn: 'Einschalten',
  1318. turnOff: 'Ausschalten',
  1319. },
  1320. // Filament Tracking Mode
  1321. filamentTracking: 'Filament-Verfolgung',
  1322. filamentTrackingDesc: 'Wählen Sie, wie Sie Ihre Filamentspulen verfolgen möchten. Sie können das integrierte Inventar oder einen externen Spoolman-Server verwenden.',
  1323. trackingModeBuiltIn: 'Integriertes Inventar',
  1324. trackingModeBuiltInDesc: 'RFID-Erkennung und Verbrauchserfassung inklusive',
  1325. trackingModeSpoolmanDesc: 'Externer Filament-Management-Server',
  1326. builtInFeatureRfid: 'Erkennt automatisch Bambu Lab RFID-Spulen im AMS',
  1327. builtInFeatureUsage: 'Erfasst den Filamentverbrauch pro Druck',
  1328. builtInFeatureCatalog: 'Spulen, Farben und K-Faktor-Profile verwalten',
  1329. builtInFeatureThirdParty: 'Drittanbieter-Spulen können Inventarspulen zugewiesen werden',
  1330. amsSyncButton: 'Gewichte vom AMS synchronisieren',
  1331. amsSyncTitle: 'Spulengewichte vom AMS synchronisieren',
  1332. amsSyncMessage: 'Alle Inventar-Spulengewichte werden mit den aktuellen AMS-Restwerten der verbundenen Drucker überschrieben. Verwenden Sie dies zur Wiederherstellung beschädigter Gewichtsdaten. Drucker müssen online sein.',
  1333. amsSyncing: 'Synchronisiere...',
  1334. amsSyncSuccess: '{{synced}} Spule(n) synchronisiert, {{skipped}} übersprungen',
  1335. amsSyncError: 'Synchronisierung der Gewichte vom AMS fehlgeschlagen',
  1336. // Spoolman settings
  1337. spoolmanUrl: 'Spoolman URL',
  1338. spoolmanUrlHint: 'URL Ihres Spoolman-Servers (z.B. http://localhost:7912)',
  1339. spoolmanConnected: 'Verbunden',
  1340. spoolmanDisconnected: 'Nicht verbunden',
  1341. status: 'Status',
  1342. connect: 'Verbinden',
  1343. disconnect: 'Trennen',
  1344. howSyncWorks: 'So funktioniert die Synchronisierung',
  1345. syncInfoRfidOnly: 'Nur offizielle Bambu Lab Spulen mit RFID werden synchronisiert',
  1346. syncInfoAutoCreate: 'Neue Spulen werden bei der ersten Synchronisierung automatisch in Spoolman erstellt',
  1347. syncInfoThirdPartySkipped: 'Nicht-Bambu-Lab-Spulen (Drittanbieter, nachgefüllt) werden übersprungen',
  1348. linkingExistingSpools: 'Vorhandene Spulen verknüpfen',
  1349. linkingExistingSpoolsDesc: 'Um vorhandene Spoolman-Spulen mit Ihrem AMS zu verknüpfen, fahren Sie über einen AMS-Slot und klicken Sie auf "Mit Spoolman verknüpfen".',
  1350. syncMode: 'Synchronisierungsmodus',
  1351. syncModeAuto: 'Automatisch',
  1352. syncModeManual: 'Nur manuell',
  1353. syncModeAutoDesc: 'AMS-Daten werden automatisch synchronisiert, wenn Änderungen erkannt werden',
  1354. syncModeManualDesc: 'Nur bei manueller Auslösung synchronisieren',
  1355. syncAmsData: 'AMS-Daten synchronisieren',
  1356. syncAmsDataDesc: 'AMS-Daten des Druckers manuell mit Spoolman synchronisieren',
  1357. allPrinters: 'Alle Drucker',
  1358. // Default printer
  1359. noDefaultPrinter: 'Kein Standard (jedes Mal fragen)',
  1360. // Sidebar
  1361. sidebarOrder: 'Seitenleisten-Reihenfolge',
  1362. // Camera
  1363. saveThumbnails: 'Vorschaubilder speichern',
  1364. captureFinishPhoto: 'Abschlussfoto aufnehmen',
  1365. noPrintersConfigured: 'Keine Drucker konfiguriert',
  1366. // Archive settings
  1367. archiveMode: {
  1368. always: 'Immer Archiveintrag erstellen',
  1369. never: 'Nie Archiveintrag erstellen',
  1370. ask: 'Jedes Mal fragen',
  1371. },
  1372. // Updates
  1373. checkForUpdatesLabel: 'Nach Updates suchen',
  1374. checkPrinterFirmware: 'Drucker-Firmware prüfen',
  1375. includeBetaUpdates: 'Beta-Versionen einschließen',
  1376. includeBetaUpdatesDesc: 'Über Beta- und Vorabversionen bei der Updateprüfung benachrichtigen',
  1377. // Queue
  1378. enableRetry: 'Wiederholung aktivieren',
  1379. // Home Assistant
  1380. homeAssistantDescription: 'Smart Plugs über Home Assistant steuern',
  1381. environmentManagedLabel: '(Umgebungsvariable)',
  1382. autoEnabledViaEnv: 'Automatisch über Umgebungsvariablen aktiviert',
  1383. urlFromEnvReadOnly: 'Wert wird über HA_URL Umgebungsvariable gesetzt (schreibgeschützt)',
  1384. tokenFromEnvReadOnly: 'Wert wird über HA_TOKEN Umgebungsvariable gesetzt (schreibgeschützt)',
  1385. // MQTT
  1386. mqttConnectedTo: 'Verbunden mit',
  1387. // Prometheus
  1388. prometheusDescription: 'Druckerdaten im Prometheus-Format bereitstellen',
  1389. // Smart plugs empty state
  1390. noSmartPlugsTitle: 'Keine Smart Plugs konfiguriert',
  1391. noSmartPlugsDescription: 'Fügen Sie einen Tasmota-basierten Smart Plug hinzu, um den Energieverbrauch zu verfolgen und die Stromsteuerung zu automatisieren.',
  1392. // Notifications empty state
  1393. noProvidersTitle: 'Keine Anbieter konfiguriert',
  1394. noProvidersDescription: 'Fügen Sie einen Anbieter hinzu, um Benachrichtigungen zu erhalten.',
  1395. noTemplatesAvailable: 'Keine Vorlagen verfügbar. Starten Sie das Backend neu, um Standardvorlagen zu laden.',
  1396. // API permissions
  1397. apiPermissionView: 'Druckerstatus und Warteschlange anzeigen',
  1398. apiPermissionEdit: 'Elemente zur Druckwarteschlange hinzufügen und entfernen',
  1399. // API keys
  1400. apiKeysEmptyTitle: 'Keine API-Schlüssel',
  1401. apiKeysEmptyDescription: 'Erstellen Sie einen API-Schlüssel zur Integration mit externen Diensten.',
  1402. // Users
  1403. noUsersFound: 'Keine Benutzer gefunden',
  1404. noGroupsFound: 'Keine Gruppen gefunden',
  1405. noGroupsAvailable: 'Keine Gruppen verfügbar',
  1406. passwordsDoNotMatch: 'Passwörter stimmen nicht überein',
  1407. systemGroupWarning: 'System-Gruppennamen können nicht geändert werden',
  1408. // Auth disabled
  1409. authDisabledTitle: 'Authentifizierung ist deaktiviert',
  1410. authDisabledFeature1: 'Anmeldung zum Zugriff auf das System erforderlich',
  1411. authDisabledFeature2: 'Mehrere Benutzer mit gruppenbasierten Berechtigungen erstellen',
  1412. authDisabledFeature3: 'Zugriff mit über 50 granularen Berechtigungen steuern',
  1413. // User deletion
  1414. userHasCreated: 'Dieser Benutzer hat erstellt:',
  1415. userItemsQuestion: 'Was möchten Sie mit diesen Elementen tun?',
  1416. deleteUserConfirm: 'Möchten Sie diesen Benutzer wirklich löschen?',
  1417. actionCannotBeUndone: 'Diese Aktion kann nicht rückgängig gemacht werden.',
  1418. // Smart plugs
  1419. addFirstSmartPlug: 'Ersten Smart Plug hinzufügen',
  1420. // Notifications
  1421. providers: 'Anbieter',
  1422. log: 'Protokoll',
  1423. testAll: 'Alle testen',
  1424. testResults: 'Testergebnisse',
  1425. testPassedCount: '{{count}} bestanden',
  1426. testFailedCount: '{{count}} fehlgeschlagen',
  1427. messageTemplates: 'Nachrichtenvorlagen',
  1428. messageTemplatesDescription: 'Passen Sie Benachrichtigungen für jedes Ereignis an.',
  1429. // API Keys section
  1430. apiKeys: 'API-Schlüssel',
  1431. apiKeysDescription: 'Erstellen Sie API-Schlüssel für externe Integrationen und Webhooks.',
  1432. createKey: 'Schlüssel erstellen',
  1433. apiKeyCreated: 'API-Schlüssel erfolgreich erstellt',
  1434. apiKeyCopyWarning: 'Kopieren Sie diesen Schlüssel jetzt - er wird nicht mehr angezeigt!',
  1435. useInApiBrowser: 'Im API-Browser verwenden',
  1436. createNewApiKey: 'Neuen API-Schlüssel erstellen',
  1437. keyName: 'Schlüsselname',
  1438. keyNamePlaceholder: 'z.B. Home Assistant, OctoPrint',
  1439. readStatus: 'Status lesen',
  1440. readStatusDescription: 'Druckerstatus und Warteschlange anzeigen',
  1441. manageQueue: 'Warteschlange verwalten',
  1442. manageQueueDescription: 'Elemente zur Druckwarteschlange hinzufügen und entfernen',
  1443. controlPrinter: 'Drucker steuern',
  1444. controlPrinterDescription: 'Drucke pausieren, fortsetzen und stoppen',
  1445. unnamedKey: 'Unbenannter Schlüssel',
  1446. lastUsed: 'Zuletzt verwendet',
  1447. read: 'Lesen',
  1448. control: 'Steuern',
  1449. createFirstKey: 'Ersten Schlüssel erstellen',
  1450. webhookEndpoints: 'Webhook-Endpunkte',
  1451. webhookApiKeyHint: 'Verwenden Sie Ihren API-Schlüssel im X-API-Key-Header.',
  1452. webhook: {
  1453. getAllStatus: 'Alle Druckerstatus abrufen',
  1454. getSpecificStatus: 'Spezifischen Druckerstatus abrufen',
  1455. addToQueue: 'Zur Druckwarteschlange hinzufügen',
  1456. pausePrint: 'Druck pausieren',
  1457. resumePrint: 'Druck fortsetzen',
  1458. stopPrint: 'Druck stoppen',
  1459. },
  1460. apiBrowser: 'API-Browser',
  1461. apiBrowserDescription: 'Erkunden und testen Sie alle verfügbaren API-Endpunkte.',
  1462. apiKeyForTesting: 'API-Schlüssel zum Testen',
  1463. apiKeyPlaceholder: 'Fügen Sie hier Ihren API-Schlüssel ein, um authentifizierte Endpunkte zu testen...',
  1464. apiKeyHint: 'Dieser Schlüssel wird als X-API-Key-Header mit Anfragen gesendet.',
  1465. deleteApiKeyTitle: 'API-Schlüssel löschen',
  1466. deleteApiKeyMessage: 'Möchten Sie diesen API-Schlüssel wirklich löschen? Alle Integrationen, die diesen Schlüssel verwenden, funktionieren nicht mehr.',
  1467. deleteKey: 'Schlüssel löschen',
  1468. // Filament tab
  1469. amsDisplayThresholds: 'AMS-Anzeigeschwellenwerte',
  1470. amsThresholdsDescription: 'Konfigurieren Sie Farbschwellenwerte für AMS-Feuchtigkeits- und Temperaturanzeigen.',
  1471. humidity: 'Luftfeuchtigkeit',
  1472. goodGreen: 'Gut (grün)',
  1473. fairOrange: 'Mittel (orange)',
  1474. aboveFairBad: 'Über dem mittleren Schwellenwert wird rot angezeigt (schlecht)',
  1475. temperature: 'Temperatur',
  1476. goodBlue: 'Gut (blau)',
  1477. aboveFairHot: 'Über dem mittleren Schwellenwert wird rot angezeigt (heiß)',
  1478. historyRetention: 'Verlaufsaufbewahrung',
  1479. keepSensorHistory: 'Sensorverlauf behalten für',
  1480. historyRetentionDescription: 'Ältere Feuchtigkeits- und Temperaturdaten werden automatisch gelöscht',
  1481. printModal: 'Druckdialog',
  1482. expandCustomMapping: 'Benutzerdefinierte Zuordnung standardmäßig erweitern',
  1483. expandCustomMappingDescription: 'Bei Druck auf mehrere Drucker die AMS-Zuordnung pro Drucker erweitert anzeigen',
  1484. // User management
  1485. authentication: 'Authentifizierung',
  1486. authEnabledDescription: 'Ihre Instanz ist mit Benutzerauthentifizierung gesichert',
  1487. authDisabledDescription: 'Aktivieren Sie die Anmeldepflicht und verwalten Sie den Benutzerzugriff',
  1488. authDisabledMessage: 'Aktivieren Sie die Authentifizierung, um Benutzerkonten zu erstellen, Berechtigungen zu verwalten und Ihre Bambuddy-Instanz zu sichern.',
  1489. enableAuthentication: 'Authentifizierung aktivieren',
  1490. currentUser: 'Aktueller Benutzer',
  1491. changePassword: 'Passwort ändern',
  1492. admin: 'Admin',
  1493. users: 'Benutzer',
  1494. addUser: 'Benutzer hinzufügen',
  1495. groups: 'Gruppen',
  1496. addGroup: 'Gruppe hinzufügen',
  1497. system: 'System',
  1498. noDescription: 'Keine Beschreibung',
  1499. userCount: '{{count}} Benutzer',
  1500. permissionCount: '{{count}} Berechtigungen',
  1501. createUser: 'Benutzer erstellen',
  1502. username: 'Benutzername',
  1503. enterUsername: 'Benutzername eingeben',
  1504. password: 'Passwort',
  1505. enterPassword: 'Passwort eingeben (min. 6 Zeichen)',
  1506. confirmPassword: 'Passwort bestätigen',
  1507. confirmPasswordPlaceholder: 'Passwort bestätigen',
  1508. // Title tooltips
  1509. viewReleaseOnGitHub: 'Release auf GitHub anzeigen',
  1510. turnAllPlugsOn: 'Alle Stecker einschalten',
  1511. turnAllPlugsOff: 'Alle Stecker ausschalten',
  1512. // Modal: Clear logs
  1513. clearNotificationLogs: 'Benachrichtigungsprotokolle löschen',
  1514. clearLogsMessage: 'Dadurch werden alle Benachrichtigungsprotokolle, die älter als 30 Tage sind, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.',
  1515. clearLogs: 'Protokolle löschen',
  1516. // Modal: Reset UI
  1517. resetUiPreferences: 'UI-Einstellungen zurücksetzen',
  1518. resetUiPreferencesMessage: 'Dadurch werden alle UI-Einstellungen auf Standardwerte zurückgesetzt: Seitenleisten-Reihenfolge, Theme, Dashboard-Layout, Ansichtsmodi und Sortiereinstellungen. Ihre Drucker, Archive und Servereinstellungen werden NICHT beeinträchtigt. Die Seite wird nach dem Löschen neu geladen.',
  1519. resetPreferences: 'Einstellungen zurücksetzen',
  1520. // Modal: Delete group
  1521. deleteGroupTitle: 'Gruppe löschen',
  1522. deleteGroupMessage: 'Möchten Sie diese Gruppe wirklich löschen? Benutzer in dieser Gruppe verlieren diese Berechtigungen.',
  1523. deleteGroup: 'Gruppe löschen',
  1524. // Modal: Disable auth
  1525. disableAuthenticationTitle: 'Authentifizierung deaktivieren',
  1526. disableAuthenticationMessage: 'Möchten Sie die Authentifizierung wirklich deaktivieren? Dadurch wird Ihre Bambuddy-Instanz ohne Anmeldung zugänglich. Alle Benutzer bleiben in der Datenbank, aber die Authentifizierung wird deaktiviert.',
  1527. disableAuthentication: 'Authentifizierung deaktivieren',
  1528. // Additional settings
  1529. configureBambuddy: 'Bambuddy konfigurieren',
  1530. systemDefault: 'Systemstandard',
  1531. archiveSettings: 'Archiv-Einstellungen',
  1532. newWindow: 'Neues Fenster',
  1533. embeddedOverlay: 'Eingebettetes Overlay',
  1534. preferredSlicer: 'Bevorzugter Slicer',
  1535. preferredSlicerDescription: 'Wähle die Slicer-Anwendung zum Öffnen von Dateien',
  1536. externalCameras: 'Externe Kameras',
  1537. costTracking: 'Kostenverfolgung',
  1538. printsOnly: 'Nur Drucke',
  1539. totalConsumption: 'Gesamtverbrauch',
  1540. dataManagement: 'Datenverwaltung',
  1541. storageUsage: 'Speichernutzung',
  1542. storageUsageDescription: 'Aufschlüsselung der Datennutzung nach Kategorie',
  1543. storageUsageTotal: 'Gesamt',
  1544. storageUsageErrors: 'Fehler',
  1545. storageUsageOtherBreakdown: 'Sonstiges (enthält statische Assets, Skripte und Konfigurationsdateien)',
  1546. storageUsageSystem: 'System',
  1547. storageUsageData: 'Daten',
  1548. storageUsageUnavailable: 'Speichernutzungsinformationen nicht verfügbar',
  1549. clearNotificationLogsDescription: 'Benachrichtigungsprotokolle älter als 30 Tage löschen',
  1550. resetUiPreferencesDescription: 'Seitenleisten-Reihenfolge, Theme, Ansichtsmodi und Layout-Einstellungen zurücksetzen. Drucker, Archive und Einstellungen werden nicht beeinflusst.',
  1551. enableHomeAssistant: 'Home Assistant aktivieren',
  1552. enableMqtt: 'MQTT aktivieren',
  1553. useTls: 'TLS verwenden',
  1554. enableMetricsEndpoint: 'Metrik-Endpunkt aktivieren',
  1555. availableMetrics: 'Verfügbare Metriken',
  1556. editUser: 'Benutzer bearbeiten',
  1557. deleteUserTitle: 'Benutzer löschen',
  1558. groupName: 'Gruppenname',
  1559. // Placeholders
  1560. leaveEmptyForAnonymous: 'Leer lassen für anonym',
  1561. leaveEmptyForNoAuth: 'Leer lassen für keine Authentifizierung',
  1562. enterNewPassword: 'Neues Passwort eingeben',
  1563. confirmNewPassword: 'Neues Passwort bestätigen',
  1564. enterGroupName: 'Gruppenname eingeben',
  1565. enterDescriptionOptional: 'Beschreibung eingeben (optional)',
  1566. enterCurrentPassword: 'Aktuelles Passwort eingeben',
  1567. enterNewPasswordMin6: 'Neues Passwort eingeben (min. 6 Zeichen)',
  1568. toast: {
  1569. keyCopied: 'Schlüssel in Zwischenablage kopiert',
  1570. copyFailed: 'Schlüssel konnte nicht kopiert werden',
  1571. keyAddedToBrowser: 'Schlüssel zum API-Browser hinzugefügt',
  1572. clearLogsFailed: 'Protokolle konnten nicht gelöscht werden',
  1573. uiPreferencesReset: 'UI-Einstellungen zurückgesetzt. Wird neu geladen...',
  1574. authDisabled: 'Authentifizierung erfolgreich deaktiviert',
  1575. authDisableFailed: 'Authentifizierung konnte nicht deaktiviert werden',
  1576. apiKeyCreated: 'API-Schlüssel erstellt',
  1577. apiKeyDeleted: 'API-Schlüssel gelöscht',
  1578. userCreated: 'Benutzer erfolgreich erstellt',
  1579. userUpdated: 'Benutzer erfolgreich aktualisiert',
  1580. userDeleted: 'Benutzer erfolgreich gelöscht',
  1581. groupCreated: 'Gruppe erfolgreich erstellt',
  1582. groupUpdated: 'Gruppe erfolgreich aktualisiert',
  1583. groupDeleted: 'Gruppe erfolgreich gelöscht',
  1584. fillRequiredFields: 'Bitte füllen Sie alle erforderlichen Felder aus',
  1585. passwordsDoNotMatch: 'Passwörter stimmen nicht überein',
  1586. passwordTooShort: 'Passwort muss mindestens 6 Zeichen lang sein',
  1587. enterGroupName: 'Bitte geben Sie einen Gruppennamen ein',
  1588. settingsSaved: 'Einstellungen gespeichert',
  1589. cameraSettingsSaved: 'Kamera-Einstellungen gespeichert',
  1590. enterCameraUrl: 'Bitte geben Sie eine Kamera-URL ein',
  1591. passwordChanged: 'Passwort erfolgreich geändert',
  1592. connectionFailed: 'Verbindung fehlgeschlagen',
  1593. testFailed: 'Test fehlgeschlagen',
  1594. cameraConnected: 'Kamera verbunden{{resolution}}',
  1595. },
  1596. testConnection: 'Verbindung testen',
  1597. catalog: {
  1598. spoolCatalog: 'Spulenkatalog',
  1599. spoolCatalogDescription: 'Leerspulengewichte nach Marke/Typ. Wird für die automatische Gewichtssuche beim Hinzufügen von Spulen verwendet.',
  1600. searchCatalog: 'Katalog durchsuchen...',
  1601. addNewEntry: 'Neuen Eintrag hinzufügen',
  1602. namePlaceholder: 'Name (z.B. Bambu Lab - Plastik)',
  1603. weight: 'Gewicht',
  1604. type: 'Typ',
  1605. default: 'Standard',
  1606. custom: 'Benutzerdefiniert',
  1607. noMatch: 'Keine Einträge entsprechen Ihrer Suche',
  1608. empty: 'Keine Einträge im Katalog',
  1609. deleteEntry: 'Eintrag löschen',
  1610. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen?',
  1611. resetCatalog: 'Katalog zurücksetzen',
  1612. resetConfirm: 'Katalog auf Standardwerte zurücksetzen? Alle benutzerdefinierten Einträge werden entfernt.',
  1613. loadFailed: 'Spulenkatalog konnte nicht geladen werden',
  1614. nameWeightRequired: 'Name und Gewicht sind erforderlich',
  1615. entryAdded: 'Eintrag hinzugefügt',
  1616. addFailed: 'Eintrag konnte nicht hinzugefügt werden',
  1617. entryUpdated: 'Eintrag aktualisiert',
  1618. updateFailed: 'Eintrag konnte nicht aktualisiert werden',
  1619. entryDeleted: 'Eintrag gelöscht',
  1620. deleteFailed: 'Eintrag konnte nicht gelöscht werden',
  1621. resetSuccess: 'Katalog auf Standardwerte zurückgesetzt',
  1622. resetFailed: 'Katalog konnte nicht zurückgesetzt werden',
  1623. exported: '{{count}} Einträge exportiert',
  1624. imported: '{{added}} Einträge importiert ({{skipped}} übersprungen)',
  1625. importFailed: 'Import fehlgeschlagen: ungültiges JSON-Format',
  1626. exportTooltip: 'Katalog als JSON exportieren',
  1627. importTooltip: 'Katalog aus JSON importieren',
  1628. resetTooltip: 'Auf Standardwerte zurücksetzen',
  1629. selectedCount: '{{count}} ausgewählt',
  1630. deleteSelected: 'Ausgewählte löschen',
  1631. bulkDeleteConfirm: 'Möchten Sie {{count}} Einträge wirklich löschen?',
  1632. bulkDeleted: '{{count}} Einträge gelöscht',
  1633. bulkDeleteFailed: 'Fehler beim Löschen der Einträge',
  1634. },
  1635. colorCatalog: {
  1636. title: 'Farbkatalog',
  1637. description: 'Filamentfarben nach Hersteller/Material. Wird für die automatische Farbsuche beim Hinzufügen von Spulen verwendet.',
  1638. searchColors: 'Farben durchsuchen...',
  1639. allManufacturers: 'Alle Hersteller',
  1640. addNewColor: 'Neue Farbe hinzufügen',
  1641. manufacturer: 'Hersteller',
  1642. colorName: 'Farbname',
  1643. hex: 'Hex',
  1644. materialOptional: 'Material (optional)',
  1645. showing: '{{filtered}} von {{total}} Farben angezeigt',
  1646. noMatch: 'Keine Farben entsprechen Ihrer Suche',
  1647. empty: 'Keine Farben im Katalog',
  1648. deleteColor: 'Farbe löschen',
  1649. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen?',
  1650. resetCatalog: 'Farbkatalog zurücksetzen',
  1651. resetConfirm: 'Katalog auf Standardwerte zurücksetzen? Alle benutzerdefinierten Farben werden entfernt.',
  1652. sync: 'Sync',
  1653. starting: 'Starten...',
  1654. syncTooltip: 'Von FilamentColors.xyz synchronisieren (2000+ Farben)',
  1655. loadFailed: 'Farbkatalog konnte nicht geladen werden',
  1656. fieldsRequired: 'Hersteller, Farbname und Hex-Farbe sind erforderlich',
  1657. colorAdded: 'Farbe hinzugefügt',
  1658. addFailed: 'Farbe konnte nicht hinzugefügt werden',
  1659. colorUpdated: 'Farbe aktualisiert',
  1660. updateFailed: 'Farbe konnte nicht aktualisiert werden',
  1661. colorDeleted: 'Farbe gelöscht',
  1662. deleteFailed: 'Farbe konnte nicht gelöscht werden',
  1663. resetSuccess: 'Farbkatalog auf Standardwerte zurückgesetzt',
  1664. resetFailed: 'Katalog konnte nicht zurückgesetzt werden',
  1665. syncUpToDate: 'Bereits aktuell ({{count}} Farben geprüft)',
  1666. syncComplete: '{{added}} neue Farben hinzugefügt ({{skipped}} bereits vorhanden)',
  1667. syncError: 'Sync-Fehler',
  1668. syncFailed: 'Synchronisierung von FilamentColors.xyz fehlgeschlagen',
  1669. exported: '{{count}} Farben exportiert',
  1670. imported: '{{added}} Farben importiert ({{skipped}} übersprungen)',
  1671. importFailed: 'Import fehlgeschlagen: ungültiges JSON-Format',
  1672. selectedCount: '{{count}} ausgewählt',
  1673. deleteSelected: 'Ausgewählte löschen',
  1674. bulkDeleteConfirm: 'Möchten Sie {{count}} Farben wirklich löschen?',
  1675. bulkDeleted: '{{count}} Farben gelöscht',
  1676. bulkDeleteFailed: 'Fehler beim Löschen der Farben',
  1677. },
  1678. // General tab
  1679. dateFormat: 'Datumsformat',
  1680. dateFormatUs: 'US (MM/TT/JJJJ)',
  1681. dateFormatEu: 'EU (TT/MM/JJJJ)',
  1682. dateFormatIso: 'ISO (JJJJ-MM-TT)',
  1683. timeFormat: 'Zeitformat',
  1684. timeFormat12: '12-Stunden (3:30 PM)',
  1685. timeFormat24: '24-Stunden (15:30)',
  1686. defaultPrinter: 'Standarddrucker',
  1687. defaultPrinterDescription: 'Diesen Drucker für Uploads, Nachdrucke und andere Vorgänge vorauswählen.',
  1688. slicerBambuStudio: 'Bambu Studio',
  1689. slicerOrcaSlicer: 'OrcaSlicer',
  1690. sidebarOrderDescription: 'Elemente in der Seitenleiste per Drag & Drop neu anordnen. Hier auf Standardreihenfolge zurücksetzen.',
  1691. reset: 'Zurücksetzen',
  1692. // Appearance
  1693. darkMode: 'Dunkelmodus',
  1694. lightMode: 'Hellmodus',
  1695. active: '(aktiv)',
  1696. background: 'Hintergrund',
  1697. accent: 'Akzent',
  1698. style: 'Stil',
  1699. bgNeutral: 'Neutral',
  1700. bgWarm: 'Warm',
  1701. bgCool: 'Kühl',
  1702. bgOled: 'OLED Schwarz',
  1703. bgSlate: 'Schieferblau',
  1704. bgForest: 'Waldgrün',
  1705. accentGreen: 'Grün',
  1706. accentTeal: 'Türkis',
  1707. accentBlue: 'Blau',
  1708. accentOrange: 'Orange',
  1709. accentPurple: 'Lila',
  1710. accentRed: 'Rot',
  1711. styleClassic: 'Klassisch',
  1712. styleGlow: 'Leuchtend',
  1713. styleVibrant: 'Lebendig',
  1714. themeToggleHint: 'Zwischen Hell- und Dunkelmodus mit dem Sonnen-/Mondsymbol in der Seitenleiste wechseln.',
  1715. // Archive
  1716. autoArchivePrints: 'Drucke automatisch archivieren',
  1717. autoArchiveDescription: '3MF-Dateien automatisch speichern, wenn Drucke abgeschlossen sind',
  1718. saveThumbnailsDescription: 'Vorschaubilder aus 3MF-Dateien extrahieren und speichern',
  1719. captureFinishPhotoDescription: 'Foto von der Druckerkamera aufnehmen, wenn der Druck abgeschlossen ist',
  1720. ffmpegNotInstalled: 'ffmpeg nicht installiert',
  1721. ffmpegRequired: 'Kameraaufnahme benötigt ffmpeg. Installieren über <brew>brew install ffmpeg</brew> (macOS) oder <apt>apt install ffmpeg</apt> (Linux).',
  1722. // Camera
  1723. camera: 'Kamera',
  1724. cameraViewMode: 'Kamera-Ansichtsmodus',
  1725. cameraOverlayDescription: 'Kamera öffnet sich als größenveränderbares Overlay auf dem Hauptbildschirm',
  1726. cameraWindowDescription: 'Kamera öffnet sich in einem separaten Browserfenster',
  1727. externalCamerasDescription: 'Externe Kameras konfigurieren, um die eingebaute Druckerkamera zu ersetzen. Unterstützt MJPEG-Streams, RTSP, HTTP-Snapshots und USB-Kameras (V4L2). Wenn aktiviert, wird die externe Kamera für Live-Ansicht und Abschlussfotos verwendet.',
  1728. cameraPlaceholderUsb: 'Gerätepfad (/dev/video0)',
  1729. cameraPlaceholderUrl: 'Kamera-URL (rtsp://... oder http://...)',
  1730. cameraTypeMjpeg: 'MJPEG-Stream',
  1731. cameraTypeRtsp: 'RTSP-Stream',
  1732. cameraTypeSnapshot: 'HTTP-Snapshot',
  1733. cameraTypeUsb: 'USB-Kamera (V4L2)',
  1734. test: 'Testen',
  1735. connected: 'Verbunden',
  1736. disconnected: 'Getrennt',
  1737. // Cost tracking
  1738. currency: 'Währung',
  1739. defaultFilamentCost: 'Standard-Filamentkosten (pro kg)',
  1740. electricityCost: 'Stromkosten pro kWh',
  1741. energyDisplayMode: 'Energieanzeige-Modus',
  1742. energyModePrintDescription: 'Dashboard zeigt Summe der während Drucken verbrauchten Energie',
  1743. energyModeTotalDescription: 'Dashboard zeigt Gesamtenergie der Smart Plugs',
  1744. // File Manager
  1745. fileManager: 'Dateimanager',
  1746. createArchiveEntry: 'Archiveintrag beim Drucken erstellen',
  1747. createArchiveEntryDescription: 'Beim Drucken aus dem Dateimanager optional einen Archiveintrag erstellen',
  1748. lowDiskSpaceWarning: 'Warnung bei wenig Speicherplatz',
  1749. lowDiskSpaceDescription: 'Warnung anzeigen, wenn freier Speicherplatz unter diesen Schwellenwert fällt',
  1750. // Updates
  1751. printerFirmware: 'Drucker-Firmware',
  1752. checkFirmwareDescription: 'Nach Firmware-Updates von Bambu Lab suchen',
  1753. bambuddySoftware: 'Bambuddy Software',
  1754. autoCheckDescription: 'Automatisch beim Start nach neuen Versionen suchen',
  1755. checkNow: 'Jetzt prüfen',
  1756. updateAvailableVersion: 'Update verfügbar: v{{version}}',
  1757. releaseNotes: 'Versionshinweise',
  1758. updateViaDocker: 'Update über Docker Compose:',
  1759. installUpdate: 'Update installieren',
  1760. latestVersionRunning: 'Sie verwenden die neueste Version',
  1761. failedToCheckUpdates: 'Update-Prüfung fehlgeschlagen: {{error}}',
  1762. // Data Management
  1763. backupRestore: 'Sicherung & Wiederherstellung',
  1764. backupRestoreDescription: 'Einstellungen exportieren/importieren und GitHub-Backup konfigurieren',
  1765. goToBackup: 'Zur Sicherung',
  1766. // Network tab
  1767. externalUrl: 'Externe URL',
  1768. externalUrlDescription: 'Die externe URL, unter der Bambuddy erreichbar ist. Wird für Benachrichtigungsbilder und externe Integrationen verwendet.',
  1769. bambuddyUrl: 'Bambuddy-URL',
  1770. externalUrlHint: 'Protokoll und Port angeben (z.B. http://192.168.1.100:8000)',
  1771. ftpRetry: 'FTP-Wiederholung',
  1772. ftpRetryDescription: 'FTP-Operationen bei unzuverlässigem Drucker-WLAN wiederholen. Gilt für 3MF-Downloads, Druck-Uploads, Zeitraffer-Downloads und Firmware-Updates.',
  1773. autoRetryDescription: 'Fehlgeschlagene FTP-Operationen automatisch wiederholen',
  1774. retryAttempts: 'Wiederholungsversuche',
  1775. retryDelay: 'Wiederholungsverzögerung',
  1776. connectionTimeout: 'Verbindungs-Timeout',
  1777. time_one: '{{count}} Mal',
  1778. time_other: '{{count}} Mal',
  1779. second_one: '{{count}} Sekunde',
  1780. second_other: '{{count}} Sekunden',
  1781. nSeconds: '{{count}} Sekunden',
  1782. increaseForWeakWifi: 'Erhöhen für Drucker mit schwachem WLAN',
  1783. // Home Assistant
  1784. homeAssistant: 'Home Assistant',
  1785. homeAssistantFullDescription: 'Mit Home Assistant verbinden, um Smart Plugs über die HA REST-API zu steuern. Unterstützt Switch-, Light-, Input_Boolean- und Script-Entitäten.',
  1786. homeAssistantUrl: 'Home Assistant URL',
  1787. longLivedAccessToken: 'Langlebiges Zugriffstoken',
  1788. haTokenHint: 'Token in HA erstellen: Profil → Langlebige Zugriffstoken → Token erstellen',
  1789. connectionSuccessful: 'Verbindung erfolgreich',
  1790. connectionFailed: 'Verbindung fehlgeschlagen',
  1791. haConnectionSuccess: 'Erfolgreich mit Home Assistant verbunden.',
  1792. haConnectionFailed: 'Verbindung zu Home Assistant fehlgeschlagen.',
  1793. // MQTT
  1794. mqttPublishing: 'MQTT-Veröffentlichung',
  1795. mqttDescription: 'BamBuddy-Ereignisse an einen externen MQTT-Broker zur Integration mit Node-RED, Home Assistant und anderen Automatisierungssystemen veröffentlichen.',
  1796. mqttEnableDescription: 'Ereignisse an externen MQTT-Broker veröffentlichen',
  1797. brokerHostname: 'Broker-Hostname',
  1798. port: 'Port',
  1799. usernameOptional: 'Benutzername (optional)',
  1800. passwordOptional: 'Passwort (optional)',
  1801. topicPrefix: 'Topic-Präfix',
  1802. topicPrefixHint: 'Topics werden sein: {{prefix}}/printers/<serial>/status, etc.',
  1803. // Prometheus
  1804. prometheusMetrics: 'Prometheus-Metriken',
  1805. prometheusEndpointDescription: 'Druckermetriken unter <code>/api/v1/metrics</code> für Prometheus/Grafana-Überwachung bereitstellen.',
  1806. bearerTokenOptional: 'Bearer-Token (optional)',
  1807. bearerTokenHint: 'Wenn gesetzt, müssen Anfragen <code>Authorization: Bearer <token></code> enthalten',
  1808. metricsConnectionStatus: 'Verbindungsstatus',
  1809. metricsPrinterState: 'Druckerstatus (idle/printing/etc)',
  1810. metricsPrintProgress: 'Druckfortschritt 0-100%',
  1811. metricsBedTemp: 'Betttemperatur',
  1812. metricsNozzleTemp: 'Düsentemperatur',
  1813. metricsPrintsTotal: 'Gesamtdrucke nach Ergebnis',
  1814. metricsMore: '...und mehr (Schichten, Lüfter, Warteschlange, Filamentverbrauch)',
  1815. // Smart Plugs
  1816. smartPlugsDescription: 'Smart Plugs (Tasmota oder Home Assistant) verbinden, um Stromsteuerung zu automatisieren und Energieverbrauch für Ihre Drucker zu verfolgen.',
  1817. allOn: 'Alle Ein',
  1818. allOff: 'Alle Aus',
  1819. addSmartPlug: 'Smart Plug hinzufügen',
  1820. energySummary: 'Energieübersicht',
  1821. currentPower: 'Aktuelle Leistung',
  1822. plugsOnline: '{{reachable}}/{{total}} Plugs online',
  1823. today: 'Heute',
  1824. yesterday: 'Gestern',
  1825. total: 'Gesamt',
  1826. enablePlugsForSummary: 'Plugs aktivieren, um Energieübersicht zu sehen',
  1827. addNotificationProvider: 'Hinzufügen',
  1828. // Users
  1829. systemBadge: '(System)',
  1830. creating: 'Erstellen...',
  1831. changing: 'Ändern...',
  1832. deleteUserAndItems: 'Benutzer UND dessen Elemente löschen',
  1833. deleteUserKeepItems: 'Benutzer löschen, Elemente behalten (werden herrenlos)',
  1834. ok: 'OK',
  1835. },
  1836. // Notifications (for push notifications)
  1837. notification: {
  1838. printStarted: {
  1839. title: 'Druck gestartet',
  1840. body: '{{printer}}: {{filename}} wird gedruckt',
  1841. },
  1842. printCompleted: {
  1843. title: 'Druck abgeschlossen',
  1844. body: '{{printer}}: {{filename}} erfolgreich abgeschlossen',
  1845. },
  1846. printFailed: {
  1847. title: 'Druck fehlgeschlagen',
  1848. body: '{{printer}}: {{filename}} ist fehlgeschlagen',
  1849. },
  1850. printStopped: {
  1851. title: 'Druck gestoppt',
  1852. body: '{{printer}}: {{filename}} wurde gestoppt',
  1853. },
  1854. printProgress: {
  1855. title: 'Druckfortschritt',
  1856. body: '{{printer}}: {{filename}} ist zu {{percent}}% abgeschlossen',
  1857. },
  1858. printerOffline: {
  1859. title: 'Drucker offline',
  1860. body: '{{printer}} ist offline',
  1861. },
  1862. printerError: {
  1863. title: 'Druckerfehler',
  1864. body: '{{printer}}: {{error}}',
  1865. },
  1866. filamentLow: {
  1867. title: 'Filament niedrig',
  1868. body: '{{printer}}: Filament geht zur Neige',
  1869. },
  1870. maintenanceDue: {
  1871. title: 'Wartung fällig',
  1872. body: '{{printer}}: {{items}} benötigen Aufmerksamkeit',
  1873. },
  1874. },
  1875. // Errors
  1876. errors: {
  1877. generic: 'Etwas ist schiefgelaufen',
  1878. networkError: 'Netzwerkfehler. Bitte überprüfen Sie Ihre Verbindung.',
  1879. notFound: 'Nicht gefunden',
  1880. unauthorized: 'Nicht autorisiert',
  1881. serverError: 'Serverfehler',
  1882. validationError: 'Bitte überprüfen Sie Ihre Eingabe',
  1883. printerConnectionFailed: 'Verbindung zum Drucker fehlgeschlagen',
  1884. saveFailed: 'Speichern fehlgeschlagen',
  1885. deleteFailed: 'Löschen fehlgeschlagen',
  1886. loadFailed: 'Laden der Daten fehlgeschlagen',
  1887. },
  1888. // HMS Errors modal
  1889. hmsErrors: {
  1890. title: 'Fehler - {{name}}',
  1891. noErrors: 'Keine Fehler',
  1892. viewOnWiki: 'Im Bambu Lab Wiki ansehen',
  1893. clearInstructions: 'Löschen Sie die Fehler am Drucker, um sie hier zu entfernen.',
  1894. clearErrors: 'Fehler löschen',
  1895. clearSuccess: 'HMS-Fehler gelöscht',
  1896. clearFailed: 'HMS-Fehler konnten nicht gelöscht werden',
  1897. },
  1898. // MQTT Debug modal
  1899. mqttDebug: {
  1900. title: 'MQTT-Debug-Protokoll',
  1901. searchPlaceholder: 'Topic oder Payload suchen...',
  1902. noMessages: 'Noch keine Nachrichten protokolliert',
  1903. startLoggingHint: 'Klicken Sie auf "Protokollierung starten", um MQTT-Nachrichten aufzuzeichnen',
  1904. noMessagesMatch: 'Keine Nachrichten entsprechen Ihrem Filter',
  1905. adjustFilterHint: 'Versuchen Sie, Ihre Such- oder Filterkriterien anzupassen',
  1906. incoming: 'Eingehend',
  1907. outgoing: 'Ausgehend',
  1908. loggingStopped: 'Protokollierung gestoppt',
  1909. loggingActive: 'Protokollierung aktiv - Nachrichten werden automatisch aktualisiert',
  1910. startLogging: 'Protokollierung starten',
  1911. stopLogging: 'Protokollierung stoppen',
  1912. clearLog: 'Protokoll löschen',
  1913. topic: 'Topic',
  1914. timestamp: 'Zeitstempel',
  1915. direction: 'Richtung',
  1916. all: 'Alle',
  1917. },
  1918. // Printer File Manager modal (printer internal storage)
  1919. printerFiles: {
  1920. title: 'Dateimanager',
  1921. storageUsed: 'Belegt:',
  1922. storageFree: 'Frei:',
  1923. filterPlaceholder: 'Dateien filtern...',
  1924. deleteButton: 'Löschen',
  1925. deleteFiles: '{{count}} Dateien löschen',
  1926. deleteFileConfirm: '"{{name}}" löschen? Dies kann nicht rückgängig gemacht werden.',
  1927. deleteFilesConfirm: '{{count}} ausgewählte Dateien löschen? Dies kann nicht rückgängig gemacht werden.',
  1928. noFiles: 'Keine Dateien auf dem Drucker',
  1929. loadingFiles: 'Dateien werden geladen...',
  1930. failedToLoad: 'Dateien konnten nicht geladen werden',
  1931. toast: {
  1932. filesDeleted: '{{count}} Datei(en) gelöscht',
  1933. deleteFailed: 'Löschen fehlgeschlagen: {{error}}',
  1934. },
  1935. },
  1936. // Confirmations
  1937. confirm: {
  1938. delete: 'Möchten Sie dies wirklich löschen?',
  1939. unsavedChanges: 'Sie haben ungespeicherte Änderungen. Möchten Sie wirklich verlassen?',
  1940. clearQueue: 'Möchten Sie die Warteschlange wirklich leeren?',
  1941. },
  1942. // Login page
  1943. login: {
  1944. title: 'Bambuddy Anmeldung',
  1945. subtitle: 'Melden Sie sich bei Ihrem Konto an',
  1946. username: 'Benutzername',
  1947. usernamePlaceholder: 'Benutzername eingeben',
  1948. usernameOrEmail: 'Benutzername oder E-Mail',
  1949. usernameOrEmailPlaceholder: 'Benutzername oder @ E-Mail',
  1950. password: 'Passwort',
  1951. passwordPlaceholder: 'Passwort eingeben',
  1952. signIn: 'Anmelden',
  1953. signingIn: 'Anmeldung läuft...',
  1954. forgotPassword: 'Passwort vergessen?',
  1955. loginSuccess: 'Erfolgreich angemeldet',
  1956. loginFailed: 'Anmeldung fehlgeschlagen',
  1957. enterCredentials: 'Bitte Benutzername und Passwort eingeben',
  1958. forgotPasswordTitle: 'Passwort vergessen',
  1959. forgotPasswordMessage: 'Wenn Sie Ihr Passwort vergessen haben, wenden Sie sich bitte an Ihren Systemadministrator.',
  1960. forgotPasswordEmailMessage: 'Geben Sie Ihre E-Mail-Adresse ein und wir senden Ihnen ein neues Passwort.',
  1961. emailAddress: 'E-Mail-Adresse',
  1962. emailPlaceholder: 'ihre.email@beispiel.de',
  1963. cancel: 'Abbrechen',
  1964. sending: 'Wird gesendet...',
  1965. sendResetEmail: 'Zurücksetzungs-E-Mail senden',
  1966. howToReset: 'So setzen Sie Ihr Passwort zurück:',
  1967. resetStep1: 'Kontaktieren Sie Ihren Bambuddy-Administrator',
  1968. resetStep2: 'Bitten Sie ihn, Ihr Passwort in der Benutzerverwaltung zurückzusetzen',
  1969. resetStep3: 'Er kann ein neues temporäres Passwort für Sie festlegen',
  1970. resetStep4: 'Melden Sie sich mit dem neuen Passwort an und ändern Sie es in den Einstellungen',
  1971. gotIt: 'Verstanden',
  1972. },
  1973. // Setup page
  1974. setup: {
  1975. title: 'Bambuddy Einrichtung',
  1976. subtitle: 'Konfigurieren Sie die Authentifizierung für Ihre Bambuddy-Instanz',
  1977. enableAuth: 'Authentifizierung aktivieren',
  1978. adminAccount: 'Admin-Konto',
  1979. adminAccountDesc: 'Wenn bereits Admin-Benutzer existieren, wird die Authentifizierung mit den vorhandenen Admin-Konten aktiviert. Lassen Sie die Felder unten leer, um vorhandene Admins zu verwenden, oder geben Sie neue Anmeldedaten ein, um einen neuen Admin-Benutzer zu erstellen.',
  1980. adminUsername: 'Admin-Benutzername',
  1981. adminPassword: 'Admin-Passwort',
  1982. optionalIfAdminExists: '(optional, wenn Admin-Benutzer existieren)',
  1983. adminUsernamePlaceholder: 'Admin-Benutzernamen eingeben (optional)',
  1984. adminPasswordPlaceholder: 'Admin-Passwort eingeben (optional)',
  1985. confirmPassword: 'Passwort bestätigen',
  1986. confirmPasswordPlaceholder: 'Admin-Passwort bestätigen',
  1987. settingUp: 'Einrichtung läuft...',
  1988. completeSetup: 'Einrichtung abschließen',
  1989. toast: {
  1990. authEnabledAdminCreated: 'Authentifizierung aktiviert und Admin-Benutzer erstellt',
  1991. authEnabledExistingAdmins: 'Authentifizierung mit vorhandenen Admin-Benutzern aktiviert',
  1992. setupCompleted: 'Einrichtung abgeschlossen',
  1993. enterBothCredentials: 'Bitte geben Sie sowohl Admin-Benutzernamen als auch Passwort ein, oder lassen Sie beide leer, um vorhandene Admin-Benutzer zu verwenden',
  1994. passwordsDoNotMatch: 'Passwörter stimmen nicht überein',
  1995. passwordTooShort: 'Passwort muss mindestens 6 Zeichen lang sein',
  1996. },
  1997. },
  1998. // Password change
  1999. changePassword: {
  2000. title: 'Passwort ändern',
  2001. currentPassword: 'Aktuelles Passwort',
  2002. currentPasswordPlaceholder: 'Aktuelles Passwort eingeben',
  2003. newPassword: 'Neues Passwort',
  2004. newPasswordPlaceholder: 'Neues Passwort eingeben (min. 6 Zeichen)',
  2005. confirmPassword: 'Neues Passwort bestätigen',
  2006. confirmPasswordPlaceholder: 'Neues Passwort bestätigen',
  2007. passwordsDoNotMatch: 'Passwörter stimmen nicht überein',
  2008. passwordTooShort: 'Passwort muss mindestens 6 Zeichen lang sein',
  2009. changing: 'Wird geändert...',
  2010. success: 'Passwort erfolgreich geändert',
  2011. failed: 'Passwortänderung fehlgeschlagen',
  2012. },
  2013. // Plate detection alert
  2014. plateAlert: {
  2015. title: 'Druck pausiert!',
  2016. message: 'Objekte auf dem Druckbett erkannt. Der Druck wurde automatisch pausiert. Bitte räumen Sie das Druckbett und setzen Sie den Druck fort.',
  2017. understand: 'Verstanden',
  2018. },
  2019. // Camera page
  2020. camera: {
  2021. title: 'Kameraansicht',
  2022. invalidPrinterId: 'Ungültige Drucker-ID',
  2023. live: 'Live',
  2024. snapshot: 'Schnappschuss',
  2025. restartStream: 'Stream neu starten',
  2026. refreshSnapshot: 'Schnappschuss aktualisieren',
  2027. fullscreen: 'Vollbild',
  2028. exitFullscreen: 'Vollbild beenden',
  2029. connectingToCamera: 'Verbinde mit Kamera...',
  2030. capturingSnapshot: 'Schnappschuss wird aufgenommen...',
  2031. connectionLost: 'Verbindung verloren',
  2032. connectionFailed: 'Kameraverbindung fehlgeschlagen',
  2033. reconnecting: 'Neuverbindung in {{countdown}}s... (Versuch {{attempt}}/{{max}})',
  2034. reconnectNow: 'Jetzt verbinden',
  2035. cameraUnavailable: 'Kamera nicht verfügbar',
  2036. cameraUnavailableDesc: 'Stellen Sie sicher, dass der Drucker eingeschaltet und verbunden ist.',
  2037. noCamera: 'Keine Kamera verfügbar',
  2038. retry: 'Erneut versuchen',
  2039. cameraStream: 'Kamera-Stream',
  2040. zoomOut: 'Verkleinern',
  2041. zoomIn: 'Vergrößern',
  2042. resetZoom: 'Zoom zurücksetzen',
  2043. recording: 'Aufnahme',
  2044. startRecording: 'Aufnahme starten',
  2045. stopRecording: 'Aufnahme stoppen',
  2046. chamberLight: 'Kammerbeleuchtung umschalten',
  2047. },
  2048. // Groups management
  2049. groups: {
  2050. title: 'Gruppenverwaltung',
  2051. subtitle: 'Berechtigungsgruppen für Zugriffskontrolle verwalten',
  2052. backToSettings: 'Zurück zu Einstellungen',
  2053. createGroup: 'Gruppe erstellen',
  2054. noPermission: 'Sie haben keine Berechtigung, auf diese Seite zuzugreifen.',
  2055. system: 'System',
  2056. noDescription: 'Keine Beschreibung',
  2057. usersCount: '{{count}} Benutzer',
  2058. permissionsCount: '{{count}} Berechtigungen',
  2059. edit: 'Bearbeiten',
  2060. delete: 'Löschen',
  2061. toast: {
  2062. created: 'Gruppe erfolgreich erstellt',
  2063. updated: 'Gruppe erfolgreich aktualisiert',
  2064. deleted: 'Gruppe erfolgreich gelöscht',
  2065. enterGroupName: 'Bitte geben Sie einen Gruppennamen ein',
  2066. },
  2067. modal: {
  2068. editGroup: 'Gruppe bearbeiten',
  2069. createGroup: 'Gruppe erstellen',
  2070. cancel: 'Abbrechen',
  2071. saving: 'Speichern...',
  2072. creating: 'Erstellen...',
  2073. saveChanges: 'Änderungen speichern',
  2074. },
  2075. form: {
  2076. groupName: 'Gruppenname',
  2077. groupNamePlaceholder: 'Gruppennamen eingeben',
  2078. systemGroupWarning: 'Systemgruppennamen können nicht geändert werden',
  2079. description: 'Beschreibung',
  2080. descriptionPlaceholder: 'Beschreibung eingeben (optional)',
  2081. permissions: 'Berechtigungen ({{count}} ausgewählt)',
  2082. },
  2083. deleteModal: {
  2084. title: 'Gruppe löschen',
  2085. message: 'Sind Sie sicher, dass Sie diese Gruppe löschen möchten? Benutzer in dieser Gruppe verlieren diese Berechtigungen.',
  2086. confirm: 'Gruppe löschen',
  2087. },
  2088. editor: {
  2089. title: 'Gruppe bearbeiten',
  2090. createTitle: 'Gruppe erstellen',
  2091. search: 'Berechtigungen suchen...',
  2092. selectAll: 'Alle auswählen',
  2093. clearAll: 'Alle abwählen',
  2094. permissionsSelected: '{{count}} ausgewählt',
  2095. noResults: 'Keine Berechtigungen entsprechen Ihrer Suche',
  2096. },
  2097. },
  2098. // Users management
  2099. users: {
  2100. title: 'Benutzerverwaltung',
  2101. subtitle: 'Benutzer und deren Zugriff auf Ihre Bambuddy-Instanz verwalten',
  2102. backToSettings: 'Zurück zu Einstellungen',
  2103. createUser: 'Benutzer erstellen',
  2104. noPermission: 'Sie haben keine Berechtigung, auf diese Seite zuzugreifen.',
  2105. admin: 'Admin',
  2106. noGroups: 'Keine Gruppen',
  2107. active: 'Aktiv',
  2108. inactive: 'Inaktiv',
  2109. edit: 'Bearbeiten',
  2110. delete: 'Löschen',
  2111. system: 'System',
  2112. noGroupsAvailable: 'Keine Gruppen verfügbar',
  2113. table: {
  2114. username: 'Benutzername',
  2115. groups: 'Gruppen',
  2116. status: 'Status',
  2117. actions: 'Aktionen',
  2118. },
  2119. toast: {
  2120. created: 'Benutzer erfolgreich erstellt',
  2121. updated: 'Benutzer erfolgreich aktualisiert',
  2122. deleted: 'Benutzer erfolgreich gelöscht',
  2123. fillRequired: 'Bitte füllen Sie alle Pflichtfelder aus',
  2124. passwordsDoNotMatch: 'Passwörter stimmen nicht überein',
  2125. passwordTooShort: 'Passwort muss mindestens 6 Zeichen lang sein',
  2126. },
  2127. modal: {
  2128. createUser: 'Benutzer erstellen',
  2129. editUser: 'Benutzer bearbeiten',
  2130. cancel: 'Abbrechen',
  2131. creating: 'Erstellen...',
  2132. saving: 'Speichern...',
  2133. saveChanges: 'Änderungen speichern',
  2134. advancedAuthSubtitle: 'mit erweiterter Authentifizierung',
  2135. },
  2136. form: {
  2137. username: 'Benutzername',
  2138. usernamePlaceholder: 'Benutzernamen eingeben',
  2139. email: 'E-Mail',
  2140. emailPlaceholder: 'benutzer@beispiel.de',
  2141. password: 'Passwort',
  2142. passwordPlaceholder: 'Passwort eingeben',
  2143. confirmPassword: 'Passwort bestätigen',
  2144. confirmPasswordPlaceholder: 'Passwort bestätigen',
  2145. newPasswordPlaceholder: 'Neues Passwort eingeben',
  2146. confirmNewPasswordPlaceholder: 'Neues Passwort bestätigen',
  2147. leaveBlankToKeep: 'leer lassen, um das aktuelle zu behalten',
  2148. groups: 'Gruppen',
  2149. optional: 'optional',
  2150. autoGeneratedPassword: 'Ein sicheres Passwort wird automatisch generiert und per E-Mail an den Benutzer gesendet.',
  2151. passwordManagedByAdvancedAuth: 'Das Passwort wird durch erweiterte Authentifizierung verwaltet. Verwenden Sie "Passwort zurücksetzen", um ein neues Passwort per E-Mail an den Benutzer zu senden.',
  2152. resetPassword: 'Passwort zurücksetzen',
  2153. resettingPassword: 'Passwort wird zurückgesetzt...',
  2154. },
  2155. deleteModal: {
  2156. title: 'Benutzer löschen',
  2157. message: 'Sind Sie sicher, dass Sie diesen Benutzer löschen möchten? Diese Aktion kann nicht rückgängig gemacht werden.',
  2158. confirm: 'Benutzer löschen',
  2159. },
  2160. },
  2161. // Stream overlay
  2162. streamOverlay: {
  2163. title: 'Stream-Overlay',
  2164. invalidPrinterId: 'Ungültige Drucker-ID',
  2165. cameraStream: 'Kamera-Stream',
  2166. progress: 'Fortschritt',
  2167. eta: 'ETA',
  2168. printerIdle: 'Drucker ist inaktiv',
  2169. printerOffline: 'Drucker offline',
  2170. status: {
  2171. printing: 'Druckt',
  2172. paused: 'Pausiert',
  2173. finished: 'Fertig',
  2174. failed: 'Fehlgeschlagen',
  2175. idle: 'Inaktiv',
  2176. unknown: 'Unbekannt',
  2177. },
  2178. },
  2179. // Profiles
  2180. profiles: {
  2181. title: 'Profile',
  2182. subtitle: 'Verwalten Sie Ihre Slicer-Voreinstellungen und Druckvorschub-Kalibrierungen',
  2183. tabs: {
  2184. cloud: 'Cloud-Profile',
  2185. local: 'Lokale Profile',
  2186. kprofiles: 'K-Profile',
  2187. },
  2188. localProfiles: {
  2189. title: 'Lokale Profile',
  2190. subtitle: 'Slicer-Voreinstellungen aus OrcaSlicer importieren und verwalten',
  2191. import: 'Profile importieren',
  2192. importDesc: '.bbscfg-, .bbsflmt-, .orca_filament-, .zip- oder .json-Dateien hier ablegen',
  2193. importing: 'Importiere...',
  2194. search: 'Lokale Voreinstellungen durchsuchen...',
  2195. noPresets: 'Noch keine lokalen Voreinstellungen',
  2196. badge: 'Lokal',
  2197. edit: 'Bearbeiten',
  2198. delete: 'Löschen',
  2199. cancel: 'Abbrechen',
  2200. deleteConfirmTitle: 'Voreinstellung löschen',
  2201. deleteConfirm: 'Möchten Sie diese Voreinstellung wirklich löschen? Dies kann nicht rückgängig gemacht werden.',
  2202. source: 'Quelle',
  2203. inheritsFrom: 'Erbt von',
  2204. filamentType: 'Typ',
  2205. vendor: 'Hersteller',
  2206. compatiblePrinters: 'Drucker',
  2207. nozzleTemp: 'Düsentemperatur',
  2208. cost: 'Kosten',
  2209. density: 'Dichte',
  2210. pressureAdvance: 'Druckvorschub',
  2211. filament: 'Filament',
  2212. process: 'Prozess',
  2213. printer: 'Drucker',
  2214. toast: {
  2215. importSuccess: '{{count}} Voreinstellung(en) importiert',
  2216. importSkipped: '{{count}} Voreinstellung(en) übersprungen (Duplikate)',
  2217. importError: '{{count}} Fehler beim Import',
  2218. deleted: 'Voreinstellung gelöscht',
  2219. updated: 'Voreinstellung aktualisiert',
  2220. },
  2221. },
  2222. connectedAs: 'Verbunden als',
  2223. logout: 'Abmelden',
  2224. noLogoutPermission: 'Sie haben keine Berechtigung zum Abmelden',
  2225. failedToLoad: 'Profile konnten nicht geladen werden',
  2226. retry: 'Erneut versuchen',
  2227. time: {
  2228. justNow: 'Gerade eben',
  2229. minsAgo: 'vor {{count}}m',
  2230. hoursAgo: 'vor {{count}}h',
  2231. daysAgo: 'vor {{count}}d',
  2232. },
  2233. toast: {
  2234. loggedOut: 'Abgemeldet',
  2235. },
  2236. login: {
  2237. title: 'Mit Bambu Cloud verbinden',
  2238. subtitle: 'Synchronisieren Sie Ihre Slicer-Voreinstellungen geräteübergreifend',
  2239. email: 'E-Mail',
  2240. password: 'Passwort',
  2241. region: 'Region',
  2242. regionGlobal: 'Global',
  2243. regionChina: 'China',
  2244. verificationCode: 'Bestätigungscode',
  2245. totpCode: 'Authenticator-Code',
  2246. checkEmail: 'Prüfen Sie Ihre E-Mail ({{email}}) für einen 6-stelligen Code',
  2247. enterTotpHint: 'Geben Sie den 6-stelligen Code aus Ihrer Authenticator-App ein',
  2248. accessToken: 'Zugriffstoken',
  2249. accessTokenHint: 'Fügen Sie Ihr Bambu Lab Zugriffstoken ein (aus Bambu Studio)',
  2250. back: 'Zurück',
  2251. loginButton: 'Anmelden',
  2252. verifyButton: 'Bestätigen',
  2253. setTokenButton: 'Token setzen',
  2254. useToken: 'Stattdessen Zugriffstoken verwenden',
  2255. useEmail: 'Stattdessen mit E-Mail anmelden',
  2256. toast: {
  2257. loggedIn: 'Erfolgreich angemeldet',
  2258. codeSent: 'Bestätigungscode an Ihre E-Mail gesendet',
  2259. enterTotp: 'Geben Sie den Code aus Ihrer Authenticator-App ein',
  2260. tokenSet: 'Token erfolgreich gesetzt',
  2261. },
  2262. },
  2263. presets: {
  2264. myPreset: 'Mein Profil (bearbeitbar)',
  2265. duplicate: 'Duplizieren',
  2266. editable: 'Bearbeitbar',
  2267. failedToLoadDetails: 'Profil-Details konnten nicht geladen werden',
  2268. deleteConfirm: 'Dieses Profil löschen?',
  2269. deleteWarning: '"{{name}}" wird dauerhaft aus Bambu Cloud gelöscht. Dies kann nicht rückgängig gemacht werden.',
  2270. noDuplicatePermission: 'Sie haben keine Berechtigung zum Duplizieren von Profilen',
  2271. noEditPermission: 'Sie haben keine Berechtigung zum Bearbeiten von Profilen',
  2272. noDeletePermission: 'Sie haben keine Berechtigung zum Löschen von Profilen',
  2273. types: {
  2274. filament: 'Filament-Profil',
  2275. printer: 'Drucker-Profil',
  2276. process: 'Prozess-Profil',
  2277. },
  2278. toast: {
  2279. deleted: 'Profil gelöscht',
  2280. created: 'Profil erstellt',
  2281. updated: 'Profil aktualisiert',
  2282. duplicated: 'Profil dupliziert',
  2283. fieldAdded: 'Feld "{{key}}" hinzugefügt',
  2284. exported: 'Profil exportiert',
  2285. },
  2286. baseLabel: 'Basis: {{name}}',
  2287. currentLabel: 'Aktuell: {{name}}',
  2288. newPreset: 'Neues Profil',
  2289. editPreset: 'Profil bearbeiten',
  2290. duplicatePreset: 'Profil duplizieren',
  2291. createNewPreset: 'Neues Profil erstellen',
  2292. customizeSettings: 'Passen Sie die Einstellungen für Ihr neues Profil an',
  2293. compareWithBase: 'Mit Basis-Profil vergleichen',
  2294. compare: 'Vergleichen',
  2295. // CreatePresetModal - Basic Info
  2296. basePreset: 'Basis-Profil',
  2297. selectBasePreset: 'Basis-Profil auswählen...',
  2298. presetName: 'Profilname',
  2299. myCustomPreset: 'Mein eigenes Profil',
  2300. inheritsFrom: 'Erbt von',
  2301. dropJsonToImport: 'JSON zum Importieren ablegen',
  2302. // CreatePresetModal - Tabs
  2303. tabs: {
  2304. common: 'Allgemein',
  2305. allFields: 'Alle Felder',
  2306. },
  2307. // CreatePresetModal - All Fields Tab
  2308. availableFields: 'Verfügbare Felder',
  2309. searchFieldsPlaceholder: 'Felder suchen...',
  2310. noMatchingFields: 'Keine passenden Felder',
  2311. allFieldsAdded: 'Alle Felder hinzugefügt',
  2312. addCustomField: 'Eigenes Feld hinzufügen',
  2313. yourOverrides: 'Ihre Überschreibungen',
  2314. noOverridesYet: 'Noch keine Überschreibungen',
  2315. clickFieldsToAdd: 'Klicken Sie links auf Felder, um sie hinzuzufügen',
  2316. saveAsTemplate: 'Als Vorlage speichern',
  2317. jsonTip: 'Tipp: Ziehen Sie eine .json-Datei auf dieses Fenster, um Einstellungen zu importieren',
  2318. },
  2319. cloudView: {
  2320. searchPlaceholder: 'Profile suchen...',
  2321. templates: 'Vorlagen',
  2322. refresh: 'Aktualisieren',
  2323. newPreset: 'Neues Profil',
  2324. clearFilters: 'Filter zurücksetzen',
  2325. // Compare mode
  2326. compareMode: 'Vergleichsmodus',
  2327. selectAnotherPreset: 'Wählen Sie ein weiteres {{type}}-Profil',
  2328. clickTwoPresets: 'Klicken Sie auf zwei Profile des gleichen Typs zum Vergleichen',
  2329. selectFirst: '1. Erstes auswählen',
  2330. selectSecond: '2. Zweites auswählen',
  2331. compareNow: 'Jetzt vergleichen',
  2332. // Status row
  2333. lastSynced: 'Zuletzt synchronisiert:',
  2334. showingCount: '{{showing}} von {{total}} Profilen',
  2335. noPresetsFound: 'Keine Profile gefunden',
  2336. // Column headers
  2337. columns: {
  2338. filament: 'Filament',
  2339. process: 'Prozess',
  2340. printer: 'Drucker',
  2341. },
  2342. noFilamentPresets: 'Keine Filament-Profile',
  2343. noProcessPresets: 'Keine Prozess-Profile',
  2344. noPrinterPresets: 'Keine Drucker-Profile',
  2345. // Filters
  2346. filters: {
  2347. type: 'Typ',
  2348. owner: 'Besitzer',
  2349. printer: 'Drucker',
  2350. nozzle: 'Düse',
  2351. filament: 'Filament',
  2352. layer: 'Schicht',
  2353. all: 'Alle',
  2354. myPresets: 'Meine Profile',
  2355. builtIn: 'Voreingestellt',
  2356. process: 'Prozess',
  2357. },
  2358. // Permissions
  2359. noTemplatesPermission: 'Sie haben keine Berechtigung, Vorlagen zu verwalten',
  2360. noRefreshPermission: 'Sie haben keine Berechtigung, Profile zu aktualisieren',
  2361. noCreatePermission: 'Sie haben keine Berechtigung, Profile zu erstellen',
  2362. },
  2363. templates: {
  2364. title: 'Schnellvorlagen',
  2365. noTemplates: 'Noch keine Vorlagen',
  2366. createFirst: 'Erstellen Sie Vorlagen aus dem Preset-Editor',
  2367. typeFilter: 'Typ:',
  2368. deleteTitle: 'Vorlage löschen',
  2369. deleteWarning: 'Diese Aktion kann nicht rückgängig gemacht werden',
  2370. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen?',
  2371. namePlaceholder: 'Vorlagenname',
  2372. descriptionPlaceholder: 'Beschreibung',
  2373. settingsJson: 'Einstellungen (JSON)',
  2374. fieldsCount: '{{count}} Felder',
  2375. shownInModals: 'In Dialogen angezeigt',
  2376. hiddenInModals: 'In Dialogen ausgeblendet',
  2377. apply: 'Anwenden',
  2378. toast: {
  2379. deleted: 'Vorlage gelöscht',
  2380. updated: 'Vorlage aktualisiert',
  2381. created: 'Vorlage erstellt',
  2382. applied: 'Vorlage angewendet',
  2383. },
  2384. },
  2385. },
  2386. // Support/Debug
  2387. support: {
  2388. debugLoggingActive: 'Debug-Protokollierung ist aktiv',
  2389. manageLogs: 'Verwalten',
  2390. collectItem7: 'Drucker-Verbindungsstatus und Firmware-Versionen',
  2391. collectItem8: 'Integrationsstatus (Spoolman, MQTT, HA)',
  2392. collectItem9: 'Netzwerkschnittstellen (nur Subnetze)',
  2393. collectItem10: 'Python-Paketversionen',
  2394. collectItem11: 'Datenbankzustandsprüfungen',
  2395. collectItem12: 'Docker-Umgebungsdetails',
  2396. },
  2397. // File manager
  2398. fileManager: {
  2399. title: 'Dateimanager',
  2400. subtitle: 'Organisieren und verwalten Sie Ihre Druckdateien',
  2401. uploadFiles: 'Dateien hochladen',
  2402. newFolder: 'Neuer Ordner',
  2403. folderName: 'Ordnername',
  2404. folderNamePlaceholder: 'z.B. Funktionsteile',
  2405. renameFile: 'Datei umbenennen',
  2406. renameFolder: 'Ordner umbenennen',
  2407. moveFiles: '{{count}} Datei(en) verschieben',
  2408. rootNoFolder: 'Stammverzeichnis (Kein Ordner)',
  2409. current: 'aktuell',
  2410. linkFolder: 'Ordner verknüpfen',
  2411. linkFolderDescription: '"{{name}}" mit einem Projekt oder Archiv verknüpfen für schnellen Zugriff.',
  2412. project: 'Projekt',
  2413. archive: 'Archiv',
  2414. noProjectsFound: 'Keine Projekte gefunden',
  2415. noArchivesFound: 'Keine Archive gefunden',
  2416. unlink: 'Verknüpfung aufheben',
  2417. link: 'Verknüpfen',
  2418. dragDropFiles: 'Dateien hierher ziehen',
  2419. dropFilesHere: 'Dateien hier ablegen',
  2420. orClickToBrowse: 'oder klicken zum Durchsuchen',
  2421. allFileTypesSupported: 'Alle Dateitypen werden unterstützt. ZIP-Dateien werden extrahiert.',
  2422. zipFilesDetected: 'ZIP-Dateien erkannt',
  2423. zipExtractOptions: 'ZIP-Dateien werden extrahiert. Wählen Sie, wie die Ordnerstruktur behandelt werden soll:',
  2424. preserveZipStructure: 'Ordnerstruktur aus ZIP beibehalten',
  2425. createFolderFromZip: 'Ordner aus ZIP-Dateiname erstellen',
  2426. stlThumbnailGeneration: 'STL-Vorschaubildgenerierung',
  2427. zipMayContainStl: 'ZIP-Dateien können STL-Dateien enthalten. Vorschaubilder können während der Extraktion generiert werden.',
  2428. thumbnailsCanBeGenerated: 'Vorschaubilder können für STL-Dateien generiert werden. Große Modelle benötigen möglicherweise mehr Zeit.',
  2429. generateThumbnailsForStl: 'Vorschaubilder für STL-Dateien generieren',
  2430. threemfDetected: '3MF-Dateien erkannt',
  2431. threemfExtractionInfo: 'Druckermodell, Material, Farbe und Druckeinstellungen werden automatisch aus 3MF-Dateien extrahiert.',
  2432. willBeExtracted: 'Wird extrahiert',
  2433. filesExtracted: '{{count}} Dateien extrahiert',
  2434. uploadComplete: 'Upload abgeschlossen: {{succeeded}} erfolgreich',
  2435. uploadFailed: 'Hochladen fehlgeschlagen',
  2436. zipFilesFailed: '{{count}} Dateien fehlgeschlagen',
  2437. uploading: 'Hochladen...',
  2438. changeLink: 'Verknüpfung ändern...',
  2439. linkTo: 'Verknüpfen mit...',
  2440. linkToProjectOrArchive: 'Mit Projekt oder Archiv verknüpfen',
  2441. addToQueue: 'Zur Warteschlange',
  2442. schedulePrint: 'Planen',
  2443. generateThumbnail: 'Vorschaubild generieren',
  2444. generateThumbnails: 'Vorschaubilder generieren',
  2445. generateThumbnailsForMissing: 'Vorschaubilder für STL-Dateien ohne Vorschau generieren',
  2446. gridView: 'Rasteransicht',
  2447. listView: 'Listenansicht',
  2448. lowDiskSpaceWarning: 'Warnung: Wenig Speicherplatz',
  2449. lowDiskSpaceDetails: 'Nur {{free}} frei von {{total}} gesamt. Schwellenwert ist auf {{threshold}} GB eingestellt.',
  2450. files: 'Dateien',
  2451. folders: 'Ordner',
  2452. size: 'Größe',
  2453. free: 'Frei',
  2454. allFiles: 'Alle Dateien',
  2455. wrap: 'Umbrechen',
  2456. enableTextWrapping: 'Textumbruch aktivieren',
  2457. disableTextWrapping: 'Textumbruch deaktivieren',
  2458. dragToResizeTooltip: 'Ziehen zum Ändern der Größe, Doppelklick zum Zurücksetzen',
  2459. searchFiles: 'Dateien suchen...',
  2460. allTypes: 'Alle Typen',
  2461. prints: 'Drucke',
  2462. ascending: 'Aufsteigend',
  2463. descending: 'Absteigend',
  2464. resultsCount: '{{showing}} von {{total}} Dateien',
  2465. selectAll: 'Alle auswählen',
  2466. deselectAll: 'Auswahl aufheben',
  2467. selected: '{{count}} ausgewählt',
  2468. adding: 'Hinzufügen...',
  2469. loadingFiles: 'Dateien werden geladen...',
  2470. folderIsEmpty: 'Ordner ist leer',
  2471. noFilesYet: 'Noch keine Dateien',
  2472. folderEmptyDescription: 'Laden Sie Dateien hoch oder verschieben Sie Dateien in diesen Ordner.',
  2473. noFilesDescription: 'Laden Sie Dateien hoch, um Ihre Druckdateien zu organisieren.',
  2474. noMatchingFiles: 'Keine passenden Dateien',
  2475. noMatchingFilesDescription: 'Keine Dateien entsprechen Ihren aktuellen Such- oder Filterkriterien.',
  2476. clearFilters: 'Filter zurücksetzen',
  2477. printedCount: '{{count}}x gedruckt',
  2478. uploadedBy: 'Hochgeladen von',
  2479. deleteFolder: 'Ordner löschen',
  2480. deleteFile: 'Datei löschen',
  2481. deleteFilesCount: '{{count}} Dateien löschen',
  2482. deleteFolderConfirm: 'Möchten Sie diesen Ordner wirklich löschen? Alle Dateien darin werden ebenfalls gelöscht.',
  2483. deleteFileConfirm: 'Möchten Sie diese Datei wirklich löschen?',
  2484. deleteFilesConfirm: 'Möchten Sie {{count}} ausgewählte Dateien wirklich löschen? Diese Aktion kann nicht rückgängig gemacht werden.',
  2485. deleting: 'Wird gelöscht...',
  2486. noPermissionRenameFolder: 'Sie haben keine Berechtigung, Ordner umzubenennen',
  2487. noPermissionLinkFolder: 'Sie haben keine Berechtigung, Ordner zu verknüpfen',
  2488. noPermissionDeleteFolder: 'Sie haben keine Berechtigung, Ordner zu löschen',
  2489. noPermissionPrint: 'Sie haben keine Berechtigung zum Drucken',
  2490. noPermissionAddToQueue: 'Sie haben keine Berechtigung, zur Warteschlange hinzuzufügen',
  2491. noPermissionDownload: 'Sie haben keine Berechtigung, Dateien herunterzuladen',
  2492. noPermissionRenameFile: 'Sie haben keine Berechtigung, diese Datei umzubenennen',
  2493. noPermissionGenerateThumbnail: 'Sie haben keine Berechtigung, Vorschaubilder zu generieren',
  2494. noPermissionDeleteFile: 'Sie haben keine Berechtigung, diese Datei zu löschen',
  2495. noPermissionCreateFolder: 'Sie haben keine Berechtigung, Ordner zu erstellen',
  2496. noPermissionUpload: 'Sie haben keine Berechtigung, Dateien hochzuladen',
  2497. noPermissionMoveFiles: 'Sie haben keine Berechtigung, Dateien zu verschieben',
  2498. noPermissionDeleteFiles: 'Sie haben keine Berechtigung, Dateien zu löschen',
  2499. toast: {
  2500. folderCreated: 'Ordner erstellt',
  2501. folderDeleted: 'Ordner gelöscht',
  2502. fileDeleted: 'Datei gelöscht',
  2503. filesDeleted: '{{count}} Dateien gelöscht',
  2504. filesMoved: 'Dateien verschoben',
  2505. folderLinked: 'Ordner verknüpft',
  2506. folderUnlinked: 'Ordnerverknüpfung aufgehoben',
  2507. addedToQueue: '{{count}} Datei(en) zur Warteschlange hinzugefügt',
  2508. addedToQueuePartial: '{{added}} Datei(en) hinzugefügt, {{failed}} fehlgeschlagen',
  2509. failedToAddToQueue: 'Fehler beim Hinzufügen: {{error}}',
  2510. fileRenamed: 'Datei umbenannt',
  2511. folderRenamed: 'Ordner umbenannt',
  2512. thumbnailsGenerated: '{{count}} Vorschaubild(er) generiert',
  2513. thumbnailsGeneratedPartial: '{{succeeded}} Vorschaubild(er) generiert, {{failed}} fehlgeschlagen',
  2514. noStlMissingThumbnails: 'Keine STL-Dateien ohne Vorschaubild',
  2515. failedToGenerateThumbnails: 'Fehler beim Generieren der Vorschaubilder: {{error}}',
  2516. thumbnailGenerated: 'Vorschaubild generiert',
  2517. failedToGenerateThumbnail: 'Fehler beim Generieren des Vorschaubildes: {{error}}',
  2518. },
  2519. },
  2520. // Projects
  2521. projects: {
  2522. title: 'Projekte',
  2523. subtitle: 'Organisieren und verfolgen Sie Ihre 3D-Druckprojekte',
  2524. newProject: 'Neues Projekt',
  2525. editProject: 'Projekt bearbeiten',
  2526. deleteProject: 'Projekt löschen',
  2527. projectName: 'Projektname',
  2528. description: 'Beschreibung',
  2529. noProjects: 'Noch keine Projekte',
  2530. noProjectsFiltered: 'Keine {{status}} Projekte',
  2531. noProjectsFilteredHelp: 'Sie haben keine {{status}} Projekte. Projekte werden hier angezeigt, wenn sich ihr Status ändert.',
  2532. createFirst: 'Erstellen Sie Ihr erstes Projekt, um verwandte Drucke zu organisieren, den Fortschritt zu verfolgen und Ihre Builds zu verwalten.',
  2533. createFirstButton: 'Erstes Projekt erstellen',
  2534. create: 'Erstellen',
  2535. files: 'Dateien',
  2536. prints: 'Drucke',
  2537. plates: 'Platten',
  2538. parts: 'Teile',
  2539. lastModified: 'Zuletzt geändert',
  2540. deleteConfirm: 'Möchten Sie dieses Projekt wirklich löschen? Archive und Warteschlangenelemente werden getrennt, aber nicht gelöscht.',
  2541. addFiles: 'Dateien hinzufügen',
  2542. removeFile: 'Datei entfernen',
  2543. viewDetails: 'Details anzeigen',
  2544. // Modal fields
  2545. namePlaceholder: 'z.B. Voron 2.4 Build',
  2546. descriptionPlaceholder: 'Optionale Beschreibung...',
  2547. color: 'Farbe',
  2548. targetPlates: 'Ziel-Platten',
  2549. targetPlatesPlaceholder: 'z.B. 25',
  2550. targetPlatesHelp: 'Anzahl der Druckaufträge',
  2551. targetParts: 'Ziel-Teile',
  2552. targetPartsPlaceholder: 'z.B. 150',
  2553. targetPartsHelp: 'Benötigte Objekte insgesamt',
  2554. tagsLabel: 'Tags (kommagetrennt)',
  2555. tagsPlaceholder: 'z.B. voron, funktional, geschenk',
  2556. dueDate: 'Fälligkeitsdatum',
  2557. priority: 'Priorität',
  2558. priorityLow: 'Niedrig',
  2559. priorityNormal: 'Normal',
  2560. priorityHigh: 'Hoch',
  2561. priorityUrgent: 'Dringend',
  2562. // Status
  2563. statusActive: 'Aktiv',
  2564. statusCompleted: 'Abgeschlossen',
  2565. statusArchived: 'Archiviert',
  2566. done: 'Fertig',
  2567. completed: 'abgeschlossen',
  2568. failed: 'fehlgeschlagen',
  2569. inQueue: 'in Warteschlange',
  2570. noPrintsYet: 'Noch keine Drucke',
  2571. // Footer stats
  2572. printJobs: 'Druckaufträge (Platten)',
  2573. partsPrinted: 'Gedruckte Teile',
  2574. failedParts: 'Fehlgeschlagene Teile',
  2575. // Actions
  2576. import: 'Importieren',
  2577. export: 'Exportieren',
  2578. importProject: 'Projekt importieren',
  2579. exportAll: 'Alle Projekte exportieren',
  2580. loading: 'Projekte werden geladen...',
  2581. // Permissions
  2582. noEditPermission: 'Sie haben keine Berechtigung, Projekte zu bearbeiten',
  2583. noDeletePermission: 'Sie haben keine Berechtigung, Projekte zu löschen',
  2584. noCreatePermission: 'Sie haben keine Berechtigung, Projekte zu erstellen',
  2585. noImportPermission: 'Sie haben keine Berechtigung, Projekte zu importieren',
  2586. noExportPermission: 'Sie haben keine Berechtigung, Projekte zu exportieren',
  2587. // Toast
  2588. toast: {
  2589. created: 'Projekt erstellt',
  2590. updated: 'Projekt aktualisiert',
  2591. deleted: 'Projekt gelöscht',
  2592. imported: 'Projekt importiert',
  2593. multipleImported: '{{count}} Projekte importiert',
  2594. importFailed: 'Import fehlgeschlagen',
  2595. exported: 'Projekte exportiert (nur Metadaten)',
  2596. },
  2597. },
  2598. // Project detail page
  2599. projectDetail: {
  2600. notFound: 'Projekt nicht gefunden',
  2601. backToProjects: 'Zurück zu Projekten',
  2602. export: 'Exportieren',
  2603. exportProject: 'Projekt exportieren',
  2604. noExportPermission: 'Sie haben keine Berechtigung, Projekte zu exportieren',
  2605. noEditPermission: 'Sie haben keine Berechtigung, Projekte zu bearbeiten',
  2606. partOf: 'Teil von:',
  2607. priorityLabel: 'Priorität:',
  2608. noPrints: 'Noch keine Drucke in diesem Projekt',
  2609. status: {
  2610. active: 'Aktiv',
  2611. completed: 'Abgeschlossen',
  2612. archived: 'Archiviert',
  2613. },
  2614. priority: {
  2615. low: 'Niedrig',
  2616. normal: 'Normal',
  2617. high: 'Hoch',
  2618. urgent: 'Dringend',
  2619. },
  2620. dueDate: {
  2621. overdue: 'Überfällig',
  2622. today: 'Heute fällig',
  2623. daysLeft: '{{count}} Tage übrig',
  2624. },
  2625. progress: {
  2626. platesProgress: 'Platten-Fortschritt',
  2627. partsProgress: 'Teile-Fortschritt',
  2628. printJobs: 'Druckaufträge',
  2629. parts: 'Teile',
  2630. percentComplete: '{{percent}}% abgeschlossen',
  2631. remaining: '{{count}} verbleibend',
  2632. },
  2633. stats: {
  2634. printJobs: 'Druckaufträge',
  2635. total: 'gesamt',
  2636. failed: '{{count}} fehlgeschlagen',
  2637. partsPrinted: '{{count}} Teile gedruckt',
  2638. printTime: 'Druckzeit',
  2639. filamentUsed: 'Filament verbraucht',
  2640. },
  2641. cost: {
  2642. title: 'Kostenverfolgung',
  2643. filamentCost: 'Filamentkosten',
  2644. energy: 'Energie',
  2645. budget: 'Budget',
  2646. remaining: 'Verbleibend',
  2647. },
  2648. subProjects: {
  2649. title: 'Unterprojekte ({{count}})',
  2650. },
  2651. notes: {
  2652. title: 'Notizen',
  2653. noEditPermission: 'Sie haben keine Berechtigung, Notizen zu bearbeiten',
  2654. placeholder: 'Notizen zu diesem Projekt hinzufügen...',
  2655. empty: 'Noch keine Notizen. Klicken Sie auf Bearbeiten, um Notizen hinzuzufügen.',
  2656. },
  2657. files: {
  2658. title: 'Dateien',
  2659. linkFolders: 'Ordner aus dem Dateimanager verknüpfen',
  2660. forQuickAccess: 'für schnellen Zugriff auf dieses Projekt.',
  2661. fileCount: '{{count}} Datei(en)',
  2662. empty: 'Keine Ordner verknüpft. Gehen Sie zum Dateimanager und verknüpfen Sie einen Ordner mit diesem Projekt.',
  2663. },
  2664. bom: {
  2665. title: 'Stückliste',
  2666. acquired: '{{completed}}/{{total}} beschafft',
  2667. showAll: 'Alle anzeigen',
  2668. hideDone: 'Erledigte ausblenden',
  2669. addPart: 'Teil hinzufügen',
  2670. noAddPermission: 'Sie haben keine Berechtigung, Teile hinzuzufügen',
  2671. partNamePlaceholder: 'Teilename (z.B. M3x8 Schrauben)',
  2672. partName: 'Teilename',
  2673. qty: 'Menge',
  2674. price: 'Preis ({{currency}})',
  2675. sourcingUrlPlaceholder: 'Bezugsquelle-URL (optional)',
  2676. remarksPlaceholder: 'Bemerkungen (optional)',
  2677. deletePart: 'Teil löschen',
  2678. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen?',
  2679. noUpdatePermission: 'Sie haben keine Berechtigung, Teile zu aktualisieren',
  2680. noEditPermission: 'Sie haben keine Berechtigung, Teile zu bearbeiten',
  2681. noDeletePermission: 'Sie haben keine Berechtigung, Teile zu löschen',
  2682. totalCost: 'Gesamtkosten:',
  2683. empty: 'Keine Teile in der Stückliste. Fügen Sie Hardware, Elektronik oder andere Komponenten hinzu, um zu verfolgen, was beschafft werden muss.',
  2684. },
  2685. timeline: {
  2686. title: 'Aktivitätsverlauf',
  2687. empty: 'Noch keine Aktivität.',
  2688. },
  2689. template: {
  2690. saveAsTemplate: 'Als Vorlage speichern',
  2691. noCreatePermission: 'Sie haben keine Berechtigung, Vorlagen zu erstellen',
  2692. },
  2693. queue: {
  2694. title: 'Warteschlange',
  2695. viewAll: 'Alle anzeigen',
  2696. printing: '{{count}} druckend',
  2697. queued: '{{count}} in Warteschlange',
  2698. },
  2699. prints: {
  2700. title: 'Drucke ({{count}})',
  2701. },
  2702. toast: {
  2703. projectUpdated: 'Projekt aktualisiert',
  2704. partAdded: 'Teil hinzugefügt',
  2705. partRemoved: 'Teil entfernt',
  2706. exportFailed: 'Export fehlgeschlagen',
  2707. projectExported: 'Projekt exportiert',
  2708. templateCreated: 'Vorlage erstellt',
  2709. },
  2710. },
  2711. // System info
  2712. system: {
  2713. title: 'Systeminformationen',
  2714. version: 'Version',
  2715. uptime: 'Laufzeit',
  2716. cpuUsage: 'CPU-Auslastung',
  2717. memoryUsage: 'Speicherauslastung',
  2718. diskUsage: 'Festplattenauslastung',
  2719. networkInfo: 'Netzwerkinformationen',
  2720. logs: 'Protokolle',
  2721. debugMode: 'Debug-Modus',
  2722. enableDebug: 'Debug-Protokollierung aktivieren',
  2723. disableDebug: 'Debug-Protokollierung deaktivieren',
  2724. downloadLogs: 'Protokolle herunterladen',
  2725. clearLogs: 'Protokolle löschen',
  2726. dockerInfo: 'Docker-Info',
  2727. containerName: 'Container-Name',
  2728. imageName: 'Image-Name',
  2729. platform: 'Plattform',
  2730. architecture: 'Architektur',
  2731. },
  2732. // Library (K Profiles)
  2733. library: {
  2734. title: 'Filament-Bibliothek',
  2735. addFilament: 'Filament hinzufügen',
  2736. editFilament: 'Filament bearbeiten',
  2737. deleteFilament: 'Filament löschen',
  2738. vendor: 'Hersteller',
  2739. material: 'Material',
  2740. color: 'Farbe',
  2741. kFactor: 'K-Faktor',
  2742. temperature: 'Temperatur',
  2743. noFilaments: 'Keine Filamente in der Bibliothek',
  2744. deleteConfirm: 'Möchten Sie dieses Filament wirklich löschen?',
  2745. importFromPrinter: 'Vom Drucker importieren',
  2746. exportToFile: 'In Datei exportieren',
  2747. },
  2748. // Spoolman
  2749. spoolman: {
  2750. title: 'Spoolman-Integration',
  2751. enabled: 'Spoolman aktiviert',
  2752. url: 'Spoolman URL',
  2753. connected: 'Verbunden',
  2754. disconnected: 'Nicht verbunden',
  2755. testConnection: 'Verbindung testen',
  2756. sync: 'Synchronisieren',
  2757. syncing: 'Synchronisiert...',
  2758. lastSync: 'Letzte Synchronisierung',
  2759. linkToSpoolman: 'Mit Spoolman verknüpfen',
  2760. openInSpoolman: 'In Spoolman öffnen',
  2761. unlinkSpool: 'Spule trennen',
  2762. unlinkConfirmTitle: 'Spule entkoppeln?',
  2763. unlinkConfirmMessage: 'Dadurch wird die Spule von Spoolman getrennt. Die Spulendaten in Spoolman bleiben unverändert.',
  2764. selectSpool: 'Spule auswählen',
  2765. noUnlinkedSpools: 'Keine nicht verknüpften Spulen verfügbar',
  2766. linkSuccess: 'Spule erfolgreich mit Spoolman verknüpft',
  2767. linkFailed: 'Verknüpfung mit Spoolman fehlgeschlagen',
  2768. unlinkSuccess: 'Spule erfolgreich von Spoolman getrennt',
  2769. unlinkFailed: 'Trennen der Spule von Spoolman fehlgeschlagen',
  2770. spoolId: 'Spulen-ID',
  2771. fillSourceLabel: '(Spoolman)',
  2772. weight: 'Gewicht',
  2773. remaining: 'Verbleibend',
  2774. disableWeightSync: 'AMS-Gewichtsschätzung deaktivieren',
  2775. disableWeightSyncDesc: 'Verbleibende Kapazität nicht aus AMS-Schätzungen aktualisieren. Verwenden Sie dies, wenn Sie die Verbrauchserfassung von Spoolman gegenüber den prozentualen AMS-Schätzungen bevorzugen. Neue Spulen verwenden weiterhin die AMS-Schätzung als Anfangsgewicht.',
  2776. reportPartialUsage: 'Teilverbrauch bei fehlgeschlagenen Drucken melden',
  2777. reportPartialUsageDesc: 'Wenn ein Druck fehlschlägt oder abgebrochen wird, den geschätzten Filamentverbrauch bis zu diesem Zeitpunkt basierend auf dem Schichtfortschritt melden.',
  2778. },
  2779. // Inventar
  2780. inventory: {
  2781. title: 'Spulen-Inventar',
  2782. addSpool: 'Spule hinzufügen',
  2783. editSpool: 'Spule bearbeiten',
  2784. material: 'Material',
  2785. selectMaterial: 'Material auswählen...',
  2786. subtype: 'Untertyp',
  2787. brand: 'Marke',
  2788. searchBrand: 'Marke suchen...',
  2789. useCustomBrand: '"{{brand}}" verwenden',
  2790. useCustomMaterial: 'Benutzerdefiniertes Material verwenden: {{material}}',
  2791. colorName: 'Farbname',
  2792. colorNamePlaceholder: 'Jade White, Fire Red...',
  2793. color: 'Farbe',
  2794. hexColor: 'Hex-Farbe',
  2795. pickColor: 'Benutzerdefinierte Farbe wählen',
  2796. labelWeight: 'Nenngewicht',
  2797. coreWeight: 'Leergewicht der Spule',
  2798. searchSpoolWeight: 'Spulengewicht suchen...',
  2799. weightUsed: 'Verbraucht',
  2800. currentWeight: 'Restgewicht',
  2801. measuredWeight: 'Gemessenes Gewicht',
  2802. costPerKg: 'Kosten pro kg',
  2803. measuredWeightError: 'Das gemessene Gewicht muss zwischen {{min}}g und {{max}}g liegen.',
  2804. slicerFilament: 'Slicer-Filament',
  2805. slicerFilamentName: 'Slicer-Preset-Name',
  2806. slicerPreset: 'Slicer-Preset',
  2807. searchPresets: 'Filament-Presets suchen...',
  2808. selectedPreset: 'Ausgewählt',
  2809. noPresetsFound: 'Keine Presets gefunden',
  2810. tempOverrides: 'Temperatur-Überschreibungen',
  2811. note: 'Notiz',
  2812. notePlaceholder: 'Zusätzliche Notizen zu dieser Spule...',
  2813. archive: 'Archivieren',
  2814. restore: 'Wiederherstellen',
  2815. noSpools: 'Noch keine Spulen. Fügen Sie Ihre erste Spule hinzu.',
  2816. noManualSpools: 'Keine manuell hinzugefügten Spulen verfügbar. Fügen Sie zuerst eine Spule zum Inventar hinzu.',
  2817. kProfiles: 'K-Profile',
  2818. addKProfile: 'K-Profil hinzufügen',
  2819. assignSpool: 'Spule zuweisen',
  2820. unassignSpool: 'Zuweisung aufheben',
  2821. assignSuccess: 'Spule zugewiesen und AMS-Slot konfiguriert',
  2822. assignFailed: 'Spulenzuweisung fehlgeschlagen',
  2823. selectSpool: 'Wählen Sie eine Spule für diesen Slot',
  2824. assigned: 'Zugewiesen',
  2825. assigning: 'Wird zugewiesen...',
  2826. searchSpools: 'Spulen suchen...',
  2827. allMaterials: 'Alle Materialien',
  2828. filterByBrand: 'Nach Marke filtern...',
  2829. showArchived: 'Archivierte anzeigen',
  2830. quickAdd: 'Schnellerfassung (Lager)',
  2831. quantity: 'Menge',
  2832. stock: 'Lager',
  2833. configured: 'Konfiguriert',
  2834. spoolsCreated: '{{count}} Spulen erstellt',
  2835. spoolCreated: 'Spule erstellt',
  2836. spoolUpdated: 'Spule aktualisiert',
  2837. spoolDeleted: 'Spule gelöscht',
  2838. spoolArchived: 'Spule archiviert',
  2839. spoolRestored: 'Spule wiederhergestellt',
  2840. deleteConfirm: 'Möchten Sie diese Spule wirklich löschen? Dies kann nicht rückgängig gemacht werden.',
  2841. archiveConfirm: 'Möchten Sie diese Spule wirklich archivieren?',
  2842. advancedSettings: 'Erweiterte Einstellungen',
  2843. filamentInfoTab: 'Filament-Info',
  2844. paProfileTab: 'PA-Profil',
  2845. filamentInfo: 'Filament',
  2846. additional: 'Zusätzlich',
  2847. loadingPresets: 'Cloud-Presets werden geladen...',
  2848. cloudConnected: 'Cloud verbunden',
  2849. cloudNotConnected: 'Cloud nicht verbunden (Standardwerte)',
  2850. recentColors: 'Zuletzt',
  2851. searchColors: 'Farben suchen...',
  2852. searchResults: 'Suchergebnisse',
  2853. allColors: 'Alle Farben',
  2854. commonColors: 'Häufige Farben',
  2855. showLess: 'Weniger',
  2856. showAll: 'Alle',
  2857. noColorsFound: 'Keine Farben gefunden',
  2858. noResults: 'Keine Ergebnisse',
  2859. selectMaterialFirst: 'Bitte zuerst ein Material im Filament-Info Tab auswählen.',
  2860. noPrintersConfigured: 'Keine Drucker konfiguriert. Fügen Sie Drucker hinzu.',
  2861. matchingFilter: 'Filter',
  2862. anyBrand: 'Jede Marke',
  2863. anyVariant: 'Jede Variante',
  2864. autoSelect: 'Auto-Auswahl',
  2865. matches: 'Treffer',
  2866. match: 'Treffer',
  2867. noMatches: 'Keine Treffer',
  2868. connected: 'Verbunden',
  2869. offline: 'Offline',
  2870. printerOffline: 'Drucker ist offline. Verbinden Sie ihn, um Kalibrierungsprofile anzuzeigen.',
  2871. noKProfilesMatch: 'Keine K-Profile stimmen mit dem gewählten Filament überein.',
  2872. leftNozzle: 'Linke Düse',
  2873. rightNozzle: 'Rechte Düse',
  2874. profilesSelected: 'Kalibrierungsprofil(e) ausgewählt',
  2875. // Stats & enhanced table
  2876. totalInventory: 'Gesamtbestand',
  2877. totalConsumed: 'Gesamtverbrauch',
  2878. byMaterial: 'Nach Material',
  2879. inPrinter: 'Im Drucker',
  2880. lowStock: 'Niedriger Bestand',
  2881. sinceTracking: 'Seit Beginn der Erfassung',
  2882. loadedInAms: 'Im AMS/Ext geladen',
  2883. remaining: 'Verbleibend',
  2884. weightCheck: 'Gewichtskontrolle',
  2885. lastWeighed: 'Zuletzt gewogen',
  2886. neverWeighed: 'Nie gewogen',
  2887. search: 'Spulen suchen...',
  2888. showing: 'Zeige',
  2889. to: 'bis',
  2890. of: 'von',
  2891. show: 'Zeige',
  2892. spools: 'Spulen',
  2893. spool: 'Spule',
  2894. page: 'Seite',
  2895. noSpoolsMatch: 'Keine Ergebnisse',
  2896. noSpoolsMatchDesc: 'Versuchen Sie, Ihre Suche oder Filter anzupassen.',
  2897. active: 'Aktiv',
  2898. archived: 'Archiviert',
  2899. all: 'Alle',
  2900. used: 'Verwendet',
  2901. new: 'Neu',
  2902. clearFilters: 'Filter löschen',
  2903. table: 'Tabelle',
  2904. cards: 'Karten',
  2905. net: 'Netto',
  2906. // Grouping
  2907. groupSimilar: 'Gruppieren',
  2908. groupedSpools: '{{count}} identische Spulen',
  2909. groupedRows: 'Zeilen',
  2910. // Column config
  2911. columns: 'Spalten',
  2912. configureColumns: 'Spalten konfigurieren',
  2913. configureColumnsDesc: 'Ziehen zum Neuordnen oder Pfeile verwenden. Sichtbarkeit mit dem Augensymbol umschalten.',
  2914. visible: 'sichtbar',
  2915. reset: 'Zurücksetzen',
  2916. cancel: 'Abbrechen',
  2917. applyChanges: 'Änderungen anwenden',
  2918. moveUp: 'Nach oben',
  2919. moveDown: 'Nach unten',
  2920. hideColumn: 'Spalte ausblenden',
  2921. showColumn: 'Spalte einblenden',
  2922. // Tag-Verknüpfung
  2923. linkToSpool: 'Mit Spule verknüpfen',
  2924. tagLinked: 'Tag mit Spule verknüpft',
  2925. tagLinkFailed: 'Tag-Verknüpfung fehlgeschlagen',
  2926. tagAlreadyLinked: 'Tag bereits mit anderer Spule verknüpft',
  2927. unknownTag: 'Unbekannter RFID-Tag erkannt',
  2928. // Verbrauchshistorie
  2929. usageHistory: 'Verbrauchshistorie',
  2930. noUsageHistory: 'Noch kein Verbrauch erfasst',
  2931. printName: 'Druckname',
  2932. weightConsumed: 'Verbrauchtes Gewicht',
  2933. clearHistory: 'Löschen',
  2934. historyCleared: 'Verbrauchshistorie gelöscht',
  2935. fillSourceLabel: '(Inv)',
  2936. lowStockThresholdError: 'Der Schwellenwert muss zwischen 0.1 und 99.9 liegen',
  2937. },
  2938. // Timelapse
  2939. timelapse: {
  2940. title: 'Zeitraffer',
  2941. create: 'Zeitraffer erstellen',
  2942. download: 'Herunterladen',
  2943. delete: 'Löschen',
  2944. preview: 'Vorschau',
  2945. frameRate: 'Bildrate',
  2946. quality: 'Qualität',
  2947. processing: 'Wird verarbeitet...',
  2948. noTimelapses: 'Keine Zeitraffer verfügbar',
  2949. },
  2950. // AMS
  2951. ams: {
  2952. title: 'AMS',
  2953. slot: 'Slot',
  2954. empty: 'Leer',
  2955. emptySlot: 'Leerer Slot',
  2956. unknown: 'Unbekannt',
  2957. humidity: 'Luftfeuchtigkeit',
  2958. temperature: 'Temperatur',
  2959. filamentType: 'Filamenttyp',
  2960. filamentColor: 'Farbe',
  2961. remaining: 'Verbleibend',
  2962. history: 'AMS-Verlauf',
  2963. noHistory: 'Kein Verlauf verfügbar',
  2964. configureSlot: 'Slot konfigurieren',
  2965. externalSpool: 'Externe Spule',
  2966. profile: 'Profil',
  2967. kFactor: 'K-Faktor',
  2968. fill: 'Füllstand',
  2969. configure: 'Konfigurieren',
  2970. used: 'verwendet',
  2971. remainingUnit: 'verbleibend',
  2972. },
  2973. // Print modal
  2974. printModal: {
  2975. title: 'Druck starten',
  2976. selectPrinter: 'Drucker auswählen',
  2977. selectPlate: 'Platte auswählen',
  2978. filamentMapping: 'Filamentzuordnung',
  2979. totalCost: 'Gesamtkosten:',
  2980. slotRemainingShort: ' - {{grams}}g übrig',
  2981. printSettings: 'Druckeinstellungen',
  2982. bedLeveling: 'Bett-Nivellierung',
  2983. flowCalibration: 'Fluss-Kalibrierung',
  2984. vibrationCalibration: 'Vibrations-Kalibrierung',
  2985. layerInspection: 'Erste-Schicht-Prüfung',
  2986. timelapse: 'Zeitraffer',
  2987. startPrint: 'Druck starten',
  2988. addToQueue: 'Zur Warteschlange hinzufügen',
  2989. cancel: 'Abbrechen',
  2990. noPrintersAvailable: 'Keine Drucker verfügbar',
  2991. printerBusy: 'Drucker ist beschäftigt',
  2992. printerOffline: 'Drucker ist offline',
  2993. sameTypeDifferentColor: 'Gleicher Typ, andere Farbe',
  2994. filamentTypeNotLoaded: 'Filamenttyp nicht geladen',
  2995. openCalendar: 'Kalender öffnen',
  2996. leftNozzle: 'L',
  2997. rightNozzle: 'R',
  2998. leftNozzleTooltip: 'Linke Düse',
  2999. rightNozzleTooltip: 'Rechte Düse',
  3000. filamentOverride: 'Filament-Überschreibung',
  3001. filamentOverrideHint: 'Filamente für modellbasierte Zuweisung optional überschreiben. Der Planer wird gegen die ausgewählten Filamente statt der ursprünglichen 3MF-Werte abgleichen.',
  3002. originalFilament: 'Original',
  3003. overrideWith: 'Ersetzen mit',
  3004. resetToOriginal: 'Auf Original zurücksetzen',
  3005. forceColorMatch: 'Farbe erzwingen',
  3006. },
  3007. // Backup
  3008. backup: {
  3009. title: 'Sichern & Wiederherstellen',
  3010. createBackup: 'Sicherung erstellen',
  3011. restoreBackup: 'Sicherung wiederherstellen',
  3012. restoreDescription: 'Alle Daten aus einer Sicherungsdatei ersetzen',
  3013. downloadBackup: 'Sicherung herunterladen',
  3014. uploadBackup: 'Sicherung hochladen',
  3015. lastBackup: 'Letzte Sicherung',
  3016. autoBackup: 'Automatische Sicherung',
  3017. backupNow: 'Jetzt sichern',
  3018. restoreWarning: 'Warnung: Das Wiederherstellen einer Sicherung überschreibt alle aktuellen Daten.',
  3019. includeArchives: 'Archive einschließen',
  3020. includeSettings: 'Einstellungen einschließen',
  3021. includeProfiles: 'Profile einschließen',
  3022. backupSuccess: 'Sicherung erfolgreich erstellt',
  3023. restoreSuccess: 'Sicherung erfolgreich wiederhergestellt',
  3024. backupFailed: 'Sicherung fehlgeschlagen',
  3025. restoreFailed: 'Wiederherstellung fehlgeschlagen',
  3026. restoreNote: 'Virtueller Drucker wird während der Wiederherstellung gestoppt',
  3027. // GitHub Backup
  3028. githubBackup: 'GitHub Backup',
  3029. enabled: 'Aktiviert',
  3030. cloudLoginRequired: 'Bambu Cloud Login erforderlich. Melden Sie sich unter Profile → Cloud-Profile an, um GitHub-Backup zu aktivieren.',
  3031. cloudLoginRequiredShort: 'Cloud-Login erforderlich',
  3032. githubDescription: 'Synchronisieren Sie Ihre Profile automatisch mit einem privaten GitHub-Repository für Backup und Versionsverlauf.',
  3033. repositoryUrl: 'Repository-URL',
  3034. personalAccessToken: 'Persönlicher Zugriffstoken',
  3035. tokenSaved: '(gespeichert)',
  3036. enterNewToken: 'Neuen Token eingeben zum Aktualisieren',
  3037. tokenHint: 'Feingranularer Token mit Lese-/Schreibberechtigung für Inhalte',
  3038. branch: 'Branch',
  3039. manualOnly: 'Nur manuell',
  3040. hourly: 'Stündlich',
  3041. daily: 'Täglich',
  3042. weekly: 'Wöchentlich',
  3043. includeInBackup: 'In Sicherung einschließen',
  3044. kProfiles: 'K-Profile',
  3045. kProfilesDescription: 'Druckvorschub-Kalibrierung von verbundenen Druckern',
  3046. noPrintersConnected: 'Keine Drucker verbunden',
  3047. printersConnected: '{{connected}}/{{total}} verbunden',
  3048. cloudProfiles: 'Cloud-Profile',
  3049. cloudProfilesDescription: 'Filament-, Drucker- und Prozessprofile aus der Bambu Cloud',
  3050. appSettings: 'App-Einstellungen',
  3051. appSettingsDescription: 'Bambuddy-Konfiguration (komplette Datenbank)',
  3052. lastBackupAt: 'Letzte Sicherung:',
  3053. noBackupsYet: 'Noch keine Sicherungen',
  3054. next: 'Nächste:',
  3055. startingBackup: 'Sicherung wird gestartet...',
  3056. test: 'Test',
  3057. enableBackup: 'Sicherung aktivieren',
  3058. testConnection: 'Verbindung testen',
  3059. enterRepoUrl: 'Repository-URL eingeben',
  3060. enterRepoAndToken: 'Repository-URL und Zugriffstoken eingeben',
  3061. repoRequired: 'Repository-URL ist erforderlich',
  3062. tokenRequired: 'Zugriffstoken ist erforderlich',
  3063. githubBackupEnabled: 'GitHub-Backup aktiviert',
  3064. tokenUpdated: 'Token aktualisiert',
  3065. settingsSaved: 'Einstellungen gespeichert',
  3066. failedToSave: 'Speichern fehlgeschlagen: {{message}}',
  3067. backupCompleteFiles: 'Sicherung abgeschlossen - {{count}} Dateien aktualisiert',
  3068. backupSkippedNoChanges: 'Sicherung übersprungen - keine Änderungen',
  3069. backupFailed2: 'Sicherung fehlgeschlagen: {{message}}',
  3070. clearedLogs: '{{count}} Protokolle gelöscht',
  3071. failedToClearLogs: 'Protokolle löschen fehlgeschlagen: {{message}}',
  3072. // History
  3073. history: 'Verlauf',
  3074. clear: 'Löschen',
  3075. date: 'Datum',
  3076. status: 'Status',
  3077. commit: 'Commit',
  3078. // Local Backup
  3079. localBackup: 'Lokale Sicherung',
  3080. localBackupDescription: 'Erstellen Sie eine vollständige Sicherung Ihrer Bambuddy-Daten einschließlich Datenbank, Archive, Uploads und aller Dateien.',
  3081. downloadBackupLabel: 'Sicherung herunterladen',
  3082. completeBackupZip: 'Vollständige Sicherung: Datenbank + alle Dateien (ZIP)',
  3083. download: 'Herunterladen',
  3084. preparingBackup: 'Sicherung wird vorbereitet...',
  3085. creatingArchive: 'Sicherungsarchiv wird erstellt... Dies kann bei großen Archiven eine Weile dauern.',
  3086. downloadingFile: 'Sicherungsdatei wird heruntergeladen...',
  3087. backupDownloaded: 'Sicherung erfolgreich heruntergeladen',
  3088. failedToCreateBackup: 'Sicherung erstellen fehlgeschlagen: {{message}}',
  3089. restore: 'Wiederherstellen',
  3090. restoreReplacesAll: 'Wiederherstellung ersetzt alle Daten.',
  3091. restoreReplacesAllDetail: 'Ihre aktuelle Datenbank und Dateien werden vollständig ersetzt. Nach der Wiederherstellung ist ein Neustart erforderlich.',
  3092. restoreConfirmTitle: 'Sicherung wiederherstellen',
  3093. restoreConfirmMessage: 'Sind Sie sicher, dass Sie von "{{filename}}" wiederherstellen möchten? Dies ersetzt Ihre aktuelle Datenbank und alle Dateien vollständig. Die Anwendung muss nach der Wiederherstellung neu gestartet werden.',
  3094. restoreConfirmButton: 'Sicherung wiederherstellen',
  3095. uploadingFile: 'Sicherungsdatei wird hochgeladen...',
  3096. backupRestoredRestart: 'Sicherung wiederhergestellt. Bitte starten Sie Bambuddy neu.',
  3097. failedToRestore: 'Sicherung wiederherstellen fehlgeschlagen. Bitte überprüfen Sie das Dateiformat.',
  3098. reloadNow: 'Jetzt neu laden',
  3099. creatingBackup: 'Sicherung erstellen',
  3100. restoringBackup: 'Sicherung wiederherstellen',
  3101. preparing: 'Vorbereiten...',
  3102. processing: 'Verarbeiten...',
  3103. doNotClosePage: 'Bitte schließen Sie diese Seite nicht und navigieren Sie nicht weg. Dieser Vorgang kann bei großen Sicherungen mehrere Minuten dauern.',
  3104. // RestoreModal
  3105. restoring: 'Wiederherstellen...',
  3106. restoreComplete: 'Wiederherstellung abgeschlossen',
  3107. restoreFailed2: 'Wiederherstellung fehlgeschlagen',
  3108. importSettings: 'Einstellungen aus einer Sicherungsdatei importieren',
  3109. pleaseWaitRestoring: 'Bitte warten Sie, während Ihre Daten wiederhergestellt werden',
  3110. selectBackupFile: 'Klicken Sie, um eine Sicherungsdatei auszuwählen (.json oder .zip)',
  3111. duplicateHandling: 'So funktioniert die Duplikatbehandlung:',
  3112. matchPrinters: 'Drucker',
  3113. matchPrintersBy: 'abgeglichen nach Seriennummer',
  3114. matchSmartPlugs: 'Smart Plugs',
  3115. matchSmartPlugsBy: 'abgeglichen nach IP-Adresse',
  3116. matchNotificationProviders: 'Benachrichtigungsanbieter',
  3117. matchNotificationProvidersBy: 'abgeglichen nach Name',
  3118. matchFilaments: 'Filamente',
  3119. matchFilamentsBy: 'abgeglichen nach Name + Typ + Marke',
  3120. matchArchives: 'Archive',
  3121. matchArchivesBy: 'abgeglichen nach Inhaltshash (immer übersprungen)',
  3122. matchPendingUploads: 'Ausstehende Uploads',
  3123. matchPendingUploadsBy: 'abgeglichen nach Dateiname',
  3124. matchSettingsTemplates: 'Einstellungen & Vorlagen',
  3125. matchSettingsTemplatesBy: 'immer überschrieben',
  3126. replaceExisting: 'Vorhandene Daten ersetzen',
  3127. keepExisting: 'Vorhandene Daten behalten',
  3128. overwriteDescription: 'Bereits vorhandene Elemente mit Sicherungsdaten überschreiben',
  3129. keepDescription: 'Nur Elemente wiederherstellen, die noch nicht vorhanden sind',
  3130. overwriteCaution: 'Achtung:',
  3131. overwriteWarning: 'Das Überschreiben ersetzt Ihre aktuellen Konfigurationen durch Daten aus der Sicherung. Drucker-Zugangscodes werden aus Sicherheitsgründen nie überschrieben.',
  3132. cancel: 'Abbrechen',
  3133. processingBackup: 'Sicherungsdatei wird verarbeitet...',
  3134. itemsRestored: 'Wiederhergestellt',
  3135. itemsSkipped: 'Übersprungen',
  3136. restored: 'Wiederhergestellt',
  3137. skippedAlreadyExist: 'Übersprungen (bereits vorhanden)',
  3138. filesCategory: 'Dateien (3MF, Thumbnails, etc.)',
  3139. andMore: '...und {{count}} weitere',
  3140. newApiKeysGenerated: 'Neue API-Schlüssel generiert',
  3141. keysShownOnce: 'Diese Schlüssel werden nur einmal angezeigt. Kopieren Sie sie jetzt!',
  3142. copy: 'Kopieren',
  3143. noDataFound: 'In der Sicherungsdatei wurden keine Daten zur Wiederherstellung gefunden.',
  3144. close: 'Schließen',
  3145. // Category labels
  3146. categories: {
  3147. settings: 'Einstellungen',
  3148. notification_providers: 'Benachrichtigungsanbieter',
  3149. notification_templates: 'Benachrichtigungsvorlagen',
  3150. smart_plugs: 'Smart Plugs',
  3151. printers: 'Drucker',
  3152. filaments: 'Filamente',
  3153. maintenance_types: 'Wartungstypen',
  3154. archives: 'Archive',
  3155. projects: 'Projekte',
  3156. pending_uploads: 'Ausstehende Uploads',
  3157. external_links: 'Externe Links',
  3158. api_keys: 'API-Schlüssel',
  3159. },
  3160. },
  3161. // Tags
  3162. tags: {
  3163. title: 'Tags',
  3164. addTag: 'Tag hinzufügen',
  3165. editTag: 'Tag bearbeiten',
  3166. deleteTag: 'Tag löschen',
  3167. tagName: 'Tag-Name',
  3168. tagColor: 'Tag-Farbe',
  3169. noTags: 'Keine Tags',
  3170. deleteConfirm: 'Möchten Sie diesen Tag wirklich löschen?',
  3171. manageTags: 'Tags verwalten',
  3172. },
  3173. // Upload modal (archives)
  3174. uploadModal: {
  3175. title: '3MF-Dateien hochladen',
  3176. dragDrop: '3MF-Dateien hierher ziehen',
  3177. or: 'oder',
  3178. browseFiles: 'Dateien durchsuchen',
  3179. extractionInfo: 'Das Druckermodell wird automatisch aus den 3MF-Datei-Metadaten extrahiert.',
  3180. uploaded: 'hochgeladen',
  3181. failed: 'fehlgeschlagen',
  3182. uploading: 'Wird hochgeladen...',
  3183. upload: 'Hochladen',
  3184. uploadFailed: 'Hochladen fehlgeschlagen',
  3185. },
  3186. // Edit archive modal
  3187. editArchive: {
  3188. title: 'Archiv bearbeiten',
  3189. name: 'Name',
  3190. namePlaceholder: 'Druckname',
  3191. printer: 'Drucker',
  3192. noPrinter: 'Kein Drucker',
  3193. project: 'Projekt',
  3194. noProject: 'Kein Projekt',
  3195. itemsPrinted: 'Gedruckte Teile',
  3196. itemsPrintedHelp: 'Anzahl der in diesem Druckauftrag produzierten Teile',
  3197. notes: 'Notizen',
  3198. notesPlaceholder: 'Notizen zu diesem Druck hinzufügen...',
  3199. externalLink: 'Externer Link',
  3200. externalLinkPlaceholder: 'https://printables.com/model/...',
  3201. externalLinkHelp: 'Link zu Printables, Thingiverse oder anderer Quelle',
  3202. tags: 'Tags',
  3203. tagsPlaceholder: 'Tags hinzufügen...',
  3204. addMoreTags: 'Weitere Tags hinzufügen...',
  3205. matchingTags: 'Übereinstimmend mit "{{query}}"',
  3206. existingTags: 'Vorhandene Tags',
  3207. clickToAdd: '(zum Hinzufügen klicken)',
  3208. status: 'Status',
  3209. failureReason: 'Fehlergrund',
  3210. selectReason: 'Grund auswählen...',
  3211. photos: 'Fotos des Druckergebnisses',
  3212. photosHelp: 'Klicken Sie auf + um Fotos Ihres Druckergebnisses hinzuzufügen',
  3213. printResult: 'Druckergebnis',
  3214. saving: 'Wird gespeichert...',
  3215. // Failure reasons
  3216. failureReasons: {
  3217. adhesionFailure: 'Haftungsfehler',
  3218. spaghettiDetached: 'Spaghetti / Abgelöst',
  3219. layerShift: 'Schichtversatz',
  3220. cloggedNozzle: 'Verstopfte Düse',
  3221. filamentRunout: 'Filament aufgebraucht',
  3222. warping: 'Verformung',
  3223. stringing: 'Fadenziehen',
  3224. underExtrusion: 'Unterextrusion',
  3225. powerFailure: 'Stromausfall',
  3226. userCancelled: 'Vom Benutzer abgebrochen',
  3227. other: 'Sonstiges',
  3228. },
  3229. // Archive statuses
  3230. statuses: {
  3231. completed: 'Abgeschlossen',
  3232. failed: 'Fehlgeschlagen',
  3233. aborted: 'Abgebrochen',
  3234. printing: 'Druckt',
  3235. },
  3236. },
  3237. // K-Profiles
  3238. kProfiles: {
  3239. title: 'K-Profile',
  3240. noPrintersConfigured: 'Keine Drucker konfiguriert',
  3241. addPrinterInSettings: 'Fügen Sie einen Drucker in den Einstellungen hinzu, um K-Profile zu verwalten',
  3242. noActivePrinters: 'Keine aktiven Drucker',
  3243. enablePrinterConnection: 'Aktivieren Sie eine Druckerverbindung, um K-Profile anzuzeigen',
  3244. loadingProfiles: 'Lade K-Profile...',
  3245. printerOffline: 'Drucker offline',
  3246. printerOfflineDesc: 'Der ausgewählte Drucker ist nicht verbunden. Schalten Sie ihn ein, um K-Profile anzuzeigen.',
  3247. noMatchingProfiles: 'Keine passenden Profile',
  3248. noMatchingProfilesDesc: 'Keine Profile entsprechen Ihren Suchkriterien',
  3249. noKProfiles: 'Keine K-Profile',
  3250. noKProfilesDesc: 'Keine Druckvorschub-Profile für {{diameter}}mm Düse gefunden',
  3251. createFirstProfile: 'Erstes Profil erstellen',
  3252. // Controls
  3253. printer: 'Drucker',
  3254. nozzle: 'Düse',
  3255. refresh: 'Aktualisieren',
  3256. addProfile: 'Profil hinzufügen',
  3257. export: 'Exportieren',
  3258. import: 'Importieren',
  3259. select: 'Auswählen',
  3260. selectAll: 'Alle auswählen',
  3261. delete: 'Löschen',
  3262. // Filters
  3263. searchPlaceholder: 'Nach Name oder Filament suchen...',
  3264. allExtruders: 'Alle Extruder',
  3265. leftOnly: 'Nur links',
  3266. rightOnly: 'Nur rechts',
  3267. allFlow: 'Alle Flusstypen',
  3268. hfOnly: 'Nur HF',
  3269. sOnly: 'Nur S',
  3270. sortName: 'Sortieren: Name',
  3271. sortKValue: 'Sortieren: K-Wert',
  3272. sortFilament: 'Sortieren: Filament',
  3273. // Dual extruder labels
  3274. leftExtruder: 'Linker Extruder',
  3275. rightExtruder: 'Rechter Extruder',
  3276. // Modal
  3277. modal: {
  3278. addTitle: 'K-Profil hinzufügen',
  3279. editTitle: 'K-Profil bearbeiten',
  3280. profileName: 'Profilname',
  3281. profileNamePlaceholder: 'Mein PLA-Profil',
  3282. kValue: 'K-Wert',
  3283. kValuePlaceholder: '0,020',
  3284. kValueHelp: 'Typischer Bereich: 0,01 - 0,06 für PLA, 0,02 - 0,10 für PETG',
  3285. filament: 'Filament',
  3286. selectFilament: 'Filament auswählen...',
  3287. noFilamentsHelp: 'Keine Filamente gefunden. Erstellen Sie zuerst ein K-Profil in Bambu Studio.',
  3288. flowType: 'Flusstyp',
  3289. highFlow: 'High Flow',
  3290. standard: 'Standard',
  3291. nozzleSize: 'Düsengröße',
  3292. extruder: 'Extruder',
  3293. extruders: 'Extruder',
  3294. left: 'Links',
  3295. right: 'Rechts',
  3296. notes: 'Notizen (lokal gespeichert)',
  3297. notesPlaceholder: 'Notizen zu diesem Profil hinzufügen...',
  3298. notesHelp: 'Notizen werden in Bambuddy gespeichert, nicht auf dem Drucker',
  3299. syncing: 'Synchronisiert mit Drucker...',
  3300. savingExtruder: 'Speichern auf Extruder {{current}}/{{total}}...',
  3301. pleaseWait: 'Bitte warten',
  3302. },
  3303. // Delete confirmation
  3304. deleteConfirm: {
  3305. title: 'Profil löschen',
  3306. cannotUndo: 'Dies kann nicht rückgängig gemacht werden',
  3307. message: 'Möchten Sie "{{name}}" wirklich vom Drucker löschen?',
  3308. },
  3309. // Bulk delete
  3310. bulkDelete: {
  3311. title: 'Profile löschen',
  3312. cannotUndo: 'Dies kann nicht rückgängig gemacht werden',
  3313. message: 'Möchten Sie wirklich {{count}} ausgewählte Profile vom Drucker löschen?',
  3314. },
  3315. // Toast
  3316. toast: {
  3317. profileSaved: 'K-Profil gespeichert',
  3318. profilesSaved: 'K-Profil auf {{count}} Extrudern gespeichert',
  3319. selectAtLeastOneExtruder: 'Bitte wählen Sie mindestens einen Extruder aus',
  3320. profileDeleted: 'K-Profil gelöscht',
  3321. profilesDeleted: '{{count}} Profile gelöscht',
  3322. exportedProfiles: '{{count}} Profile exportiert',
  3323. importedProfiles: '{{count}} von {{total}} Profilen importiert',
  3324. noProfilesToExport: 'Keine Profile zum Exportieren',
  3325. invalidFileFormat: 'Ungültiges Dateiformat',
  3326. failedToParseImport: 'Import-Datei konnte nicht gelesen werden',
  3327. failedToSaveBatch: 'K-Profile konnten nicht gespeichert werden',
  3328. noteSaved: 'Notiz gespeichert',
  3329. failedToSaveNote: 'Notiz konnte nicht gespeichert werden',
  3330. },
  3331. // Permissions
  3332. permission: {
  3333. noRead: 'Sie haben keine Berechtigung, Profile zu aktualisieren',
  3334. noCreate: 'Sie haben keine Berechtigung, Profile hinzuzufügen',
  3335. noUpdate: 'Sie haben keine Berechtigung, K-Profile zu aktualisieren',
  3336. noDelete: 'Sie haben keine Berechtigung, K-Profile zu löschen',
  3337. noExport: 'Sie haben keine Berechtigung, Profile zu exportieren',
  3338. noImport: 'Sie haben keine Berechtigung, Profile zu importieren',
  3339. },
  3340. },
  3341. // Virtual Printer
  3342. virtualPrinter: {
  3343. title: 'Virtueller Drucker',
  3344. running: 'Läuft',
  3345. stopped: 'Gestoppt',
  3346. description: {
  3347. default: 'Aktiviere einen virtuellen Drucker, der in Bambu Studio und OrcaSlicer erscheint. Dateien, die an diesen Drucker gesendet werden, werden direkt archiviert ohne zu drucken.',
  3348. proxy: 'Aktiviere einen Proxy, der Slicer-Datenverkehr an einen echten Drucker weiterleitet, um Ferndruck über jedes Netzwerk zu ermöglichen.',
  3349. },
  3350. enable: {
  3351. title: 'Virtuellen Drucker aktivieren',
  3352. visibleInSlicer: 'Sichtbar als "Bambuddy" in der Slicer-Erkennung',
  3353. proxyingTo: 'Proxy zu {{name}}',
  3354. notActive: 'Nicht aktiv',
  3355. },
  3356. model: {
  3357. title: 'Druckermodell',
  3358. description: 'Wähle welches Druckermodell emuliert werden soll.',
  3359. restartWarning: 'Das Ändern des Modells startet den virtuellen Drucker neu',
  3360. },
  3361. accessCode: {
  3362. title: 'Zugangscode',
  3363. isSet: 'Zugangscode ist gesetzt',
  3364. notSet: 'Kein Zugangscode gesetzt - erforderlich zum Aktivieren',
  3365. placeholder: '8-Zeichen-Code eingeben',
  3366. placeholderChange: 'Neuen Code eingeben zum Ändern',
  3367. hint: 'Muss genau 8 Zeichen lang sein. Wird von Slicern zur Authentifizierung verwendet.',
  3368. charCount: '({{count}}/8)',
  3369. },
  3370. targetPrinter: {
  3371. title: 'Zieldrucker',
  3372. configured: 'Proxy-Ziel konfiguriert',
  3373. notConfigured: 'Kein Zieldrucker ausgewählt - erforderlich für Proxy-Modus',
  3374. placeholder: 'Drucker auswählen...',
  3375. hint: 'Wähle den Drucker aus, an den der Slicer-Datenverkehr weitergeleitet werden soll. Der Drucker muss im LAN-Modus sein.',
  3376. noPrinters: 'Keine Drucker konfiguriert. Füge zuerst einen Drucker hinzu, um den Proxy-Modus zu verwenden.',
  3377. },
  3378. remoteInterface: {
  3379. title: 'Netzwerkschnittstelle überschreiben',
  3380. configured: 'Schnittstellenüberschreibung aktiv',
  3381. optional: 'Optional - verwenden wenn die automatisch erkannte IP falsch ist (z.B. mehrere NICs, Docker, VPN)',
  3382. placeholder: 'Automatisch erkennen (Standard)...',
  3383. hint: 'Überschreibt die per SSDP beworbene und im TLS-Zertifikat verwendete IP-Adresse. Nützlich wenn Bambuddy mehrere Netzwerkschnittstellen hat.',
  3384. },
  3385. mode: {
  3386. title: 'Modus',
  3387. archive: 'Archivieren',
  3388. archiveDesc: 'Dateien sofort archivieren',
  3389. review: 'Überprüfen',
  3390. reviewDesc: 'Vor dem Archivieren überprüfen',
  3391. queue: 'Warteschlange',
  3392. queueDesc: 'Archivieren und zur Warteschlange hinzufügen',
  3393. proxy: 'Proxy',
  3394. proxyDesc: 'An echten Drucker weiterleiten',
  3395. },
  3396. autoDispatch: {
  3397. title: 'Automatisch starten',
  3398. description: 'Drucke automatisch starten, wenn sie zur Warteschlange hinzugefügt werden. Wenn deaktiviert, warten Drucke auf manuellen Start.',
  3399. },
  3400. setupRequired: {
  3401. title: 'Einrichtung erforderlich',
  3402. description: 'Die virtuelle Druckerfunktion erfordert zusätzliche Systemkonfiguration, bevor sie funktioniert. Dies beinhaltet Portweiterleitung, Firewall-Regeln und plattformspezifische Einstellungen.',
  3403. readGuide: 'Lese die Einrichtungsanleitung vor dem Aktivieren',
  3404. },
  3405. howItWorks: {
  3406. title: 'So funktioniert es',
  3407. step1: 'Im selben LAN erscheinen virtuelle Drucker automatisch in deinem Slicer (Bambu Studio / OrcaSlicer). Aus anderen Netzwerken füge sie manuell per IP-Adresse und Zugangscode hinzu.',
  3408. step2: 'Im Archiv-, Überprüfungs- und Warteschlangen-Modus verwende die "Senden"-Funktion im Slicer, um 3MF-Dateien an Bambuddy zu senden. Der Slicer zeigt "Druck erfolgreich" — die Datei wird gespeichert, nicht gedruckt.',
  3409. step3: 'Im Proxy-Modus leitet der virtuelle Drucker den gesamten Datenverkehr an einen echten Drucker weiter — Drucke starten sofort wie bei einer direkten Verbindung.',
  3410. },
  3411. status: {
  3412. title: 'Status-Details',
  3413. printerName: 'Druckername',
  3414. model: 'Modell',
  3415. serialNumber: 'Seriennummer',
  3416. mode: 'Modus',
  3417. pendingFiles: 'Ausstehende Dateien',
  3418. targetPrinter: 'Zieldrucker',
  3419. ftpPort: 'FTP-Port',
  3420. mqttPort: 'MQTT-Port',
  3421. ftpConnections: 'FTP-Verbindungen',
  3422. mqttConnections: 'MQTT-Verbindungen',
  3423. },
  3424. toast: {
  3425. updated: 'Virtuelle Druckereinstellungen aktualisiert',
  3426. failedToUpdate: 'Einstellungen konnten nicht aktualisiert werden',
  3427. accessCodeRequired: 'Bitte zuerst einen Zugangscode setzen',
  3428. targetPrinterRequired: 'Bitte zuerst einen Zieldrucker auswählen',
  3429. bindIpRequired: 'Bitte zuerst eine Bind-IP setzen',
  3430. accessCodeEmpty: 'Zugangscode darf nicht leer sein',
  3431. accessCodeLength: 'Zugangscode muss genau 8 Zeichen lang sein',
  3432. created: 'Virtueller Drucker erstellt',
  3433. failedToCreate: 'Virtueller Drucker konnte nicht erstellt werden',
  3434. deleted: 'Virtueller Drucker gelöscht',
  3435. failedToDelete: 'Virtueller Drucker konnte nicht gelöscht werden',
  3436. },
  3437. list: {
  3438. title: 'Virtuelle Drucker',
  3439. add: 'Hinzufügen',
  3440. addFirst: 'Virtuellen Drucker hinzufügen',
  3441. empty: 'Keine virtuellen Drucker konfiguriert. Fügen Sie einen hinzu, um zu beginnen.',
  3442. },
  3443. bindIp: {
  3444. title: 'Bind-Interface',
  3445. placeholder: 'Interface auswählen...',
  3446. hint: 'Netzwerkinterface, an das dieser virtuelle Drucker gebunden wird. Muss pro Drucker eindeutig sein.',
  3447. },
  3448. proxy: {
  3449. accessCodeHint: 'Im Proxy-Modus den Zugangscode des Zieldruckers im Slicer verwenden. Die Verbindung wird transparent zum echten Drucker weitergeleitet.',
  3450. },
  3451. addDialog: {
  3452. title: 'Virtuellen Drucker hinzufügen',
  3453. name: 'Name',
  3454. hint: 'Sie können Zugangscode, Zieldrucker und andere Einstellungen nach dem Erstellen konfigurieren.',
  3455. create: 'Erstellen',
  3456. },
  3457. deleteConfirm: {
  3458. title: 'Virtuellen Drucker löschen',
  3459. message: 'Möchten Sie "{{name}}" wirklich löschen? Dies stoppt alle Dienste für diesen Drucker.',
  3460. },
  3461. },
  3462. // Model Viewer
  3463. modelViewer: {
  3464. openInSlicer: 'Im Slicer öffnen',
  3465. tabs: {
  3466. model: '3D-Modell',
  3467. gcode: 'G-Code Vorschau',
  3468. },
  3469. notAvailable: 'nicht verfügbar',
  3470. notSliced: 'nicht geslicet',
  3471. plates: 'Platten',
  3472. allPlates: 'Alle Platten',
  3473. plateNumber: 'Platte {{number}}',
  3474. plateCount: '{{count}} Platte',
  3475. plateCount_other: '{{count}} Platten',
  3476. objectCount: '{{count}} Objekt',
  3477. objectCount_other: '{{count}} Objekte',
  3478. filamentCount: '{{count}} Filament',
  3479. filamentCount_other: '{{count}} Filamente',
  3480. eta: 'ETA {{minutes}} Min',
  3481. noPreview: 'Keine Vorschau für diese Datei verfügbar',
  3482. pagination: {
  3483. pageOf: 'Seite {{current}} von {{total}}',
  3484. prev: 'Zurück',
  3485. next: 'Weiter',
  3486. },
  3487. errors: {
  3488. failedToLoad: 'Datei konnte nicht geladen werden',
  3489. noMeshes: 'Keine Meshes in 3MF-Datei gefunden',
  3490. unsupportedFormat: 'Nicht unterstütztes Dateiformat',
  3491. },
  3492. },
  3493. // Maintenance type descriptions (built-in)
  3494. maintenanceDescriptions: {
  3495. lubricateCarbonRods: 'Schmiermittel auf Karbonstäbe für sanfte Bewegung auftragen',
  3496. lubricateRails: 'Schmiermittel auf Linearschienen für sanfte Bewegung auftragen',
  3497. cleanNozzle: 'Hotend und Düse reinigen, um Verstopfungen zu verhindern',
  3498. checkBelts: 'Riemenspannung für präzise Drucke überprüfen',
  3499. cleanBuildPlate: 'Druckplatte für bessere Haftung reinigen',
  3500. checkExtruder: 'Extruderzahnräder auf Verschleiß prüfen',
  3501. checkCooling: 'Sicherstellen, dass Lüfter ordnungsgemäß funktionieren',
  3502. generalInspection: 'Allgemeine Druckerinspektion',
  3503. cleanCarbonRods: 'Karbonstäbe reinigen, um Reibung zu reduzieren',
  3504. lubricateSteelRods: 'Schmiermittel auf Stahlstangen für sanfte Bewegung auftragen',
  3505. cleanSteelRods: 'Stahlstangen reinigen, um Reibung zu reduzieren',
  3506. cleanLinearRails: 'Linearschienen abwischen, um Staub und Schmutz zu entfernen',
  3507. checkPtfeTube: 'PTFE-Schlauch auf Verschleiß oder Beschädigung prüfen',
  3508. replaceHepaFilter: 'HEPA-Filter für Luftqualität ersetzen',
  3509. replaceCarbonFilter: 'Aktivkohlefilter ersetzen',
  3510. lubricateLeftNozzleRail: 'Linke Düsenschiene schmieren (H2-Serie)',
  3511. },
  3512. // Smart Plugs
  3513. smartPlugs: {
  3514. offline: 'Offline',
  3515. admin: 'Admin',
  3516. openPlugAdminPage: 'Plug-Admin-Seite öffnen',
  3517. deleteSmartPlug: 'Smart Plug löschen',
  3518. turnOnSmartPlug: 'Smart Plug einschalten',
  3519. turnOffSmartPlug: 'Smart Plug ausschalten',
  3520. turnOn: 'Einschalten',
  3521. turnOff: 'Ausschalten',
  3522. addSmartPlug: {
  3523. scanningNetwork: 'Netzwerk wird durchsucht...',
  3524. chooseEntity: 'Entität auswählen...',
  3525. connectionFailed: 'Verbindung fehlgeschlagen',
  3526. searchEntities: 'Entitäten suchen...',
  3527. searchPowerSensors: 'Leistungssensoren suchen...',
  3528. searchEnergySensors: 'Energiesensoren suchen...',
  3529. placeholders: {
  3530. plugName: 'Wohnzimmer Steckdose',
  3531. mqttStateOnValue: 'ON, true, 1',
  3532. mqttSameAsPower: 'Gleich wie Leistungs-Topic oder anders',
  3533. },
  3534. },
  3535. // SmartPlugCard
  3536. linkedTo: 'Verbunden mit:',
  3537. monitorOnly: 'Nur Überwachung',
  3538. alerts: 'Alarme',
  3539. scheduleOn: 'Ein {{time}}',
  3540. scheduleOff: 'Aus {{time}}',
  3541. on: 'Ein',
  3542. off: 'Aus',
  3543. power: 'Leistung',
  3544. kwhToday: 'kWh Heute',
  3545. settings: 'Einstellungen',
  3546. automationSettings: 'Automatisierungseinstellungen',
  3547. showInSwitchbar: 'In Schaltleiste anzeigen',
  3548. quickAccessSidebar: 'Schnellzugriff über Seitenleiste',
  3549. enabled: 'Aktiviert',
  3550. enableAutomation: 'Automatisierung für diesen Stecker aktivieren',
  3551. autoOn: 'Auto Ein',
  3552. autoOnDescription: 'Einschalten wenn Druck startet',
  3553. autoOff: 'Auto Aus',
  3554. autoOffDescription: 'Ausschalten wenn Druck abgeschlossen (einmalig)',
  3555. turnOffDelayMode: 'Ausschaltverzögerungsmodus',
  3556. time: 'Zeit',
  3557. temp: 'Temp',
  3558. delayMinutes: 'Verzögerung (Minuten)',
  3559. tempThreshold: 'Temperaturschwelle (°C)',
  3560. tempThresholdDescription: 'Schaltet aus wenn die Düse unter diese Temperatur abkühlt',
  3561. edit: 'Bearbeiten',
  3562. deleteConfirm: 'Möchten Sie "{{name}}" wirklich löschen? Dies kann nicht rückgängig gemacht werden.',
  3563. turnOnConfirm: 'Möchten Sie "{{name}}" wirklich einschalten?',
  3564. turnOffConfirm: 'Möchten Sie "{{name}}" wirklich ausschalten? Dies unterbricht die Stromversorgung des angeschlossenen Geräts.',
  3565. failedToTurn: '{{name}}" konnte nicht {{action}} werden',
  3566. unknown: 'Unbekannt',
  3567. // AddSmartPlugModal
  3568. addTitle: 'Smart Plug hinzufügen',
  3569. editTitle: 'Smart Plug bearbeiten',
  3570. stopScanning: 'Suche beenden',
  3571. discoverTasmota: 'Tasmota Geräte suchen',
  3572. foundDevices: '{{count}} Gerät(e) gefunden - zum Auswählen klicken:',
  3573. noDevicesFound: 'Keine Tasmota Geräte in Ihrem Netzwerk gefunden',
  3574. haNotConfigured: 'Home Assistant ist nicht konfiguriert. Einrichtung unter',
  3575. haSettingsPath: 'Einstellungen → Netzwerk → Home Assistant',
  3576. selectEntity: 'Entität auswählen *',
  3577. ipAddress: 'IP-Adresse *',
  3578. nameLabel: 'Name *',
  3579. username: 'Benutzername',
  3580. password: 'Passwort',
  3581. authHint: 'Leer lassen, wenn Ihr Tasmota-Gerät keine Authentifizierung benötigt',
  3582. linkToPrinter: 'Mit Drucker verbinden',
  3583. noPrinter: 'Kein Drucker (nur manuelle Steuerung)',
  3584. linkingDescription: 'Verknüpfung ermöglicht automatisches Ein-/Ausschalten bei Druckstart/-ende',
  3585. powerAlerts: 'Leistungsalarme',
  3586. alertAbove: 'Alarm wenn über (W)',
  3587. alertBelow: 'Alarm wenn unter (W)',
  3588. alertDescription: 'Benachrichtigung wenn der Stromverbrauch diese Schwellenwerte überschreitet. Leer lassen um diese Richtung zu deaktivieren.',
  3589. dailySchedule: 'Tagesplan',
  3590. turnOnAt: 'Einschalten um',
  3591. turnOffAt: 'Ausschalten um',
  3592. scheduleDescription: 'Den Stecker automatisch täglich zu diesen Zeiten ein-/ausschalten. Leer lassen um diese Aktion zu überspringen.',
  3593. showOnPrinterCard: 'Auf Druckerkarte anzeigen',
  3594. displayOnPrinterCard: 'Schaltfläche auf Druckerkarte anzeigen',
  3595. connectedResult: 'Verbunden!',
  3596. deviceLabel: 'Gerät: {{name}} - ',
  3597. stateLabel: 'Status: {{state}}',
  3598. test: 'Test',
  3599. delete: 'Löschen',
  3600. save: 'Speichern',
  3601. add: 'Hinzufügen',
  3602. cancel: 'Abbrechen',
  3603. failedToStartScan: 'Suche konnte nicht gestartet werden',
  3604. nameRequired: 'Name ist erforderlich',
  3605. entityRequired: 'Entität ist für Home Assistant Stecker erforderlich',
  3606. mqttTopicRequired: 'Mindestens ein MQTT-Topic muss für Leistung, Energie oder Statusüberwachung konfiguriert sein',
  3607. loadingEntities: 'Entitäten werden geladen...',
  3608. loading: 'Laden...',
  3609. failedToLoadEntities: 'Entitäten konnten nicht geladen werden: {{error}}',
  3610. noEntitiesMatching: 'Keine Entitäten gefunden die "{{search}}" entsprechen',
  3611. noEntitiesAvailable: 'Keine Entitäten verfügbar',
  3612. searchingEntities: 'Alle Entitäten durchsuchen ({{count}} gefunden)',
  3613. showingEntities: 'Zeige switch, light, input_boolean ({{count}} verfügbar)',
  3614. energyMonitoringOptional: 'Energieüberwachung (Optional)',
  3615. energyMonitoringHint: 'Sensoren suchen und auswählen, die Leistungs-/Energiedaten liefern.',
  3616. powerSensorW: 'Leistungssensor (W)',
  3617. energyTodayKwh: 'Energie Heute (kWh)',
  3618. totalEnergyKwh: 'Gesamtenergie (kWh)',
  3619. noMatchingSensors: 'Keine passenden Sensoren',
  3620. none: 'Keine',
  3621. mqttNotConfigured: 'MQTT-Broker nicht konfiguriert. Broker-Adresse einstellen unter',
  3622. mqttSettingsPath: 'Einstellungen → Netzwerk → MQTT-Veröffentlichung',
  3623. mqttNotConfiguredSuffix: '(Sie müssen die Veröffentlichung nicht aktivieren, nur die Broker-Details ausfüllen).',
  3624. mqttMonitorOnlyDescription: 'MQTT-Stecker empfangen Leistungs-/Energiedaten über MQTT-Abonnement. Ein-/Ausschalten ist nicht verfügbar - verwenden Sie Ihren MQTT-Broker oder Ihr Home-Automation-System.',
  3625. powerMonitoring: 'Leistungsüberwachung',
  3626. energyMonitoring: 'Energieüberwachung',
  3627. stateMonitoring: 'Statusüberwachung',
  3628. optional: 'optional',
  3629. topic: 'Topic',
  3630. jsonPath: 'JSON-Pfad',
  3631. multiplier: 'Multiplikator',
  3632. onValue: 'EIN-Wert',
  3633. mqttPowerHint: 'JSON-Pfad extrahiert Wert aus JSON-Payload (z.B. "power_l1"). Leer lassen wenn Topic rohe numerische Werte sendet.\nMultiplikator 0.001 für mW→W, 1000 für kW→W verwenden.',
  3634. mqttEnergyHint: 'JSON-Pfad extrahiert Wert aus JSON-Payload. Leer lassen für rohe Werte.\nMultiplikator 0.001 für Wh→kWh, 1000 für MWh→kWh verwenden.',
  3635. mqttStateHint: 'JSON-Pfad extrahiert Wert aus JSON-Payload. Leer lassen für rohe Werte.\nEIN-Wert: der genaue String der "EIN" bedeutet. Leer lassen für Auto-Erkennung (ON, true, 1).',
  3636. noSwitchesInSwitchbar: 'Keine Schalter in der Schaltleiste',
  3637. enableSwitchbarHint: '"In Schaltleiste anzeigen" unter Einstellungen > Smart Plugs aktivieren',
  3638. },
  3639. // Notifications
  3640. notifications: {
  3641. // Provider types
  3642. providerTypes: {
  3643. callmebot: 'CallMeBot/WhatsApp',
  3644. ntfy: 'ntfy',
  3645. pushover: 'Pushover',
  3646. telegram: 'Telegram',
  3647. email: 'E-Mail',
  3648. discord: 'Discord',
  3649. webhook: 'Webhook',
  3650. homeassistant: 'Home Assistant',
  3651. },
  3652. // Provider descriptions
  3653. providerDescriptions: {
  3654. email: 'SMTP-E-Mail-Benachrichtigungen',
  3655. telegram: 'Benachrichtigungen über Telegram-Bot',
  3656. discord: 'An Discord-Kanal per Webhook senden',
  3657. ntfy: 'Kostenlose, selbst-hostbare Push-Benachrichtigungen',
  3658. pushover: 'Einfache, zuverlässige Push-Benachrichtigungen',
  3659. callmebot: 'Kostenlose WhatsApp-Benachrichtigungen über CallMeBot',
  3660. webhook: 'Generischer HTTP-POST an beliebige URL',
  3661. homeassistant: 'Dauerhafte Benachrichtigungen im Home Assistant Dashboard',
  3662. },
  3663. // NotificationProviderCard
  3664. lastSuccess: 'Zuletzt: {{date}}',
  3665. error: 'Fehler',
  3666. printer: 'Drucker:',
  3667. allPrinters: 'Alle Drucker',
  3668. sendTestNotification: 'Testbenachrichtigung senden',
  3669. eventSettings: 'Ereigniseinstellungen',
  3670. enabled: 'Aktiviert',
  3671. sendFromProvider: 'Benachrichtigungen von diesem Anbieter senden',
  3672. // Event categories
  3673. printEvents: 'Druckereignisse',
  3674. printerStatus: 'Druckerstatus',
  3675. amsAlarms: 'AMS-Alarme',
  3676. amsHtAlarms: 'AMS-HT-Alarme',
  3677. printQueue: 'Druckwarteschlange',
  3678. // Event tags (badges)
  3679. start: 'Start',
  3680. plateCheck: 'Plattenkontrolle',
  3681. complete: 'Abgeschlossen',
  3682. failed: 'Fehlgeschlagen',
  3683. stopped: 'Gestoppt',
  3684. progress: 'Fortschritt',
  3685. offline: 'Offline',
  3686. lowFilament: 'Filament niedrig',
  3687. maintenance: 'Wartung',
  3688. amsHumidity: 'AMS-Feuchtigkeit',
  3689. amsTemp: 'AMS-Temperatur',
  3690. amsHtHumidity: 'AMS-HT-Feuchtigkeit',
  3691. amsHtTemp: 'AMS-HT-Temperatur',
  3692. bedCooled: 'Bett abgekühlt',
  3693. firstLayer: 'Erste Schicht',
  3694. quiet: 'Ruhe',
  3695. digest: 'Zusammenfassung {{time}}',
  3696. // Event labels (expanded settings)
  3697. printStarted: 'Druck gestartet',
  3698. plateNotEmpty: 'Platte nicht leer',
  3699. plateNotEmptyDescription: 'Objekte vor dem Druck erkannt',
  3700. printCompleted: 'Druck abgeschlossen',
  3701. bedCooledLabel: 'Bett abgekühlt',
  3702. bedCooledDescription: 'Bett nach dem Druck unter Schwellenwert abgekühlt',
  3703. firstLayerCompleteLabel: 'Erste Schicht fertig',
  3704. firstLayerCompleteDescription: 'Benachrichtigung mit Foto nach erster Schicht',
  3705. printFailed: 'Druck fehlgeschlagen',
  3706. printStopped: 'Druck gestoppt',
  3707. progressMilestones: 'Fortschrittsmeilensteine',
  3708. progressMilestonesDescription: 'Benachrichtigung bei 25%, 50%, 75%',
  3709. printerOffline: 'Drucker offline',
  3710. printerError: 'Druckerfehler',
  3711. lowFilamentLabel: 'Filament niedrig',
  3712. maintenanceDue: 'Wartung fällig',
  3713. maintenanceDueDescription: 'Benachrichtigen, wenn Wartung erforderlich ist',
  3714. amsHumidityHigh: 'AMS-Feuchtigkeit hoch',
  3715. amsHumidityHighDescription: 'Normale AMS-Feuchtigkeit überschreitet Schwellenwert',
  3716. amsTemperatureHigh: 'AMS-Temperatur hoch',
  3717. amsTemperatureHighDescription: 'Normale AMS-Temperatur überschreitet Schwellenwert',
  3718. amsHtHumidityHigh: 'AMS-HT-Feuchtigkeit hoch',
  3719. amsHtHumidityHighDescription: 'AMS-HT-Feuchtigkeit überschreitet Schwellenwert',
  3720. amsHtTemperatureHigh: 'AMS-HT-Temperatur hoch',
  3721. amsHtTemperatureHighDescription: 'AMS-HT-Temperatur überschreitet Schwellenwert',
  3722. // Queue events
  3723. jobAdded: 'Auftrag hinzugefügt',
  3724. jobAddedDescription: 'Auftrag zur Warteschlange hinzugefügt',
  3725. jobAssigned: 'Auftrag zugewiesen',
  3726. jobAssignedDescription: 'Modellbasierter Auftrag einem Drucker zugewiesen',
  3727. jobStarted: 'Auftrag gestartet',
  3728. jobStartedDescription: 'Warteschlangenauftrag hat Druck begonnen',
  3729. jobWaiting: 'Auftrag wartet',
  3730. jobWaitingDescription: 'Auftrag wartet auf Filament',
  3731. jobSkipped: 'Auftrag übersprungen',
  3732. jobSkippedDescription: 'Auftrag übersprungen (vorheriger fehlgeschlagen)',
  3733. jobFailed: 'Auftrag fehlgeschlagen',
  3734. jobFailedDescription: 'Auftrag konnte nicht gestartet werden',
  3735. queueComplete: 'Warteschlange abgeschlossen',
  3736. queueCompleteDescription: 'Alle Warteschlangenaufträge beendet',
  3737. // Quiet hours
  3738. quietHours: 'Ruhezeiten',
  3739. noNotificationsDuring: 'Keine Benachrichtigungen während dieser Zeiten',
  3740. editProviderToChangeQuietHours: 'Anbieter bearbeiten, um Ruhezeiten zu ändern',
  3741. // Daily digest
  3742. dailyDigest: 'Tägliche Zusammenfassung',
  3743. batchNotifications: 'Benachrichtigungen zu einer täglichen Zusammenfassung bündeln',
  3744. sendAt: 'Senden um {{time}}',
  3745. editProviderToChangeDigestTime: 'Anbieter bearbeiten, um Zusammenfassungszeit zu ändern',
  3746. // Actions
  3747. edit: 'Bearbeiten',
  3748. deleteProvider: 'Benachrichtigungsanbieter löschen',
  3749. deleteConfirm: 'Sind Sie sicher, dass Sie "{{name}}" löschen möchten? Dies kann nicht rückgängig gemacht werden.',
  3750. delete: 'Löschen',
  3751. // AddNotificationModal
  3752. addTitle: 'Benachrichtigungsanbieter hinzufügen',
  3753. editTitle: 'Benachrichtigungsanbieter bearbeiten',
  3754. nameLabel: 'Name *',
  3755. namePlaceholder: 'Meine Benachrichtigungen',
  3756. providerTypeLabel: 'Anbietertyp *',
  3757. configuration: 'Konfiguration',
  3758. testConfiguration: 'Konfiguration testen',
  3759. printerFilter: 'Druckerfilter',
  3760. onlyFromPrinter: 'Nur Benachrichtigungen für Ereignisse von diesem Drucker senden',
  3761. quietHoursDnd: 'Ruhezeiten (Nicht stören)',
  3762. quietStart: 'Start',
  3763. quietEnd: 'Ende',
  3764. dailyDigestLabel: 'Tägliche Zusammenfassung',
  3765. sendDigestAt: 'Zusammenfassung senden um',
  3766. digestCollected: 'Ereignisse werden gesammelt und als einzelne Zusammenfassung zu dieser Zeit gesendet',
  3767. notificationEvents: 'Benachrichtigungsereignisse',
  3768. progressPercent: '(25%, 50%, 75%)',
  3769. bedCooledAfterPrint: '(nach Druckabschluss)',
  3770. cancel: 'Abbrechen',
  3771. save: 'Speichern',
  3772. add: 'Hinzufügen',
  3773. nameRequired: 'Name ist erforderlich',
  3774. fieldRequired: '{{field}} ist erforderlich',
  3775. // Config field labels
  3776. phoneNumber: 'Telefonnummer',
  3777. apiKey: 'API-Schlüssel',
  3778. serverUrl: 'Server-URL',
  3779. topic: 'Thema',
  3780. authToken: 'Auth-Token',
  3781. userKey: 'Benutzerschlüssel',
  3782. appToken: 'App-Token',
  3783. priority: 'Priorität',
  3784. botToken: 'Bot-Token',
  3785. chatId: 'Chat-ID',
  3786. smtpServer: 'SMTP-Server',
  3787. smtpPort: 'SMTP-Port',
  3788. security: 'Sicherheit',
  3789. authentication: 'Authentifizierung',
  3790. username: 'Benutzername',
  3791. password: 'Passwort',
  3792. fromEmail: 'Absender-E-Mail',
  3793. toEmail: 'Empfänger-E-Mail',
  3794. webhookUrl: 'Webhook-URL',
  3795. payloadFormat: 'Payload-Format',
  3796. authorization: 'Autorisierung',
  3797. titleFieldName: 'Titel-Feldname',
  3798. messageFieldName: 'Nachrichten-Feldname',
  3799. // NotificationTemplateEditor
  3800. editTemplate: 'Vorlage bearbeiten: {{name}}',
  3801. titleLabel: 'Titel',
  3802. bodyLabel: 'Inhalt',
  3803. titlePlaceholder: 'Benachrichtigungstitel...',
  3804. bodyPlaceholder: 'Benachrichtigungsinhalt...',
  3805. availableVariables: 'Verfügbare Variablen',
  3806. clickToInsert: 'Klicken, um an Cursorposition im Inhalt einzufügen',
  3807. livePreview: 'Live-Vorschau',
  3808. hide: 'Ausblenden',
  3809. show: 'Anzeigen',
  3810. loadingPreview: 'Vorschau wird geladen...',
  3811. enterTemplateContent: 'Vorlageninhalt eingeben, um Vorschau zu sehen',
  3812. titlePreview: 'Titel:',
  3813. bodyPreview: 'Inhalt:',
  3814. resetToDefault: 'Auf Standard zurücksetzen',
  3815. titleRequired: 'Titel ist erforderlich',
  3816. bodyRequired: 'Inhalt ist erforderlich',
  3817. // NotificationLogViewer
  3818. notificationLog: 'Benachrichtigungsprotokoll',
  3819. showFailedOnly: 'Nur fehlgeschlagene',
  3820. last24Hours: 'Letzte 24 Stunden',
  3821. last7Days: 'Letzte 7 Tage',
  3822. last30Days: 'Letzte 30 Tage',
  3823. last90Days: 'Letzte 90 Tage',
  3824. justNow: 'Gerade eben',
  3825. noFailedNotifications: 'Keine fehlgeschlagenen Benachrichtigungen',
  3826. noNotificationsLogged: 'Keine Benachrichtigungen protokolliert',
  3827. unknownProvider: 'Unbekannter Anbieter',
  3828. logTitle: 'Titel',
  3829. logMessage: 'Nachricht',
  3830. logError: 'Fehler',
  3831. logProvider: 'Anbieter: {{type}}',
  3832. logTime: 'Zeit: {{time}}',
  3833. refresh: 'Aktualisieren',
  3834. clearOld: 'Alte löschen',
  3835. statsSummary: 'Letzte {{days}} Tage:',
  3836. statsNotifications: 'Benachrichtigungen',
  3837. statsSent: '{{count}} gesendet',
  3838. statsFailed: '{{count}} fehlgeschlagen',
  3839. // Event type labels (for log viewer)
  3840. eventTypes: {
  3841. print_start: 'Druck gestartet',
  3842. print_complete: 'Druck abgeschlossen',
  3843. print_failed: 'Druck fehlgeschlagen',
  3844. print_stopped: 'Druck gestoppt',
  3845. print_progress: 'Fortschritt',
  3846. printer_offline: 'Drucker offline',
  3847. printer_error: 'Druckerfehler',
  3848. filament_low: 'Filament niedrig',
  3849. maintenance_due: 'Wartung fällig',
  3850. test: 'Test',
  3851. },
  3852. },
  3853. // Rich Text Editor
  3854. richTextEditor: {
  3855. bold: 'Fett',
  3856. italic: 'Kursiv',
  3857. underline: 'Unterstrichen',
  3858. bulletList: 'Aufzählungsliste',
  3859. numberedList: 'Nummerierte Liste',
  3860. alignLeft: 'Linksbündig',
  3861. alignCenter: 'Zentriert',
  3862. alignRight: 'Rechtsbündig',
  3863. addLink: 'Link hinzufügen',
  3864. removeLink: 'Link entfernen',
  3865. },
  3866. // External Links
  3867. externalLinks: {
  3868. noLinksConfigured: 'Keine externen Links konfiguriert',
  3869. deleteLink: 'Link löschen',
  3870. removeCustomIcon: 'Benutzerdefiniertes Symbol entfernen',
  3871. openInNewTab: 'In neuem Tab öffnen',
  3872. placeholders: {
  3873. linkName: 'Mein Link',
  3874. },
  3875. },
  3876. // Keyboard Shortcuts Modal
  3877. keyboardShortcuts: {
  3878. title: 'Tastaturkürzel',
  3879. navigation: 'Navigation',
  3880. archivesSection: 'Archive',
  3881. kProfilesSection: 'K-Profile',
  3882. generalSection: 'Allgemein',
  3883. shortcuts: {
  3884. goToPrinters: 'Zu Drucker gehen',
  3885. goToArchives: 'Zu Archiv gehen',
  3886. goToQueue: 'Zur Warteschlange gehen',
  3887. goToStats: 'Zu Statistiken gehen',
  3888. goToProfiles: 'Zu Cloud-Profilen gehen',
  3889. goToSettings: 'Zu Einstellungen gehen',
  3890. focusSearch: 'Suche fokussieren',
  3891. openUploadModal: 'Upload-Modal öffnen',
  3892. clearSelection: 'Auswahl löschen / Eingabe aufheben',
  3893. contextMenu: 'Kontextmenü auf Karten',
  3894. refreshProfiles: 'Profile aktualisieren',
  3895. newProfile: 'Neues Profil',
  3896. exitSelectionMode: 'Auswahlmodus beenden',
  3897. showHelp: 'Diese Hilfe anzeigen',
  3898. },
  3899. footer: 'Drücken Sie Esc oder klicken Sie außerhalb, um zu schließen',
  3900. },
  3901. // Notification Log
  3902. notificationLog: {
  3903. title: 'Benachrichtigungsprotokoll',
  3904. events: {
  3905. printStarted: 'Druck gestartet',
  3906. printComplete: 'Druck abgeschlossen',
  3907. printFailed: 'Druck fehlgeschlagen',
  3908. printStopped: 'Druck gestoppt',
  3909. progress: 'Fortschritt',
  3910. printerOffline: 'Drucker offline',
  3911. printerError: 'Druckerfehler',
  3912. lowFilament: 'Wenig Filament',
  3913. maintenanceDue: 'Wartung fällig',
  3914. test: 'Test',
  3915. },
  3916. timeAgo: {
  3917. justNow: 'Gerade eben',
  3918. minutesAgo: 'vor {{minutes}}m',
  3919. hoursAgo: 'vor {{hours}}h',
  3920. },
  3921. },
  3922. // Restore/Backup Modal
  3923. restoreBackup: {
  3924. title: 'Backup wiederherstellen',
  3925. restoring: 'Wird wiederhergestellt...',
  3926. restoreComplete: 'Wiederherstellung abgeschlossen',
  3927. restoreFailed: 'Wiederherstellung fehlgeschlagen',
  3928. importSettings: 'Einstellungen aus Backup-Datei importieren',
  3929. pleaseWait: 'Bitte warten Sie, während Ihre Daten wiederhergestellt werden',
  3930. clickToSelect: 'Klicken Sie, um Backup-Datei auszuwählen (.json oder .zip)',
  3931. howDuplicateHandling: 'So funktioniert die Duplikatbehandlung:',
  3932. categories: {
  3933. printers: 'Drucker',
  3934. smartPlugs: 'Smart Plugs',
  3935. notificationProviders: 'Benachrichtigungsanbieter',
  3936. filaments: 'Filamente',
  3937. archives: 'Archive',
  3938. pendingUploads: 'Ausstehende Uploads',
  3939. settingsTemplates: 'Einstellungen & Vorlagen',
  3940. },
  3941. matchingInfo: {
  3942. printers: 'abgeglichen nach Seriennummer',
  3943. smartPlugs: 'abgeglichen nach IP-Adresse',
  3944. notificationProviders: 'abgeglichen nach Name',
  3945. filaments: 'abgeglichen nach Name + Typ + Marke',
  3946. archives: 'abgeglichen nach Inhalts-Hash',
  3947. pendingUploads: 'abgeglichen nach Dateiname',
  3948. settingsTemplates: 'immer überschrieben',
  3949. },
  3950. replaceExisting: 'Vorhandene Daten ersetzen',
  3951. keepExisting: 'Vorhandene Daten behalten',
  3952. replaceDescription: 'Bereits vorhandene Elemente mit Backup-Daten überschreiben',
  3953. keepDescription: 'Nur Elemente wiederherstellen, die noch nicht existieren',
  3954. caution: 'Vorsicht:',
  3955. cautionText: 'Das Überschreiben ersetzt Ihre aktuellen Konfigurationen durch Backup-Daten. Drucker-Zugangscodes werden aus Sicherheitsgründen niemals überschrieben.',
  3956. itemsRestored: 'Wiederhergestellte Elemente',
  3957. itemsSkipped: 'Übersprungene Elemente',
  3958. restored: 'Wiederhergestellt',
  3959. skipped: 'Übersprungen (existieren bereits)',
  3960. filesLabel: 'Dateien (3MF, Thumbnails, etc.)',
  3961. newApiKeysGenerated: 'Neue API-Schlüssel generiert',
  3962. newApiKeysWarning: 'Diese Schlüssel werden nur einmal angezeigt. Kopieren Sie sie jetzt!',
  3963. processingBackup: 'Backup-Datei wird verarbeitet...',
  3964. noDataFound: 'In der Backup-Datei wurden keine wiederherzustellenden Daten gefunden.',
  3965. failedToRestore: 'Backup konnte nicht wiederhergestellt werden. Bitte überprüfen Sie das Dateiformat.',
  3966. },
  3967. // Backup Export Modal
  3968. backupExport: {
  3969. title: 'Backup exportieren',
  3970. selectData: 'Zu exportierende Daten auswählen',
  3971. selectAll: 'Alle auswählen',
  3972. selectNone: 'Keine auswählen',
  3973. categoryDescriptions: {
  3974. settings: 'Sprache, Theme, Update-Einstellungen',
  3975. notifications: 'ntfy, Pushover, Discord, usw.',
  3976. templates: 'Benutzerdefinierte Nachrichtenvorlagen',
  3977. smartPlugs: 'Tasmota-Plug-Konfigurationen',
  3978. externalLinks: 'Seitenleiste Links zu externen Diensten',
  3979. printers: 'Druckerinformationen (Zugangscodes ausgeschlossen)',
  3980. plateDetection: 'Leere Platten-Referenzbilder',
  3981. filaments: 'Filamenttypen und -kosten',
  3982. maintenance: 'Benutzerdefinierte Wartungspläne',
  3983. archives: 'Alle Druckdaten + Dateien (3MF, Thumbnails, Fotos)',
  3984. projects: 'Projekte, BOM-Elemente und Anhänge',
  3985. pendingUploads: 'Virtueller Drucker-Uploads zur Überprüfung',
  3986. apiKeys: 'Webhook-API-Schlüssel (neue Schlüssel bei Import generiert)',
  3987. },
  3988. requiresPrinters: 'Drucker müssen ausgewählt sein',
  3989. zipFileWarning: 'ZIP-Datei wird erstellt.',
  3990. zipFileDescription: 'Enthält alle 3MF-Dateien, Thumbnails, Zeitraffer und Fotos. Dies kann eine Weile dauern und zu einer großen Datei führen.',
  3991. includeAccessCodes: 'Zugangscodes einschließen',
  3992. includeAccessCodesDescription: 'Für die Übertragung auf eine andere Maschine',
  3993. includeAccessCodesWarning: 'Zugangscodes werden im Klartext eingeschlossen. Bewahren Sie diese Backup-Datei sicher auf!',
  3994. categoriesSelected: '{{selectedCount}} Kategorien ausgewählt',
  3995. },
  3996. // Pending Uploads Panel
  3997. pendingUploads: {
  3998. placeholders: {
  3999. notes: 'Notizen zu diesem Druck hinzufügen...',
  4000. },
  4001. discardUpload: 'Upload verwerfen',
  4002. archiveAllUploads: 'Alle Uploads archivieren',
  4003. discardAllUploads: 'Alle Uploads verwerfen',
  4004. archive: 'Archivieren',
  4005. timeAgo: {
  4006. justNow: 'Gerade eben',
  4007. minutesAgo: 'vor {{minutes}}m',
  4008. hoursAgo: 'vor {{hours}}h',
  4009. daysAgo: 'vor {{days}}d',
  4010. },
  4011. },
  4012. // API Browser
  4013. apiBrowser: {
  4014. placeholders: {
  4015. requestBody: 'JSON-Anforderungstext...',
  4016. searchEndpoints: 'Endpunkte suchen...',
  4017. },
  4018. },
  4019. // Configure AMS Slot Modal
  4020. configureAmsSlot: {
  4021. title: 'AMS-Slot konfigurieren',
  4022. slotConfigured: 'Slot konfiguriert!',
  4023. configuringSlot: 'Slot wird konfiguriert:',
  4024. slotLabel: '{{ams}} Slot {{slot}}',
  4025. searchPresets: 'Voreinstellungen suchen...',
  4026. colorPlaceholder: 'Farbname oder Hex (z.B. braun, FF8800)',
  4027. clearCustomColor: 'Benutzerdefinierte Farbe löschen',
  4028. noCloudPresets: 'Keine Cloud-Voreinstellungen. Melden Sie sich bei Bambu Cloud an, um zu synchronisieren.',
  4029. noPresetsAvailable: 'Keine Voreinstellungen verfügbar. Melden Sie sich bei Bambu Cloud an oder importieren Sie lokale Profile.',
  4030. noMatchingPresets: 'Keine passenden Voreinstellungen gefunden.',
  4031. custom: 'Benutzerdefiniert',
  4032. builtin: 'Integriert',
  4033. settingsSentToPrinter: 'Einstellungen an Drucker gesendet',
  4034. filamentProfile: 'Filamentprofil',
  4035. kProfileLabel: 'K-Profil (Pressure Advance)',
  4036. filteringFor: 'Filtern nach: {{material}}',
  4037. noKProfile: 'Kein K-Profil (Standard 0.020 verwenden)',
  4038. noMatchingKProfiles: 'Keine passenden K-Profile gefunden. Standard K=0.020 wird verwendet.',
  4039. selectFilamentFirst: 'Zuerst ein Filamentprofil auswählen',
  4040. kFromCalibration: 'K={{value}} aus Druckerkalibrierung',
  4041. customColorLabel: 'Benutzerdefinierte Farbe (optional)',
  4042. presetColors: '{{name}} Farben:',
  4043. showLessColors: 'Weniger Farben anzeigen',
  4044. showMoreColors: 'Mehr Farben anzeigen',
  4045. clear: 'Löschen',
  4046. hexLabel: 'Hex: #{{hex}}',
  4047. resetting: 'Wird zurückgesetzt...',
  4048. resetSlot: 'Slot zurücksetzen',
  4049. cancel: 'Abbrechen',
  4050. configuring: 'Wird konfiguriert...',
  4051. configureSlot: 'Slot konfigurieren',
  4052. },
  4053. // GitHub Backup Settings
  4054. githubBackup: {
  4055. title: 'GitHub-Backup',
  4056. history: 'Verlauf',
  4057. downloadBackup: 'Backup herunterladen',
  4058. restoreBackup: 'Backup wiederherstellen',
  4059. noBackupsYet: 'Noch keine Backups',
  4060. },
  4061. // Email Settings
  4062. emailSettings: {
  4063. placeholders: {
  4064. fromName: 'BamBuddy',
  4065. },
  4066. },
  4067. // Tag Management Modal
  4068. tagManagement: {
  4069. searchTags: 'Tags suchen...',
  4070. renameTag: 'Tag umbenennen',
  4071. deleteTag: 'Tag löschen',
  4072. },
  4073. // Notification Template Editor
  4074. notificationTemplates: {
  4075. placeholders: {
  4076. title: 'Benachrichtigungstitel...',
  4077. body: 'Benachrichtigungstext...',
  4078. },
  4079. },
  4080. // Batch Tag Modal
  4081. batchTag: {
  4082. placeholders: {
  4083. newTag: 'Neuen Tag eingeben...',
  4084. },
  4085. },
  4086. // Photo Gallery Modal
  4087. photoGallery: {
  4088. deletePhoto: 'Foto löschen',
  4089. },
  4090. // Filament Hover Card
  4091. filamentHoverCard: {
  4092. copySpoolUuid: 'Spulen-UUID kopieren',
  4093. },
  4094. // K Profiles View
  4095. kProfilesView: {
  4096. hasNote: 'Hat Notiz',
  4097. copyProfile: 'Profil kopieren',
  4098. },
  4099. // Layout/Navigation
  4100. layout: {
  4101. openMenu: 'Menü öffnen',
  4102. noPermissionSystemInfo: 'Sie haben keine Berechtigung zum Anzeigen von Systeminformationen',
  4103. },
  4104. // Dashboard
  4105. dashboard: {
  4106. dragToReorder: 'Ziehen zum Neuordnen',
  4107. hideWidget: 'Widget ausblenden',
  4108. },
  4109. // Notification Provider Card
  4110. notificationProviderCard: {
  4111. deleteNotificationProvider: 'Benachrichtigungsanbieter löschen',
  4112. },
  4113. // File Manager Modal
  4114. fileManagerModal: {
  4115. closeFileManager: 'Dateimanager schließen',
  4116. sortFiles: 'Dateien sortieren',
  4117. goToParentFolder: 'Zum übergeordneten Ordner gehen',
  4118. threeView: '3D-Ansicht',
  4119. },
  4120. // Embedded Camera Viewer
  4121. embeddedCameraViewer: {
  4122. refreshStream: 'Stream aktualisieren',
  4123. close: 'Schließen',
  4124. zoomOut: 'Verkleinern',
  4125. resetZoom: 'Zoom zurücksetzen',
  4126. zoomIn: 'Vergrößern',
  4127. dragToResize: 'Ziehen zum Größe ändern',
  4128. },
  4129. // Timelapse Viewer
  4130. timelapseViewer: {
  4131. skipBack5s: '5s zurückspringen',
  4132. skipForward5s: '5s vorspringen',
  4133. },
  4134. // Notification Providers
  4135. notificationProviders: {
  4136. descriptions: {
  4137. email: 'SMTP-E-Mail-Benachrichtigungen',
  4138. telegram: 'Benachrichtigungen über Telegram-Bot',
  4139. discord: 'An Discord-Kanal über Webhook senden',
  4140. ntfy: 'Kostenlose, selbst hostbare Push-Benachrichtigungen',
  4141. pushover: 'Einfache, zuverlässige Push-Benachrichtigungen',
  4142. callmebot: 'Kostenlose WhatsApp-Benachrichtigungen über CallMeBot',
  4143. webhook: 'Generischer HTTP POST zu beliebiger URL',
  4144. },
  4145. },
  4146. // Log Viewer
  4147. logViewer: {
  4148. searchPlaceholder: 'Nachricht oder Logger-Name suchen...',
  4149. noLogEntries: 'Keine Logeinträge gefunden',
  4150. },
  4151. // Switchbar Popover
  4152. switchbarPopover: {
  4153. noSwitchesInSwitchbar: 'Keine Schalter in Schalterleiste',
  4154. },
  4155. // Project Page Modal
  4156. projectPageModal: {
  4157. placeholders: {
  4158. title: 'Titel',
  4159. designer: 'Designer',
  4160. license: 'Lizenz',
  4161. description: 'Beschreibung eingeben...',
  4162. profileTitle: 'Profil-Titel',
  4163. profileDescription: 'Profilbeschreibung...',
  4164. },
  4165. },
  4166. // Spoolman Settings
  4167. spoolmanSettings: {},
  4168. // Time
  4169. time: {
  4170. unknown: '-',
  4171. waiting: 'Wartend',
  4172. justNow: 'Gerade eben',
  4173. now: 'Jetzt',
  4174. minsAgo: 'vor {{count}}m',
  4175. inMins: 'in {{count}}m',
  4176. hoursAgo: 'vor {{count}}h',
  4177. inHours: 'in {{count}}h',
  4178. daysAgo: 'vor {{count}}d',
  4179. inDays: 'in {{count}}d',
  4180. },
  4181. // SpoolBuddy Kiosk
  4182. spoolbuddy: {
  4183. nav: {
  4184. dashboard: 'Dashboard',
  4185. ams: 'AMS',
  4186. inventory: 'Inventar',
  4187. writeTag: 'Schreiben',
  4188. settings: 'Einstellungen',
  4189. },
  4190. status: {
  4191. nfcReady: 'NFC bereit',
  4192. nfcOff: 'NFC aus',
  4193. offline: 'Offline',
  4194. online: 'Online',
  4195. noPrinters: 'Keine Drucker',
  4196. deviceOffline: 'Gerät offline',
  4197. waitingConnection: 'Warte auf Geräteverbindung...',
  4198. systemReady: 'System bereit',
  4199. status: 'Status',
  4200. },
  4201. dashboard: {
  4202. readyToScan: 'Bereit zum Scannen',
  4203. idleMessage: 'Spule auf die Waage legen zum Identifizieren',
  4204. nfcHint: 'NFC-Tag wird automatisch gelesen',
  4205. device: 'Gerät',
  4206. syncWeight: 'Gewicht sync.',
  4207. weightSynced: 'Synchronisiert!',
  4208. unknownTag: 'Unbekannter Tag',
  4209. newTag: 'Neuer Tag erkannt',
  4210. onScale: 'auf der Waage',
  4211. linkSpool: 'Mit Spule verknüpfen',
  4212. linkTagTitle: 'Tag mit Spule verknüpfen',
  4213. linkTag: 'Tag verknüpfen',
  4214. selectSpool: 'Spule zum Verknüpfen auswählen:',
  4215. noUntagged: 'Keine Spulen ohne Tags gefunden',
  4216. tagDetected: 'Tag erkannt',
  4217. noTag: 'Kein Tag',
  4218. tagId: 'Tag',
  4219. grossWeight: 'Bruttogewicht',
  4220. spoolSize: 'Spulengröße',
  4221. close: 'Schließen',
  4222. currentSpool: 'Aktuelle Spule',
  4223. },
  4224. modal: {
  4225. spoolDetected: 'Spule erkannt',
  4226. assignToAms: 'AMS zuweisen',
  4227. syncWeight: 'Gewicht sync.',
  4228. weightSynced: 'Synchronisiert!',
  4229. syncing: 'Synchronisiere...',
  4230. newTagDetected: 'Neuer Tag erkannt',
  4231. addToInventory: 'Zum Inventar hinzufügen',
  4232. assignToAmsTitle: 'AMS zuweisen',
  4233. selectSlot: 'Slot auswählen',
  4234. assign: 'Zuweisen',
  4235. assigning: 'Zuweisen...',
  4236. assignSuccess: 'Zugewiesen!',
  4237. assignError: 'Fehler beim Zuweisen. Bitte erneut versuchen.',
  4238. noPrinterSelected: 'Drucker auswählen...',
  4239. noAmsDetected: 'Kein AMS an diesem Drucker erkannt',
  4240. slot: 'Slot',
  4241. },
  4242. weight: {
  4243. noReading: 'Kein Messwert',
  4244. stable: 'Stabil',
  4245. measuring: 'Messen...',
  4246. tare: 'Tarieren',
  4247. calibrate: 'Kalibrieren',
  4248. },
  4249. spool: {
  4250. remaining: 'Verbleibend',
  4251. material: 'Material',
  4252. brand: 'Marke',
  4253. color: 'Farbe',
  4254. coreWeight: 'Kern',
  4255. labelWeight: 'Etikett',
  4256. scaleWeight: 'Waage',
  4257. netWeight: 'Netto',
  4258. lastUsed: 'Zuletzt verwendet',
  4259. },
  4260. ams: {
  4261. noData: 'Kein AMS erkannt',
  4262. connectAms: 'AMS anschließen um Filament-Slots zu sehen',
  4263. noPrinter: 'Kein Drucker ausgewählt',
  4264. selectPrinter: 'Drucker in der oberen Leiste auswählen',
  4265. printerDisconnected: 'Drucker getrennt',
  4266. humidity: 'Feuchtigkeit',
  4267. level: 'Stufe',
  4268. active: 'Aktiv',
  4269. slot: 'Slot',
  4270. empty: 'Leer',
  4271. },
  4272. inventory: {
  4273. search: 'Spulen suchen...',
  4274. empty: 'Keine Spulen im Inventar',
  4275. noResults: 'Keine passenden Spulen',
  4276. spools: 'Spulen',
  4277. addSpool: 'Spule hinzufügen',
  4278. },
  4279. settings: {
  4280. // Tabs
  4281. tabDevice: 'Gerät',
  4282. tabDisplay: 'Anzeige',
  4283. tabScale: 'Waage',
  4284. tabUpdates: 'Updates',
  4285. // Device tab
  4286. nfcReader: 'NFC-Leser',
  4287. type: 'Typ',
  4288. connection: 'Verbindung',
  4289. notConnected: 'N/A',
  4290. deviceInfo: 'Geräteinfo',
  4291. hostname: 'Host',
  4292. uptime: 'Betriebszeit',
  4293. // Display tab
  4294. brightness: 'Helligkeit',
  4295. saved: 'Gespeichert',
  4296. noBacklight: 'Keine DSI-Hintergrundbeleuchtung erkannt. Helligkeitssteuerung erfordert ein DSI-Display.',
  4297. screenBlank: 'Bildschirm-Abschaltzeit',
  4298. screenBlankDesc: 'Bildschirm schaltet sich nach Inaktivität ab. Zum Aufwecken berühren.',
  4299. displayNote: 'Helligkeit wird als Software-Filter angewendet.',
  4300. // Scale tab
  4301. scaleCalibration: 'Waagen-Kalibrierung',
  4302. currentWeight: 'Aktuelles Gewicht',
  4303. tareOffset: 'Tara',
  4304. calFactor: 'Faktor',
  4305. knownWeight: 'Bekanntes Gewicht',
  4306. calStep1: 'Alle Gegenstände von der Waage entfernen und Nullpunkt setzen.',
  4307. calStep2: 'Bekanntes Gewicht auf die Waage legen.',
  4308. setZero: 'Nullpunkt setzen',
  4309. calibrateNow: 'Kalibrieren',
  4310. calibrated: 'Kalibriert',
  4311. tareSet: 'Tara-Befehl gesendet. Warte auf Gerät...',
  4312. tareFailed: 'Tara-Befehl fehlgeschlagen',
  4313. zeroSet: 'Nullpunkt gesetzt. Bekanntes Gewicht auf die Waage legen.',
  4314. calibrationDone: 'Kalibrierung abgeschlossen!',
  4315. calibrationFailed: 'Kalibrierung fehlgeschlagen',
  4316. lastCalibrated: 'Zuletzt kalibriert',
  4317. stable: 'Stabil',
  4318. settling: 'Stabilisierung...',
  4319. firmware: 'Firmware',
  4320. scale: 'Waage',
  4321. noDevice: 'Kein SpoolBuddy-Gerät gefunden',
  4322. // Updates tab
  4323. daemonVersion: 'Daemon-Version',
  4324. currentVersion: 'Aktuell',
  4325. versionPending: 'Warte auf Daemon...',
  4326. checking: 'Prüfe...',
  4327. checkUpdates: 'Nach Updates suchen',
  4328. updateAvailable: 'Update verfügbar',
  4329. updateInstructions: 'Update per SSH: SpoolBuddy-Installationsskript ausführen.',
  4330. upToDate: 'Aktuell',
  4331. includeBeta: 'Beta-Versionen einschließen',
  4332. },
  4333. writeTag: {
  4334. tabExisting: 'Vorhandene Spule',
  4335. tabNew: 'Neue Spule',
  4336. tabReplace: 'Tag ersetzen',
  4337. searchPlaceholder: 'Suche nach Material, Farbe, Marke...',
  4338. noUntaggedSpools: 'Keine Spulen ohne Tags',
  4339. noTaggedSpools: 'Keine Spulen mit Tags',
  4340. selectSpool: 'Spule auswählen, dann einen NTAG auf den Leser legen',
  4341. placeTag: 'NTAG auf den Leser legen',
  4342. tagReady: 'Tag erkannt — bereit zum Schreiben',
  4343. writeTag: 'Tag beschreiben',
  4344. replaceTag: 'Tag ersetzen',
  4345. writing: 'Tag wird beschrieben...',
  4346. waiting: 'Warte auf SpoolBuddy...',
  4347. writeSuccess: 'Tag erfolgreich beschrieben!',
  4348. writeFailed: 'Schreiben fehlgeschlagen',
  4349. queueFailed: 'Schreibbefehl konnte nicht eingereiht werden',
  4350. tryAgain: 'Erneut versuchen',
  4351. cancel: 'Abbrechen',
  4352. replaceWarning: 'Alter Tag wird getrennt. Neuer Tag ersetzt ihn.',
  4353. deviceOffline: 'SpoolBuddy ist offline',
  4354. material: 'Material',
  4355. colorName: 'Farbname',
  4356. color: 'Farbe',
  4357. brand: 'Marke',
  4358. weight: 'Gewicht (g)',
  4359. createSpool: 'Spule erstellen',
  4360. creating: 'Wird erstellt...',
  4361. spoolCreated: 'Spule erstellt! Bereit zum Schreiben.',
  4362. createFailed: 'Spule konnte nicht erstellt werden',
  4363. },
  4364. },
  4365. bugReport: {
  4366. title: 'Fehler melden',
  4367. description: 'Beschreibung',
  4368. descriptionPlaceholder: 'Was ist schiefgelaufen? Bitte beschreiben Sie das Problem...',
  4369. email: 'E-Mail (optional)',
  4370. emailPlaceholder: 'ihre@email.de',
  4371. emailPrivacy: 'Falls angegeben, wird Ihre E-Mail in einem eingeklappten Abschnitt des GitHub-Issues aufgeführt, damit der Betreuer sich melden kann.',
  4372. screenshot: 'Screenshot',
  4373. uploadOrPaste: 'Bild hochladen, einfügen oder ziehen',
  4374. dataCollectedSummary: 'Welche Daten werden im Bericht gesendet?',
  4375. dataIncluded: 'Enthalten:',
  4376. dataIncludedList: 'App-Version, Betriebssystem, Architektur, Python-Version, Datenbankstatistiken (nur Anzahl), Druckermodelle, Düsenanzahl, Firmware-Versionen, Verbindungsstatus, Integrationsstatus (Spoolman, MQTT, HA), nicht-sensible Einstellungen, Netzwerkschnittstellenanzahl, Docker-Details, Abhängigkeitsversionen.',
  4377. dataNeverIncluded: 'Nie enthalten:',
  4378. dataNeverIncludedList: 'Druckernamen, Seriennummern, Zugangscodes, Passwörter, IP-Adressen, E-Mail-Adressen, API-Schlüssel, Tokens, Webhook-URLs, Hostnamen oder Benutzernamen.',
  4379. submit: 'Absenden',
  4380. collectingLogs: 'Diagnoseprotokolle werden gesammelt...',
  4381. collectingLogsHint: 'Debug-Protokollierung aktiviert, Drucker werden nach aktuellen Daten abgefragt.',
  4382. submitting: 'Fehlerbericht wird gesendet...',
  4383. submitSuccess: 'Fehlerbericht erfolgreich gesendet!',
  4384. submitFailed: 'Fehlerbericht konnte nicht gesendet werden',
  4385. thankYou: 'Vielen Dank!',
  4386. submitted: 'Ihr Fehlerbericht wurde eingereicht.',
  4387. viewIssue: 'Issue ansehen',
  4388. unexpectedError: 'Ein unerwarteter Fehler ist aufgetreten',
  4389. countdownSeconds: '{{seconds}}s',
  4390. },
  4391. };