it.ts 256 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858
  1. export default {
  2. // Navigation
  3. nav: {
  4. printers: 'Stampanti',
  5. archives: 'Archivi',
  6. queue: 'Coda di stampa',
  7. stats: 'Statistiche',
  8. profiles: 'Profili',
  9. maintenance: 'Manutenzione',
  10. projects: 'Progetti',
  11. inventory: 'Filamento',
  12. files: 'File',
  13. makerworld: 'MakerWorld',
  14. notifications: 'Notifiche',
  15. settings: 'Impostazioni',
  16. system: 'Sistema',
  17. collapseSidebar: 'Comprimi barra laterale',
  18. expandSidebar: 'Espandi barra laterale',
  19. update: 'Aggiorna',
  20. updateAvailable: 'Aggiornamento disponibile: v{{version}}',
  21. updateAvailableBanner: 'Versione {{version}} disponibile!',
  22. viewUpdate: 'Vedi aggiornamento',
  23. viewOnGithub: 'Vedi su GitHub',
  24. keyboardShortcuts: 'Scorciatoie da tastiera (?)',
  25. switchToLight: 'Passa a tema chiaro',
  26. switchToDark: 'Passa a tema scuro',
  27. smartSwitches: 'Interruttori Smart',
  28. logout: 'Esci',
  29. },
  30. // Common
  31. common: {
  32. save: 'Salva',
  33. saving: 'Salvataggio...',
  34. cancel: 'Annulla',
  35. delete: 'Elimina',
  36. edit: 'Modifica',
  37. add: 'Aggiungi',
  38. close: 'Chiudi',
  39. confirm: 'Conferma',
  40. loading: 'Caricamento...',
  41. error: 'Errore',
  42. errorLoading: 'Errore di caricamento',
  43. retry: 'Riprova',
  44. success: 'Successo',
  45. warning: 'Avviso',
  46. enabled: 'Abilitato',
  47. disabled: 'Disabilitato',
  48. yes: 'Si',
  49. no: 'No',
  50. on: 'On',
  51. off: 'Spento',
  52. all: 'Tutti',
  53. none: 'Nessuno',
  54. search: 'Cerca',
  55. filter: 'Filtro',
  56. sort: 'Ordina',
  57. refresh: 'Aggiorna',
  58. download: 'Scarica',
  59. upload: 'Carica',
  60. uploading: 'Caricamento...',
  61. uploadFailed: 'Caricamento fallito',
  62. actions: 'Azioni',
  63. status: 'Stato',
  64. name: 'Nome',
  65. description: 'Descrizione',
  66. date: 'Data',
  67. time: 'Ora',
  68. hours: 'ore',
  69. minutes: 'minuti',
  70. seconds: 'secondi',
  71. days: 'giorni',
  72. enable: 'Abilita',
  73. disable: 'Disabilita',
  74. permissions: 'Permessi',
  75. noPrinters: 'Nessuna stampante configurata',
  76. noData: 'Nessun dato disponibile',
  77. linkNotFound: 'Link non trovato',
  78. required: 'Obbligatorio',
  79. optional: 'Opzionale',
  80. dismiss: 'Chiudi',
  81. apply: 'Applica',
  82. reset: 'Reimposta',
  83. export: 'Esporta',
  84. import: 'Importa',
  85. clear: 'Pulisci',
  86. selectAll: 'Seleziona tutto',
  87. deselectAll: 'Deseleziona tutto',
  88. noChange: '— Nessun cambio —',
  89. unchanged: 'Invariato',
  90. unassigned: 'Non assegnato',
  91. unknown: 'Sconosciuto',
  92. unknownError: 'Errore sconosciuto',
  93. today: 'Oggi',
  94. tomorrow: 'Domani',
  95. asap: 'ASAP',
  96. overdue: 'Scaduto',
  97. now: 'Ora',
  98. collapse: 'Comprimi',
  99. expand: 'Espandi',
  100. viewArchive: 'Vedi archivio',
  101. viewInFileManager: 'Vedi nel Gestore file',
  102. addedBy: 'Aggiunto da {{username}}',
  103. prints: 'stampe',
  104. more: '+{{count}} altre',
  105. ascending: 'Crescente',
  106. descending: 'Decrescente',
  107. back: 'Indietro',
  108. copy: 'Copia',
  109. copied: 'Copiato!',
  110. printer: 'Stampante',
  111. remove: 'Rimuovi',
  112. type: 'Tipo',
  113. print: 'Stampa',
  114. rename: 'Rinomina',
  115. move: 'Sposta',
  116. create: 'Crea',
  117. duplicate: 'Duplica',
  118. left: 'Sinistra',
  119. right: 'Destra',
  120. },
  121. // Printers page
  122. printers: {
  123. title: 'Stampanti',
  124. addPrinter: 'Aggiungi Stampante',
  125. editPrinter: 'Modifica Stampante',
  126. deletePrinter: 'Elimina Stampante',
  127. printerName: 'Nome Stampante',
  128. serialNumber: 'Numero Seriale',
  129. ipAddress: 'Indirizzo IP',
  130. accessCode: 'Codice di Accesso',
  131. model: 'Modello',
  132. nozzleCount: 'Numero Ugelli',
  133. autoArchive: 'Auto Archiviazione',
  134. status: {
  135. available: 'Disponibile',
  136. idle: 'Inattiva',
  137. printing: 'In stampa',
  138. paused: 'In pausa',
  139. offline: 'Offline',
  140. problem: 'Problema',
  141. error: 'Errore',
  142. finished: 'Finita',
  143. unknown: 'Sconosciuto',
  144. },
  145. temperatures: {
  146. nozzle: 'Ugello',
  147. bed: 'Piatto',
  148. chamber: 'Camera',
  149. },
  150. progress: '{{percent}}% completato',
  151. timeRemaining: '{{time}} rimanente',
  152. deleteConfirm: 'Sei sicuro di eliminare "{{name}}"?',
  153. maintenanceOk: 'Manutenzione OK',
  154. maintenanceWarning: '{{count}} avviso',
  155. maintenanceWarning_plural: '{{count}} avvisi',
  156. maintenanceDue: '{{count}} in scadenza',
  157. maintenanceDue_plural: '{{count}} in scadenza',
  158. // Sort options
  159. sort: {
  160. name: 'Nome',
  161. status: 'Stato',
  162. model: 'Modello',
  163. location: 'Posizione',
  164. ascending: 'Ordina crescente',
  165. descending: 'Ordina decrescente',
  166. },
  167. // Card size
  168. cardSize: {
  169. small: 'Schede piccole',
  170. medium: 'Schede medie',
  171. large: 'Schede grandi',
  172. extraLarge: 'Schede extra grandi',
  173. },
  174. // Controls
  175. hideOffline: 'Nascondi offline',
  176. nextAvailable: 'Prossima disponibile',
  177. powerOn: 'Accendi',
  178. offlinePrintersWithPlugs: 'Stampanti offline con smart plug',
  179. noPrintersConfigured: 'Nessuna stampante configurata',
  180. search: 'Cerca stampanti...',
  181. noSearchResults: 'Nessuna stampante corrisponde alla tua ricerca o ai tuoi filtri',
  182. filter: {
  183. allStatuses: 'Tutti gli stati',
  184. allLocations: 'Tutti i luoghi',
  185. },
  186. toolbar: {
  187. filters: 'Filtri',
  188. view: 'Vista',
  189. actions: 'Azioni',
  190. },
  191. // Printer card
  192. readyToPrint: 'Pronta a stampare',
  193. external: 'Esterna',
  194. extL: 'Ext-L',
  195. extR: 'Ext-R',
  196. deleteArchives: 'Elimina archivi stampa',
  197. noLabel: 'Nessuna etichetta',
  198. printPreview: 'Anteprima stampa',
  199. width: 'Larghezza',
  200. height: 'Altezza',
  201. noObjectsFound: 'Nessun oggetto trovato',
  202. objectsLoadedOnPrintStart: 'Gli oggetti sono caricati quando inizia una stampa',
  203. willBeSkipped: 'Verra saltato',
  204. name: 'Nome',
  205. serialCannotBeChanged: 'Il numero seriale non può essere cambiato',
  206. locationHelp: 'Usato per raggruppare stampanti e filtrare i lavori in coda',
  207. // WiFi signal strength
  208. wifiSignal: {
  209. veryWeak: 'Molto debole',
  210. weak: 'Debole',
  211. fair: 'Discreto',
  212. good: 'Buono',
  213. excellent: 'Eccellente',
  214. },
  215. // Maintenance
  216. maintenanceUpToDate: 'Tutta la manutenzione aggiornata - Clicca per vedere',
  217. // Chamber light
  218. chamberLightOn: 'Accendi luce camera',
  219. chamberLightOff: 'Spegni luce camera',
  220. // Files
  221. files: 'File',
  222. browseFiles: 'Sfoglia file stampante',
  223. // Smart plug
  224. autoOffAfterPrint: 'Spegnimento automatico dopo stampa',
  225. autoOffExecuted: 'Spegnimento automatico eseguito - accendi la stampante per reimpostare',
  226. // HMS errors
  227. hmsErrors: 'Errori HMS',
  228. viewHmsErrors: 'Vedi {{count}} errore(i) HMS',
  229. // Actions
  230. resume: 'Riprendi',
  231. pause: 'Pausa',
  232. stop: 'Ferma',
  233. camera: 'Telecamera',
  234. skipObject: 'Salta Oggetto',
  235. reconnect: 'Riconnetti',
  236. forceRefresh: 'Forza aggiornamento',
  237. forceRefreshSuccess: 'Aggiornamento richiesto',
  238. mqttDebug: 'Debug MQTT',
  239. printerInformation: 'Informazioni stampante',
  240. copyToClipboard: 'Copia',
  241. copied: 'Copiato!',
  242. state: 'Stato',
  243. wifiSignalLabel: 'Segnale WiFi',
  244. developerMode: 'Modalità sviluppatore',
  245. enabled: 'Attivato',
  246. disabled: 'Disattivato',
  247. addedOn: 'Aggiunta il',
  248. sdCard: 'Scheda SD',
  249. inserted: 'Inserita',
  250. notInserted: 'Non inserita',
  251. totalPrintHours: 'Ore di stampa',
  252. activeNozzle: 'Attivo: ugello {{nozzle}}',
  253. nozzleRack: 'Rack Ugelli',
  254. nozzleDocked: 'Agganciato',
  255. nozzleMounted: 'Montato',
  256. nozzleActive: 'Attivo',
  257. nozzleIdle: 'Inattivo',
  258. nozzleDiameter: 'Diametro',
  259. nozzleType: 'Tipo',
  260. nozzleStatus: 'Stato',
  261. nozzleFilament: 'Filamento',
  262. nozzleWear: 'Usura',
  263. nozzleMaxTemp: 'Temp Max',
  264. nozzleSerial: 'Seriale',
  265. nozzleHardenedSteel: 'Acciaio Temprato',
  266. nozzleStainlessSteel: 'Acciaio Inox',
  267. nozzleTungstenCarbide: 'Carburo di Tungsteno',
  268. nozzleFlow: 'Flusso',
  269. nozzleHighFlow: 'Alto Flusso',
  270. nozzleStandardFlow: 'Standard',
  271. // Firmware
  272. firmwareUpdate: 'Aggiornamento Firmware',
  273. firmwareInstructions: 'Sul touchscreen della stampante, vai a',
  274. firmwareNav: 'Vai a',
  275. settings: 'Impostazioni',
  276. firmware: 'Firmware',
  277. // Discovery
  278. discoverPrinters: 'Trova Stampanti',
  279. searching: 'Ricerca...',
  280. manualEntry: 'Inserimento manuale',
  281. addFromCloud: 'Aggiungi da Cloud',
  282. // Toast messages
  283. toast: {
  284. printerDeleted: 'Stampante eliminata',
  285. missingSpoolAssignment: 'Stampa avviata su {{printer}}. Mancano assegnazioni bobina per: {{slots}}',
  286. printerAdded: 'Stampante aggiunta',
  287. printerUpdated: 'Stampante aggiornata',
  288. failedToDelete: 'Impossibile eliminare stampante',
  289. failedToAdd: 'Impossibile aggiungere stampante',
  290. connectionFailedNotAdded: 'Impossibile connettersi alla stampante. Verifica IP, numero di serie e codice di accesso e conferma che la modalità solo LAN sia attiva. La stampante non è stata aggiunta.',
  291. failedToUpdate: 'Impossibile aggiornare stampante',
  292. commandSent: 'Comando inviato',
  293. failedToSendCommand: 'Impossibile inviare comando',
  294. turnedOn: '{{name}} accesa',
  295. failedToPowerOn: 'Impossibile accendere {{name}}',
  296. scriptTriggered: 'Script avviato',
  297. printStopped: 'Stampa fermata',
  298. printPaused: 'Stampa in pausa',
  299. printResumed: 'Stampa ripresa',
  300. referenceDeleted: 'Riferimento eliminato',
  301. detectionAreaSaved: 'Area rilevamento salvata',
  302. failedToRunScript: 'Impossibile eseguire script',
  303. failedToStopPrint: 'Impossibile fermare stampa',
  304. failedToPausePrint: 'Impossibile mettere in pausa stampa',
  305. failedToResumePrint: 'Impossibile riprendere stampa',
  306. failedToControlChamberLight: 'Impossibile controllare luce camera',
  307. failedToSetSpeed: 'Impossibile impostare la velocità di stampa',
  308. failedToUpdateSetting: 'Impossibile aggiornare impostazione',
  309. failedToSkipObjects: 'Impossibile saltare oggetti',
  310. failedToRereadRfid: 'Impossibile rileggere RFID',
  311. failedToCheckPlate: 'Impossibile controllare piatto',
  312. failedToUpdateLabel: 'Impossibile aggiornare etichetta',
  313. failedToDeleteReference: 'Impossibile eliminare riferimento',
  314. failedToSaveDetectionArea: 'Impossibile salvare area rilevamento',
  315. plateCheckEnabled: 'Controllo piatto abilitato',
  316. plateCheckDisabled: 'Controllo piatto disabilitato',
  317. calibrationSaved: 'Calibrazione salvata!',
  318. calibrationFailed: 'Calibrazione non riuscita',
  319. rfidRereadInitiated: 'Rilettura RFID avviata',
  320. loadInitiated: 'Caricamento filamento…',
  321. unloadInitiated: 'Scaricamento filamento…',
  322. failedToLoad: 'Caricamento filamento fallito',
  323. failedToUnload: 'Scaricamento filamento fallito',
  324. },
  325. // Connection status
  326. connection: {
  327. connected: 'Connesso',
  328. offline: 'Offline',
  329. },
  330. plateStatus: {
  331. markCleared: 'Segna il piatto come liberato',
  332. cleared: 'Piatto libero',
  333. notCleared: 'Piatto non libero',
  334. inUse: 'Piatto in uso',
  335. },
  336. // Queue info
  337. queue: {
  338. inQueue: '{{count}} stampa in coda',
  339. inQueue_plural: '{{count}} stampe in coda',
  340. },
  341. // Controls section
  342. controls: 'Controlli',
  343. // RFID
  344. rfid: {
  345. reread: 'Rileggi RFID',
  346. },
  347. // AMS load/unload (#891)
  348. ams: {
  349. load: 'Carica',
  350. unload: 'Scarica',
  351. },
  352. bedJog: {
  353. title: 'Muovi il piano di stampa',
  354. bed: 'Piano',
  355. step: 'Passo (mm)',
  356. up: 'Sposta piano su',
  357. down: 'Sposta piano giù',
  358. disabledWhilePrinting: 'Disabilitato durante la stampa',
  359. notHomedTitle: 'Stampante non azzerata',
  360. notHomedMessage: 'La stampante non è stata azzerata dall\'ultima stampa. Esegui prima l\'azzeramento automatico per un posizionamento sicuro (parcheggia la testa di stampa, poi azzera X, Y e Z), oppure muovi comunque — i finecorsa software verranno ignorati.',
  361. homeZ: 'Azzeramento automatico',
  362. moveAnyway: 'Muovi comunque',
  363. homingStarted: 'Azzeramento automatico in corso…',
  364. },
  365. // Permissions
  366. permission: {
  367. noAdd: 'Non hai il permesso di aggiungere stampanti',
  368. noEdit: 'Non hai il permesso di modificare stampanti',
  369. noDelete: 'Non hai il permesso di eliminare stampanti',
  370. noControl: 'Non hai il permesso di controllare stampanti',
  371. noFiles: 'Non hai il permesso di accedere ai file stampante',
  372. noAmsRfid: 'Non hai il permesso di rileggere AMS RFID',
  373. noSmartPlugControl: 'Non hai il permesso di controllare smart plug',
  374. noCamera: 'Non hai il permesso di visualizzare le telecamere',
  375. },
  376. // Add/Edit modal
  377. modal: {
  378. addTitle: 'Aggiungi Stampante',
  379. editTitle: 'Modifica Stampante',
  380. myPrinter: 'La mia Stampante',
  381. selectModel: 'Seleziona modello...',
  382. locationGroup: 'Posizione / Gruppo (opzionale)',
  383. locationPlaceholder: 'es. Officina, Ufficio, Cantina',
  384. autoArchiveLabel: 'Archivia automaticamente stampe completate',
  385. fromPrinterSettings: 'Dalle impostazioni della stampante',
  386. modelOptional: 'Modello (opzionale)',
  387. saveChanges: 'Salva modifiche',
  388. },
  389. // Skip objects
  390. skipObjects: {
  391. tooltip: 'Salta oggetti',
  392. onlyWhilePrinting: 'Salta oggetti (solo durante la stampa)',
  393. requiresMultiple: 'Salta oggetti (richiede 2+ oggetti)',
  394. title: 'Salta Oggetti',
  395. matchIdsInfo: 'Abbina gli ID con il display della stampante',
  396. printerShowsIds: 'Lo schermo mostra gli ID oggetto sul piatto',
  397. skipSelected: 'Salta selezionati',
  398. skipping: 'Saltando...',
  399. noObjectsSelected: 'Nessun oggetto selezionato',
  400. selectObjectsToSkip: 'Seleziona gli oggetti da saltare nella stampa corrente',
  401. skipped: 'saltato',
  402. objectsSkipped: 'Oggetti saltati',
  403. activeCount: '{{count}} attivi',
  404. waitForLayer: 'Attendi il layer 2+ per saltare oggetti (attualmente layer {{layer}})',
  405. skip: 'Salta',
  406. confirmTitle: 'Saltare oggetto?',
  407. confirmMessage: 'Sei sicuro di voler saltare "{{name}}"? Questa azione non può essere annullata.',
  408. },
  409. // Confirm modals
  410. confirm: {
  411. deleteTitle: 'Elimina Stampante',
  412. deleteMessage: 'Sei sicuro di eliminare "{{name}}"? Questo rimuoverà tutte le impostazioni di connessione.',
  413. deleteArchivesNote: 'Tutta la cronologia di stampa sarà eliminata definitivamente.',
  414. keepArchivesNote: 'La cronologia sarà mantenuta ma non più associata a questa stampante.',
  415. stopTitle: 'Ferma Stampa',
  416. stopMessage: 'Sei sicuro di fermare la stampa corrente su "{{name}}"? Questo annullerà il lavoro di stampa.',
  417. stopButton: 'Ferma Stampa',
  418. pauseTitle: 'Pausa Stampa',
  419. pauseMessage: 'Sei sicuro di mettere in pausa la stampa corrente su "{{name}}"?',
  420. pauseButton: 'Pausa Stampa',
  421. resumeTitle: 'Riprendi Stampa',
  422. resumeMessage: 'Sei sicuro di riprendere la stampa su "{{name}}"?',
  423. resumeButton: 'Riprendi Stampa',
  424. powerOnTitle: 'Accendi Stampante',
  425. powerOnMessage: 'Sei sicuro di accendere "{{name}}"?',
  426. powerOnButton: 'Accendi',
  427. powerOffTitle: 'Spegni Stampante',
  428. powerOffMessage: 'Sei sicuro di spegnere "{{name}}"?',
  429. powerOffWarning: 'AVVISO: "{{name}}" sta stampando! Sei sicuro di spegnere? Questo interromperà la stampa e potrebbe danneggiare la stampante.',
  430. powerOffButton: 'Spegni',
  431. haToggleTitle: 'Commuta "{{name}}"',
  432. haToggleMessage: 'Commutare l\'entità Home Assistant {{entity}}? Questo potrebbe spegnere l\'alimentazione se attualmente è accesa.',
  433. haToggleWarning: 'AVVISO: "{{name}}" sta stampando! La commutazione di {{entity}} potrebbe togliere l\'alimentazione e interrompere la stampa. Continuare?',
  434. haToggleButton: 'Commuta',
  435. },
  436. // Bulk actions
  437. bulk: {
  438. select: 'Seleziona',
  439. selectAll: 'Seleziona tutto',
  440. selectByLocation: 'Seleziona per posizione',
  441. selected: '{{count}} selezionato/i',
  442. actions: {
  443. stop: 'Ferma',
  444. pause: 'Pausa',
  445. resume: 'Riprendi',
  446. clearPlate: 'Svuota piano',
  447. clearHMS: 'Cancella notifiche',
  448. },
  449. confirm: {
  450. stopTitle: 'Ferma {{count}} stampe',
  451. stopMessage: 'Questo annullerà le stampe attive su {{count}} stampante/i. Questa azione non può essere annullata.',
  452. stopButton: 'Ferma tutte',
  453. pauseTitle: 'Pausa {{count}} stampe',
  454. pauseMessage: 'Questo metterà in pausa le stampe attive su {{count}} stampante/i.',
  455. pauseButton: 'Pausa tutte',
  456. clearPlateTitle: 'Svuota {{count}} piani di stampa',
  457. clearPlateMessage: 'Questo svuoterà il piano di stampa su {{count}} stampante/i e potrebbe avviare i lavori in coda.',
  458. clearPlateButton: 'Svuota tutti',
  459. },
  460. success: '{{action}} completato su {{count}} stampante/i',
  461. partial: '{{succeeded}} riuscito/i, {{failed}} fallito/i',
  462. noneApplicable: 'Nessuna stampante selezionata è nello stato corretto per questa azione',
  463. selectByState: 'Seleziona per stato',
  464. },
  465. // Discovery
  466. discovery: {
  467. title: 'Trova Stampanti',
  468. searching: 'Ricerca...',
  469. scanning: 'Scansione...',
  470. scanProgress: 'Scansione... {{scanned}}/{{total}}',
  471. foundPrinters: 'Trovate {{count}} stampante(i)',
  472. noPrintersFound: 'Nessuna stampante trovata',
  473. noPrintersFoundSubnet: 'Nessuna stampante trovata nella sottorete specificata.',
  474. noPrintersFoundNetwork: 'Nessuna stampante trovata sulla rete.',
  475. allConfigured: 'Tutte le stampanti trovate sono già configurate.',
  476. alreadyAdded: 'Già aggiunta',
  477. select: 'Seleziona',
  478. manualEntry: 'Inserimento manuale',
  479. addFromCloud: 'Aggiungi da Cloud',
  480. subnetToScan: 'Sottorete da scansionare',
  481. dockerNote: 'Docker rilevato. Inserisci la sottorete della stampante in notazione CIDR. Richiede network_mode: host in docker-compose.yml.',
  482. scanSubnet: 'Scansiona sottorete per stampanti',
  483. discoverNetwork: 'Trova stampanti in rete',
  484. scanningSubnet: 'Scansione sottorete per stampanti Bambu...',
  485. scanningNetwork: 'Scansione rete...',
  486. serialRequired: 'Seriale richiesto',
  487. unknown: 'Sconosciuto',
  488. failedToStart: 'Avvio ricerca non riuscito',
  489. },
  490. // AMS Drying
  491. drying: {
  492. start: 'Avvia essiccazione',
  493. stop: 'Ferma essiccazione',
  494. temperature: 'Temperatura',
  495. duration: 'Durata',
  496. hours: 'ore',
  497. timeRemaining: '{{time}} rimanente',
  498. active: 'Essiccazione',
  499. notSupported: 'Essiccazione non supportata',
  500. powerRequired: 'Collegare l\'alimentatore AMS per abilitare l\'asciugatura',
  501. startingDrying: 'Avvio essiccazione...',
  502. stoppingDrying: 'Arresto essiccazione...',
  503. rotateTray: 'Ruota la bobina durante l\'essiccazione',
  504. },
  505. // Filaments section
  506. filaments: 'Filamenti',
  507. // Camera
  508. openCameraOverlay: 'Apri overlay camera',
  509. openCameraWindow: 'Apri camera in nuova finestra',
  510. // Firmware
  511. firmwareUpdateAvailable: 'Aggiornamento firmware disponibile: {{current}} → {{latest}}',
  512. firmwareUpToDate: 'Firmware {{version}} — Aggiornato',
  513. firmwareUpdateButton: 'Aggiorna',
  514. // Plate detection
  515. plateDetection: {
  516. noPermission: 'Non hai il permesso di aggiornare le stampanti',
  517. enabledClick: 'Controllo piatto abilitato - Clicca per disabilitare',
  518. disabledClick: 'Controllo piatto disabilitato - Clicca per abilitare',
  519. manageCalibration: 'Gestisci calibrazione rilevamento piatto',
  520. calibrationRequired: 'Calibrazione richiesta',
  521. calibrationInstructions: 'Assicurati che il piatto sia <strong>completamente vuoto</strong>, poi clicca Calibra.',
  522. calibrationDescription: 'La calibrazione salva un\'immagine di riferimento del piatto vuoto. I controlli futuri confronteranno con questo riferimento per rilevare oggetti.',
  523. calibrationTip: '<strong>Suggerimento:</strong> Puoi salvare fino a 5 calibrazioni per piatti diversi. Il sistema usa automaticamente la migliore corrispondenza durante il controllo.',
  524. plateEmpty: 'Il piatto sembra vuoto',
  525. objectsDetected: 'Oggetti rilevati sul piatto',
  526. confidence: 'Confidenza',
  527. difference: 'Differenza',
  528. analysisPreview: 'Anteprima analisi:',
  529. analysisLegend: 'Riquadro verde = area rilevamento, overlay rosso = differenze dalla calibrazione',
  530. savedReferences: 'Riferimenti salvati ({{count}}/{{max}})',
  531. deleteReference: 'Elimina riferimento',
  532. labelPlaceholder: 'Etichetta...',
  533. clickToEdit: '{{label}} - Clicca per modificare',
  534. clickToAddLabel: 'Clicca per aggiungere etichetta',
  535. },
  536. // Speed
  537. speed: {
  538. title: 'Velocità di stampa',
  539. silent: 'Silenzioso (50%)',
  540. standard: 'Standard (100%)',
  541. sport: 'Sport (124%)',
  542. ludicrous: 'Ludicrous (166%)',
  543. },
  544. airduct: {
  545. title: 'Modalità condotto d\'aria',
  546. cooling: 'Raffreddamento',
  547. heating: 'Riscaldamento',
  548. },
  549. noSdCard: 'Nessuna SD',
  550. door: {
  551. open: 'Aperta',
  552. closed: 'Chiusa',
  553. },
  554. // Fans
  555. fans: {
  556. partCooling: 'Ventola raffreddamento parte',
  557. auxiliary: 'Ventola ausiliaria',
  558. chamber: 'Ventola camera',
  559. },
  560. // HMS errors
  561. clickToViewHmsErrors: 'Clicca per vedere errori HMS',
  562. estimatedCompletion: 'Tempo completamento stimato',
  563. plateNumber: 'Piastra {{number}}',
  564. slotOptions: 'Opzioni slot',
  565. // AMS hover popup
  566. amsPopup: {
  567. friendlyName: 'Nome AMS',
  568. friendlyNamePlaceholder: 'es. Nome AMS amichevole',
  569. serialNumber: 'Numero di serie',
  570. firmwareVersion: 'Firmware',
  571. save: 'Salva',
  572. clear: 'Cancella',
  573. noEditPermission: 'Non hai il permesso di rinominare le unità AMS',
  574. },
  575. // Firmware modal
  576. firmwareModal: {
  577. title: 'Aggiornamento Firmware',
  578. titleUpToDate: 'Info Firmware',
  579. currentVersion: 'Corrente:',
  580. latestVersion: 'Ultima:',
  581. releaseNotes: 'Note di rilascio',
  582. checkingPrereqs: 'Controllo prerequisiti...',
  583. sdCardReady: 'SD pronta. Clicca sotto per caricare firmware.',
  584. uploadedSuccess: 'Firmware caricato su SD!',
  585. applyInstructions: 'Per applicare l\'aggiornamento sulla stampante:',
  586. step1: 'Sul touchscreen della stampante, vai a <strong>Impostazioni</strong>',
  587. step2: 'Vai a <strong>Firmware</strong>',
  588. step3: 'Seleziona <strong>Aggiorna da SD</strong>',
  589. step4: 'L\'aggiornamento richiede 10-20 minuti',
  590. done: 'Fatto',
  591. starting: 'Avvio...',
  592. uploadFirmware: 'Carica Firmware',
  593. uploadFailed: 'Avvio caricamento fallito: {{error}}',
  594. uploadedToast: 'Firmware caricato! Avvia aggiornamento dal display.',
  595. availableVersions: 'Versioni disponibili',
  596. usable: 'Utilizzabile',
  597. unavailable: 'Non disponibile',
  598. installed: 'Installato',
  599. newerBadge: 'più recente',
  600. olderBadge: 'più vecchio',
  601. currentBadge: 'attuale',
  602. },
  603. accessCodePlaceholder: 'Lascia vuoto per mantenere quello attuale',
  604. // ROI editor
  605. roi: {
  606. title: 'Area di rilevamento (ROI)',
  607. xStart: 'X Inizio',
  608. yStart: 'Y Inizio',
  609. width: 'Larghezza',
  610. height: 'Altezza',
  611. instruction: 'Regola l\'area di rilevamento per focalizzare il piatto. Il riquadro verde mostra l\'area corrente.',
  612. },
  613. developerModeWarning: 'La modalità sviluppatore LAN non è attivata su: {{names}}. Alcune funzionalità potrebbero non funzionare.',
  614. howToEnable: 'Come attivare',
  615. incompatibleFile: 'Questo file è stato preparato per {{slicedFor}}, ma questa stampante è una {{printerModel}}',
  616. dropNotPrintable: 'Solo i file .gcode e .gcode.3mf possono essere stampati',
  617. dropToPrint: 'Rilascia per stampare',
  618. cannotPrint: 'Stampante occupata',
  619. },
  620. // Archives page
  621. archives: {
  622. title: 'Archivi di stampa',
  623. searchPlaceholder: 'Cerca archivi...',
  624. filterByPrinter: 'Filtra per stampante',
  625. filterByStatus: 'Filtra per stato',
  626. sortBy: 'Ordina per',
  627. sortNewest: 'Più recenti',
  628. sortOldest: 'Meno recenti',
  629. sortName: 'Nome',
  630. sortDuration: 'Durata',
  631. sortLargest: 'Più grandi',
  632. sortSmallest: 'Più piccoli',
  633. sortSize: 'Dimensione',
  634. noArchives: 'Nessun archivio trovato',
  635. noArchivesSearch: 'Nessun archivio corrisponde alla ricerca',
  636. originalPrintNotVisible: 'Stampa originale non visibile - prova a rimuovere i filtri',
  637. noArchivesYet: 'Nessun archivio ancora',
  638. prints: 'stampe',
  639. pagination: {
  640. showing: 'Mostrando',
  641. to: 'a',
  642. of: 'di',
  643. show: 'Mostra',
  644. page: 'Pagina',
  645. all: 'Tutti',
  646. },
  647. loadingArchives: 'Caricamento archivi...',
  648. releaseToUpload: 'Rilascia per caricare',
  649. showAll: 'Mostra tutti',
  650. showFavoritesOnly: 'Solo preferiti',
  651. gridView: 'Vista griglia',
  652. listView: 'Vista elenco',
  653. calendarView: 'Vista calendario',
  654. logView: 'Registro stampe',
  655. manageTags: 'Gestisci tag',
  656. showFailedPrints: 'Mostra stampe fallite',
  657. hideFailedPrints: 'Nascondi stampe fallite',
  658. hideDuplicates: 'Nascondi duplicati',
  659. viewOriginalPrint: 'Fai clic per visualizzare la stampa originale (#{{id}})',
  660. printTime: 'Tempo di stampa',
  661. filamentUsed: 'Filamento usato',
  662. cost: 'Costo',
  663. reprint: 'Ristampa',
  664. preview: 'Anteprima',
  665. deleteArchive: 'Elimina archivio',
  666. deleteConfirm: 'Sei sicuro di eliminare questo archivio?',
  667. favorite: 'Preferito',
  668. unfavorite: 'Rimuovi dai preferiti',
  669. viewDetails: 'Vedi dettagli',
  670. status: {
  671. completed: 'Completato',
  672. failed: 'Fallito',
  673. stopped: 'Fermato',
  674. },
  675. toast: {
  676. source3mfAttached: 'Sorgente 3MF allegata: {{filename}}',
  677. failedUploadSource3mf: 'Caricamento sorgente 3MF non riuscito',
  678. source3mfRemoved: 'Sorgente 3MF rimossa',
  679. failedRemoveSource3mf: 'Rimozione sorgente 3MF non riuscita',
  680. f3dAttached: 'F3D allegato: {{filename}}',
  681. failedUploadF3d: 'Caricamento F3D non riuscito',
  682. f3dRemoved: 'F3D rimosso',
  683. failedRemoveF3d: 'Rimozione F3D non riuscita',
  684. timelapseAttached: 'Timelapse allegato: {{filename}}',
  685. timelapseAlreadyAttached: 'Timelapse già allegato',
  686. noMatchingTimelapse: 'Nessun timelapse corrispondente',
  687. failedScanTimelapse: 'Scansione timelapse non riuscita',
  688. failedAttachTimelapse: 'Allegato timelapse non riuscito',
  689. timelapseRemoved: 'Timelapse rimosso',
  690. failedRemoveTimelapse: 'Impossibile rimuovere il timelapse',
  691. timelapseUploaded: 'Timelapse caricato: {{filename}}',
  692. failedUploadTimelapse: 'Impossibile caricare il timelapse',
  693. archiveDeleted: 'Archivio eliminato',
  694. failedDeleteArchive: 'Eliminazione archivio non riuscita',
  695. addedToFavorites: 'Aggiunto ai preferiti',
  696. removedFromFavorites: 'Rimosso dai preferiti',
  697. projectUpdated: 'Progetto aggiornato',
  698. failedUpdateProject: 'Aggiornamento progetto non riuscito',
  699. linkCopied: 'Link copiato negli appunti',
  700. failedCopyLink: 'Copia link non riuscita',
  701. photoDeleted: 'Foto eliminata',
  702. failedDeletePhoto: 'Eliminazione foto non riuscita',
  703. failedDeleteArchives: 'Eliminazione archivi non riuscita',
  704. failedUpdateFavorites: 'Aggiornamento preferiti non riuscito',
  705. exportDownloaded: 'Export scaricato',
  706. exportFailed: 'Export non riuscito',
  707. },
  708. menu: {
  709. print: 'Stampa',
  710. schedule: 'Programma',
  711. openInBambuStudio: 'Apri nello slicer',
  712. slice: 'Slice',
  713. externalLink: 'Link esterno',
  714. viewOnMakerWorld: 'Vedi su MakerWorld',
  715. preview3d: 'Anteprima 3D',
  716. viewTimelapse: 'Vedi Timelapse',
  717. scanForTimelapse: 'Cerca Timelapse',
  718. uploadTimelapse: 'Carica timelapse',
  719. removeTimelapse: 'Rimuovi timelapse',
  720. downloadSource3mf: 'Scarica Sorgente 3MF',
  721. uploadSource3mf: 'Carica Sorgente 3MF',
  722. replaceSource3mf: 'Sostituisci Sorgente 3MF',
  723. removeSource3mf: 'Rimuovi Sorgente 3MF',
  724. uploadF3d: 'Carica F3D',
  725. replaceF3d: 'Sostituisci F3D',
  726. downloadF3d: 'Scarica F3D',
  727. removeF3d: 'Rimuovi F3D',
  728. download: 'Scarica',
  729. copyDownloadLink: 'Copia link download',
  730. qrCode: 'Codice QR',
  731. viewPhotos: 'Vedi foto',
  732. viewPhotosCount: 'Vedi foto ({{count}})',
  733. projectPage: 'Pagina progetto',
  734. addToFavorites: 'Aggiungi ai preferiti',
  735. removeFromFavorites: 'Rimuovi dai preferiti',
  736. edit: 'Modifica',
  737. printLog: 'Registro stampe',
  738. goToProject: 'Vai al progetto: {{name}}',
  739. addToProject: 'Aggiungi al progetto',
  740. removeFromProject: 'Rimuovi dal progetto',
  741. loading: 'Caricamento...',
  742. noProjectsAvailable: 'Nessun progetto disponibile',
  743. searchProjects: 'Cerca progetti…',
  744. select: 'Seleziona',
  745. deselect: 'Deseleziona',
  746. delete: 'Elimina',
  747. },
  748. permission: {
  749. noReprint: 'Non hai il permesso di ristampare questo archivio',
  750. noAddToQueue: 'Non hai il permesso di aggiungere alla coda',
  751. noUpdateArchives: 'Non hai il permesso di aggiornare archivi',
  752. noUploadFiles: 'Non hai il permesso di caricare file',
  753. noDownload: 'Non hai il permesso di scaricare archivi',
  754. noCopyLink: 'Non hai il permesso di copiare link download',
  755. noDelete: 'Non hai il permesso di eliminare questo archivio',
  756. noCreate: 'Non hai il permesso di creare archivi',
  757. },
  758. platePicker: {
  759. title: 'Seleziona la piastra da visualizzare',
  760. hint: 'Questo archivio contiene più piastre. Scegline una da aprire nel visualizzatore GCode.',
  761. plateLabel: 'Piastra {{index}}',
  762. objectCount: '{{count}} oggetto',
  763. objectCount_plural: '{{count}} oggetti',
  764. noGcode: 'Questo archivio non contiene G-code generato da visualizzare. Aprilo prima in Bambu Studio per sezionarlo.',
  765. },
  766. card: {
  767. previousPlate: 'Piatto precedente',
  768. nextPlate: 'Piatto successivo',
  769. plateNumber: 'Piatto {{index}}',
  770. moreOptions: 'Clic destro per altre opzioni',
  771. addToFavorites: 'Aggiungi ai preferiti',
  772. removeFromFavorites: 'Rimuovi dai preferiti',
  773. cancelled: 'annullato',
  774. failed: 'fallito',
  775. duplicate: 'duplicato',
  776. duplicateTitle: 'Questo modello è stato stampato prima',
  777. openSource3mf: 'Apri sorgente 3MF in Bambu Studio (clic destro per altre opzioni)',
  778. downloadF3d: 'Scarica file design Fusion 360',
  779. viewTimelapse: 'Vedi timelapse',
  780. viewPhoto: 'Vedi 1 foto',
  781. viewPhotos: 'Vedi {{count}} foto',
  782. openFolder: 'Apri cartella: {{name}}',
  783. slicedFile: 'File slice - pronto a stampare',
  784. sourceFile: 'Solo file sorgente - nessuna mappatura AMS disponibile',
  785. gcode: 'GCODE',
  786. source: 'SOURCE',
  787. project: 'Progetto: {{name}}',
  788. runsBadge: '{{count}} stampe',
  789. runsBadgeTitle: '{{count}} stampe in totale — {{successful}} riuscite, {{failed}} fallite. Fai clic per vedere il registro completo.',
  790. estimated: 'Stimato: {{time}}',
  791. actual: 'Reale: {{time}}',
  792. accuracy: 'Accuratezza: {{percent}}%',
  793. filament: '{{weight}} g',
  794. layer: '{{count}} strato',
  795. layers: '{{count}} strati',
  796. object: '{{count}} oggetto',
  797. objects: '{{count}} oggetti',
  798. slicedFor: 'Sliced per {{model}}',
  799. uploadedBy: 'Caricato da',
  800. noPermissionReprint: 'Non hai il permesso di ristampare',
  801. noFileForReprint: 'Nessun file 3MF disponibile — il file non è stato scaricato dalla stampante durante la registrazione',
  802. noPermissionEdit: 'Non hai il permesso di modificare archivi',
  803. noPermissionDelete: 'Non hai il permesso di eliminare archivi',
  804. reprint: 'Ristampa',
  805. schedulePrint: 'Programma Stampa',
  806. schedule: 'Programma',
  807. openInBambuStudio: 'Apri nello slicer',
  808. openInBambuStudioToSlice: 'Apri nello slicer per slicing',
  809. slice: 'Slice',
  810. externalLink: 'Link esterno',
  811. makerWorld: 'MakerWorld – {{designer}}',
  812. viewProject: 'Vedi progetto',
  813. noExternalLink: 'Nessun link esterno',
  814. preview3d: 'Anteprima 3D',
  815. download: 'Scarica',
  816. edit: 'Modifica',
  817. delete: 'Elimina',
  818. },
  819. runLog: {
  820. title: 'Registro stampe',
  821. modalTitle: 'Registro stampe — {{name}}',
  822. modalTitleFallback: 'questo archivio',
  823. empty: 'Nessun evento di stampa ancora registrato per questo archivio.',
  824. col: {
  825. date: 'Data',
  826. status: 'Stato',
  827. duration: 'Durata',
  828. filament: 'Filamento',
  829. cost: 'Costo',
  830. },
  831. status: {
  832. completed: 'Completata',
  833. failed: 'Fallita',
  834. cancelled: 'Annullata',
  835. stopped: 'Interrotta',
  836. skipped: 'Saltata',
  837. printing: 'In stampa',
  838. },
  839. },
  840. modal: {
  841. deleteArchive: 'Elimina Archivio',
  842. deleteConfirm: 'Sei sicuro di eliminare "{{name}}"? Questa azione non può essere annullata.',
  843. deleteButton: 'Elimina',
  844. deletePurgeStats: 'Rimuovi anche questa stampa dalle Quick Stats (filamento, tempo, costo, energia)',
  845. removeSource3mf: 'Rimuovi Sorgente 3MF',
  846. removeSource3mfConfirm: 'Sei sicuro di rimuovere il file sorgente 3MF da "{{name}}"? Questo eliminerà il progetto slicer originale.',
  847. removeButton: 'Rimuovi',
  848. removeF3d: 'Rimuovi F3D',
  849. removeF3dConfirm: 'Sei sicuro di rimuovere il file Fusion 360 da "{{name}}"?',
  850. removeTimelapse: 'Rimuovi timelapse',
  851. removeTimelapseConfirm: 'Sei sicuro di voler rimuovere il video timelapse da "{{name}}"?',
  852. timelapse: '{{name}} – Timelapse',
  853. selectTimelapse: 'Seleziona Timelapse',
  854. selectTimelapseDesc: 'Nessun abbinamento automatico trovato. Seleziona il timelapse per questa stampa:',
  855. deleteArchives: 'Elimina Archivi',
  856. deleteArchivesConfirm: 'Sei sicuro di eliminare {{count}} archivio(i)? Questa azione non può essere annullata.',
  857. deleteCount: 'Elimina {{count}}',
  858. },
  859. page: {
  860. title: 'Archivi',
  861. printsCount: '{{filtered}} di {{total}} stampe',
  862. dropFilesHere: 'Rilascia file .3mf qui',
  863. releaseToUpload: 'Rilascia per caricare',
  864. only3mfSupported: 'Solo file .3mf supportati',
  865. close: 'Chiudi',
  866. selected: '{{count}} selezionati',
  867. selectAll: 'Seleziona tutto',
  868. tags: 'Tag',
  869. project: 'Progetto',
  870. favorite: 'Preferito',
  871. delete: 'Elimina',
  872. toggledFavorites: 'Preferiti aggiornati per {{count}} archivio(i)',
  873. failedUpdateFavorites: 'Aggiornamento preferiti non riuscito',
  874. archivesDeleted: '{{count}} archivio(i) eliminati',
  875. failedDeleteArchives: 'Eliminazione archivi non riuscita',
  876. photoDeleted: 'Foto eliminata',
  877. failedDeletePhoto: 'Eliminazione foto non riuscita',
  878. },
  879. list: {
  880. name: 'Nome',
  881. printer: 'Stampante',
  882. date: 'Data',
  883. size: 'Dimensione',
  884. actions: 'Azioni',
  885. hasTimelapse: 'Ha timelapse',
  886. },
  887. log: {
  888. date: 'Data',
  889. printName: 'Nome stampa',
  890. printer: 'Stampante',
  891. user: 'Utente',
  892. status: 'Stato',
  893. duration: 'Durata',
  894. filament: 'Filamento',
  895. allPrinters: 'Tutte le stampanti',
  896. allUsers: 'Tutti gli utenti',
  897. allStatuses: 'Tutti gli stati',
  898. cancelled: 'Annullato',
  899. skipped: 'Saltato',
  900. dateFrom: 'Dal',
  901. dateTo: 'Al',
  902. noEntries: 'Nessuna voce di registro trovata',
  903. showing: '{{count}} di {{total}} voci',
  904. rowsPerPage: 'Righe',
  905. page: 'Pagina',
  906. prev: 'Prec.',
  907. next: 'Succ.',
  908. clearLog: 'Cancella registro',
  909. clearLogTitle: 'Cancella registro stampe',
  910. clearLogConfirm: 'Tutte le voci del registro di stampa verranno eliminate permanentemente. Gli archivi e gli elementi della coda non sono interessati. Questa azione non può essere annullata. Sei sicuro?',
  911. clearLogButton: 'Cancella tutto',
  912. cleared: '{{count}} voci di registro cancellate',
  913. clearFailed: 'Impossibile cancellare il registro stampe',
  914. },
  915. },
  916. // Queue page
  917. queue: {
  918. title: 'Coda di stampa',
  919. subtitle: 'Programma e gestisci i tuoi lavori di stampa',
  920. addToQueue: 'Aggiungi alla coda',
  921. // Print modal
  922. print: 'Stampa',
  923. reprint: 'Ristampa',
  924. schedulePrint: 'Programma Stampa',
  925. editQueueItem: 'Modifica elemento coda',
  926. printToPrinters: 'Stampa su {{count}} Stampanti',
  927. queueToPrinters: 'Metti in coda su {{count}} Stampanti',
  928. queueSelectedPlates: 'Metti in coda {{count}} piastre',
  929. selectAllPlates: 'Seleziona tutte le {{count}} piastre',
  930. deselectAll: 'Deseleziona tutto',
  931. printQueued: 'Stampa in coda',
  932. itemsQueued: '{{count}} elementi in coda',
  933. sending: 'Invio...',
  934. sendingProgress: 'Invio {{current}}/{{total}}...',
  935. adding: 'Aggiunta...',
  936. addingProgress: 'Aggiunta {{current}}/{{total}}...',
  937. savingProgress: 'Salvataggio {{current}}/{{total}}...',
  938. clearQueue: 'Svuota coda',
  939. clearHistory: 'Svuota cronologia',
  940. emptyQueue: 'La coda è vuota',
  941. position: 'Posizione',
  942. scheduledTime: 'Ora programmata',
  943. moveUp: 'Sposta su',
  944. moveDown: 'Sposta giù',
  945. startNow: 'Avvia ora',
  946. printingInProgress: 'Stampa in corso...',
  947. viewArchive: 'Vedi archivio',
  948. viewInFileManager: 'Vedi nel Gestore file',
  949. itemCount: '{{count}} elemento',
  950. itemCount_plural: '{{count}} elementi',
  951. dragToReorder: 'Trascina per riordinare (solo ASAP)',
  952. reorderHint: 'La posizione influisce solo sugli elementi ASAP. Quelli programmati partono all\'orario.',
  953. sjf: {
  954. label: 'SJF',
  955. tooltip: 'Lavoro più breve prima — lo scheduler dà priorità alle stampe più brevi',
  956. },
  957. addedBy: 'Aggiunto da {{name}}',
  958. nextInQueue: 'Prossimo in coda',
  959. clearPlateSuccess: 'Piatto liberato — pronto per la prossima stampa',
  960. plateNumber: 'Piatto {{index}}',
  961. // Batch / quantity
  962. quantity: 'Quantità',
  963. quantityHint: 'Crea {{count}} elementi in coda',
  964. activeBatches: 'Lotti attivi',
  965. batchProgress: '{{completed}} di {{total}} completati',
  966. cancelBatch: 'Annulla rimanenti',
  967. batchCancelled: 'Elementi rimanenti del lotto annullati',
  968. cancelBatchConfirmTitle: 'Annulla lotto',
  969. cancelBatchConfirmMessage: 'Annullare tutti gli elementi in sospeso rimanenti in questo lotto?',
  970. batch: 'Lotto',
  971. // Sections
  972. sections: {
  973. currentlyPrinting: 'In stampa',
  974. queued: 'In coda',
  975. history: 'Cronologia',
  976. },
  977. // Status
  978. status: {
  979. pending: 'In attesa',
  980. waiting: 'In attesa',
  981. printing: 'In stampa',
  982. paused: 'In pausa',
  983. completed: 'Completato',
  984. failed: 'Fallito',
  985. skipped: 'Saltato',
  986. cancelled: 'Annullato',
  987. },
  988. // Summary cards
  989. summary: {
  990. printing: 'In stampa',
  991. queued: 'In coda',
  992. totalTime: 'Tempo totale coda',
  993. totalWeight: 'Peso totale della coda',
  994. history: 'Cronologia',
  995. },
  996. // Filters
  997. filter: {
  998. allPrinters: 'Tutte le stampanti',
  999. unassigned: 'Non assegnato',
  1000. allStatus: 'Tutti gli stati',
  1001. allLocations: 'Tutte le posizioni',
  1002. any: 'Qualsiasi',
  1003. },
  1004. // Sort
  1005. sort: {
  1006. byPosition: 'Ordina per posizione',
  1007. byName: 'Ordina per nome',
  1008. byPrinter: 'Ordina per stampante',
  1009. bySchedule: 'Ordina per programma',
  1010. byDate: 'Ordina per data',
  1011. ascendingOldest: 'Crescente (più vecchi)',
  1012. descendingNewest: 'Decrescente (più recenti)',
  1013. },
  1014. // Badges
  1015. badges: {
  1016. staged: 'In staging',
  1017. requiresPrevious: 'Richiede successo precedente',
  1018. autoPowerOff: 'Spegnimento automatico',
  1019. gcodeInjection: 'G-code',
  1020. },
  1021. // Empty state
  1022. empty: {
  1023. title: 'Nessuna stampa programmata',
  1024. description: 'Programma una stampa dalla pagina Archivi usando l\'opzione "Programma" nel menu contestuale, o trascina i file per iniziare.',
  1025. },
  1026. // Time
  1027. time: {
  1028. asap: 'ASAP',
  1029. overdue: 'Scaduto',
  1030. now: 'Ora',
  1031. lessThanMinute: 'Tra meno di un minuto',
  1032. inMinutes: 'Tra {{count}} min',
  1033. inHours: 'Tra {{count}} ore',
  1034. },
  1035. // Actions
  1036. actions: {
  1037. stopPrint: 'Ferma Stampa',
  1038. startPrint: 'Avvia Stampa',
  1039. requeue: 'Rimetti in coda',
  1040. },
  1041. // Bulk edit
  1042. bulkEdit: {
  1043. title: 'Modifica {{count}} elemento',
  1044. title_plural: 'Modifica {{count}} elementi',
  1045. description: 'Solo le impostazioni modificate saranno applicate agli elementi selezionati.',
  1046. printer: 'Stampante',
  1047. noChange: '— Nessun cambio —',
  1048. queueOptions: 'Opzioni coda',
  1049. staged: 'In staging (avvio manuale)',
  1050. autoPowerOff: 'Spegnimento automatico dopo stampa',
  1051. requirePrevious: 'Richiede successo precedente',
  1052. printOptions: 'Opzioni stampa',
  1053. bedLevelling: 'Livellamento piatto',
  1054. flowCalibration: 'Calibrazione flusso',
  1055. vibrationCalibration: 'Calibrazione vibrazioni',
  1056. layerInspection: 'Controllo primo layer',
  1057. timelapse: 'Timelapse',
  1058. useAms: 'Usa AMS',
  1059. applyChanges: 'Applica modifiche',
  1060. selectAll: 'Seleziona tutto',
  1061. deselectAll: 'Deseleziona tutto',
  1062. selected: '{{count}} selezionati',
  1063. editSelected: 'Modifica selezionati',
  1064. cancelSelected: 'Annulla selezionati',
  1065. },
  1066. // Confirmations
  1067. confirm: {
  1068. cancelTitle: 'Annulla stampa programmata',
  1069. cancelMessage: 'Sei sicuro di annullare "{{name}}"?',
  1070. stopTitle: 'Ferma Stampa',
  1071. stopMessage: 'Sei sicuro di fermare la stampa corrente "{{name}}"? Questo annullerà il lavoro sulla stampante.',
  1072. removeTitle: 'Rimuovi dalla cronologia',
  1073. removeMessage: 'Sei sicuro di rimuovere "{{name}}" dalla cronologia coda?',
  1074. clearHistoryTitle: 'Svuota cronologia',
  1075. clearHistoryMessage: 'Sei sicuro di rimuovere {{count}} elemento(i) dalla cronologia?',
  1076. cancelButton: 'Annulla Stampa',
  1077. stopButton: 'Ferma Stampa',
  1078. thisPrint: 'questa stampa',
  1079. thisItem: 'questo elemento',
  1080. },
  1081. // Toast messages
  1082. toast: {
  1083. cancelled: 'Elemento coda annullato',
  1084. cancelFailed: 'Annullamento non riuscito',
  1085. removed: 'Elemento coda rimosso',
  1086. removeFailed: 'Rimozione non riuscita',
  1087. stopped: 'Stampa fermata',
  1088. stopFailed: 'Impossibile fermare stampa',
  1089. released: 'Stampa rilasciata in coda',
  1090. startFailed: 'Avvio stampa non riuscito',
  1091. reorderFailed: 'Riordino coda non riuscito',
  1092. historyCleared: 'Cancellati {{count}} elementi cronologia',
  1093. clearHistoryFailed: 'Svuotamento cronologia non riuscito',
  1094. updateFailed: 'Aggiornamento elementi non riuscito',
  1095. bulkCancelled: 'Annullati {{count}} elementi',
  1096. bulkCancelFailed: 'Annullamento elementi non riuscito',
  1097. },
  1098. // Timeline view
  1099. timeline: {
  1100. listView: 'Lista',
  1101. timelineView: 'Cronologia',
  1102. unassigned: 'Non assegnato',
  1103. noData: 'Nessuna stampa programmata per questo giorno',
  1104. allDoneBy: 'Tutte le stampe completate entro le {{time}}',
  1105. staged: 'In attesa',
  1106. filterAll: 'Mostra tutto',
  1107. filterPrinting: 'In stampa',
  1108. filterQueued: 'In coda',
  1109. time: {
  1110. anyMoment: 'a momenti',
  1111. minutesLeft: '{{minutes}}m rimanenti',
  1112. hoursLeft: '{{hours}}h rimanenti',
  1113. hoursMinutesLeft: '{{hours}}h {{minutes}}m rimanenti',
  1114. },
  1115. day: {
  1116. previous: 'Giorno precedente',
  1117. next: 'Giorno successivo',
  1118. today: 'Oggi',
  1119. },
  1120. },
  1121. // Permissions
  1122. permissions: {
  1123. noStopPrint: 'Non hai il permesso di fermare stampe',
  1124. noStartPrint: 'Non hai il permesso di avviare stampe',
  1125. noEdit: 'Non hai il permesso di modificare questo elemento coda',
  1126. noCancel: 'Non hai il permesso di annullare questo elemento coda',
  1127. noRequeue: 'Non hai il permesso di rimettere in coda elementi',
  1128. noRemove: 'Non hai il permesso di rimuovere questo elemento coda',
  1129. noClearHistory: 'Non hai il permesso di svuotare tutta la cronologia',
  1130. noEditItems: 'Non hai il permesso di modificare elementi coda',
  1131. noCancelItems: 'Non hai il permesso di annullare elementi coda',
  1132. },
  1133. },
  1134. backgroundDispatch: {
  1135. unknownFile: 'File sconosciuto',
  1136. unknownPrinter: 'Stampante sconosciuta',
  1137. startingPrints: 'Avvio stampe',
  1138. progressSummary: '{{complete}}/{{total}} completati • Inviati: {{dispatched}} • In elaborazione: {{processing}}',
  1139. expandDetails: 'Espandi dettagli dispatch',
  1140. collapseDetails: 'Comprimi dettagli dispatch',
  1141. dismissToast: 'Chiudi notifica dispatch',
  1142. cancelDispatchJob: 'Annulla job dispatch',
  1143. cancel: 'Annulla',
  1144. cancelling: 'Annullamento…',
  1145. awaitingPrinter: 'In attesa della stampante…',
  1146. status: {
  1147. dispatched: 'Inviato',
  1148. processing: 'In elaborazione',
  1149. completed: 'Completato',
  1150. failed: 'Fallito',
  1151. cancelled: 'Annullato',
  1152. },
  1153. toast: {
  1154. cancellingUpload: 'Annullamento upload...',
  1155. cancelled: 'Dispatch annullato',
  1156. cancelFailed: 'Impossibile annullare il dispatch',
  1157. completeWithFailures: 'Dispatch in background completato: {{completed}} riusciti, {{failed}} falliti',
  1158. completeSuccess: 'Dispatch in background completato: {{completed}} riusciti',
  1159. printStartedRemaining: '{{completed}} stampa/e avviata/e, {{remaining}} in invio...',
  1160. },
  1161. },
  1162. // Statistics page
  1163. stats: {
  1164. title: 'Statistiche',
  1165. subtitle: 'Trascina i widget per riordinare. Clicca l\'icona occhio per nascondere.',
  1166. overview: 'Panoramica',
  1167. totalPrints: 'Stampe totali',
  1168. successRate: 'Tasso di successo',
  1169. totalPrintTime: 'Tempo totale di stampa',
  1170. printTime: 'Tempo di stampa',
  1171. totalFilament: 'Filamento totale usato',
  1172. filamentUsed: 'Filamento usato',
  1173. filamentCost: 'Costo filamento',
  1174. totalCost: 'Costo totale',
  1175. energyUsed: 'Energia usata',
  1176. energyCost: 'Costo energia',
  1177. energyWarmingUpTooltip: 'Il tracciamento energia sta ancora raccogliendo snapshot orari. I totali per intervallo diventeranno accurati quando esisterà almeno uno snapshot prima dell’intervallo selezionato. I primi valori potrebbero essere sottostimati.',
  1178. averagePrintTime: 'Tempo medio di stampa',
  1179. printsPerDay: 'Stampe al giorno',
  1180. byPrinter: 'Per stampante',
  1181. printsByPrinter: 'Stampe per stampante',
  1182. byMaterial: 'Per materiale',
  1183. byMonth: 'Per mese',
  1184. last7Days: 'Ultimi 7 giorni',
  1185. last30Days: 'Ultimi 30 giorni',
  1186. last90Days: 'Ultimi 90 giorni',
  1187. allTime: 'Sempre',
  1188. // Widgets
  1189. quickStats: 'Statistiche rapide',
  1190. printActivity: 'Attivita di stampa',
  1191. filamentTypes: 'Tipi di filamento',
  1192. filamentTrends: 'Trend filamento',
  1193. failureAnalysis: 'Analisi guasti',
  1194. timeAccuracy: 'Accuratezza tempo',
  1195. successful: 'Riuscite:',
  1196. failed: 'Fallite:',
  1197. perfectEstimate: '100% = stima perfetta',
  1198. noTimeAccuracyData: 'Nessun dato accuratezza tempo',
  1199. noFilamentData: 'Nessun dato filamento',
  1200. noPrinterData: 'Nessun dato stampante',
  1201. noPrintData: 'Nessun dato stampa',
  1202. noPrintDataLast30Days: 'Nessun dato stampa negli ultimi 30 giorni',
  1203. failureReasons: 'Cause guasto',
  1204. topFailureReasons: 'Cause principali',
  1205. failedPrintsCount: '{{failed}} / {{total}} stampe fallite',
  1206. lastWeekRate: 'Settimana scorsa: {{rate}}%',
  1207. // Actions
  1208. resetLayout: 'Reimposta layout',
  1209. recalculateCosts: 'Ricalcola costi',
  1210. recalculateCostsHint: 'Ricalcola tutti i costi archivi usando i prezzi filamento correnti',
  1211. exportStats: 'Esporta statistiche',
  1212. exportAsCsv: 'Esporta come CSV',
  1213. exportAsExcel: 'Esporta come Excel',
  1214. hiddenCount: '{{count}} Nascosti',
  1215. // Toast
  1216. exportDownloaded: 'Export scaricato',
  1217. exportFailed: 'Export non riuscito',
  1218. layoutReset: 'Layout reimpostato',
  1219. recalculatedCosts: 'Costi ricalcolati per {{count}} archivi',
  1220. recalculateFailed: 'Ricalcolo costi non riuscito',
  1221. // Loading
  1222. loadingStats: 'Caricamento statistiche...',
  1223. // Permissions
  1224. noPermissionResetLayout: 'Non hai il permesso di reimpostare il layout',
  1225. noPermissionRecalculate: 'Non hai il permesso di ricalcolare i costi',
  1226. noPrintDataInRange: 'Nessun dato nel periodo selezionato',
  1227. periodFilament: 'Filamento utilizzato',
  1228. periodCost: 'Costo',
  1229. avgPerPrint: 'Media per stampa',
  1230. usageOverTime: 'Utilizzo nel tempo',
  1231. filamentByWeight: 'Peso',
  1232. printDuration: 'Durata stampa',
  1233. printerUtilization: 'Utilizzo stampante',
  1234. filamentSuccess: 'Successo per materiale',
  1235. printHabits: 'Abitudini di stampa',
  1236. printTimeOfDay: 'Ora di stampa',
  1237. colorDistribution: 'Distribuzione colori',
  1238. noColorData: 'Nessun dato colore disponibile',
  1239. records: 'Record',
  1240. longestPrint: 'Stampa più lunga',
  1241. heaviestPrint: 'Stampa più pesante',
  1242. mostExpensivePrint: 'Più costosa',
  1243. busiestDay: 'Giorno più attivo',
  1244. successStreak: 'Serie di successi',
  1245. streakPrint: 'stampa consecutiva',
  1246. streakPrints: '{{count}} stampe consecutive',
  1247. printerStats: 'Statistiche stampante',
  1248. hours: 'ore',
  1249. avgPrints: 'Media stampe',
  1250. noArchiveData: 'Nessun dato di stampa disponibile',
  1251. filamentByTime: 'Tempo',
  1252. avgWeight: 'Media peso',
  1253. avgTime: 'Media tempo',
  1254. filamentByPrints: 'Stampe',
  1255. timeframe: {
  1256. today: 'Oggi',
  1257. 'this-week': 'Questa settimana',
  1258. 'this-month': 'Questo mese',
  1259. 'last-7': 'Ultimi 7 giorni',
  1260. 'last-30': 'Ultimi 30 giorni',
  1261. 'last-90': 'Ultimi 90 giorni',
  1262. 'this-year': 'Quest\'anno',
  1263. 'all-time': 'Tutto',
  1264. custom: 'Personalizzato',
  1265. from: 'Da',
  1266. to: 'A',
  1267. },
  1268. allUsers: 'Tutti gli utenti',
  1269. noUser: 'Nessun utente (Sistema)',
  1270. filterByUser: 'Filtra per utente',
  1271. },
  1272. // Maintenance page
  1273. maintenance: {
  1274. title: 'Manutenzione',
  1275. overview: 'Panoramica',
  1276. allOk: 'Tutta la manutenzione aggiornata',
  1277. dueCount: '{{count}} elemento in scadenza',
  1278. dueCount_plural: '{{count}} elementi in scadenza',
  1279. warningCount: '{{count}} avviso',
  1280. warningCount_plural: '{{count}} avvisi',
  1281. totalPrintTime: 'Tempo totale di stampa',
  1282. nextMaintenance: 'Prossima manutenzione',
  1283. nothingDue: 'Niente in scadenza',
  1284. tasks: 'Attivita',
  1285. lastPerformed: 'Ultima esecuzione',
  1286. interval: 'Intervallo',
  1287. hoursRemaining: '{{hours}}h rimanenti',
  1288. hoursOverdue: '{{hours}}h in ritardo',
  1289. markDone: 'Segna come fatto',
  1290. performMaintenance: 'Esegui manutenzione',
  1291. history: 'Cronologia',
  1292. noHistory: 'Nessuna cronologia manutenzione',
  1293. editPrintHours: 'Modifica ore stampa',
  1294. currentHours: 'Ore attuali',
  1295. // Tabs
  1296. statusTab: 'Stato',
  1297. settingsTab: 'Impostazioni',
  1298. // Status
  1299. overdueCount: '{{count}} in ritardo',
  1300. dueSoonCount: '{{count}} in scadenza',
  1301. dueSoon: 'In scadenza',
  1302. allGood: 'Tutto ok',
  1303. overdueBy: 'In ritardo di {{duration}}',
  1304. dueIn: 'Scade tra {{duration}}',
  1305. timeLeft: '{{duration}} rimanenti',
  1306. // Duration formats
  1307. day: '1 giorno',
  1308. days: '{{count}} giorni',
  1309. week: '1 settimana',
  1310. weeks: '{{count}} settimane',
  1311. month: '1 mese',
  1312. months: '{{count}} mesi',
  1313. year: '1 anno',
  1314. // Settings
  1315. maintenanceTypes: 'Tipi di manutenzione',
  1316. maintenanceTypesDescription: 'Tipi di sistema e tue attivita personalizzate',
  1317. addCustomType: 'Aggiungi tipo personalizzato',
  1318. restoreDefaults: 'Ripristina attivita predefinite',
  1319. intervalType: 'Tipo intervallo',
  1320. intervalValue: 'Intervallo ({{type}})',
  1321. icon: 'Icona',
  1322. documentationLink: 'Link documentazione (opzionale)',
  1323. assignToPrinters: 'Assegna alle stampanti',
  1324. selectAtLeastOnePrinter: 'Seleziona almeno una stampante',
  1325. addType: 'Aggiungi tipo',
  1326. custom: 'Personalizzato',
  1327. printHours: 'Ore di stampa',
  1328. calendarDays: 'Giorni calendario',
  1329. exampleName: 'es. Sostituisci filtro HEPA',
  1330. viewDocumentation: 'Vedi documentazione',
  1331. timeBasedInterval: 'Intervallo basato sul tempo',
  1332. // Interval overrides
  1333. intervalOverrides: 'Override intervallo',
  1334. intervalOverridesDescription: 'Personalizza intervalli per stampanti specifiche',
  1335. // Printer assignment
  1336. assignedToPrinters: 'Assegnato alle stampanti:',
  1337. noPrintersAssigned: 'Nessuna stampante assegnata',
  1338. addPrinterShort: 'Aggiungi:',
  1339. printersAssignedClick: '{{count}} stampante(i) assegnata - clicca per gestire',
  1340. removeFromPrinter: 'Rimuovi da questa stampante',
  1341. // Types
  1342. types: {
  1343. lubricateCarbonRods: 'Lubrifica aste in carbonio',
  1344. lubricateRails: 'Lubrifica guide lineari',
  1345. cleanNozzle: 'Pulisci ugello/Hotend',
  1346. checkBelts: 'Controlla tensione cinghie',
  1347. cleanBuildPlate: 'Pulisci piatto',
  1348. checkExtruder: 'Controlla ingranaggi estrusore',
  1349. checkCooling: 'Controlla ventole raffreddamento',
  1350. generalInspection: 'Ispezione generale',
  1351. cleanCarbonRods: 'Pulisci aste in carbonio',
  1352. lubricateSteelRods: 'Lubrifica aste in acciaio',
  1353. cleanSteelRods: 'Pulisci aste in acciaio',
  1354. cleanLinearRails: 'Pulisci guide lineari',
  1355. checkPtfeTube: 'Controlla tubo PTFE',
  1356. replaceHepaFilter: 'Sostituisci filtro HEPA',
  1357. replaceCarbonFilter: 'Sostituisci filtro carbone',
  1358. lubricateLeftNozzleRail: 'Lubrifica guida ugello sinistro',
  1359. },
  1360. // Toast
  1361. maintenanceComplete: 'Manutenzione segnata come completata',
  1362. typeUpdated: 'Tipo manutenzione aggiornato',
  1363. typeDeleted: 'Tipo manutenzione eliminato',
  1364. defaultsRestored: 'Ripristinate {{count}} attivita predefinite',
  1365. printHoursUpdated: 'Ore di stampa aggiornate',
  1366. printerAssigned: 'Stampante assegnata',
  1367. printerRemoved: 'Stampante rimossa',
  1368. // Confirmation
  1369. deleteTypeConfirm: 'Eliminare "{{name}}"?',
  1370. deleteSystemTypeTitle: 'Eliminare attività di manutenzione predefinita?',
  1371. deleteSystemTypeMessage: 'Sei sicuro di voler eliminare l\'attività di manutenzione predefinita "{{name}}"?',
  1372. // Permissions
  1373. noPermissionUpdate: 'Non hai il permesso di aggiornare elementi manutenzione',
  1374. noPermissionPerform: 'Non hai il permesso di eseguire manutenzione',
  1375. noPermissionEditTypes: 'Non hai il permesso di modificare tipi manutenzione',
  1376. noPermissionDeleteTypes: 'Non hai il permesso di eliminare tipi manutenzione',
  1377. noPermissionEditHours: 'Non hai il permesso di modificare ore stampa',
  1378. noPermissionRemovePrinter: 'Non hai il permesso di rimuovere assegnazioni stampanti',
  1379. noPermissionAssignPrinter: 'Non hai il permesso di assegnare stampanti',
  1380. noPermissionEditIntervals: 'Non hai il permesso di modificare intervalli',
  1381. // Configure link
  1382. configureSettings: 'Configura tipi e intervalli manutenzione',
  1383. },
  1384. // Settings page
  1385. settings: {
  1386. title: 'Impostazioni',
  1387. general: 'Generale',
  1388. // Tab names
  1389. tabs: {
  1390. general: 'Generale',
  1391. smartPlugs: 'Prese smart',
  1392. notifications: 'Notifiche',
  1393. queue: 'Flusso',
  1394. filament: 'Filamento',
  1395. network: 'Rete',
  1396. apiKeys: 'Chiavi API',
  1397. virtualPrinter: 'Stampante virtuale',
  1398. failureDetection: 'Rilevamento guasti',
  1399. users: 'Utenti',
  1400. backup: 'Backup',
  1401. emailAuth: 'Autenticazione Email',
  1402. ldap: 'LDAP',
  1403. twoFa: 'Autenticazione 2FA',
  1404. oidc: 'SSO / OIDC',
  1405. security: 'Sicurezza',
  1406. spoolbuddy: 'SpoolBuddy',
  1407. },
  1408. ldap: {
  1409. title: 'Autenticazione LDAP',
  1410. enabledDesc: "L'autenticazione LDAP è attiva",
  1411. disabledDesc: "L'autenticazione LDAP è disattivata",
  1412. disabledHint: 'Configura e salva le impostazioni LDAP qui sotto, poi attiva.',
  1413. enabled: 'Autenticazione LDAP attivata',
  1414. disabled: 'Autenticazione LDAP disattivata',
  1415. feature1: 'Gli utenti possono accedere con le credenziali LDAP',
  1416. feature2: "L'account amministratore locale rimane come fallback",
  1417. feature3: 'I gruppi LDAP vengono mappati ai gruppi BamBuddy al login',
  1418. serverConfig: 'Configurazione server LDAP',
  1419. serverUrl: 'URL del server',
  1420. serverUrlHint: 'Usa ldap:// per standard o ldaps:// per connessioni SSL',
  1421. security: 'Sicurezza',
  1422. securityHint: 'StartTLS aggiorna una connessione semplice a TLS. LDAPS usa TLS fin dall\'inizio.',
  1423. bindDn: 'Bind DN (account di servizio)',
  1424. bindPassword: 'Password Bind',
  1425. searchBase: 'Base DN di ricerca',
  1426. userFilter: 'Filtro di ricerca utente',
  1427. userFilterHint: '{username} viene sostituito con il nome utente. Usa (uid={username}) per OpenLDAP.',
  1428. advanced: 'Avanzate',
  1429. autoProvision: 'Provisioning automatico utenti',
  1430. autoProvisionHint: 'Crea automaticamente un account BamBuddy al primo accesso LDAP',
  1431. defaultGroup: 'Gruppo predefinito',
  1432. defaultGroupNone: '— Nessuno (nessun fallback) —',
  1433. defaultGroupHint: 'Gruppo di fallback assegnato quando un utente LDAP si autentica ma non è presente in nessun gruppo LDAP mappato. Lascia vuoto per lasciare gli utenti non mappati senza autorizzazioni.',
  1434. groupMapping: 'Mappatura gruppi (JSON)',
  1435. groupMappingHint: 'Mappa i DN dei gruppi LDAP ai gruppi BamBuddy. Gruppi disponibili: ',
  1436. testConnection: 'Test connessione',
  1437. settingsSaved: 'Impostazioni LDAP salvate',
  1438. errors: {
  1439. serverRequired: "L'URL del server LDAP è obbligatorio",
  1440. searchBaseRequired: 'Il Base DN di ricerca è obbligatorio',
  1441. enableAuthFirst: "Attiva prima l'autenticazione",
  1442. configureLdapFirst: 'Salva prima le impostazioni LDAP',
  1443. },
  1444. },
  1445. // Email settings
  1446. email: {
  1447. smtpSettings: 'Configurazione SMTP',
  1448. smtpHost: 'Server SMTP',
  1449. smtpPort: 'Porta SMTP',
  1450. security: 'Sicurezza',
  1451. authentication: 'Autenticazione',
  1452. username: 'Nome utente',
  1453. password: 'Password',
  1454. fromEmail: 'Email mittente',
  1455. fromName: 'Nome mittente',
  1456. testConnection: 'Testa connessione SMTP',
  1457. testRecipient: 'Email destinatario test',
  1458. sendTest: 'Invia email di test',
  1459. sending: 'Invio...',
  1460. save: 'Salva impostazioni',
  1461. saving: 'Salvataggio...',
  1462. advancedAuth: 'Autenticazione avanzata',
  1463. advancedAuthEnabled: 'L\'autenticazione avanzata è abilitata',
  1464. advancedAuthEnabledDesc: 'Le funzionalità di gestione utenti via email sono attive. I nuovi utenti riceveranno password generate automaticamente via email e potranno reimpostare la password tramite la funzione di recupero.',
  1465. advancedAuthDisabled: 'L\'autenticazione avanzata è disabilitata',
  1466. advancedAuthDisabledDesc: 'Abilita l\'autenticazione avanzata per attivare le funzionalità email per la gestione utenti.',
  1467. enable: 'Abilita',
  1468. disable: 'Disabilita',
  1469. feature1: 'Le password vengono generate automaticamente e inviate via email ai nuovi utenti',
  1470. feature2: 'Gli utenti possono accedere con nome utente o email',
  1471. feature3: 'La funzione di recupero password è disponibile',
  1472. feature4: 'Gli amministratori possono reimpostare le password utente via email',
  1473. // Error messages
  1474. errors: {
  1475. requiredFields: 'Compilare tutti i campi obbligatori',
  1476. usernameRequired: 'Il nome utente è obbligatorio quando l\'autenticazione è abilitata',
  1477. enterTestEmail: 'Inserire un indirizzo email di test',
  1478. smtpServerAndEmail: 'Compilare Server SMTP e Email mittente prima di testare',
  1479. usernamePasswordRequired: 'Nome utente e password sono obbligatori quando l\'autenticazione è abilitata',
  1480. configureSmtpFirst: 'Configurare e testare le impostazioni SMTP prima',
  1481. enableAuthFirst: 'Per utilizzare le funzionalità basate sulla posta elettronica, è necessario prima abilitare l\'autenticazione.',
  1482. },
  1483. // Success messages
  1484. success: {
  1485. settingsSaved: 'Impostazioni SMTP salvate con successo',
  1486. },
  1487. // Security options
  1488. securityOptions: {
  1489. starttls: 'STARTTLS (Porta 587)',
  1490. ssl: 'SSL/TLS (Porta 465)',
  1491. none: 'Nessuna (Porta 25)',
  1492. },
  1493. // Authentication options
  1494. authOptions: {
  1495. enabled: 'Abilitata',
  1496. disabled: 'Disabilitata',
  1497. },
  1498. },
  1499. appearance: 'Aspetto',
  1500. notifications: 'Notifiche',
  1501. smartPlugs: 'Prese smart',
  1502. spoolman: 'Spoolman',
  1503. updates: 'Aggiornamenti',
  1504. language: 'Lingua',
  1505. languageDescription: 'Seleziona la lingua preferita',
  1506. theme: 'Tema',
  1507. themeLight: 'Chiaro',
  1508. themeDark: 'Scuro',
  1509. themeSystem: 'Sistema',
  1510. defaultView: 'Vista predefinita',
  1511. defaultViewDescription: 'Pagina da mostrare all\'apertura dell\'app',
  1512. checkForUpdates: 'Controlla aggiornamenti',
  1513. autoUpdate: 'Aggiornamento automatico',
  1514. currentVersion: 'Versione attuale',
  1515. latestVersion: 'Ultima versione',
  1516. upToDate: 'Sei aggiornato',
  1517. updateAvailable: 'Aggiornamento disponibile',
  1518. // Notifications
  1519. notificationLanguage: 'Lingua notifiche',
  1520. notificationLanguageDescription: 'Lingua per notifiche push',
  1521. bedCooledThreshold: 'Soglia raffreddamento piatto',
  1522. bedCooledThresholdDescription: 'Temperatura sotto la quale il piatto è considerato raffreddato dopo una stampa',
  1523. userNotificationsEnabled: 'Notifiche utente',
  1524. userNotificationsEnabledDescription: "Abilita il menu notifiche utente e le notifiche e-mail per gli eventi di stampa. Richiede l'autenticazione avanzata.",
  1525. userNotificationsDisabledHint: "Abilita l'autenticazione avanzata per usare le notifiche utente.",
  1526. notificationProviders: 'Provider notifiche',
  1527. addProvider: 'Aggiungi provider',
  1528. editProvider: 'Modifica provider',
  1529. providerType: 'Tipo provider',
  1530. testNotification: 'Notifica di test',
  1531. testSuccess: 'Notifica di test inviata',
  1532. testFailed: 'Invio notifica di test fallito',
  1533. quietHours: 'Ore silenziose',
  1534. quietHoursDescription: 'Non disturbare in queste ore',
  1535. quietHoursStart: 'Inizio',
  1536. quietHoursEnd: 'Fine',
  1537. events: {
  1538. title: 'Eventi notifica',
  1539. printStart: 'Stampa avviata',
  1540. printComplete: 'Stampa completata',
  1541. printFailed: 'Stampa fallita',
  1542. printStopped: 'Stampa interrotta',
  1543. printProgress: 'Avanzamento',
  1544. printProgressDescription: 'Notifica al 25%, 50%, 75%',
  1545. printerOffline: 'Stampante offline',
  1546. printerError: 'Errore stampante',
  1547. filamentLow: 'Filamento in esaurimento',
  1548. maintenanceDue: 'Manutenzione dovuta',
  1549. maintenanceDueDescription: 'Notifica quando serve manutenzione',
  1550. },
  1551. // Smart Plugs
  1552. smartPlug: {
  1553. title: 'Prese smart',
  1554. add: 'Aggiungi presa smart',
  1555. edit: 'Modifica presa smart',
  1556. name: 'Nome',
  1557. ipAddress: 'Indirizzo IP',
  1558. linkedPrinter: 'Stampante collegata',
  1559. autoOn: 'Accensione automatica',
  1560. autoOnDescription: 'Accendi all\'avvio stampa',
  1561. autoOff: 'Spegnimento automatico',
  1562. autoOffDescription: 'Spegni dopo il completamento',
  1563. offDelay: 'Ritardo spegnimento',
  1564. offDelayMinutes: 'Minuti dopo la stampa',
  1565. offDelayTemp: 'Quando ugello sotto temperatura',
  1566. currentState: 'Stato attuale',
  1567. turnOn: 'Accendi',
  1568. turnOff: 'Spegni',
  1569. },
  1570. // Filament Tracking Mode
  1571. filamentTracking: 'Tracciamento filamento',
  1572. filamentTrackingDesc: 'Scegli come tracciare le bobine di filamento. Puoi usare l\'inventario integrato o collegare un server Spoolman esterno.',
  1573. filamentChecks: 'Controlli filamento',
  1574. disableFilamentWarnings: 'Disabilita avvisi filamento',
  1575. disableFilamentWarningsDesc: 'Non mostrare avvisi per filamento insufficiente durante la stampa o l\'accodamento',
  1576. preferLowestFilament: 'Preferisci il filamento con meno residuo',
  1577. preferLowestFilamentDesc: 'Quando più bobine corrispondono, usa quella con meno filamento rimanente',
  1578. trackingModeBuiltIn: 'Inventario integrato',
  1579. trackingModeBuiltInDesc: 'Riconoscimento RFID automatico e tracciamento dell\'uso inclusi',
  1580. trackingModeSpoolmanDesc: 'Server esterno per la gestione del filamento',
  1581. builtInFeatureRfid: 'Rileva automaticamente le bobine Bambu Lab RFID nell\'AMS',
  1582. builtInFeatureUsage: 'Traccia il consumo di filamento per stampa',
  1583. builtInFeatureCatalog: 'Gestisci bobine, colori e profili K-factor',
  1584. builtInFeatureThirdParty: 'Le bobine di terze parti possono essere assegnate alle bobine dell\'inventario',
  1585. amsSyncButton: 'Sincronizza pesi dall\'AMS',
  1586. amsSyncTitle: 'Sincronizza pesi bobine dall\'AMS',
  1587. amsSyncMessage: 'Questo sovrascriverà tutti i pesi delle bobine dell\'inventario con i valori attuali di percentuale rimanente dell\'AMS dalle stampanti connesse. Usa questa funzione per recuperare dati di peso corrotti. Le stampanti devono essere online.',
  1588. amsSyncing: 'Sincronizzazione...',
  1589. amsSyncSuccess: '{{synced}} bobina/e sincronizzata/e, {{skipped}} saltata/e',
  1590. amsSyncError: 'Impossibile sincronizzare i pesi dall\'AMS',
  1591. spoolmanAmsSyncButton: 'Sincronizza i pesi Spoolman dall\'AMS',
  1592. spoolmanAmsSyncTitle: 'Sincronizza i pesi delle bobine Spoolman dall\'AMS',
  1593. spoolmanAmsSyncMessage: 'Questo aggiornerà i pesi di tutte le bobine Spoolman in base ai valori di riempimento AMS correnti delle stampanti connesse. Le stampanti devono essere online.',
  1594. spoolmanAmsSyncing: 'Sincronizzazione...',
  1595. spoolmanAmsSyncSuccess: '{{synced}} bobina/e sincronizzata/e, {{skipped}} saltata/e',
  1596. spoolmanAmsSyncError: 'Impossibile sincronizzare i pesi Spoolman dall\'AMS',
  1597. spoolmanAmsSyncErrorUnreachable: 'Sincronizzazione fallita (Spoolman non raggiungibile)',
  1598. spoolmanAmsSyncErrorNotConfigured: 'Sincronizzazione fallita (Spoolman non configurato)',
  1599. spoolmanNotConfigured: 'Spoolman non configurato',
  1600. // Spoolman filament catalog section in spool catalog settings
  1601. spoolmanFilamentCatalogTitle: 'Catalogo filamenti Spoolman',
  1602. spoolmanFilamentCatalogDesc: 'Nomi dei filamenti e pesi tara dalla tua istanza Spoolman. Nome e peso bobina sono modificabili qui; tutte le altre proprietà sono gestite direttamente in Spoolman.',
  1603. // Spoolman settings
  1604. spoolmanUrl: 'URL Spoolman',
  1605. spoolmanUrlHint: 'URL del server Spoolman (es. http://localhost:7912)',
  1606. spoolmanConnected: 'Connesso',
  1607. spoolmanDisconnected: 'Disconnesso',
  1608. status: 'Stato',
  1609. connect: 'Connetti',
  1610. disconnect: 'Disconnetti',
  1611. howSyncWorks: 'Come funziona la sincronizzazione',
  1612. syncInfoRfidOnly: 'Solo le bobine ufficiali Bambu Lab con RFID vengono sincronizzate',
  1613. syncInfoAutoCreate: 'Le nuove bobine vengono create automaticamente in Spoolman alla prima sincronizzazione',
  1614. syncInfoThirdPartySkipped: 'Le bobine non Bambu Lab (terze parti, ricaricate) vengono saltate',
  1615. linkingExistingSpools: 'Collegamento bobine esistenti',
  1616. linkingExistingSpoolsDesc: 'Per collegare le bobine Spoolman esistenti all\'AMS, passa il mouse su uno slot AMS e clicca "Collega a Spoolman".',
  1617. syncMode: 'Modalità sincronizzazione',
  1618. syncModeAuto: 'Automatica',
  1619. syncModeManual: 'Solo manuale',
  1620. syncModeAutoDesc: 'I dati AMS si sincronizzano automaticamente quando vengono rilevate modifiche',
  1621. syncModeManualDesc: 'Sincronizzazione solo quando attivata manualmente',
  1622. syncAmsData: 'Sincronizza dati AMS',
  1623. syncAmsDataDesc: 'Sincronizza manualmente i dati AMS della stampante su Spoolman',
  1624. allPrinters: 'Tutte le stampanti',
  1625. // Default printer
  1626. noDefaultPrinter: 'Nessuna predefinita (chiedi ogni volta)',
  1627. // Sidebar
  1628. sidebarOrder: 'Ordine barra laterale',
  1629. // Camera
  1630. saveThumbnails: 'Salva miniature',
  1631. captureFinishPhoto: 'Acquisisci foto finale',
  1632. noPrintersConfigured: 'Nessuna stampante configurata',
  1633. // Archive settings
  1634. archiveMode: {
  1635. always: 'Crea sempre voce archivio',
  1636. never: 'Non creare mai voce archivio',
  1637. ask: 'Chiedi ogni volta',
  1638. },
  1639. // Updates
  1640. checkForUpdatesLabel: 'Controlla aggiornamenti',
  1641. checkPrinterFirmware: 'Controlla firmware stampante',
  1642. includeBetaUpdates: 'Includi versioni beta',
  1643. includeBetaUpdatesDesc: 'Notifica versioni beta e prerelease durante il controllo aggiornamenti',
  1644. // Queue
  1645. enableRetry: 'Abilita retry',
  1646. // Home Assistant
  1647. homeAssistantDescription: 'Controlla prese smart tramite Home Assistant',
  1648. environmentManagedLabel: '(Gestito dall\'ambiente)',
  1649. autoEnabledViaEnv: 'Abilitato automaticamente tramite variabili d\'ambiente',
  1650. urlFromEnvReadOnly: 'Valore impostato dalla variabile d\'ambiente HA_URL (sola lettura)',
  1651. tokenFromEnvReadOnly: 'Valore impostato dalla variabile d\'ambiente HA_TOKEN (sola lettura)',
  1652. // MQTT
  1653. mqttConnectedTo: 'Connesso a',
  1654. // Prometheus
  1655. prometheusDescription: 'Esponi dati stampante in formato Prometheus',
  1656. // Smart plugs empty state
  1657. noSmartPlugsTitle: 'Nessuna presa smart configurata',
  1658. noSmartPlugsDescription: 'Aggiungi una presa smart Tasmota per monitorare energia e automatizzare il controllo.',
  1659. // Notifications empty state
  1660. noProvidersTitle: 'Nessun provider configurato',
  1661. noProvidersDescription: 'Aggiungi un provider per ricevere avvisi.',
  1662. noTemplatesAvailable: 'Nessun template disponibile. Riavvia il backend per generare i template predefiniti.',
  1663. // API permissions
  1664. apiPermissionView: 'Visualizza stato stampante e coda',
  1665. apiPermissionEdit: 'Aggiungi e rimuovi elementi dalla coda di stampa',
  1666. // API keys
  1667. apiKeysEmptyTitle: 'Nessuna chiave API',
  1668. apiKeysEmptyDescription: 'Crea una chiave API per integrare servizi esterni.',
  1669. // Users
  1670. noUsersFound: 'Nessun utente trovato',
  1671. noGroupsFound: 'Nessun gruppo trovato',
  1672. noGroupsAvailable: 'Nessun gruppo disponibile',
  1673. passwordsDoNotMatch: 'Le password non coincidono',
  1674. systemGroupWarning: 'I nomi dei gruppi di sistema non possono essere modificati',
  1675. // Auth disabled
  1676. authDisabledTitle: 'Autenticazione disabilitata',
  1677. authDisabledFeature1: 'Richiedi accesso per usare il sistema',
  1678. authDisabledFeature2: 'Crea più utenti con permessi basati sui gruppi',
  1679. authDisabledFeature3: 'Controlla accesso con 50+ permessi granulari',
  1680. // User deletion
  1681. userHasCreated: 'Questo utente ha creato:',
  1682. userItemsQuestion: 'Cosa vuoi fare con questi elementi?',
  1683. deleteUserConfirm: 'Sei sicuro di voler eliminare questo utente?',
  1684. actionCannotBeUndone: 'Questa azione non può essere annullata.',
  1685. // Smart plugs
  1686. addFirstSmartPlug: 'Aggiungi la tua prima presa smart',
  1687. // Notifications
  1688. providers: 'Provider',
  1689. log: 'Registro',
  1690. testAll: 'Testa tutto',
  1691. testResults: 'Risultati test',
  1692. testPassedCount: '{{count}} riusciti',
  1693. testFailedCount: '{{count}} falliti',
  1694. messageTemplates: 'Template messaggi',
  1695. messageTemplatesDescription: 'Personalizza i messaggi per ogni evento.',
  1696. // API Keys section
  1697. apiKeys: 'Chiavi API',
  1698. apiKeysDescription: 'Crea chiavi API per integrazioni esterne e webhook.',
  1699. createKey: 'Crea chiave',
  1700. apiKeyCreated: 'Chiave API creata con successo',
  1701. apiKeyCopyWarning: 'Copia questa chiave ora - non verra mostrata di nuovo!',
  1702. useInApiBrowser: 'Usa nel Browser API',
  1703. createNewApiKey: 'Crea nuova chiave API',
  1704. keyName: 'Nome chiave',
  1705. keyNamePlaceholder: 'es., Home Assistant, OctoPrint',
  1706. readStatus: 'Leggi stato',
  1707. readStatusDescription: 'Visualizza stato stampante e coda',
  1708. manageQueue: 'Gestisci coda',
  1709. manageQueueDescription: 'Aggiungi e rimuovi elementi dalla coda di stampa',
  1710. controlPrinter: 'Controlla stampante',
  1711. controlPrinterDescription: 'Metti in pausa, riprendi e ferma stampe',
  1712. cloudAccess: 'Consenti accesso cloud',
  1713. cloudAccessDescription: 'Legge i preset e i filamenti Bambu Cloud per tuo conto. Richiede l\'accesso a Bambu Cloud.',
  1714. cloudBadge: 'Cloud',
  1715. updateEnergyCost: 'Aggiorna prezzo elettricità',
  1716. updateEnergyCostDescription: 'Consenti a questa chiave di inviare in POST un nuovo prezzo elettricità per kWh a /settings/electricity-price. Utile per automazioni Home Assistant a tariffa dinamica (Tibber, Octopus, ecc.). Questo è l\'unico campo di impostazioni scrivibile via API key.',
  1717. energyCostBadge: 'Energia',
  1718. legacyKey: 'Legacy',
  1719. legacyKeyTooltip: 'Creato prima della proprietà per utente; ricreare per accesso cloud',
  1720. unnamedKey: 'Chiave senza nome',
  1721. lastUsed: 'Ultimo uso',
  1722. read: 'Lettura',
  1723. control: 'Controllo',
  1724. createFirstKey: 'Crea la tua prima chiave',
  1725. webhookEndpoints: 'Endpoint webhook',
  1726. webhookApiKeyHint: 'Usa la tua chiave API nell\'header X-API-Key.',
  1727. webhook: {
  1728. getAllStatus: 'Ottieni stato di tutte le stampanti',
  1729. getSpecificStatus: 'Ottieni stato di una stampante',
  1730. addToQueue: 'Aggiungi alla coda di stampa',
  1731. pausePrint: 'Metti in pausa stampa',
  1732. resumePrint: 'Riprendi stampa',
  1733. stopPrint: 'Ferma stampa',
  1734. },
  1735. apiBrowser: 'Browser API',
  1736. apiBrowserDescription: 'Esplora e testa tutti gli endpoint API disponibili.',
  1737. apiKeyForTesting: 'Chiave API per test',
  1738. apiKeyPlaceholder: 'Incolla qui la tua chiave API per testare gli endpoint autenticati...',
  1739. apiKeyHint: 'Questa chiave verra inviata come header X-API-Key.',
  1740. deleteApiKeyTitle: 'Elimina chiave API',
  1741. deleteApiKeyMessage: 'Sei sicuro di voler eliminare questa chiave API? Le integrazioni che la usano non funzioneranno più.',
  1742. deleteKey: 'Elimina chiave',
  1743. // Filament tab
  1744. amsDisplayThresholds: 'Soglie visualizzazione AMS',
  1745. amsThresholdsDescription: 'Configura soglie colore per umidità e temperatura AMS.',
  1746. humidity: 'Umidità',
  1747. goodGreen: 'Buono (verde)',
  1748. fairOrange: 'Discreto (arancione)',
  1749. aboveFairBad: 'Sopra soglia discreta mostra rosso (scarso)',
  1750. fairAlsoDryingThreshold: 'Questa soglia viene usata anche per attivare l\'asciugatura automatica',
  1751. temperature: 'Temperatura',
  1752. goodBlue: 'Buono (blu)',
  1753. aboveFairHot: 'Sopra soglia discreta mostra rosso (caldo)',
  1754. historyRetention: 'Conservazione cronologia',
  1755. keepSensorHistory: 'Mantieni cronologia sensori per',
  1756. historyRetentionDescription: 'I dati più vecchi saranno eliminati automaticamente',
  1757. defaultPrintOptions: 'Opzioni di stampa predefinite',
  1758. defaultPrintOptionsDescription: 'Imposta i valori predefiniti per le opzioni di stampa. Possono essere modificati nella finestra di stampa.',
  1759. defaultBedLevelling: 'Livellamento piatto',
  1760. defaultBedLevellingDesc: 'Livellamento automatico del piatto prima della stampa',
  1761. defaultFlowCali: 'Calibrazione flusso',
  1762. defaultFlowCaliDesc: 'Calibra il flusso di estrusione',
  1763. defaultVibrationCali: 'Calibrazione vibrazioni',
  1764. defaultVibrationCaliDesc: 'Riduce gli artefatti di ringing',
  1765. defaultLayerInspect: 'Ispezione primo strato',
  1766. defaultLayerInspectDesc: 'Ispezione IA del primo strato',
  1767. defaultTimelapse: 'Timelapse',
  1768. defaultTimelapseDesc: 'Registra un video timelapse',
  1769. staggeredStart: 'Avvio scaglionato',
  1770. staggeredStartDescription: 'Dimensione gruppo e intervallo predefiniti per scaglionare avvii di batch multi-stampante. Sovrascrivibili per batch nella finestra di stampa.',
  1771. plateClear: 'Conferma piatto libero',
  1772. requirePlateClear: 'Richiedi conferma piatto libero',
  1773. requirePlateClearDescription: 'Quando questa opzione è abilitata, lo scheduler attende una conferma per stampante che il piatto sia libero prima di avviare le stampe in coda su stampanti con lavori completati. Disabilitandola vengono nascosti anche il badge di stato del piatto e il pulsante "Segna il piatto come liberato" sulle schede stampante.',
  1774. gcodeInjection: 'Iniezione G-code',
  1775. gcodeInjectionDescription: 'Configura G-code personalizzato da iniettare all\'inizio e/o alla fine delle stampe per sistemi di stampa automatica come Farmloop, SwapMod, AutoClear e Printflow 3D. Gli snippet sono configurati per modello di stampante e applicati quando "Inietta G-code" è abilitato su un elemento della coda.',
  1776. gcodeInjectionNoPrinters: 'Nessuna stampante trovata. Aggiungi stampanti per configurare gli snippet G-code.',
  1777. gcodeStartLabel: 'G-code iniziale',
  1778. gcodeEndLabel: 'G-code finale',
  1779. gcodeStartPlaceholder: 'G-code inserito prima dell\'inizio della stampa...',
  1780. gcodeEndPlaceholder: 'G-code aggiunto dopo la fine della stampa...',
  1781. staggerGroupSize: 'Dimensione gruppo',
  1782. staggerGroupSizeHelp: 'Stampanti da avviare simultaneamente per gruppo',
  1783. staggerInterval: 'Intervallo (minuti)',
  1784. staggerIntervalHelp: 'Ritardo tra l\'avvio di ogni gruppo',
  1785. queueDrying: 'Asciugatura automatica',
  1786. queueDryingDescription: 'Asciugare automaticamente il filamento AMS quando la stampante è inattiva tra le stampe in coda. Usa la soglia di umidità sopra.',
  1787. queueDryingEnabled: 'Abilita asciugatura automatica',
  1788. queueDryingEnabledDescription: 'Avvia l\'asciugatura AMS automaticamente quando la stampante è inattiva e l\'umidità supera la soglia',
  1789. queueDryingBlock: 'Attendi completamento asciugatura',
  1790. queueDryingBlockDescription: 'Blocca la coda di stampa fino al completamento dell\'asciugatura. Se disattivato, le stampe hanno priorità.',
  1791. ambientDryingEnabled: 'Asciugatura ambientale',
  1792. ambientDryingEnabledDescription: 'Asciuga automaticamente il filamento sulle stampanti inattive quando l\'umidità supera la soglia, anche senza stampe in coda.',
  1793. dryingPresets: 'Preset di asciugatura',
  1794. dryingPresetsDescription: 'Temperatura e durata per tipo di filamento. AMS 2 Pro usa temperature più basse, AMS-HT supporta temperature più alte.',
  1795. dryingFilament: 'Filamento',
  1796. printModal: 'Modale stampa',
  1797. expandCustomMapping: 'Espandi mapping personalizzato di default',
  1798. expandCustomMappingDescription: 'Quando stampi su più stampanti, mostra mapping AMS per stampante espanso',
  1799. // User management
  1800. authentication: 'Autenticazione',
  1801. authEnabledDescription: 'La tua istanza è protetta con autenticazione',
  1802. authDisabledDescription: 'Abilita per richiedere accesso e gestire utenti',
  1803. authDisabledMessage: 'Abilita autenticazione per creare account, gestire permessi e proteggere la tua istanza Bambuddy.',
  1804. enableAuthentication: 'Abilita autenticazione',
  1805. currentUser: 'Utente corrente',
  1806. changePassword: 'Cambia password',
  1807. admin: 'Amministratore',
  1808. users: 'Utenti',
  1809. addUser: 'Aggiungi utente',
  1810. groups: 'Gruppi',
  1811. addGroup: 'Aggiungi gruppo',
  1812. system: 'Sistema',
  1813. noDescription: 'Nessuna descrizione',
  1814. userCount: '{{count}} utenti',
  1815. permissionCount: '{{count}} permessi',
  1816. createUser: 'Crea utente',
  1817. username: 'Nome utente',
  1818. enterUsername: 'Inserisci nome utente',
  1819. password: 'Password',
  1820. enterPassword: 'Inserisci password',
  1821. passwordRequirements: 'Almeno 8 caratteri, con una maiuscola, una minuscola, una cifra e un carattere speciale.',
  1822. confirmPassword: 'Conferma password',
  1823. confirmPasswordPlaceholder: 'Conferma password',
  1824. // Title tooltips
  1825. viewReleaseOnGitHub: 'Vedi release su GitHub',
  1826. turnAllPlugsOn: 'Accendi tutte le prese',
  1827. turnAllPlugsOff: 'Spegni tutte le prese',
  1828. // Modal: Clear logs
  1829. clearNotificationLogs: 'Cancella log notifiche',
  1830. clearLogsMessage: 'Questo eliminerà definitivamente tutti i log notifiche più vecchi di 30 giorni. Questa azione non può essere annullata.',
  1831. clearLogs: 'Cancella log',
  1832. // Modal: Reset UI
  1833. resetUiPreferences: 'Reimposta preferenze UI',
  1834. resetUiPreferencesMessage: 'Questo reimposterà le preferenze UI ai valori predefiniti: ordine barra laterale, tema, layout dashboard, modalità vista e preferenze ordinamento. Stampanti, archivi e impostazioni server NON saranno modificati. La pagina si ricaricherà dopo la cancellazione.',
  1835. resetPreferences: 'Reimposta preferenze',
  1836. // Modal: Delete group
  1837. deleteGroupTitle: 'Elimina gruppo',
  1838. deleteGroupMessage: 'Sei sicuro di voler eliminare questo gruppo? Gli utenti in questo gruppo perderanno questi permessi.',
  1839. deleteGroup: 'Elimina gruppo',
  1840. // Modal: Disable auth
  1841. disableAuthenticationTitle: 'Disabilita autenticazione',
  1842. disableAuthenticationMessage: 'Sei sicuro di voler disabilitare l\'autenticazione? Questo renderà la tua istanza Bambuddy accessibile senza login. Tutti gli utenti resteranno nel database ma l\'autenticazione sarà disabilitata.',
  1843. disableAuthentication: 'Disabilita autenticazione',
  1844. // Additional settings
  1845. configureBambuddy: 'Configura Bambuddy',
  1846. systemDefault: 'Predefinito di sistema',
  1847. archiveSettings: 'Impostazioni archivio',
  1848. newWindow: 'Nuova finestra',
  1849. embeddedOverlay: 'Overlay incorporato',
  1850. preferredSlicer: 'Slicer preferito',
  1851. preferredSlicerDescription: 'Scegli quale applicazione slicer usare per aprire i file',
  1852. orcaslicerKnownIssuesWarning: 'OrcaSlicer 2.3.2 / 2.4.0-dev hanno bug CLI noti che bloccano lo slicing di molti 3MF creati da Bambu — vedi le issue upstream #12426 (segfault su file multi-estrusore dipinti) e #13386 (rifiuto della validazione rigorosa dei range di parametri). Bambu Studio è raccomandato finché non arrivano le correzioni upstream.',
  1853. useSlicerApi: 'Usa Slicer API',
  1854. useSlicerApiDescription: 'Se attivo, le azioni "Slice" aprono il modale slicer integrato e chiamano il sidecar slicer-API. Se disattivo (predefinito), inoltrano al slicer desktop tramite schema URI.',
  1855. slicerCard: 'Slicer',
  1856. orcaslicerApiUrl: 'OrcaSlicer sidecar URL',
  1857. bambuStudioApiUrl: 'Bambu Studio sidecar URL',
  1858. slicerApiUrlDescription: 'URL del container sidecar slicer-API. Lascia vuoto per usare le variabili d\'ambiente SLICER_API_URL / BAMBU_STUDIO_API_URL.',
  1859. slicerBundles: {
  1860. title: 'Bundle slicer',
  1861. description: 'Importa un Printer Preset Bundle (.bbscfg) esportato da BambuStudio (File → Esporta → Esporta bundle preset → "Printer preset bundle"). Una volta importato, le richieste di slicing possono scegliere preset dal bundle per nome senza ricaricare il triplet di profili JSON.',
  1862. uploadButton: 'Carica bundle',
  1863. uploading: 'Caricamento…',
  1864. loading: 'Caricamento bundle…',
  1865. empty: 'Nessun bundle importato ancora.',
  1866. summary: '{{processCount}} processo · {{filamentCount}} preset filamento',
  1867. delete: 'Elimina',
  1868. uploadSuccess: '{{name}} importato',
  1869. uploadError: 'Caricamento bundle fallito: {{message}}',
  1870. deleteSuccess: 'Bundle rimosso',
  1871. deleteError: 'Eliminazione bundle fallita: {{message}}',
  1872. confirmDeleteTitle: 'Rimuovere questo bundle?',
  1873. confirmDeleteMessage: 'Le richieste di slicing che fanno riferimento a "{{name}}" falliranno fino al re-import del bundle.',
  1874. },
  1875. externalCameras: 'Camere esterne',
  1876. costTracking: 'Tracciamento costi',
  1877. printsOnly: 'Solo stampe',
  1878. totalConsumption: 'Consumo totale',
  1879. dataManagement: 'Gestione dati',
  1880. storageUsage: 'Memoria utilizzata',
  1881. storageUsageDescription: 'Ripartizione della memoria per categoria',
  1882. storageUsageTotal: 'Totale',
  1883. storageUsageErrors: 'Errori',
  1884. storageUsageOtherBreakdown: 'Altro (include risorse statiche, script e file di configurazione)',
  1885. storageUsageSystem: 'Sistema',
  1886. storageUsageData: 'Dati',
  1887. storageUsageUnavailable: 'Informazioni sull\'utilizzo della memoria non disponibili',
  1888. clearNotificationLogsDescription: 'Elimina log notifiche più vecchi di 30 giorni',
  1889. resetUiPreferencesDescription: 'Reimposta ordine barra laterale, tema, modalità vista e preferenze layout. Stampanti, archivi e impostazioni non vengono modificati.',
  1890. enableHomeAssistant: 'Abilita Home Assistant',
  1891. enableMqtt: 'Abilita MQTT',
  1892. useTls: 'Usa TLS',
  1893. enableMetricsEndpoint: 'Abilita endpoint metriche',
  1894. availableMetrics: 'Metriche disponibili',
  1895. editUser: 'Modifica utente',
  1896. deleteUserTitle: 'Elimina utente',
  1897. groupName: 'Nome gruppo',
  1898. // Placeholders
  1899. leaveEmptyForAnonymous: 'Lascia vuoto per anonimo',
  1900. leaveEmptyForNoAuth: 'Lascia vuoto per nessuna autenticazione',
  1901. enterNewPassword: 'Inserisci nuova password',
  1902. confirmNewPassword: 'Conferma nuova password',
  1903. enterGroupName: 'Inserisci nome gruppo',
  1904. enterDescriptionOptional: 'Inserisci descrizione (opzionale)',
  1905. enterCurrentPassword: 'Inserisci password attuale',
  1906. enterNewPasswordMin6: 'Inserisci nuova password (min 6 caratteri)',
  1907. toast: {
  1908. keyCopied: 'Chiave copiata negli appunti',
  1909. copyFailed: 'Copia chiave fallita',
  1910. keyAddedToBrowser: 'Chiave aggiunta al Browser API',
  1911. clearLogsFailed: 'Eliminazione log fallita',
  1912. uiPreferencesReset: 'Preferenze UI reimpostate. Aggiornamento...',
  1913. authDisabled: 'Autenticazione disabilitata con successo',
  1914. authDisableFailed: 'Disabilitazione autenticazione fallita',
  1915. apiKeyCreated: 'Chiave API creata',
  1916. apiKeyDeleted: 'Chiave API eliminata',
  1917. userCreated: 'Utente creato con successo',
  1918. userUpdated: 'Utente aggiornato con successo',
  1919. userDeleted: 'Utente eliminato con successo',
  1920. groupCreated: 'Gruppo creato con successo',
  1921. groupUpdated: 'Gruppo aggiornato con successo',
  1922. groupDeleted: 'Gruppo eliminato con successo',
  1923. fillRequiredFields: 'Compila tutti i campi obbligatori',
  1924. passwordsDoNotMatch: 'Le password non coincidono',
  1925. passwordTooShort: 'La password deve essere di almeno 8 caratteri',
  1926. passwordNeedsUppercase: 'La password deve contenere almeno una lettera maiuscola',
  1927. passwordNeedsLowercase: 'La password deve contenere almeno una lettera minuscola',
  1928. passwordNeedsDigit: 'La password deve contenere almeno una cifra',
  1929. passwordNeedsSpecial: 'La password deve contenere almeno un carattere speciale',
  1930. enterGroupName: 'Inserisci un nome gruppo',
  1931. settingsSaved: 'Impostazioni salvate',
  1932. noPermissionUpdate: 'Non hai il permesso di modificare le impostazioni',
  1933. cameraSettingsSaved: 'Impostazioni camera salvate',
  1934. enterCameraUrl: 'Inserisci un URL camera',
  1935. passwordChanged: 'Password cambiata con successo',
  1936. connectionFailed: 'Connessione fallita',
  1937. testFailed: 'Test fallito',
  1938. cameraConnected: 'Camera connessa{{resolution}}',
  1939. },
  1940. testConnection: 'Testa connessione',
  1941. catalog: {
  1942. spoolCatalog: 'Catalogo bobine',
  1943. spoolCatalogDescription: 'Pesi delle bobine vuote per marca/tipo. Utilizzato per la ricerca automatica del peso quando si aggiungono bobine.',
  1944. searchCatalog: 'Cerca nel catalogo...',
  1945. addNewEntry: 'Aggiungi nuova voce',
  1946. namePlaceholder: 'Nome (es. Bambu Lab - Plastica)',
  1947. weight: 'Peso',
  1948. type: 'Tipo',
  1949. default: 'Predefinito',
  1950. custom: 'Personalizzato',
  1951. noMatch: 'Nessuna voce corrisponde alla ricerca',
  1952. empty: 'Nessuna voce nel catalogo',
  1953. deleteEntry: 'Elimina voce',
  1954. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"?',
  1955. resetCatalog: 'Ripristina catalogo',
  1956. resetConfirm: 'Ripristinare il catalogo ai valori predefiniti? Tutte le voci personalizzate verranno rimosse.',
  1957. loadFailed: 'Impossibile caricare il catalogo bobine',
  1958. nameWeightRequired: 'Nome e peso sono obbligatori',
  1959. entryAdded: 'Voce aggiunta',
  1960. addFailed: 'Impossibile aggiungere la voce',
  1961. entryUpdated: 'Voce aggiornata',
  1962. updateFailed: 'Impossibile aggiornare la voce',
  1963. entryDeleted: 'Voce eliminata',
  1964. deleteFailed: 'Impossibile eliminare la voce',
  1965. resetSuccess: 'Catalogo ripristinato ai valori predefiniti',
  1966. resetFailed: 'Impossibile ripristinare il catalogo',
  1967. exported: '{{count}} voci esportate',
  1968. imported: '{{added}} voci importate ({{skipped}} saltate)',
  1969. importFailed: 'Impossibile importare: formato JSON non valido',
  1970. exportTooltip: 'Esporta catalogo in JSON',
  1971. importTooltip: 'Importa catalogo da JSON',
  1972. resetTooltip: 'Ripristina valori predefiniti',
  1973. selectedCount: '{{count}} selezionati',
  1974. deleteSelected: 'Elimina selezionati',
  1975. bulkDeleteConfirm: 'Eliminare {{count}} voci?',
  1976. bulkDeleted: '{{count}} voci eliminate',
  1977. bulkDeleteFailed: 'Impossibile eliminare le voci',
  1978. material: 'Materiale',
  1979. spoolWeight: 'Peso bobina',
  1980. color: 'Colore',
  1981. updateSpoolWeight: 'Aggiorna peso bobina',
  1982. filamentUpdated: 'Filamento aggiornato',
  1983. filamentUpdateFailed: 'Aggiornamento filamento non riuscito',
  1984. filamentUpdateInvalid: 'Dati filamento non validi',
  1985. keepExistingSpoolWeight: 'Mantieni vecchio peso per le bobine esistenti',
  1986. keepExistingSpoolWeightDesc: 'Le bobine già create con questo tipo di filamento mantengono il vecchio peso tara. Le nuove bobine usano il valore aggiornato.',
  1987. applyToAllSpools: 'Applica a tutte le bobine',
  1988. applyToAllSpoolsDesc: 'Tutti i calcoli del peso per questo tipo di filamento usano immediatamente il nuovo peso tara.',
  1989. },
  1990. colorCatalog: {
  1991. title: 'Catalogo colori',
  1992. description: 'Colori del filamento per produttore/materiale. Utilizzato per la ricerca automatica del colore quando si aggiungono bobine.',
  1993. searchColors: 'Cerca colori...',
  1994. allManufacturers: 'Tutti i produttori',
  1995. addNewColor: 'Aggiungi nuovo colore',
  1996. manufacturer: 'Produttore',
  1997. colorName: 'Nome colore',
  1998. hex: 'Hex',
  1999. materialOptional: 'Materiale (opzionale)',
  2000. showing: 'Visualizzazione di {{filtered}} su {{total}} colori',
  2001. noMatch: 'Nessun colore corrisponde alla ricerca',
  2002. empty: 'Nessun colore nel catalogo',
  2003. deleteColor: 'Elimina colore',
  2004. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"?',
  2005. resetCatalog: 'Ripristina catalogo colori',
  2006. resetConfirm: 'Ripristinare il catalogo ai valori predefiniti? Tutti i colori personalizzati verranno rimossi.',
  2007. sync: 'Sincronizza',
  2008. starting: 'Avvio...',
  2009. syncTooltip: 'Sincronizza da FilamentColors.xyz (2000+ colori, potrebbe richiedere un minuto)',
  2010. loadFailed: 'Impossibile caricare il catalogo colori',
  2011. fieldsRequired: 'Produttore, nome colore e colore hex sono obbligatori',
  2012. colorAdded: 'Colore aggiunto',
  2013. addFailed: 'Impossibile aggiungere il colore',
  2014. colorUpdated: 'Colore aggiornato',
  2015. updateFailed: 'Impossibile aggiornare il colore',
  2016. colorDeleted: 'Colore eliminato',
  2017. deleteFailed: 'Impossibile eliminare il colore',
  2018. resetSuccess: 'Catalogo colori ripristinato ai valori predefiniti',
  2019. resetFailed: 'Impossibile ripristinare il catalogo',
  2020. syncUpToDate: 'Già aggiornato ({{count}} colori verificati)',
  2021. syncComplete: '{{added}} nuovi colori aggiunti ({{skipped}} già esistenti)',
  2022. syncError: 'Errore di sincronizzazione',
  2023. syncFailed: 'Impossibile sincronizzare da FilamentColors.xyz',
  2024. exported: '{{count}} colori esportati',
  2025. imported: '{{added}} colori importati ({{skipped}} saltati)',
  2026. importFailed: 'Impossibile importare: formato JSON non valido',
  2027. selectedCount: '{{count}} selezionati',
  2028. deleteSelected: 'Elimina selezionati',
  2029. bulkDeleteConfirm: 'Eliminare {{count}} colori?',
  2030. bulkDeleted: '{{count}} colori eliminati',
  2031. bulkDeleteFailed: 'Impossibile eliminare i colori',
  2032. },
  2033. dateFormat: 'Formato data',
  2034. dateFormatUs: 'US (MM/GG/AAAA)',
  2035. dateFormatEu: 'EU (GG/MM/AAAA)',
  2036. dateFormatIso: 'ISO (AAAA-MM-GG)',
  2037. timeFormat: 'Formato ora',
  2038. timeFormat12: '12 ore (3:30 PM)',
  2039. timeFormat24: '24 ore (15:30)',
  2040. defaultPrinter: 'Stampante predefinita',
  2041. defaultPrinterDescription: 'Preseleziona questa stampante per upload, ristampe e altre operazioni.',
  2042. slicerBambuStudio: 'Bambu Studio',
  2043. slicerOrcaSlicer: 'OrcaSlicer',
  2044. sidebarOrderDescription: 'Trascina gli elementi nella barra laterale per riordinare. Ripristina l\'ordine predefinito qui.',
  2045. setDefault: 'Imposta predefinito',
  2046. sidebarOrderSetDefaultHint: 'Imposta predefinito applica l\'ordine attuale del menu agli utenti che non hanno ancora personalizzato il proprio.',
  2047. sidebarDefaultSet: 'L\'ordine predefinito del menu è stato impostato.',
  2048. sidebarDefaultCleared: 'Ordine predefinito del menu cancellato.',
  2049. sidebarDefaultFailed: 'Impossibile impostare l\'ordine predefinito del menu.',
  2050. reset: 'Ripristina',
  2051. darkMode: 'Modalità scura',
  2052. lightMode: 'Modalità chiara',
  2053. active: '(attivo)',
  2054. background: 'Sfondo',
  2055. accent: 'Accento',
  2056. style: 'Stile',
  2057. bgNeutral: 'Neutro',
  2058. bgWarm: 'Caldo',
  2059. bgCool: 'Freddo',
  2060. bgOled: 'OLED Nero',
  2061. bgSlate: 'Blu ardesia',
  2062. bgForest: 'Verde foresta',
  2063. accentGreen: 'Verde',
  2064. accentTeal: 'Verde acqua',
  2065. accentBlue: 'Blu',
  2066. accentOrange: 'Arancione',
  2067. accentPurple: 'Viola',
  2068. accentRed: 'Rosso',
  2069. styleClassic: 'Classico',
  2070. styleGlow: 'Luminoso',
  2071. styleVibrant: 'Vibrante',
  2072. themeToggleHint: 'Passa tra modalità scura e chiara con l\'icona sole/luna nella barra laterale.',
  2073. autoArchivePrints: 'Archiviazione automatica stampe',
  2074. autoArchiveDescription: 'Salva automaticamente i file 3MF al completamento delle stampe',
  2075. saveThumbnailsDescription: 'Estrai e salva le immagini di anteprima dai file 3MF',
  2076. captureFinishPhotoDescription: 'Scatta una foto dalla fotocamera della stampante al completamento della stampa',
  2077. ffmpegNotInstalled: 'ffmpeg non installato',
  2078. ffmpegRequired: 'L\'acquisizione dalla fotocamera richiede ffmpeg. Installalo tramite <brew>brew install ffmpeg</brew> (macOS) o <apt>apt install ffmpeg</apt> (Linux).',
  2079. camera: 'Fotocamera',
  2080. cameraViewMode: 'Modalità visualizzazione fotocamera',
  2081. cameraOverlayDescription: 'La fotocamera si apre in un overlay ridimensionabile sulla schermata principale',
  2082. cameraWindowDescription: 'La fotocamera si apre in una finestra separata del browser',
  2083. externalCamerasDescription: 'Configura fotocamere esterne per sostituire la fotocamera integrata della stampante. Supporta stream MJPEG, RTSP, snapshot HTTP e fotocamere USB (V4L2). Quando abilitata, la fotocamera esterna viene usata per la vista in diretta e le foto di completamento.',
  2084. cameraPlaceholderUsb: 'Percorso dispositivo (/dev/video0)',
  2085. cameraPlaceholderUrl: 'URL fotocamera (rtsp://... o http://...)',
  2086. cameraTypeMjpeg: 'Stream MJPEG',
  2087. cameraTypeRtsp: 'Stream RTSP',
  2088. cameraTypeSnapshot: 'Snapshot HTTP',
  2089. cameraTypeUsb: 'Fotocamera USB (V4L2)',
  2090. cameraSnapshotUrl: 'URL istantanea (facoltativo)',
  2091. cameraSnapshotUrlPlaceholder: 'http://192.168.1.61:1984/api/frame.jpeg?src=printer',
  2092. cameraSnapshotUrlHelp: 'URL singolo frame usato per miniature di notifica, foto di fine, frame del layer timelapse e rilevamento del piano. Timelapse e rilevamento del piano richiedono ciascuno il proprio toggle per stampante — questo URL è solo la sorgente immagine che usano quando attivi. Lascia vuoto per acquisire dallo stream live sopra. Utile per go2rtc (/api/frame.jpeg) e telecamere IP con endpoint snapshot dedicato.',
  2093. cameraRotation: 'Rotazione',
  2094. test: 'Test',
  2095. connected: 'Connesso',
  2096. disconnected: 'Disconnesso',
  2097. currency: 'Valuta',
  2098. defaultFilamentCost: 'Costo filamento predefinito (per kg)',
  2099. electricityCost: 'Costo elettricità per kWh',
  2100. energyDisplayMode: 'Modalità visualizzazione energia',
  2101. energyModePrintDescription: 'La dashboard mostra la somma dell\'energia usata durante le stampe',
  2102. energyModeTotalDescription: 'La dashboard mostra l\'energia totale dalle prese smart',
  2103. fileManager: 'Gestore file',
  2104. createArchiveEntry: 'Crea voce archivio durante la stampa',
  2105. createArchiveEntryDescription: 'Quando si stampa dal gestore file, crea opzionalmente una voce di archivio',
  2106. lowDiskSpaceWarning: 'Avviso spazio disco insufficiente',
  2107. lowDiskSpaceDescription: 'Mostra avviso quando lo spazio disco scende sotto questa soglia',
  2108. printerFirmware: 'Firmware stampante',
  2109. checkFirmwareDescription: 'Controlla aggiornamenti firmware da Bambu Lab',
  2110. bambuddySoftware: 'Software Bambuddy',
  2111. autoCheckDescription: 'Controlla automaticamente nuove versioni all\'avvio',
  2112. checkNow: 'Controlla ora',
  2113. updateAvailableVersion: 'Aggiornamento disponibile: v{{version}}',
  2114. releaseNotes: 'Note di rilascio',
  2115. updateViaDocker: 'Aggiorna tramite Docker Compose:',
  2116. updateViaHomeAssistant: 'Gli aggiornamenti sono gestiti dal Supervisor di Home Assistant. Apri Impostazioni → Add-on → Bambuddy in Home Assistant per installare la nuova versione.',
  2117. installUpdate: 'Installa aggiornamento',
  2118. latestVersionRunning: 'Stai usando l\'ultima versione',
  2119. failedToCheckUpdates: 'Controllo aggiornamenti fallito: {{error}}',
  2120. backupRestore: 'Backup e ripristino',
  2121. backupRestoreDescription: 'Esporta/importa impostazioni e configura backup GitHub',
  2122. goToBackup: 'Vai al backup',
  2123. externalUrl: 'URL esterno',
  2124. externalUrlDescription: 'L\'URL esterno dove Bambuddy è accessibile. Usato per immagini di notifica e integrazioni esterne.',
  2125. bambuddyUrl: 'URL Bambuddy',
  2126. externalUrlHint: 'Includi protocollo e porta (es. http://192.168.1.100:8000)',
  2127. ftpRetry: 'Riprova FTP',
  2128. ftpRetryDescription: 'Riprova le operazioni FTP quando il WiFi della stampante è instabile. Si applica a download 3MF, upload stampe, download timelapse e aggiornamenti firmware.',
  2129. autoRetryDescription: 'Riprova automaticamente le operazioni FTP fallite',
  2130. retryAttempts: 'Tentativi di ripetizione',
  2131. retryDelay: 'Ritardo ripetizione',
  2132. connectionTimeout: 'Timeout connessione',
  2133. time_one: '{{count}} volta',
  2134. time_other: '{{count}} volte',
  2135. second_one: '{{count}} secondo',
  2136. second_other: '{{count}} secondi',
  2137. nSeconds: '{{count}} secondi',
  2138. increaseForWeakWifi: 'Aumenta per stampanti con WiFi debole',
  2139. homeAssistant: 'Home Assistant',
  2140. homeAssistantFullDescription: 'Connetti a Home Assistant per controllare le prese smart tramite l\'API REST HA. Supporta entità switch, light, input_boolean e script.',
  2141. homeAssistantUrl: 'URL Home Assistant',
  2142. longLivedAccessToken: 'Token di accesso a lunga durata',
  2143. haTokenHint: 'Crea un token in HA: Profilo → Token di accesso a lunga durata → Crea token',
  2144. connectionSuccessful: 'Connessione riuscita',
  2145. connectionFailed: 'Connessione fallita',
  2146. haConnectionSuccess: 'Connesso con successo a Home Assistant.',
  2147. haConnectionFailed: 'Connessione a Home Assistant fallita.',
  2148. mqttPublishing: 'Pubblicazione MQTT',
  2149. mqttDescription: 'Pubblica eventi BamBuddy su un broker MQTT esterno per l\'integrazione con Node-RED, Home Assistant e altri sistemi di automazione.',
  2150. mqttEnableDescription: 'Pubblica eventi su broker MQTT esterno',
  2151. brokerHostname: 'Hostname broker',
  2152. port: 'Porta',
  2153. usernameOptional: 'Nome utente (opzionale)',
  2154. passwordOptional: 'Password (opzionale)',
  2155. topicPrefix: 'Prefisso topic',
  2156. topicPrefixHint: 'I topic saranno: {{prefix}}/printers/<serial>/status, ecc.',
  2157. prometheusMetrics: 'Metriche Prometheus',
  2158. prometheusEndpointDescription: 'Esponi metriche stampante su <code>/api/v1/metrics</code> per monitoraggio Prometheus/Grafana.',
  2159. bearerTokenOptional: 'Token Bearer (opzionale)',
  2160. bearerTokenHint: 'Se impostato, le richieste devono includere <code>Authorization: Bearer <token></code>',
  2161. metricsConnectionStatus: 'Stato connessione',
  2162. metricsPrinterState: 'Stato stampante (idle/printing/ecc)',
  2163. metricsPrintProgress: 'Progresso stampa 0-100%',
  2164. metricsBedTemp: 'Temperatura piatto',
  2165. metricsNozzleTemp: 'Temperatura ugello',
  2166. metricsPrintsTotal: 'Stampe totali per risultato',
  2167. metricsMore: '...e altro (strati, ventole, coda, consumo filamento)',
  2168. smartPlugsDescription: 'Connetti prese smart (Tasmota o Home Assistant) per automatizzare il controllo dell\'alimentazione e monitorare il consumo energetico delle stampanti.',
  2169. allOn: 'Tutte accese',
  2170. allOff: 'Tutte spente',
  2171. addSmartPlug: 'Aggiungi presa smart',
  2172. energySummary: 'Riepilogo energia',
  2173. currentPower: 'Potenza attuale',
  2174. plugsOnline: '{{reachable}}/{{total}} prese online',
  2175. today: 'Oggi',
  2176. yesterday: 'Ieri',
  2177. total: 'Totale',
  2178. enablePlugsForSummary: 'Abilita le prese per vedere il riepilogo energia',
  2179. addNotificationProvider: 'Aggiungi',
  2180. systemBadge: '(Sistema)',
  2181. creating: 'Creazione...',
  2182. changing: 'Modifica...',
  2183. deleteUserAndItems: 'Elimina utente E i suoi elementi',
  2184. deleteUserKeepItems: 'Elimina utente, mantieni elementi (diventeranno senza proprietario)',
  2185. ok: 'OK',
  2186. // 2FA settings
  2187. twoFa: {
  2188. totpTitle: 'App Authenticator (TOTP)',
  2189. totpDesc: 'Usa un\'app come Google Authenticator, Aegis o Authy.',
  2190. emailOtpTitle: 'OTP via e-mail',
  2191. emailOtpDesc: 'Invia un codice monouso a {{email}} al momento del login.',
  2192. emailOtpNoEmail: 'Aggiungi un indirizzo e-mail al tuo account per abilitare questo metodo.',
  2193. addEmailFirst: 'Il tuo account non ha un indirizzo e-mail. Chiedi a un amministratore di aggiungerne uno.',
  2194. setupTotp: 'Configura app Authenticator',
  2195. setupAuthApp: 'Configura app Authenticator',
  2196. setupInstructions: 'Scansiona il codice QR con la tua app authenticator, poi conferma con un codice.',
  2197. manualEntry: 'Impossibile scansionare? Inserisci questo segreto manualmente:',
  2198. scannedContinue: 'Codice scansionato — continua',
  2199. enterCodeToConfirm: 'Inserisci il codice a 6 cifre dalla tua app authenticator per confermare.',
  2200. activate: 'Attiva',
  2201. disableTotp: 'Disabilita Authenticator',
  2202. disableConfirmHint: 'Inserisci un codice TOTP valido o un codice di backup per disabilitare l\'authenticator.',
  2203. totpDisabled: 'App Authenticator disabilitata.',
  2204. emailOtpEnabled: 'OTP via e-mail abilitato.',
  2205. emailOtpDisabled: 'OTP via e-mail disabilitato.',
  2206. smtpRequired: 'Configura e testa prima le impostazioni SMTP.',
  2207. invalidCode: 'Codice non valido. Riprova.',
  2208. enableEmailOtp: 'Abilita OTP via e-mail',
  2209. disableEmailOtp: 'Disabilita OTP via e-mail',
  2210. emailSetupEnterCode: 'È stato inviato un codice di verifica al tuo indirizzo e-mail. Inseriscilo qui sotto per confermare che possiedi questa casella di posta.',
  2211. verifyAndEnable: 'Verifica e abilita',
  2212. emailDisablePasswordHint: 'Inserisci la password del tuo account per confermare la disabilitazione dell\'OTP via e-mail.',
  2213. passwordPlaceholder: 'Inserisci la tua password',
  2214. backupCodesTitle: 'Salva i tuoi codici di backup',
  2215. backupCodesWarning: 'Conserva questi codici in un posto sicuro. Ogni codice può essere usato una sola volta.',
  2216. backupCodesRemaining: '{{count}} codici di backup rimanenti',
  2217. savedCodes: 'Codici salvati',
  2218. regenBackup: 'Rigenera codici di backup',
  2219. regenBackupHint: 'Inserisci il tuo codice TOTP corrente per generare 10 nuovi codici di backup.',
  2220. newBackupCodes: 'Nuovi codici di backup',
  2221. linkedAccounts: 'Account SSO collegati',
  2222. linkedAccountsDesc: 'Questi provider di identità esterni sono collegati al tuo account.',
  2223. oidcUnlinked: 'Account scollegato.',
  2224. },
  2225. // OIDC provider settings
  2226. oidc: {
  2227. title: 'Provider SSO / OIDC',
  2228. desc: 'Configura provider OpenID Connect per il single sign-on.',
  2229. addProvider: 'Aggiungi provider',
  2230. newProvider: 'Nuovo provider',
  2231. empty: 'Nessun provider OIDC configurato.',
  2232. created: 'Provider creato.',
  2233. updated: 'Provider aggiornato.',
  2234. deleted: 'Provider eliminato.',
  2235. refreshIcon: 'Aggiorna icona',
  2236. removeIcon: 'Rimuovi icona',
  2237. iconRefreshed: 'Icona aggiornata.',
  2238. iconRemoved: 'Icona rimossa.',
  2239. iconFetchFailed: 'Impossibile recuperare l\'icona dall\'URL del provider.',
  2240. deleteTitle: 'Elimina provider',
  2241. deleteMessage: 'Eliminare "{{name}}"? Tutti gli account collegati verranno disconnessi.',
  2242. form: {
  2243. name: 'Nome visualizzato',
  2244. issuerUrl: 'URL emittente',
  2245. clientId: 'ID client',
  2246. clientSecret: 'Client secret',
  2247. scopes: 'Scope',
  2248. iconUrl: 'URL icona (opzionale)',
  2249. enabled: 'Abilitato',
  2250. autoCreate: 'Crea utenti automaticamente',
  2251. autoCreateDesc: 'Crea automaticamente un account locale al primo accesso.',
  2252. autoLink: 'Collega automaticamente gli account esistenti',
  2253. autoLinkDesc: 'Collega gli account locali esistenti tramite email al primo accesso.',
  2254. secretHint: 'lascia vuoto per mantenere',
  2255. secretPlaceholder: 'nuovo segreto',
  2256. emailClaim: 'Claim email',
  2257. emailClaimDesc: "Claim JWT usato come identità email. Usare 'preferred_username' o 'upn' per Azure Entra ID (che non invia email_verified). Usare solo nomi di claim affidabili.",
  2258. emailClaimPlaceholder: 'e-mail',
  2259. emailClaimCustomClaimAutoLinkWarning: 'I claim personalizzati sono sicuri per il collegamento automatico solo se il valore è gestito dal tenant (es. Azure Entra ID upn / preferred_username). Non abilitare il collegamento automatico se il tuo IdP consente agli utenti di auto-assegnare questo claim.',
  2260. requireEmailVerified: 'Richiedi verifica email',
  2261. requireEmailVerifiedDesc: "Accetta il claim email solo se il provider lo contrassegna come verificato.",
  2262. requireEmailVerifiedWarning: 'Attenzione: l\'email sarà accettata senza verifica. Usare solo con provider affidabili.',
  2263. requireEmailVerifiedAutoLink: 'Disabilitare prima il collegamento automatico per modificare questa impostazione.',
  2264. defaultGroup: 'Gruppo predefinito',
  2265. defaultGroupDesc: 'Gruppo assegnato agli utenti creati automaticamente. Ritorno a Viewers se non impostato.',
  2266. defaultGroupViewersFallback: 'Viewers (predefinito)',
  2267. },
  2268. },
  2269. // TODO: translate encryption keys
  2270. encryption: {
  2271. title: 'Stato crittografia MFA',
  2272. enabledFromEnv: 'Crittografia a riposo abilitata (chiave dalla variabile d\'ambiente MFA_ENCRYPTION_KEY)',
  2273. enabledFromFile: 'Crittografia a riposo abilitata (chiave caricata dalla directory dei dati)',
  2274. enabledGenerated: 'Crittografia a riposo abilitata con chiave auto-generata',
  2275. notConfigured: 'Crittografia a riposo non configurata',
  2276. notConfiguredDesc: 'I segreti TOTP e i client_secrets OIDC sono memorizzati in chiaro. Imposta MFA_ENCRYPTION_KEY o riavvia Bambuddy con una directory dati scrivibile per generarne uno automaticamente.',
  2277. allEncrypted: 'Tutti i segreti MFA sono crittografati a riposo.',
  2278. legacyRowsLabel: 'Righe legacy in chiaro',
  2279. encryptedRowsLabel: 'Righe crittografate',
  2280. legacyRowsWarning: 'Rilevate {{count}} righe legacy in chiaro. Salva di nuovo il provider OIDC o re-iscrivi l\'app authenticator dell\'utente per migrare allo storage crittografato.',
  2281. backupHint: 'La chiave generata automaticamente è memorizzata in DATA_DIR/.mfa_encryption_key ed è inclusa nei backup locali ZIP. Mantieni sicuri i tuoi backup o imposta MFA_ENCRYPTION_KEY esplicitamente.',
  2282. decryptionBrokenTitle: 'Chiave di crittografia mancante',
  2283. decryptionBrokenError: '{{count}} record crittografati non possono essere decifrati perché la chiave di crittografia non è più disponibile. Ripristina il precedente MFA_ENCRYPTION_KEY o DATA_DIR/.mfa_encryption_key per recuperare.',
  2284. migrationErrorWarning: "{{count}} riga/righe legacy non sono state ricifrate all'avvio. Controlla i log del server e riavvia Bambuddy per riprovare.",
  2285. },
  2286. spoolbuddy: {
  2287. infoTitle: 'Dispositivi SpoolBuddy',
  2288. infoBody: 'I kiosk SpoolBuddy si registrano automaticamente tramite heartbeat. Annulla la registrazione qui se un dispositivo non è più in uso o se un duplicato obsoleto è rimasto dopo un crash del daemon.',
  2289. duplicatesTitle: '{{count}} dispositivi registrati',
  2290. duplicatesBody: 'Solo il primo dispositivo registrato viene utilizzato dall\'interfaccia kiosk. Se uno di questi è un duplicato obsoleto da un crash, annulla la sua registrazione — un dispositivo online si ri-registrerà al prossimo heartbeat.',
  2291. empty: 'Nessun dispositivo SpoolBuddy registrato.',
  2292. online: 'Online',
  2293. offline: 'Offline',
  2294. unregister: 'Annulla registrazione',
  2295. unregisterSuccess: 'Dispositivo deregistrato',
  2296. unregisterError: 'Deregistrazione non riuscita',
  2297. confirmTitle: 'Annullare la registrazione del dispositivo SpoolBuddy?',
  2298. confirmBody: 'Questo rimuoverà "{{hostname}}" ({{deviceId}}) dal database. Se il dispositivo è online, si ri-registrerà al prossimo heartbeat.',
  2299. ipAddress: 'Indirizzo IP',
  2300. firmware: 'Firmware',
  2301. lastSeen: 'Ultimo rilevamento',
  2302. daemonUptime: 'Uptime del daemon',
  2303. systemUptime: 'Uptime sistema',
  2304. never: 'mai',
  2305. nfc: 'NFC',
  2306. scale: 'Bilancia',
  2307. cpuTemp: 'Temp. CPU',
  2308. memory: 'Memoria',
  2309. disk: 'Disco',
  2310. update: 'Aggiorna',
  2311. updateConfirmTitle: 'Aggiornare il daemon Spoolbuddy?',
  2312. updateConfirmBody: 'Avviare un aggiornamento software su "{{hostname}}"? Il daemon si riavvierà al termine dell\'aggiornamento.',
  2313. restartBrowser: 'Riavvia browser',
  2314. restartBrowserConfirmTitle: 'Riavviare il browser del kiosk?',
  2315. restartBrowserConfirmBody: 'Riavviare il browser del kiosk su "{{hostname}}"? Il display si oscurerà brevemente.',
  2316. restartDaemon: 'Riavvia daemon',
  2317. restartDaemonConfirmTitle: 'Riavviare il daemon Spoolbuddy?',
  2318. restartDaemonConfirmBody: 'Riavviare il daemon Spoolbuddy su "{{hostname}}"? Il dispositivo sarà offline per alcuni secondi.',
  2319. reboot: 'Riavvia',
  2320. rebootConfirmTitle: 'Riavviare il dispositivo?',
  2321. rebootConfirmBody: 'Riavviare "{{hostname}}"? Il dispositivo sarà offline per circa un minuto.',
  2322. shutdown: 'Spegni',
  2323. shutdownConfirmTitle: 'Spegnere il dispositivo?',
  2324. shutdownConfirmBody: 'Spegnere "{{hostname}}"? Sarà necessario un accesso fisico per riaccenderlo.',
  2325. commandConfirm: 'Conferma',
  2326. commandQueued: 'Comando in coda',
  2327. commandError: 'Invio comando non riuscito',
  2328. },
  2329. },
  2330. // Notifications (for push notifications)
  2331. notification: {
  2332. printStarted: {
  2333. title: 'Stampa avviata',
  2334. body: '{{printer}}: {{filename}} ha iniziato a stampare',
  2335. },
  2336. printCompleted: {
  2337. title: 'Stampa completata',
  2338. body: '{{printer}}: {{filename}} completata con successo',
  2339. },
  2340. printFailed: {
  2341. title: 'Stampa fallita',
  2342. body: '{{printer}}: {{filename}} fallita',
  2343. },
  2344. printStopped: {
  2345. title: 'Stampa interrotta',
  2346. body: '{{printer}}: {{filename}} interrotta',
  2347. },
  2348. printProgress: {
  2349. title: 'Avanzamento stampa',
  2350. body: '{{printer}}: {{filename}} al {{percent}}% completamento',
  2351. },
  2352. printerOffline: {
  2353. title: 'Stampante offline',
  2354. body: '{{printer}} e offline',
  2355. },
  2356. printerError: {
  2357. title: 'Errore stampante',
  2358. body: '{{printer}} – {{error}}',
  2359. },
  2360. filamentLow: {
  2361. title: 'Filamento in esaurimento',
  2362. body: '{{printer}}: Filamento in esaurimento',
  2363. },
  2364. maintenanceDue: {
  2365. title: 'Manutenzione dovuta',
  2366. body: '{{printer}}: {{items}} richiedono attenzione',
  2367. },
  2368. },
  2369. // Errors
  2370. errors: {
  2371. generic: 'Qualcosa e andato storto',
  2372. networkError: 'Errore di rete. Controlla la connessione.',
  2373. notFound: 'Non trovato',
  2374. unauthorized: 'Non autorizzato',
  2375. serverError: 'Errore server',
  2376. validationError: 'Controlla i dati inseriti',
  2377. printerConnectionFailed: 'Connessione alla stampante fallita',
  2378. saveFailed: 'Salvataggio modifiche fallito',
  2379. deleteFailed: 'Eliminazione fallita',
  2380. loadFailed: 'Caricamento dati fallito',
  2381. },
  2382. // HMS Errors modal
  2383. hmsErrors: {
  2384. title: 'Errori - {{name}}',
  2385. noErrors: 'Nessun errore',
  2386. viewOnWiki: 'Vedi su Bambu Lab Wiki',
  2387. clearInstructions: 'Cancella gli errori sulla stampante per rimuoverli qui.',
  2388. clearErrors: 'Cancella errori',
  2389. clearSuccess: 'Errori HMS cancellati',
  2390. clearFailed: 'Impossibile cancellare gli errori HMS',
  2391. },
  2392. // MQTT Debug modal
  2393. mqttDebug: {
  2394. title: 'Log debug MQTT',
  2395. searchPlaceholder: 'Cerca topic o payload...',
  2396. noMessages: 'Nessun messaggio registrato',
  2397. startLoggingHint: 'Clicca "Avvia logging" per iniziare a catturare messaggi MQTT',
  2398. noMessagesMatch: 'Nessun messaggio corrisponde al filtro',
  2399. adjustFilterHint: 'Prova a modificare la ricerca o i filtri',
  2400. incoming: 'In ingresso',
  2401. outgoing: 'In uscita',
  2402. loggingStopped: 'Logging fermato',
  2403. loggingActive: 'Logging attivo - i messaggi si aggiornano automaticamente',
  2404. startLogging: 'Avvia logging',
  2405. stopLogging: 'Ferma logging',
  2406. clearLog: 'Pulisci log',
  2407. topic: 'Argomento',
  2408. timestamp: 'Timestamp',
  2409. direction: 'Direzione',
  2410. all: 'Tutti',
  2411. },
  2412. // Printer File Manager modal (printer internal storage)
  2413. printerFiles: {
  2414. title: 'Gestore file',
  2415. storageUsed: 'Usato:',
  2416. storageFree: 'Libero:',
  2417. filterPlaceholder: 'Filtra file...',
  2418. deleteButton: 'Elimina',
  2419. deleteFiles: 'Elimina {{count}} file',
  2420. deleteFileConfirm: 'Eliminare "{{name}}"? Questa azione non può essere annullata.',
  2421. deleteFilesConfirm: 'Eliminare {{count}} file selezionati? Questa azione non può essere annullata.',
  2422. noFiles: 'Nessun file sulla stampante',
  2423. loadingFiles: 'Caricamento file...',
  2424. failedToLoad: 'Caricamento file fallito',
  2425. toast: {
  2426. filesDeleted: 'Eliminati {{count}} file',
  2427. deleteFailed: 'Eliminazione fallita: {{error}}',
  2428. },
  2429. },
  2430. // Confirmations
  2431. confirm: {
  2432. delete: 'Sei sicuro di voler eliminare questo?',
  2433. unsavedChanges: 'Hai modifiche non salvate. Sei sicuro di voler uscire?',
  2434. clearQueue: 'Sei sicuro di voler svuotare la coda?',
  2435. },
  2436. // Login page
  2437. login: {
  2438. title: 'Login Bambuddy',
  2439. subtitle: 'Accedi al tuo account',
  2440. username: 'Nome utente',
  2441. usernamePlaceholder: 'Inserisci il nome utente',
  2442. usernameOrEmail: 'Nome utente o email',
  2443. usernameOrEmailPlaceholder: 'Nome utente o @ Email',
  2444. password: 'Password',
  2445. passwordPlaceholder: 'Inserisci la password',
  2446. signIn: 'Accedi',
  2447. signingIn: 'Accesso in corso...',
  2448. rememberMe: 'Ricordami',
  2449. forgotPassword: 'Hai dimenticato la password?',
  2450. loginSuccess: 'Accesso riuscito',
  2451. loginFailed: 'Accesso fallito',
  2452. enterCredentials: 'Inserisci nome utente e password',
  2453. enterEmail: 'Inserisci il tuo indirizzo e-mail',
  2454. oidcLoginFailed: 'Accesso OIDC fallito',
  2455. oidcErrors: {
  2456. providerError: "Il provider di identità ha restituito un errore",
  2457. missingParameters: 'Parametri obbligatori mancanti nel callback OIDC',
  2458. invalidState: 'Lo stato OIDC non è valido o è già stato utilizzato',
  2459. stateExpired: 'La sessione OIDC è scaduta — riprovare',
  2460. providerNotFound: 'Provider OIDC non trovato',
  2461. discoveryFailed: 'Impossibile recuperare il documento di discovery OIDC',
  2462. invalidDiscovery: 'Il documento di discovery OIDC non è valido',
  2463. networkError: "Errore di rete durante lo scambio di token OIDC",
  2464. badResponse: "Risposta inattesa durante lo scambio di token OIDC",
  2465. noIdToken: 'Il provider OIDC non ha restituito un ID token',
  2466. validationFailed: 'La validazione del token OIDC non è riuscita',
  2467. nonceMismatch: 'Il nonce OIDC non corrisponde — possibile attacco di replay',
  2468. missingSubClaim: 'Il token OIDC è privo del claim sub',
  2469. noLinkedAccount: 'Nessun account locale è collegato a questa identità OIDC',
  2470. accountInactive: 'Il tuo account è inattivo',
  2471. userResolutionFailed: 'Impossibile risolvere il tuo account',
  2472. internalError: "Si è verificato un errore interno durante il login OIDC",
  2473. tokenExchangeFailed: 'Lo scambio di token OIDC non è riuscito',
  2474. },
  2475. forgotPasswordTitle: 'Password dimenticata',
  2476. forgotPasswordMessage: 'Se hai dimenticato la password, contatta il tuo amministratore di sistema per reimpostarla.',
  2477. forgotPasswordEmailMessage: 'Inserisci il tuo indirizzo email e ti invieremo una nuova password.',
  2478. emailAddress: 'Indirizzo email',
  2479. emailPlaceholder: 'tua.email@esempio.com',
  2480. cancel: 'Annulla',
  2481. sending: 'Invio...',
  2482. sendResetEmail: 'Invia email di reimpostazione',
  2483. howToReset: 'Come reimpostare la password:',
  2484. resetStep1: 'Contatta il tuo amministratore Bambuddy',
  2485. resetStep2: 'Chiedi di reimpostare la password in Gestione utenti',
  2486. resetStep3: 'Possono impostare una nuova password temporanea',
  2487. resetStep4: 'Accedi con la nuova password e cambiala in Impostazioni',
  2488. gotIt: 'Capito',
  2489. twoFA: {
  2490. title: 'Autenticazione a due fattori',
  2491. subtitle: 'Il tuo account è protetto da 2FA. Inserisci il codice di verifica qui sotto.',
  2492. methodAuthenticator: 'App di autenticazione',
  2493. methodEmail: 'Codice via e-mail',
  2494. methodBackup: 'Codice di recupero',
  2495. instructionsTotp: "Apri la tua app di autenticazione e inserisci il codice a 6 cifre per Bambuddy.",
  2496. instructionsEmail: "Un codice a 6 cifre è stato inviato al tuo indirizzo e-mail. È valido per 10 minuti.",
  2497. instructionsEmailNotSent: 'Clicca il pulsante qui sotto per ricevere un codice di verifica via e-mail.',
  2498. instructionsBackup: 'Inserisci uno dei tuoi codici di recupero a 8 caratteri. Ogni codice può essere utilizzato una sola volta.',
  2499. sendCodeButton: 'Invia codice via e-mail',
  2500. sendingCode: 'Invio in corso...',
  2501. resendCode: 'Invia nuovamente il codice',
  2502. codeLabel: 'Codice di verifica',
  2503. backupCodeLabel: 'Codice di recupero',
  2504. codePlaceholder: '000000',
  2505. backupCodePlaceholder: 'XXXXXXXX',
  2506. verifyButton: 'Verifica',
  2507. verifyingButton: 'Verifica in corso...',
  2508. backToLogin: '← Torna alla pagina di accesso',
  2509. orContinueWith: 'oppure accedi con',
  2510. signInWith: 'Accedi con {{provider}}',
  2511. enterCode: 'Inserisci il codice di verifica',
  2512. sendCodeFailed: 'Invio del codice di verifica non riuscito',
  2513. invalidCode: 'Codice non valido. Riprova.',
  2514. },
  2515. resetPassword: {
  2516. title: 'Imposta nuova password',
  2517. subtitle: 'Inserisci e conferma la nuova password qui sotto.',
  2518. newPassword: 'Nuova password',
  2519. newPasswordPlaceholder: 'Almeno 8 caratteri',
  2520. confirmPassword: 'Conferma password',
  2521. confirmPasswordPlaceholder: 'Ripeti la nuova password',
  2522. saving: 'Salvataggio…',
  2523. submit: 'Imposta nuova password',
  2524. backToLogin: 'Torna al login',
  2525. passwordsDoNotMatch: 'Le password non coincidono',
  2526. passwordTooShort: 'La password deve avere almeno 8 caratteri',
  2527. resetFailed: 'Reimpostazione non riuscita. Il link potrebbe essere scaduto.',
  2528. },
  2529. },
  2530. // Setup page
  2531. setup: {
  2532. title: 'Configurazione Bambuddy',
  2533. subtitle: 'Configura autenticazione per la tua istanza Bambuddy',
  2534. enableAuth: 'Abilita autenticazione',
  2535. adminAccount: 'Account admin',
  2536. adminAccountDesc: 'Se esistono già admin, l\'autenticazione verrà abilitata usando gli account esistenti. Lascia i campi sotto vuoti per usare gli admin esistenti, oppure inserisci nuove credenziali per creare un nuovo utente admin.',
  2537. adminUsername: 'Nome utente admin',
  2538. adminPassword: 'Password admin',
  2539. optionalIfAdminExists: '(opzionale se esistono admin)',
  2540. adminUsernamePlaceholder: 'Inserisci nome utente admin (opzionale)',
  2541. adminPasswordPlaceholder: 'Inserisci password admin (opzionale)',
  2542. confirmPassword: 'Conferma password',
  2543. confirmPasswordPlaceholder: 'Conferma password admin',
  2544. settingUp: 'Configurazione...',
  2545. completeSetup: 'Completa configurazione',
  2546. toast: {
  2547. authEnabledAdminCreated: 'Autenticazione abilitata e utente admin creato',
  2548. authEnabledExistingAdmins: 'Autenticazione abilitata usando admin esistenti',
  2549. setupCompleted: 'Configurazione completata',
  2550. enterBothCredentials: 'Inserisci nome utente e password admin, oppure lascia entrambi vuoti per usare admin esistenti',
  2551. passwordsDoNotMatch: 'Le password non coincidono',
  2552. passwordTooShort: 'La password deve essere di almeno 6 caratteri',
  2553. },
  2554. },
  2555. // Password change
  2556. changePassword: {
  2557. title: 'Cambia password',
  2558. currentPassword: 'Password attuale',
  2559. currentPasswordPlaceholder: 'Inserisci password attuale',
  2560. newPassword: 'Nuova password',
  2561. newPasswordPlaceholder: 'Inserisci nuova password (min 6 caratteri)',
  2562. confirmPassword: 'Conferma nuova password',
  2563. confirmPasswordPlaceholder: 'Conferma nuova password',
  2564. passwordsDoNotMatch: 'Le password non coincidono',
  2565. passwordTooShort: 'La password deve essere di almeno 6 caratteri',
  2566. changing: 'Modifica in corso...',
  2567. success: 'Password cambiata con successo',
  2568. failed: 'Modifica password fallita',
  2569. },
  2570. // Plate detection alert
  2571. plateAlert: {
  2572. title: 'Stampa in pausa!',
  2573. message: 'Oggetti rilevati sul piatto. La stampa è stata messa automaticamente in pausa. Svuota il piatto e riprendi la stampa.',
  2574. understand: 'Ho capito',
  2575. },
  2576. // Camera page
  2577. camera: {
  2578. title: 'Vista camera',
  2579. invalidPrinterId: 'ID stampante non valido',
  2580. live: 'Live',
  2581. snapshot: 'Istantanea',
  2582. restartStream: 'Riavvia stream',
  2583. refreshSnapshot: 'Aggiorna snapshot',
  2584. fullscreen: 'Schermo intero',
  2585. exitFullscreen: 'Esci da schermo intero',
  2586. connectingToCamera: 'Connessione alla camera...',
  2587. capturingSnapshot: 'Acquisizione snapshot...',
  2588. connectionLost: 'Connessione persa',
  2589. connectionFailed: 'Connessione camera fallita',
  2590. reconnecting: 'Riconnessione tra {{countdown}}s... (tentativo {{attempt}}/{{max}})',
  2591. reconnectNow: 'Riconnetti ora',
  2592. cameraUnavailable: 'Camera non disponibile',
  2593. cameraUnavailableDesc: 'Assicurati che la stampante sia accesa e connessa.',
  2594. noCamera: 'Nessuna camera disponibile',
  2595. retry: 'Riprova',
  2596. cameraStream: 'Stream camera',
  2597. zoomOut: 'Zoom indietro',
  2598. zoomIn: 'Zoom avanti',
  2599. resetZoom: 'Reimposta zoom',
  2600. recording: 'Registrazione',
  2601. startRecording: 'Avvia registrazione',
  2602. stopRecording: 'Ferma registrazione',
  2603. chamberLight: 'Accendi/Spegni luce camera',
  2604. unavailable: 'Telecamera non disponibile',
  2605. diagnose: {
  2606. button: 'Diagnostica',
  2607. modalTitle: 'Diagnostica telecamera',
  2608. running: 'Diagnostica in corso...',
  2609. runFailed: 'Impossibile eseguire la diagnostica: {{error}}',
  2610. retry: 'Riesegui',
  2611. stage: {
  2612. tcp_reachable: 'Raggiungibilità di rete',
  2613. first_frame: 'Acquisizione frame',
  2614. live_stream_active: 'Stream live attivo',
  2615. },
  2616. summary: {
  2617. all_ok: 'La telecamera funziona. La diagnostica ha completato tutte le fasi con successo.',
  2618. live_stream_active_healthy: 'La telecamera sta trasmettendo con frame recenti — nessun test necessario.',
  2619. printer_unreachable: 'La stampante non è raggiungibile. Verifica l\'indirizzo IP, la connessione di rete e che la stampante sia accesa.',
  2620. camera_port_closed: 'La stampante risponde ma la porta della telecamera è chiusa. Assicurati che la modalità LAN e la modalità sviluppatore siano attive nelle impostazioni della stampante.',
  2621. no_frame: 'Connessione alla telecamera riuscita ma nessun frame ricevuto. Riprova o verifica che la telecamera sia abilitata nelle impostazioni della stampante.',
  2622. unknown_failure: 'Diagnostica della telecamera fallita per motivo sconosciuto. Controlla il log di supporto per i dettagli.',
  2623. },
  2624. meta: {
  2625. protocol: 'Protocollo',
  2626. port: 'Porta',
  2627. profile: 'Profilo',
  2628. },
  2629. },
  2630. },
  2631. // Groups management
  2632. groups: {
  2633. title: 'Gestione gruppi',
  2634. subtitle: 'Gestisci gruppi permessi per controllo accesso',
  2635. backToSettings: 'Torna a Impostazioni',
  2636. createGroup: 'Crea gruppo',
  2637. noPermission: 'Non hai il permesso di accedere a questa pagina.',
  2638. system: 'Sistema',
  2639. noDescription: 'Nessuna descrizione',
  2640. usersCount: '{{count}} utenti',
  2641. permissionsCount: '{{count}} permessi',
  2642. edit: 'Modifica',
  2643. delete: 'Elimina',
  2644. toast: {
  2645. created: 'Gruppo creato con successo',
  2646. updated: 'Gruppo aggiornato con successo',
  2647. deleted: 'Gruppo eliminato con successo',
  2648. enterGroupName: 'Inserisci un nome gruppo',
  2649. },
  2650. modal: {
  2651. editGroup: 'Modifica gruppo',
  2652. createGroup: 'Crea gruppo',
  2653. cancel: 'Annulla',
  2654. saving: 'Salvataggio...',
  2655. creating: 'Creazione...',
  2656. saveChanges: 'Salva modifiche',
  2657. },
  2658. form: {
  2659. groupName: 'Nome gruppo',
  2660. groupNamePlaceholder: 'Inserisci nome gruppo',
  2661. systemGroupWarning: 'I nomi dei gruppi di sistema non possono essere modificati',
  2662. description: 'Descrizione',
  2663. descriptionPlaceholder: 'Inserisci descrizione (opzionale)',
  2664. permissions: 'Permessi ({{count}} selezionati)',
  2665. },
  2666. deleteModal: {
  2667. title: 'Elimina gruppo',
  2668. message: 'Sei sicuro di voler eliminare questo gruppo? Gli utenti in questo gruppo perderanno questi permessi.',
  2669. confirm: 'Elimina gruppo',
  2670. },
  2671. editor: {
  2672. title: 'Modifica gruppo',
  2673. createTitle: 'Crea gruppo',
  2674. search: 'Cerca permessi...',
  2675. selectAll: 'Seleziona tutto',
  2676. clearAll: 'Deseleziona tutto',
  2677. permissionsSelected: '{{count}} selezionati',
  2678. noResults: 'Nessun permesso corrisponde alla ricerca',
  2679. },
  2680. },
  2681. // Users management
  2682. users: {
  2683. title: 'Gestione utenti',
  2684. subtitle: 'Gestisci utenti e accesso alla tua istanza Bambuddy',
  2685. backToSettings: 'Torna a Impostazioni',
  2686. createUser: 'Crea utente',
  2687. noPermission: 'Non hai il permesso di accedere a questa pagina.',
  2688. admin: 'Amministratore',
  2689. noGroups: 'Nessun gruppo',
  2690. active: 'Attivo',
  2691. inactive: 'Inattivo',
  2692. edit: 'Modifica',
  2693. delete: 'Elimina',
  2694. system: 'Sistema',
  2695. noGroupsAvailable: 'Nessun gruppo disponibile',
  2696. table: {
  2697. username: 'Nome utente',
  2698. groups: 'Gruppi',
  2699. status: 'Stato',
  2700. actions: 'Azioni',
  2701. },
  2702. toast: {
  2703. created: 'Utente creato con successo',
  2704. updated: 'Utente aggiornato con successo',
  2705. deleted: 'Utente eliminato con successo',
  2706. fillRequired: 'Compila tutti i campi obbligatori',
  2707. passwordsDoNotMatch: 'Le password non coincidono',
  2708. passwordTooShort: 'La password deve essere di almeno 6 caratteri',
  2709. ldapProvisioned: 'Utente LDAP "{{username}}" provisionato',
  2710. },
  2711. modal: {
  2712. createUser: 'Crea utente',
  2713. editUser: 'Modifica utente',
  2714. cancel: 'Annulla',
  2715. creating: 'Creazione...',
  2716. saving: 'Salvataggio...',
  2717. saveChanges: 'Salva modifiche',
  2718. advancedAuthSubtitle: 'con autenticazione avanzata',
  2719. // Manual LDAP provisioning (#1298) — English fallbacks
  2720. tabsAriaLabel: 'Origine utente',
  2721. localTab: 'Locale',
  2722. ldapTab: 'LDAP',
  2723. ldapSearchLabel: 'Cerca nella directory',
  2724. ldapSearchPlaceholder: 'Digita un nome utente, nome o e-mail...',
  2725. ldapMinChars: 'Digita almeno 2 caratteri per cercare',
  2726. ldapTypeToSearch: 'Inizia a digitare per cercare nella directory LDAP',
  2727. ldapSearching: 'Ricerca nella directory...',
  2728. ldapNoResults: 'Nessun utente corrispondente nella directory',
  2729. ldapSearchError: 'Ricerca nella directory fallita. Verifica lo stato del server LDAP.',
  2730. ldapAlreadyProvisioned: 'Già provisionato',
  2731. ldapSelectedLabel: 'Selezionato',
  2732. ldapProvision: 'Provisiona utente',
  2733. ldapProvisioning: 'Provisioning...',
  2734. ldapErrorProvision: 'Provisioning fallito. Verifica lo stato del server LDAP e riprova.',
  2735. },
  2736. form: {
  2737. username: 'Nome utente',
  2738. usernamePlaceholder: 'Inserisci nome utente',
  2739. email: 'E-mail',
  2740. emailPlaceholder: 'utente@esempio.com',
  2741. password: 'Password',
  2742. passwordPlaceholder: 'Inserisci password',
  2743. confirmPassword: 'Conferma password',
  2744. confirmPasswordPlaceholder: 'Conferma password',
  2745. newPasswordPlaceholder: 'Inserisci nuova password',
  2746. confirmNewPasswordPlaceholder: 'Conferma nuova password',
  2747. leaveBlankToKeep: 'lascia vuoto per mantenere attuale',
  2748. groups: 'Gruppi',
  2749. optional: 'opzionale',
  2750. autoGeneratedPassword: 'Una password sicura verrà generata automaticamente e inviata via email all\'utente.',
  2751. passwordManagedByAdvancedAuth: 'La password è gestita dall\'autenticazione avanzata. Usa "Reimposta password" per inviare una nuova password all\'utente via email.',
  2752. resetPassword: 'Reimposta password',
  2753. resettingPassword: 'Reimpostazione password...',
  2754. },
  2755. deleteModal: {
  2756. title: 'Elimina utente',
  2757. message: 'Sei sicuro di voler eliminare questo utente? Questa azione non può essere annullata.',
  2758. confirm: 'Elimina utente',
  2759. },
  2760. },
  2761. // Stream overlay
  2762. streamOverlay: {
  2763. title: 'Overlay stream',
  2764. invalidPrinterId: 'ID stampante non valido',
  2765. cameraStream: 'Stream camera',
  2766. progress: 'Avanzamento',
  2767. eta: 'ETA',
  2768. printerIdle: 'Stampante inattiva',
  2769. printerOffline: 'Stampante offline',
  2770. status: {
  2771. printing: 'In stampa',
  2772. paused: 'In pausa',
  2773. finished: 'Completata',
  2774. failed: 'Fallita',
  2775. idle: 'Inattiva',
  2776. unknown: 'Sconosciuto',
  2777. },
  2778. },
  2779. // Profiles
  2780. profiles: {
  2781. title: 'Profili',
  2782. subtitle: 'Gestisci preset slicer e calibrazioni pressure advance',
  2783. tabs: {
  2784. cloud: 'Profili cloud',
  2785. local: 'Profili locali',
  2786. kprofiles: 'Profili K',
  2787. },
  2788. localProfiles: {
  2789. title: 'Profili locali',
  2790. subtitle: 'Importa e gestisci preset slicer da OrcaSlicer',
  2791. import: 'Importa profili',
  2792. importDesc: 'Trascina file .bbscfg, .bbsflmt, .orca_filament, .zip o .json qui',
  2793. importing: 'Importazione...',
  2794. search: 'Cerca preset locali...',
  2795. noPresets: 'Nessun preset locale ancora',
  2796. badge: 'Locale',
  2797. edit: 'Modifica',
  2798. delete: 'Elimina',
  2799. cancel: 'Annulla',
  2800. deleteConfirmTitle: 'Elimina preset',
  2801. deleteConfirm: 'Sei sicuro di voler eliminare questo preset? Questa azione non può essere annullata.',
  2802. source: 'Fonte',
  2803. inheritsFrom: 'Eredita da',
  2804. filamentType: 'Tipo',
  2805. vendor: 'Produttore',
  2806. compatiblePrinters: 'Stampanti',
  2807. nozzleTemp: 'Temp. ugello',
  2808. cost: 'Costo',
  2809. density: 'Densità',
  2810. pressureAdvance: 'Pressure Advance',
  2811. filament: 'Filamento',
  2812. process: 'Processo',
  2813. printer: 'Stampante',
  2814. toast: {
  2815. importSuccess: '{{count}} preset importati',
  2816. importSkipped: '{{count}} preset saltati (duplicati)',
  2817. importError: '{{count}} errori durante l\'importazione',
  2818. deleted: 'Preset eliminato',
  2819. updated: 'Preset aggiornato',
  2820. },
  2821. },
  2822. connectedAs: 'Connesso come',
  2823. logout: 'Esci',
  2824. noLogoutPermission: 'Non hai il permesso di disconnetterti',
  2825. failedToLoad: 'Caricamento profili fallito',
  2826. retry: 'Riprova',
  2827. time: {
  2828. justNow: 'Proprio ora',
  2829. minsAgo: '{{count}}m fa',
  2830. hoursAgo: '{{count}}h fa',
  2831. daysAgo: '{{count}}g fa',
  2832. },
  2833. toast: {
  2834. loggedOut: 'Disconnesso',
  2835. },
  2836. login: {
  2837. title: 'Connetti a Bambu Cloud',
  2838. subtitle: 'Sincronizza i preset del slicer tra dispositivi',
  2839. email: 'E-mail',
  2840. password: 'Password',
  2841. region: 'Regione',
  2842. regionGlobal: 'Globale',
  2843. regionChina: 'Cina',
  2844. verificationCode: 'Codice di verifica',
  2845. totpCode: 'Codice autenticatore',
  2846. checkEmail: 'Controlla la tua email ({{email}}) per un codice a 6 cifre',
  2847. enterTotpHint: 'Inserisci il codice a 6 cifre dalla tua app autenticatore',
  2848. accessToken: 'Token di accesso',
  2849. accessTokenHint: 'Incolla il tuo access token Bambu Cloud. Gli account della regione Cina devono usare questa via (vincolati al numero di telefono — login via e-mail non disponibile). Il wiki spiega come recuperare il token dai cookie di MakerWorld.',
  2850. back: 'Indietro',
  2851. loginButton: 'Accedi',
  2852. verifyButton: 'Verifica',
  2853. setTokenButton: 'Imposta token',
  2854. useToken: 'Usa access token invece',
  2855. useEmail: 'Accedi con email invece',
  2856. toast: {
  2857. loggedIn: 'Accesso riuscito',
  2858. codeSent: 'Codice di verifica inviato via email',
  2859. enterTotp: 'Inserisci il codice dalla tua app autenticatore',
  2860. tokenSet: 'Token impostato con successo',
  2861. },
  2862. },
  2863. presets: {
  2864. myPreset: 'Il mio preset (modificabile)',
  2865. duplicate: 'Duplica',
  2866. editable: 'Modificabile',
  2867. failedToLoadDetails: 'Caricamento dettagli preset fallito',
  2868. deleteConfirm: 'Eliminare questo preset?',
  2869. deleteWarning: 'Questo eliminerà definitivamente "{{name}}" da Bambu Cloud. Questa azione non può essere annullata.',
  2870. noDuplicatePermission: 'Non hai il permesso di duplicare preset',
  2871. noEditPermission: 'Non hai il permesso di modificare preset',
  2872. noDeletePermission: 'Non hai il permesso di eliminare preset',
  2873. types: {
  2874. filament: 'Preset filamento',
  2875. printer: 'Preset stampante',
  2876. process: 'Preset processo',
  2877. },
  2878. toast: {
  2879. deleted: 'Preset eliminato',
  2880. created: 'Preset creato',
  2881. updated: 'Preset aggiornato',
  2882. duplicated: 'Preset duplicato',
  2883. fieldAdded: 'Campo "{{key}}" aggiunto',
  2884. exported: 'Preset esportato',
  2885. },
  2886. baseLabel: 'Base: {{name}}',
  2887. currentLabel: 'Corrente: {{name}}',
  2888. newPreset: 'Nuovo preset',
  2889. editPreset: 'Modifica preset',
  2890. duplicatePreset: 'Duplica preset',
  2891. createNewPreset: 'Crea nuovo preset',
  2892. customizeSettings: 'Personalizza le impostazioni per il nuovo preset',
  2893. compareWithBase: 'Confronta con base',
  2894. compare: 'Confronta',
  2895. // CreatePresetModal - Basic Info
  2896. basePreset: 'Preset base',
  2897. selectBasePreset: 'Seleziona preset base...',
  2898. presetName: 'Nome preset',
  2899. myCustomPreset: 'Il mio preset personalizzato',
  2900. inheritsFrom: 'Deriva da',
  2901. dropJsonToImport: 'Rilascia JSON per importare',
  2902. // CreatePresetModal - Tabs
  2903. tabs: {
  2904. common: 'Comune',
  2905. allFields: 'Tutti i campi',
  2906. },
  2907. // CreatePresetModal - All Fields Tab
  2908. availableFields: 'Campi disponibili',
  2909. searchFieldsPlaceholder: 'Cerca campi...',
  2910. noMatchingFields: 'Nessun campo corrispondente',
  2911. allFieldsAdded: 'Tutti i campi aggiunti',
  2912. addCustomField: 'Aggiungi campo personalizzato',
  2913. yourOverrides: 'Le tue override',
  2914. noOverridesYet: 'Nessun override ancora',
  2915. clickFieldsToAdd: 'Clicca i campi a sinistra per aggiungerli',
  2916. saveAsTemplate: 'Salva come template',
  2917. jsonTip: 'Suggerimento: trascina e rilascia un file .json ovunque in questa modale per importare impostazioni',
  2918. },
  2919. cloudView: {
  2920. searchPlaceholder: 'Cerca preset...',
  2921. templates: 'Template',
  2922. refresh: 'Aggiorna',
  2923. newPreset: 'Nuovo preset',
  2924. clearFilters: 'Pulisci filtri',
  2925. // Compare mode
  2926. compareMode: 'Modalita confronto',
  2927. selectAnotherPreset: 'Seleziona un altro preset {{type}}',
  2928. clickTwoPresets: 'Clicca due preset dello stesso tipo per confrontare',
  2929. selectFirst: '1. Seleziona il primo',
  2930. selectSecond: '2. Seleziona il secondo',
  2931. compareNow: 'Confronta ora',
  2932. // Status row
  2933. lastSynced: 'Ultima sincronizzazione:',
  2934. showingCount: 'Mostrati {{showing}} di {{total}} preset',
  2935. noPresetsFound: 'Nessun preset trovato',
  2936. // Column headers
  2937. columns: {
  2938. filament: 'Filamento',
  2939. process: 'Processo',
  2940. printer: 'Stampante',
  2941. },
  2942. noFilamentPresets: 'Nessun preset filamento',
  2943. noProcessPresets: 'Nessun preset processo',
  2944. noPrinterPresets: 'Nessun preset stampante',
  2945. // Filters
  2946. filters: {
  2947. type: 'Tipo',
  2948. owner: 'Proprietario',
  2949. printer: 'Stampante',
  2950. nozzle: 'Ugello',
  2951. filament: 'Filamento',
  2952. layer: 'Layer',
  2953. all: 'Tutti',
  2954. myPresets: 'I miei preset',
  2955. builtIn: 'Integrati',
  2956. process: 'Processo',
  2957. },
  2958. // Permissions
  2959. noTemplatesPermission: 'Non hai il permesso di gestire i template',
  2960. noRefreshPermission: 'Non hai il permesso di aggiornare i profili',
  2961. noCreatePermission: 'Non hai il permesso di creare preset',
  2962. },
  2963. templates: {
  2964. title: 'Template rapidi',
  2965. noTemplates: 'Nessun template ancora',
  2966. createFirst: 'Crea template dall\'editor preset',
  2967. typeFilter: 'Tipo:',
  2968. deleteTitle: 'Elimina template',
  2969. deleteWarning: 'Questa azione non può essere annullata',
  2970. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"?',
  2971. namePlaceholder: 'Nome template',
  2972. descriptionPlaceholder: 'Descrizione',
  2973. settingsJson: 'Impostazioni (JSON)',
  2974. fieldsCount: '{{count}} campi',
  2975. shownInModals: 'Mostrati nelle modali',
  2976. hiddenInModals: 'Nascosti nelle modali',
  2977. apply: 'Applica',
  2978. toast: {
  2979. deleted: 'Template eliminato',
  2980. updated: 'Template aggiornato',
  2981. created: 'Template creato',
  2982. applied: 'Template applicato',
  2983. },
  2984. },
  2985. },
  2986. // Support/Debug
  2987. support: {
  2988. debugLoggingActive: 'Log debug attivo',
  2989. manageLogs: 'Gestisci',
  2990. collectItem7: 'Connettività stampante e versioni firmware',
  2991. collectItem8: 'Stato integrazioni (Spoolman, MQTT, HA)',
  2992. collectItem9: 'Interfacce di rete (solo subnet)',
  2993. collectItem10: 'Versioni dei pacchetti Python',
  2994. collectItem11: 'Controlli di integrità del database',
  2995. collectItem12: 'Dettagli dell\'ambiente Docker',
  2996. },
  2997. // File manager
  2998. fileManager: {
  2999. title: 'Gestore file',
  3000. subtitle: 'Organizza e gestisci i tuoi file di stampa',
  3001. uploadFiles: 'Carica file',
  3002. newFolder: 'Nuova cartella',
  3003. folderName: 'Nome cartella',
  3004. folderNamePlaceholder: 'es., Parti funzionali',
  3005. renameFile: 'Rinomina file',
  3006. renameFolder: 'Rinomina cartella',
  3007. moveFiles: 'Sposta {{count}} file',
  3008. rootNoFolder: 'Root (nessuna cartella)',
  3009. current: 'corrente',
  3010. linkFolder: 'Collega cartella',
  3011. linkFolderDescription: 'Collega "{{name}}" a un progetto o archivio per accesso rapido.',
  3012. project: 'Progetto',
  3013. archive: 'Archivio',
  3014. noProjectsFound: 'Nessun progetto trovato',
  3015. noArchivesFound: 'Nessun archivio trovato',
  3016. unlink: 'Scollega',
  3017. link: 'Collega',
  3018. dragDropFiles: 'Trascina e rilascia file qui',
  3019. dropFilesHere: 'Rilascia file qui',
  3020. orClickToBrowse: 'oppure clicca per sfogliare',
  3021. allFileTypesSupported: 'Tutti i tipi di file supportati. I file ZIP saranno estratti.',
  3022. zipFilesDetected: 'File ZIP rilevati',
  3023. zipExtractOptions: 'I file ZIP saranno estratti. Scegli come gestire la struttura cartelle:',
  3024. preserveZipStructure: 'Mantieni struttura cartelle dal ZIP',
  3025. createFolderFromZip: 'Crea cartella dal nome ZIP',
  3026. stlThumbnailGeneration: 'Generazione miniature STL',
  3027. zipMayContainStl: 'I file ZIP possono contenere STL. Le miniature possono essere generate durante l\'estrazione.',
  3028. thumbnailsCanBeGenerated: 'Le miniature possono essere generate per file STL. I modelli grandi possono richiedere più tempo.',
  3029. generateThumbnailsForStl: 'Genera miniature per file STL',
  3030. threemfDetected: 'File 3MF rilevati',
  3031. threemfExtractionInfo: 'Modello stampante, materiale, colore e impostazioni stampa saranno estratti automaticamente dai file 3MF.',
  3032. willBeExtracted: 'Sara estratto',
  3033. filesExtracted: '{{count}} file estratti',
  3034. uploadComplete: 'Caricamento completato: {{succeeded}} riusciti',
  3035. uploadFailed: 'Caricamento fallito',
  3036. zipFilesFailed: '{{count}} file falliti',
  3037. uploading: 'Caricamento...',
  3038. changeLink: 'Cambia collegamento...',
  3039. linkTo: 'Collega a...',
  3040. linkToProjectOrArchive: 'Collega a progetto o archivio',
  3041. addToQueue: 'Aggiungi alla coda',
  3042. schedulePrint: 'Pianifica',
  3043. generateThumbnail: 'Genera miniatura',
  3044. generateThumbnails: 'Genera miniature',
  3045. generateThumbnailsForMissing: 'Genera miniature per STL senza miniatura',
  3046. gridView: 'Vista griglia',
  3047. listView: 'Vista elenco',
  3048. lowDiskSpaceWarning: 'Avviso spazio disco basso',
  3049. lowDiskSpaceDetails: 'Solo {{free}} liberi su {{total}} totali. La soglia e {{threshold}} GB nelle impostazioni.',
  3050. files: 'File',
  3051. folders: 'Cartelle',
  3052. size: 'Dimensione',
  3053. free: 'Libero',
  3054. allFiles: 'Tutti i file',
  3055. wrap: 'A capo',
  3056. enableTextWrapping: 'Abilita a capo testo',
  3057. disableTextWrapping: 'Disabilita a capo testo',
  3058. collapse: 'Comprimi',
  3059. collapseFoldersByDefault: 'Comprimi le cartelle per impostazione predefinita',
  3060. expandFoldersByDefault: 'Espandi le cartelle per impostazione predefinita',
  3061. dragToResizeTooltip: 'Trascina per ridimensionare, doppio clic per reset',
  3062. searchFiles: 'Cerca file...',
  3063. allTypes: 'Tutti i tipi',
  3064. prints: 'Stampe',
  3065. ascending: 'Crescente',
  3066. descending: 'Decrescente',
  3067. resultsCount: '{{showing}} di {{total}} file',
  3068. selectAll: 'Seleziona tutto',
  3069. deselectAll: 'Deseleziona tutto',
  3070. selected: '{{count}} selezionati',
  3071. adding: 'Aggiunta...',
  3072. loadingFiles: 'Caricamento file...',
  3073. folderIsEmpty: 'La cartella e vuota',
  3074. noFilesYet: 'Nessun file ancora',
  3075. folderEmptyDescription: 'Carica file o sposta file in questa cartella per iniziare.',
  3076. noFilesDescription: 'Carica file per iniziare a organizzare i file di stampa.',
  3077. noMatchingFiles: 'Nessun file corrispondente',
  3078. noMatchingFilesDescription: 'Nessun file corrisponde ai criteri di ricerca o filtro.',
  3079. clearFilters: 'Pulisci filtri',
  3080. printedCount: 'Stampato {{count}}x',
  3081. uploadedBy: 'Caricato da',
  3082. deleteFolder: 'Elimina cartella',
  3083. deleteFile: 'Elimina file',
  3084. deleteFilesCount: 'Elimina {{count}} file',
  3085. deleteFolderConfirm: 'Sei sicuro di voler eliminare questa cartella? Tutti i file dentro saranno eliminati.',
  3086. deleteFileConfirm: 'Sei sicuro di voler eliminare questo file?',
  3087. deleteFilesConfirm: 'Sei sicuro di voler eliminare {{count}} file selezionati? Questa azione non può essere annullata.',
  3088. deleting: 'Eliminazione...',
  3089. noPermissionRenameFolder: 'Non hai il permesso di rinominare cartelle',
  3090. noPermissionLinkFolder: 'Non hai il permesso di collegare cartelle',
  3091. noPermissionDeleteFolder: 'Non hai il permesso di eliminare cartelle',
  3092. noPermissionPrint: 'Non hai il permesso di stampare',
  3093. noPermissionSlice: 'Non hai il permesso di sezionare i file',
  3094. noPermissionAddToQueue: 'Non hai il permesso di aggiungere alla coda',
  3095. noPermissionDownload: 'Non hai il permesso di scaricare file',
  3096. noPermissionRenameFile: 'Non hai il permesso di rinominare questo file',
  3097. noPermissionGenerateThumbnail: 'Non hai il permesso di generare miniature',
  3098. noPermissionDeleteFile: 'Non hai il permesso di eliminare questo file',
  3099. noPermissionCreateFolder: 'Non hai il permesso di creare cartelle',
  3100. noPermissionUpload: 'Non hai il permesso di caricare file',
  3101. noPermissionMoveFiles: 'Non hai il permesso di spostare file',
  3102. noPermissionDeleteFiles: 'Non hai il permesso di eliminare file',
  3103. // External folder
  3104. linkExternal: 'Collega esterno',
  3105. linkExternalFolder: 'Collega cartella esterna',
  3106. linkExternalFolderDescription: 'Monta una directory host (NAS, USB, condivisione di rete) nel File Manager. I file non vengono copiati — vengono letti direttamente dal percorso originale.',
  3107. externalFolderNamePlaceholder: 'es. Stampe NAS',
  3108. externalPath: 'Percorso host',
  3109. externalPathHelp: 'Percorso assoluto della directory sull\'host Docker. Deve essere montato come bind nel container.',
  3110. readOnly: 'Sola lettura',
  3111. readOnlyHelp: 'impedisce caricamenti e cancellazioni',
  3112. showHiddenFiles: 'Mostra file nascosti (file punto)',
  3113. externalFolder: 'Cartella esterna',
  3114. scanFolder: 'Scansiona',
  3115. toast: {
  3116. folderCreated: 'Cartella creata',
  3117. folderDeleted: 'Cartella eliminata',
  3118. fileDeleted: 'File eliminato',
  3119. filesDeleted: 'Eliminati {{count}} file',
  3120. filesMoved: 'File spostati',
  3121. folderLinked: 'Cartella collegata',
  3122. folderUnlinked: 'Cartella scollegata',
  3123. externalFolderLinked: 'Cartella esterna collegata e scansionata',
  3124. folderScanned: 'Scansione completata: {{added}} aggiunti, {{removed}} rimossi',
  3125. addedToQueue: 'Aggiunti {{count}} file alla coda',
  3126. addedToQueuePartial: 'Aggiunti {{added}} file, {{failed}} falliti',
  3127. failedToAddToQueue: 'Aggiunta file fallita: {{error}}',
  3128. fileRenamed: 'File rinominato',
  3129. folderRenamed: 'Cartella rinominata',
  3130. thumbnailsGenerated: 'Generate {{count}} miniature',
  3131. thumbnailsGeneratedPartial: 'Generate {{succeeded}} miniature, {{failed}} fallite',
  3132. noStlMissingThumbnails: 'Nessun file STL senza miniature',
  3133. failedToGenerateThumbnails: 'Generazione miniature fallita: {{error}}',
  3134. thumbnailGenerated: 'Miniatura generata',
  3135. failedToGenerateThumbnail: 'Generazione miniatura fallita: {{error}}',
  3136. },
  3137. },
  3138. // Projects
  3139. projects: {
  3140. title: 'Progetti',
  3141. subtitle: 'Organizza e traccia i tuoi progetti di stampa 3D',
  3142. newProject: 'Nuovo progetto',
  3143. editProject: 'Modifica progetto',
  3144. deleteProject: 'Elimina progetto',
  3145. projectName: 'Nome progetto',
  3146. description: 'Descrizione',
  3147. noProjects: 'Nessun progetto ancora',
  3148. noProjectsFiltered: 'Nessun progetto {{status}}',
  3149. noProjectsFilteredHelp: 'Non hai progetti {{status}}. I progetti appariranno qui quando il loro stato cambia.',
  3150. createFirst: 'Crea il tuo primo progetto per organizzare stampe correlate, tracciare progressi e gestire i tuoi build.',
  3151. createFirstButton: 'Crea il tuo primo progetto',
  3152. create: 'Crea',
  3153. files: 'File',
  3154. prints: 'Stampe',
  3155. plates: 'piatti',
  3156. parts: 'parti',
  3157. lastModified: 'Ultima modifica',
  3158. deleteConfirm: 'Sei sicuro di voler eliminare questo progetto? Archivi e elementi in coda saranno scollegati ma non eliminati.',
  3159. addFiles: 'Aggiungi file',
  3160. removeFile: 'Rimuovi file',
  3161. viewDetails: 'Vedi dettagli',
  3162. // Modal fields
  3163. namePlaceholder: 'es., Build Voron 2.4',
  3164. descriptionPlaceholder: 'Descrizione opzionale...',
  3165. urlLabel: 'URL',
  3166. urlPlaceholder: 'https://makerworld.com/...',
  3167. urlInvalid: "L'URL deve iniziare con http:// o https://",
  3168. openExternalUrl: 'Apri URL del progetto',
  3169. coverImageLabel: 'Immagine di copertina',
  3170. coverImageAlt: 'Immagine di copertina del progetto',
  3171. coverImageUpload: 'Carica',
  3172. coverImageReplace: 'Sostituisci',
  3173. coverImageRemove: 'Rimuovi',
  3174. color: 'Colore',
  3175. targetPlates: 'Piatti target',
  3176. targetPlatesPlaceholder: 'es., 25',
  3177. targetPlatesHelp: 'Numero di job di stampa',
  3178. targetParts: 'Parti target',
  3179. targetPartsPlaceholder: 'es., 150',
  3180. targetPartsHelp: 'Totale oggetti necessari',
  3181. tagsLabel: 'Tag (separati da virgola)',
  3182. tagsPlaceholder: 'es., voron, funzionale, regalo',
  3183. dueDate: 'Data scadenza',
  3184. priority: 'Priorita',
  3185. priorityLow: 'Bassa',
  3186. priorityNormal: 'Normale',
  3187. priorityHigh: 'Alta',
  3188. priorityUrgent: 'Urgente',
  3189. // Status
  3190. statusActive: 'Attivo',
  3191. statusCompleted: 'Completato',
  3192. statusArchived: 'Archiviato',
  3193. done: 'Fatto',
  3194. completed: 'completato',
  3195. failed: 'fallito',
  3196. inQueue: 'in coda',
  3197. noPrintsYet: 'Nessuna stampa ancora',
  3198. // Footer stats
  3199. printJobs: 'Job di stampa (piatti)',
  3200. partsPrinted: 'Parti stampate',
  3201. failedParts: 'Parti fallite',
  3202. // Actions
  3203. import: 'Importa',
  3204. export: 'Esporta',
  3205. importProject: 'Importa progetto',
  3206. exportAll: 'Esporta tutti i progetti',
  3207. loading: 'Caricamento progetti...',
  3208. // Permissions
  3209. noEditPermission: 'Non hai il permesso di modificare progetti',
  3210. noDeletePermission: 'Non hai il permesso di eliminare progetti',
  3211. noCreatePermission: 'Non hai il permesso di creare progetti',
  3212. noImportPermission: 'Non hai il permesso di importare progetti',
  3213. noExportPermission: 'Non hai il permesso di esportare progetti',
  3214. // Toast
  3215. toast: {
  3216. created: 'Progetto creato',
  3217. updated: 'Progetto aggiornato',
  3218. deleted: 'Progetto eliminato',
  3219. imported: 'Progetto importato',
  3220. multipleImported: '{{count}} progetti importati',
  3221. importFailed: 'Import fallito',
  3222. exported: 'Progetti esportati (solo metadati)',
  3223. },
  3224. },
  3225. // Project detail page
  3226. projectDetail: {
  3227. notFound: 'Progetto non trovato',
  3228. backToProjects: 'Torna a Progetti',
  3229. export: 'Esporta',
  3230. exportProject: 'Esporta progetto',
  3231. noExportPermission: 'Non hai il permesso di esportare progetti',
  3232. noEditPermission: 'Non hai il permesso di modificare progetti',
  3233. partOf: 'Parte di:',
  3234. priorityLabel: 'Priorita:',
  3235. noPrints: 'Nessuna stampa in questo progetto ancora',
  3236. status: {
  3237. active: 'Attivo',
  3238. completed: 'Completato',
  3239. archived: 'Archiviato',
  3240. },
  3241. priority: {
  3242. low: 'Bassa',
  3243. normal: 'Normale',
  3244. high: 'Alta',
  3245. urgent: 'Urgente',
  3246. },
  3247. dueDate: {
  3248. overdue: 'Scaduto',
  3249. today: 'Scade oggi',
  3250. daysLeft: '{{count}} giorni rimanenti',
  3251. },
  3252. progress: {
  3253. platesProgress: 'Avanzamento piatti',
  3254. partsProgress: 'Avanzamento parti',
  3255. printJobs: 'job di stampa',
  3256. parts: 'parti',
  3257. percentComplete: '{{percent}}% completato',
  3258. remaining: '{{count}} rimanenti',
  3259. },
  3260. stats: {
  3261. printJobs: 'Job di stampa',
  3262. total: 'totale',
  3263. failed: '{{count}} falliti',
  3264. partsPrinted: '{{count}} parti stampate',
  3265. printTime: 'Tempo di stampa',
  3266. filamentUsed: 'Filamento usato',
  3267. },
  3268. cost: {
  3269. title: 'Tracciamento costi',
  3270. filamentCost: 'Costo filamento',
  3271. energy: 'Energia',
  3272. totalCost: 'Costo totale',
  3273. total: 'Totale',
  3274. includesBom: 'incl. distinta materiali',
  3275. budget: 'Budget',
  3276. remaining: 'Rimanente',
  3277. },
  3278. subProjects: {
  3279. title: 'Sotto-progetti ({{count}})',
  3280. },
  3281. notes: {
  3282. title: 'Note',
  3283. noEditPermission: 'Non hai il permesso di modificare le note',
  3284. placeholder: 'Aggiungi note su questo progetto...',
  3285. empty: 'Nessuna nota ancora. Clicca Modifica per aggiungere note.',
  3286. },
  3287. files: {
  3288. title: 'File',
  3289. linkFolders: 'Collega cartelle dal Gestore file',
  3290. forQuickAccess: 'a questo progetto per accesso rapido.',
  3291. fileCount: '{{count}} file',
  3292. empty: 'Nessuna cartella collegata. Vai a Gestore file e collega una cartella a questo progetto.',
  3293. noFiles: 'Nessun file in questa cartella.',
  3294. print: 'Stampa ora',
  3295. addToQueue: 'Aggiungi alla coda',
  3296. },
  3297. bom: {
  3298. title: 'Distinta materiali',
  3299. acquired: '{{completed}}/{{total}} acquisiti',
  3300. showAll: 'Mostra tutti',
  3301. hideDone: 'Nascondi completati',
  3302. addPart: 'Aggiungi parte',
  3303. noAddPermission: 'Non hai il permesso di aggiungere parti',
  3304. partNamePlaceholder: 'Nome parte (es., viti M3x8)',
  3305. partName: 'Nome parte',
  3306. qty: 'Qta',
  3307. price: 'Prezzo ({{currency}})',
  3308. sourcingUrlPlaceholder: 'URL fornitura (opzionale)',
  3309. remarksPlaceholder: 'Note (opzionale)',
  3310. deletePart: 'Elimina parte',
  3311. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"?',
  3312. noUpdatePermission: 'Non hai il permesso di aggiornare parti',
  3313. noEditPermission: 'Non hai il permesso di modificare parti',
  3314. noDeletePermission: 'Non hai il permesso di eliminare parti',
  3315. totalCost: 'Costo totale:',
  3316. empty: 'Nessuna parte nella distinta materiali. Aggiungi hardware, elettronica o altri componenti da reperire.',
  3317. },
  3318. timeline: {
  3319. title: 'Timeline attivita',
  3320. empty: 'Nessuna attivita ancora.',
  3321. },
  3322. template: {
  3323. saveAsTemplate: 'Salva come template',
  3324. noCreatePermission: 'Non hai il permesso di creare template',
  3325. },
  3326. queue: {
  3327. title: 'Coda',
  3328. viewAll: 'Vedi tutto',
  3329. printing: '{{count}} in stampa',
  3330. queued: '{{count}} in coda',
  3331. },
  3332. prints: {
  3333. title: 'Stampe ({{count}})',
  3334. },
  3335. toast: {
  3336. projectUpdated: 'Progetto aggiornato',
  3337. partAdded: 'Parte aggiunta',
  3338. partRemoved: 'Parte rimossa',
  3339. exportFailed: 'Export fallito',
  3340. projectExported: 'Progetto esportato',
  3341. templateCreated: 'Template creato',
  3342. },
  3343. },
  3344. // System info
  3345. system: {
  3346. title: 'Informazioni sistema',
  3347. version: 'Versione',
  3348. uptime: 'Tempo attivo',
  3349. cpuUsage: 'Uso CPU',
  3350. memoryUsage: 'Uso memoria',
  3351. diskUsage: 'Uso disco',
  3352. networkInfo: 'Info rete',
  3353. logs: 'Log',
  3354. debugMode: 'Modalita debug',
  3355. enableDebug: 'Abilita log debug',
  3356. disableDebug: 'Disabilita log debug',
  3357. downloadLogs: 'Scarica log',
  3358. clearLogs: 'Cancella log',
  3359. dockerInfo: 'Info Docker',
  3360. containerName: 'Nome container',
  3361. imageName: 'Nome immagine',
  3362. platform: 'Piattaforma',
  3363. architecture: 'Architettura',
  3364. },
  3365. // Library (K Profiles)
  3366. library: {
  3367. title: 'Libreria filamenti',
  3368. addFilament: 'Aggiungi filamento',
  3369. editFilament: 'Modifica filamento',
  3370. deleteFilament: 'Elimina filamento',
  3371. vendor: 'Produttore',
  3372. material: 'Materiale',
  3373. color: 'Colore',
  3374. kFactor: 'Fattore K',
  3375. temperature: 'Temperatura',
  3376. noFilaments: 'Nessun filamento in libreria',
  3377. deleteConfirm: 'Sei sicuro di voler eliminare questo filamento?',
  3378. importFromPrinter: 'Importa da stampante',
  3379. exportToFile: 'Esporta su file',
  3380. },
  3381. // Slice (slicer-API integration via SliceModal)
  3382. slice: {
  3383. title: 'Slicing modello',
  3384. action: 'Slice',
  3385. slicing: 'Slicing…',
  3386. printer: 'Profilo stampante',
  3387. process: 'Profilo processo',
  3388. filament: 'Profilo filamento',
  3389. filamentSlot: 'Filamento {{index}} ({{type}})',
  3390. selectPreset: '— Seleziona un preset —',
  3391. loadingPresets: 'Caricamento preset…',
  3392. analyzingPlateFilaments: 'Analisi filamenti del piano…',
  3393. analyzingPlateFilamentsHint: 'Slicing di anteprima per scoprire quali slot AMS usa questo piano. In cache dopo — la riapertura è istantanea.',
  3394. previewToast: 'Analisi di {{name}} – {{elapsed}}',
  3395. previewWithProgress: 'Analisi di {{name}} – {{stage}} ({{percent}}%) – {{elapsed}}',
  3396. notUsedByPlate: '— non usato da questo piano',
  3397. printerMismatch: 'Questo 3MF è stato sezionato per {{source}}, ma hai scelto {{target}}. La CLI del slicer non può ri-sezionare un 3MF per una stampante diversa — apri la sorgente in Bambu Studio, cambia stampante e ri-esporta.',
  3398. noPresetsForSlot: 'Nessun preset disponibile',
  3399. presetsLoadFailed: 'Caricamento preset fallito. Apri Impostazioni → Profili per importarli prima.',
  3400. allPresetsRequired: 'Tutti i preset devono essere selezionati',
  3401. enqueuing: 'Invio lavoro di slicing…',
  3402. queued: 'In coda…',
  3403. failed: 'Slicing fallito. Controlla i log del sidecar.',
  3404. startedToast: 'Slicing di {{name}} in background…',
  3405. queuedToast: 'In coda: {{name}} – {{elapsed}}',
  3406. runningToast: 'Slicing {{name}} – {{elapsed}}',
  3407. runningWithProgress: '{{name}} – {{stage}} ({{percent}}%) – {{elapsed}}',
  3408. completedToast: '{{name}} sezionato',
  3409. failedToast: 'Slicing di {{name}} fallito: {{detail}}',
  3410. tier: {
  3411. local: 'Importato',
  3412. cloud: 'Cloud',
  3413. standard: 'Standard',
  3414. },
  3415. cloud: {
  3416. notAuthenticated: 'Accedi a Bambu Cloud (Impostazioni → Profili → Cloud) per vedere i preset cloud.',
  3417. expired: 'Sessione Bambu Cloud scaduta – accedi di nuovo per aggiornare i preset cloud.',
  3418. unreachable: 'Bambu Cloud non è raggiungibile. I preset locali e standard funzionano ancora.',
  3419. },
  3420. bedType: {
  3421. label: 'Piano di stampa',
  3422. auto: 'Auto (usa preset di processo)',
  3423. coolPlate: 'Cool Plate',
  3424. coolPlateSuperTack: 'Cool Plate SuperTack',
  3425. engineering: 'Engineering Plate',
  3426. highTemp: 'High Temp Plate',
  3427. texturedPEI: 'Textured PEI Plate',
  3428. smoothPEI: 'Smooth PEI Plate',
  3429. },
  3430. },
  3431. // Spoolman
  3432. spoolman: {
  3433. title: 'Integrazione Spoolman',
  3434. enabled: 'Spoolman abilitato',
  3435. url: 'URL Spoolman',
  3436. connected: 'Connesso',
  3437. disconnected: 'Non connesso',
  3438. testConnection: 'Testa connessione',
  3439. sync: 'Sincronizza',
  3440. syncing: 'Sincronizzazione...',
  3441. lastSync: 'Ultima sincronizzazione',
  3442. linkToSpoolman: 'Collega a Spoolman',
  3443. openInSpoolman: 'Apri in Spoolman',
  3444. unlinkSpool: 'Scollega bobina',
  3445. unlinkConfirmTitle: 'Rimuovere bobina?',
  3446. unlinkConfirmMessage: 'Questo rimuoverà la bobina da questo slot. I dati della bobina stessa rimarranno invariati.',
  3447. selectSpool: 'Seleziona bobina',
  3448. noUnlinkedSpools: 'Nessuna bobina disponibile',
  3449. linkSuccess: 'Bobina assegnata con successo',
  3450. linkFailed: 'Impossibile assegnare la bobina',
  3451. unlinkSuccess: 'Bobina rimossa con successo',
  3452. unlinkFailed: 'Impossibile rimuovere la bobina',
  3453. linkedSpool: 'Bobina assegnata',
  3454. spoolId: 'ID bobina',
  3455. fillSourceLabel: '(Spoolman)',
  3456. weight: 'Peso',
  3457. remaining: 'Rimanente',
  3458. disableWeightSync: 'Disabilita sync peso stimato AMS',
  3459. disableWeightSyncDesc: 'Non aggiornare la capacità rimanente dalle stime AMS. Usalo se preferisci il tracciamento di Spoolman rispetto alle stime AMS. Le nuove bobine useranno comunque la stima AMS come peso iniziale.',
  3460. reportPartialUsage: 'Segnala uso parziale per stampe fallite',
  3461. reportPartialUsageDesc: 'Quando una stampa fallisce o viene annullata, segnala il filamento stimato usato fino a quel punto in base all\'avanzamento layer.',
  3462. },
  3463. // Inventory
  3464. inventory: {
  3465. title: 'Inventario Bobine',
  3466. subtitle: 'Gestisci le tue bobine',
  3467. spoolmanMixedContentTitle: 'Spoolman non può essere caricato tramite HTTPS — contenuto misto bloccato dal browser',
  3468. spoolmanMixedContentBody: 'Bambuddy viene servito tramite HTTPS (dietro il tuo reverse proxy), ma l\'URL di Spoolman è ancora HTTP. I browser bloccano il contenuto misto per motivi di sicurezza, quindi l\'interfaccia Spoolman incorporata non può essere visualizzata. Anche Spoolman deve essere raggiungibile via HTTPS.',
  3469. spoolmanMixedContentFixReverseProxy: 'Metti Spoolman dietro lo stesso reverse proxy di Bambuddy (Traefik / Nginx / Caddy) in HTTPS, poi aggiorna l\'URL di Spoolman nelle Impostazioni con il nuovo indirizzo HTTPS.',
  3470. spoolmanMixedContentFixOpenNewTab: 'Come alternativa, apri Spoolman in una nuova scheda via HTTP — le regole sul contenuto misto si applicano solo ai frame incorporati, una scheda autonoma funziona.',
  3471. spoolmanOpenInNewTab: 'Apri Spoolman in una nuova scheda',
  3472. labels: {
  3473. title: 'Stampa etichette bobine',
  3474. selectedCount: '{{count}} selezionato',
  3475. pickSpools: 'Scegli per quali bobine stampare le etichette:',
  3476. searchPlaceholder: 'Cerca per nome, marca o #ID',
  3477. filterByMaterial: 'Materiale:',
  3478. allMaterials: 'Tutto',
  3479. selectVisible: 'Seleziona tutti visibili ({{count}})',
  3480. deselectVisible: 'Deseleziona visibili',
  3481. clearAll: 'Cancella tutto',
  3482. noSpoolsToShow: 'Nessuna bobina da mostrare. Modifica il filtro e riprova.',
  3483. noMatches: 'Nessuna bobina corrisponde alla ricerca o al filtro corrente.',
  3484. printOne: 'Stampa etichetta per questa bobina',
  3485. printLabels: 'Stampa etichette…',
  3486. bulkTitle: 'Scegli le bobine da etichettare tra le {{count}} mostrate',
  3487. noSpoolsTitle: 'Nessuna bobina da etichettare',
  3488. error: 'Impossibile generare etichette: {{msg}}',
  3489. sortBy: {
  3490. label: 'Ordina:',
  3491. id: 'Per ID',
  3492. color: 'Per colore',
  3493. },
  3494. templates: {
  3495. ams: {
  3496. label: 'AMS holder (30 × 15 mm)',
  3497. hint: 'Una etichetta per pagina; adatta al popolare portaetichette AMS.',
  3498. },
  3499. box40x30: {
  3500. label: 'Etichetta scatola (40 × 30 mm)',
  3501. hint: 'Una etichetta per pagina; misura comune DK/Brother, ideale per etichette di sacchetti filamento e contenitori.',
  3502. },
  3503. box: {
  3504. label: 'Box label (62 × 29 mm)',
  3505. hint: 'Una etichetta per pagina; dimensionata per Brother PT/QL e piccole etichette Dymo.',
  3506. },
  3507. averyL7160: {
  3508. label: 'Avery L7160 — A4 sheet (38.1 × 63.5 mm × 21)',
  3509. hint: 'Foglio formato UE; 21 etichette per pagina A4.',
  3510. },
  3511. avery5160: {
  3512. label: 'Avery 5160 — US Letter sheet (25.4 × 66.7 mm × 30)',
  3513. hint: 'Foglio formato US; 30 etichette per pagina Letter.',
  3514. },
  3515. },
  3516. },
  3517. addSpool: 'Aggiungi Bobina',
  3518. editSpool: 'Modifica Bobina',
  3519. copySpool: 'Copia Bobina',
  3520. material: 'Materiale',
  3521. selectMaterial: 'Seleziona materiale...',
  3522. subtype: 'Sottotipo',
  3523. brand: 'Marchio',
  3524. searchBrand: 'Cerca marchio...',
  3525. useCustomBrand: 'Usa "{{brand}}"',
  3526. useCustomMaterial: 'Usa materiale personalizzato: {{material}}',
  3527. colorName: 'Nome Colore',
  3528. colorNamePlaceholder: 'Bianco Giada, Rosso Fuoco...',
  3529. color: 'Colore',
  3530. hexColor: 'Colore Hex',
  3531. pickColor: 'Scegli colore personalizzato',
  3532. labelWeight: 'Peso da Etichetta',
  3533. coreWeight: 'Peso Bobina Vuota',
  3534. searchSpoolWeight: 'Cerca peso bobina...',
  3535. weightUsed: 'Utilizzato',
  3536. currentWeight: 'Peso Rimanente',
  3537. measuredWeight: 'Peso Misurato',
  3538. spoolName: 'Bobina',
  3539. costPerKg: 'Costo per kg',
  3540. storageLocation: 'Posizione di archiviazione',
  3541. storageLocationPlaceholder: 'es. Scaffale A, Cassetto 1',
  3542. openInInventory: "Apri nell'inventario",
  3543. measuredWeightError: 'Il peso misurato deve essere compreso tra {{min}}g e {{max}}g.',
  3544. slicerFilament: 'Filamento Slicer',
  3545. slicerFilamentName: 'Nome Preset Slicer',
  3546. slicerPreset: 'Preset Slicer',
  3547. searchPresets: 'Cerca preset filamento...',
  3548. selectedPreset: 'Selezionato',
  3549. noPresetsFound: 'Nessun preset trovato',
  3550. tempOverrides: 'Override Temperatura',
  3551. note: 'Nota',
  3552. notePlaceholder: 'Eventuali note aggiuntive su questa bobina...',
  3553. // Per-spool category + low-stock threshold override (#729)
  3554. category: 'Categoria',
  3555. categoryPlaceholder: 'es. Produzione, Prototipo, Cliente A',
  3556. categoryNone: 'Senza categoria',
  3557. storageLocationNone: 'Nessuna posizione impostata',
  3558. lowStockThresholdOverride: 'Soglia scorte basse (questa bobina)',
  3559. lowStockThresholdOverrideHelp: 'Lascia vuoto per usare la soglia globale ({{global}}%).',
  3560. clearRfid: 'Cancella tag RFID',
  3561. rfidCleared: 'Tag RFID cancellato',
  3562. archive: 'Archivia',
  3563. restore: 'Ripristina',
  3564. noSpools: 'Ancora nessuna bobina. Aggiungi la tua prima bobina per iniziare.',
  3565. noAvailableSpools: 'Nessuna bobina disponibile. Aggiungi una bobina al tuo inventario o rimuovine l\'assegnazione da un altro slot.',
  3566. kProfiles: 'Profili K',
  3567. addKProfile: 'Aggiungi K-Profile',
  3568. assignSpool: 'Assegna Bobina',
  3569. unassignSpool: 'Scollega',
  3570. assignSuccess: 'Bobina assegnata e slot AMS configurato',
  3571. assignFailed: 'Assegnazione bobina fallita',
  3572. selectSpool: 'Seleziona una bobina da assegnare a questo slot',
  3573. assigned: 'Assegnato',
  3574. assigning: 'Assegnazione...',
  3575. searchSpools: 'Cerca bobine...',
  3576. showAllSpools: 'Mostra tutte le bobine',
  3577. spoolmanSpools: 'Bobine Spoolman',
  3578. allMaterials: 'Tutti i Materiali',
  3579. filterByBrand: 'Filtra per marchio...',
  3580. showArchived: 'Mostra archiviate',
  3581. quickAdd: 'Aggiunta rapida (Scorta)',
  3582. quantity: 'Quantità',
  3583. stock: 'Scorta',
  3584. configured: 'Configurata',
  3585. spoolsCreated: '{{count}} bobine create',
  3586. spoolsPartiallyCreated: '{{created}} di {{total}} bobine create (alcune non riuscite)',
  3587. spoolCreated: 'Bobina creata',
  3588. spoolUpdated: 'Bobina aggiornata',
  3589. spoolDeleted: 'Bobina eliminata',
  3590. deepLinkSpoolNotFound: 'Bobina non trovata',
  3591. deepLinkFetchFailed: 'Impossibile caricare la bobina — riprova',
  3592. spoolArchived: 'Bobina archiviata',
  3593. spoolRestored: 'Bobina ripristinata',
  3594. kProfileSaveFailed: 'Impossibile salvare le impostazioni del profilo K',
  3595. syncWeightSpoolNotFound: 'Bobina non trovata — potrebbe essere stata eliminata',
  3596. syncWeightSpoolmanUnreachable: 'Spoolman non è raggiungibile — riprovare più tardi',
  3597. syncWeightFailed: 'Sincronizzazione del peso non riuscita',
  3598. spoolmanUnreachable: 'Spoolman non è raggiungibile — riprovare più tardi',
  3599. deleteSpoolNotFound: 'Bobina non trovata — potrebbe essere già stata eliminata',
  3600. deleteFailed: 'Impossibile eliminare la bobina',
  3601. archiveSpoolNotFound: 'Bobina non trovata — potrebbe essere già stata eliminata',
  3602. archiveFailed: 'Impossibile archiviare la bobina',
  3603. restoreSpoolNotFound: 'Bobina non trovata — potrebbe essere già stata eliminata',
  3604. restoreFailed: 'Impossibile ripristinare la bobina',
  3605. saveFailed: 'Impossibile salvare le modifiche',
  3606. tagClearFailed: 'Impossibile cancellare il tag',
  3607. deleteConfirm: 'Sei sicuro di voler eliminare questa bobina? Questa azione non può essere annullata.',
  3608. archiveConfirm: 'Sei sicuro di voler archiviare questa bobina?',
  3609. advancedSettings: 'Impostazioni Avanzate',
  3610. // Tabs
  3611. filamentInfoTab: 'Info filamento',
  3612. paProfileTab: 'Profilo PA',
  3613. filamentInfo: 'Filamento',
  3614. additional: 'Aggiuntivo',
  3615. // Cloud
  3616. loadingPresets: 'Caricamento preset cloud...',
  3617. cloudConnected: 'Cloud connesso',
  3618. cloudNotConnected: 'Cloud non connesso (valori predefiniti)',
  3619. // Colors
  3620. recentColors: 'Recenti',
  3621. searchColors: 'Cerca colori...',
  3622. searchResults: 'Risultati della ricerca',
  3623. allColors: 'Tutti i colori',
  3624. commonColors: 'Colori comuni',
  3625. showLess: 'Mostra meno',
  3626. showAll: 'Mostra tutto',
  3627. noColorsFound: 'Nessun colore corrisponde alla ricerca',
  3628. noResults: 'Nessun risultato trovato',
  3629. // Multi-color gradient + visual effect (#1154) — English fallback.
  3630. extraColorsLabel: 'Colori extra',
  3631. extraColorsPlaceholder: 'EC984C,#6CD4BC,A66EB9,D87694',
  3632. extraColorsHint: 'Incolla da 2 a 8 stop hex, separati da virgole. Visualizzato come sfumatura.',
  3633. extraColorsInvalid: 'Hex non validi ignorati: {{tokens}}',
  3634. colorEffectLabel: 'Effetto',
  3635. colorEffect: {
  3636. none: 'Nessuno',
  3637. sparkle: 'Scintillante',
  3638. wood: 'Legno',
  3639. marble: 'Marmo',
  3640. glow: 'Bagliore',
  3641. matte: 'Opaco',
  3642. silk: 'Silk',
  3643. galaxy: 'Galassia',
  3644. rainbow: 'Arcobaleno',
  3645. metal: 'Metallo',
  3646. translucent: 'Traslucido',
  3647. gradient: 'Sfumatura',
  3648. dualColor: 'Bicolore',
  3649. triColor: 'Tricolore',
  3650. multicolor: 'Multicolore',
  3651. },
  3652. // PA Profiles
  3653. selectMaterialFirst: 'Selezionare prima un materiale nella scheda Info filamento.',
  3654. noPrintersConfigured: 'Nessuna stampante configurata. Aggiungi stampanti per usare i profili PA.',
  3655. matchingFilter: 'Corrispondenti',
  3656. anyBrand: 'Qualsiasi marca',
  3657. anyVariant: 'Qualsiasi variante',
  3658. autoSelect: 'Selezione automatica',
  3659. matches: 'corrispondenze',
  3660. match: 'corrispondenza',
  3661. noMatches: 'Nessuna corrispondenza',
  3662. connected: 'Connessa',
  3663. offline: 'Offline',
  3664. printerOffline: 'La stampante è offline. Connetti per visualizzare i profili di calibrazione.',
  3665. noKProfilesMatch: 'Nessun profilo K corrisponde al filamento selezionato.',
  3666. leftNozzle: 'Ugello sinistro',
  3667. rightNozzle: 'Ugello destro',
  3668. profilesSelected: 'profili di calibrazione selezionati',
  3669. // Stats & enhanced table
  3670. totalInventory: 'Inventario totale',
  3671. totalConsumed: 'Totale consumato',
  3672. byMaterial: 'Per materiale',
  3673. inPrinter: 'In stampante',
  3674. lowStock: 'Scorta bassa',
  3675. sinceTracking: 'Dall\'inizio del tracciamento',
  3676. resetUsage: 'Azzera utilizzo',
  3677. resetUsageTooltip: 'Azzera il contatore di grammi consumati per questa bobina',
  3678. resetUsageConfirm: 'Azzerare il contatore di grammi consumati di questa bobina? Le stampe future ripartiranno da zero. La bobina, il calcolo del peso rimanente e le impostazioni non vengono modificati.',
  3679. resetAllUsage: 'Azzera utilizzo di tutte le bobine',
  3680. resetAllUsageTooltip: 'Azzera il contatore di grammi consumati su ogni bobina',
  3681. resetAllUsageConfirm: 'Azzerare il contatore di grammi consumati su tutte le {{count}} bobine (incluse quelle archiviate)? La statistica "Totale Consumato" verrà azzerata e le stampe future ripartiranno da zero. Bobine e pesi rimanenti restano invariati.',
  3682. usageReset: 'Utilizzo della bobina azzerato',
  3683. allUsageReset: '{{count}} bobina/e azzerata/e',
  3684. resetUsageFailed: 'Impossibile azzerare l\'utilizzo della bobina',
  3685. loadedInAms: 'Caricato in AMS/Est',
  3686. remaining: 'Rimanente',
  3687. weightCheck: 'Controllo Peso',
  3688. lastWeighed: 'Ultima pesatura',
  3689. neverWeighed: 'Mai pesato',
  3690. search: 'Cerca bobine...',
  3691. showing: 'Visualizzazione',
  3692. to: 'a',
  3693. of: 'di',
  3694. show: 'Mostra',
  3695. spools: 'bobine',
  3696. spool: 'bobina',
  3697. page: 'Pagina',
  3698. noSpoolsMatch: 'Nessun risultato trovato',
  3699. noSpoolsMatchDesc: 'Prova a modificare la ricerca o i filtri per trovare quello che cerchi.',
  3700. active: 'Attive',
  3701. archived: 'Archiviate',
  3702. all: 'Tutte',
  3703. used: 'Usato',
  3704. new: 'Nuovo',
  3705. clearFilters: 'Cancella filtri',
  3706. table: 'Tabella',
  3707. cards: 'Schede',
  3708. net: 'Netto',
  3709. // Grouping
  3710. groupSimilar: 'Raggruppa',
  3711. groupedSpools: '{{count}} bobine identiche',
  3712. groupedRows: 'righe',
  3713. // Column config
  3714. columns: 'Colonne',
  3715. configureColumns: 'Configura colonne',
  3716. configureColumnsDesc: 'Trascina per riordinare le colonne o usa le frecce. Attiva/disattiva la visibilità con l\'icona dell\'occhio.',
  3717. visible: 'visibili',
  3718. reset: 'Ripristina',
  3719. cancel: 'Annulla',
  3720. applyChanges: 'Applica modifiche',
  3721. moveUp: 'Sposta su',
  3722. moveDown: 'Sposta giù',
  3723. hideColumn: 'Nascondi colonna',
  3724. showColumn: 'Mostra colonna',
  3725. // Tag linking
  3726. linkToSpool: 'Collega a bobina',
  3727. tagLinked: 'Tag collegato alla bobina',
  3728. tagLinkFailed: 'Impossibile collegare il tag',
  3729. tagAlreadyLinked: 'Tag già collegato a un\'altra bobina',
  3730. unknownTag: 'Tag RFID sconosciuto rilevato',
  3731. // Usage history
  3732. usageHistory: 'Cronologia utilizzo',
  3733. noUsageHistory: 'Nessun utilizzo registrato',
  3734. printName: 'Nome stampa',
  3735. weightConsumed: 'Peso consumato',
  3736. clearHistory: 'Cancella',
  3737. historyCleared: 'Cronologia utilizzo cancellata',
  3738. fillSourceLabel: '(Inv)',
  3739. lowStockThresholdError: 'La soglia deve essere tra 0.1 e 99.9',
  3740. assignMismatchTitle: 'Materiale non corrispondente',
  3741. assignMismatchMessage: 'Il materiale della bobina selezionata "{{spoolMaterial}}" non corrisponde al materiale del vassoio "{{trayMaterial}}" per {{location}}. Assegnare comunque?',
  3742. assignMismatchConfirm: 'Assegna comunque',
  3743. assignPartialMismatchMessage: 'Il materiale della bobina "{{spoolMaterial}}" è simile ma non corrisponde esattamente a "{{trayMaterial}}" in {{location}}. Vuoi procedere?',
  3744. assignProfileMismatchMessage: 'Il profilo della bobina "{{spoolProfile}}" non corrisponde al profilo del vassoio "{{trayProfile}}" in {{location}}. Vuoi procedere?',
  3745. // Spoolman filament catalog picker
  3746. spoolmanFilamentCatalog: 'Catalogo filamenti Spoolman',
  3747. pickFromSpoolmanCatalog: 'Scegli dal catalogo Spoolman…',
  3748. spoolmanFilamentSelected: 'Filamento selezionato dal catalogo Spoolman',
  3749. spoolmanFilamentUnlinked: 'Collegamento al catalogo filamenti rimosso',
  3750. noSpoolmanFilaments: 'Nessun filamento trovato nel catalogo Spoolman',
  3751. spoolmanFilamentColorSwatch: 'Colore del filamento',
  3752. spoolWeightManagedBySpoolman: 'Il peso della bobina vuota è gestito per tipo di filamento in Spoolman',
  3753. spoolmanCatalogLoadFailed: 'Impossibile caricare il catalogo Spoolman',
  3754. },
  3755. // Timelapse
  3756. timelapse: {
  3757. title: 'Timelapse',
  3758. create: 'Crea timelapse',
  3759. download: 'Scarica',
  3760. delete: 'Elimina',
  3761. preview: 'Anteprima',
  3762. frameRate: 'Frame rate',
  3763. quality: 'Qualità',
  3764. processing: 'Elaborazione...',
  3765. noTimelapses: 'Nessun timelapse disponibile',
  3766. },
  3767. // AMS
  3768. ams: {
  3769. title: 'AMS',
  3770. slot: 'Slot',
  3771. empty: 'Vuoto',
  3772. emptySlot: 'Slot vuoto',
  3773. unknown: 'Sconosciuto',
  3774. humidity: 'Umidità',
  3775. temperature: 'Temperatura',
  3776. filamentType: 'Tipo filamento',
  3777. filamentColor: 'Colore',
  3778. remaining: 'Rimanente',
  3779. history: 'Cronologia AMS',
  3780. noHistory: 'Nessuna cronologia disponibile',
  3781. configureSlot: 'Configura slot',
  3782. externalSpool: 'Bobina esterna',
  3783. profile: 'Profilo',
  3784. kFactor: 'Fattore K',
  3785. fill: 'Livello',
  3786. configure: 'Configura',
  3787. used: 'utilizzato',
  3788. remainingUnit: 'rimanente',
  3789. },
  3790. // Print modal
  3791. printModal: {
  3792. title: 'Avvia stampa',
  3793. selectPrinter: 'Seleziona stampante',
  3794. selectPlate: 'Seleziona piatto',
  3795. filamentMapping: 'Mappatura filamento',
  3796. totalCost: 'Costo totale:',
  3797. slotRemainingShort: ' - {{grams}}g rim.',
  3798. printSettings: 'Impostazioni stampa',
  3799. bedLeveling: 'Livellamento piatto',
  3800. flowCalibration: 'Calibrazione flusso',
  3801. vibrationCalibration: 'Calibrazione vibrazioni',
  3802. layerInspection: 'Ispezione primo layer',
  3803. timelapse: 'Timelapse',
  3804. startPrint: 'Avvia stampa',
  3805. addToQueue: 'Aggiungi alla coda',
  3806. cancel: 'Annulla',
  3807. noPrintersAvailable: 'Nessuna stampante disponibile',
  3808. printerBusy: 'Stampante occupata',
  3809. printerOffline: 'Stampante offline',
  3810. sameTypeDifferentColor: 'Stesso tipo, colore diverso',
  3811. filamentTypeNotLoaded: 'Tipo di filamento non caricato',
  3812. openCalendar: 'Apri calendario',
  3813. leftNozzle: 'L',
  3814. rightNozzle: 'R',
  3815. leftNozzleTooltip: 'Ugello sinistro',
  3816. rightNozzleTooltip: 'Ugello destro',
  3817. filamentOverride: 'Sostituzione filamento',
  3818. filamentOverrideHint: 'Sostituisci opzionalmente i filamenti per l\'assegnazione basata sul modello. Lo scheduler abbinerà i filamenti selezionati invece dei valori 3MF originali.',
  3819. originalFilament: 'Originale',
  3820. overrideWith: 'Sostituisci con',
  3821. resetToOriginal: 'Ripristina originale',
  3822. insufficientFilamentTitle: 'Filamento insufficiente',
  3823. insufficientFilamentMessage: 'Alcune bobine assegnate hanno meno filamento rimanente di quanto necessario per questa stampa:',
  3824. insufficientFilamentLine: '{{printer}} - {{slot}}: necessita di {{required}}g, rimanenti {{remaining}}g',
  3825. printAnyway: 'Stampa comunque',
  3826. forceColorMatch: 'Forza corrispondenza colore',
  3827. staggerPrinterStarts: 'Scaglionare avvii',
  3828. staggerGroupSize: 'Dimensione gruppo',
  3829. staggerInterval: 'Intervallo (min)',
  3830. staggerPreview: '{{printers}} stampanti → {{groups}} gruppi di {{size}}, avvio ogni {{interval}} min',
  3831. staggerLastGroup: 'ultimo gruppo: {{count}}',
  3832. staggerTotal: 'totale: {{minutes}} min',
  3833. staggerToPrinters: 'Scagliona a {{count}} stampanti',
  3834. gcodeInjection: 'Inietta G-code auto-stampa',
  3835. },
  3836. // Backup
  3837. backup: {
  3838. includesEncryptionKey: 'I backup locali includono il file della chiave di crittografia MFA (DATA_DIR/.mfa_encryption_key), quindi un backup ZIP è autonomo. Tratta lo ZIP come sensibile — chiunque abbia il file può decifrare i client secret OIDC e i segreti TOTP contenuti.',
  3839. title: 'Backup e ripristino',
  3840. createBackup: 'Crea backup',
  3841. restoreBackup: 'Ripristina backup',
  3842. restoreDescription: 'Sostituisci tutti i dati da un file di backup',
  3843. downloadBackup: 'Scarica backup',
  3844. uploadBackup: 'Carica backup',
  3845. lastBackup: 'Ultimo backup',
  3846. autoBackup: 'Backup automatico',
  3847. backupNow: 'Esegui backup ora',
  3848. restoreWarning: 'Avviso: il ripristino sovrascriverà tutti i dati attuali.',
  3849. includeArchives: 'Includi archivi',
  3850. includeSettings: 'Includi impostazioni',
  3851. includeProfiles: 'Includi profili',
  3852. backupSuccess: 'Backup creato con successo',
  3853. restoreSuccess: 'Backup ripristinato con successo',
  3854. backupFailed: 'Backup fallito',
  3855. restoreFailed: 'Ripristino fallito',
  3856. restoreNote: 'La stampante virtuale verrà fermata durante il ripristino',
  3857. // GitHub Backup
  3858. githubBackup: 'Backup GitHub',
  3859. enabled: 'Abilitato',
  3860. cloudLoginRequired: 'Accesso Bambu Cloud richiesto. Accedi in Profili → Profili Cloud per abilitare il backup GitHub.',
  3861. cloudLoginRequiredShort: 'Accesso Cloud richiesto',
  3862. githubDescription: 'Sincronizza automaticamente i tuoi profili con un repository GitHub privato per backup e cronologia delle versioni.',
  3863. repoIsPrivate: 'Il repository è privato — è sicuro effettuare il backup.',
  3864. repoIsPublicWarning: 'Il repository è PUBBLICO. I backup di Bambuddy includono credenziali MQTT, token di Home Assistant, token di Prometheus, la tua e-mail Bambu Cloud e i codici di accesso alle stampanti tramite K-profile. Il salvataggio è bloccato finché non rendi privato il repository nelle impostazioni del tuo provider.',
  3865. repoVisibilityUnknown: 'Impossibile determinare la visibilità del repository. Bambuddy rifiuta di eseguire backup su qualsiasi target non confermato come privato; il salvataggio sarà bloccato.',
  3866. repositoryUrl: 'URL del repository',
  3867. repoUrlPlaceholderGitHub: 'https://github.com/username/repo-name',
  3868. repoUrlPlaceholderGitea: 'https://gitea.example.com/username/repo-name',
  3869. repoUrlPlaceholderForgejo: 'https://forgejo.example.com/username/repo-name',
  3870. repoUrlPlaceholderGitLab: 'https://gitlab.com/username/repo-name',
  3871. allowInsecureHttp: 'Consenti HTTP non sicuro',
  3872. allowInsecureHttpHint: 'Abilita per istanze self-hosted su reti private senza TLS',
  3873. personalAccessToken: 'Token di accesso personale',
  3874. tokenSaved: '(salvato)',
  3875. enterNewToken: 'Inserisci un nuovo token per aggiornare',
  3876. tokenHint: 'Token a grana fine con permesso di lettura/scrittura dei contenuti',
  3877. branch: 'Branch',
  3878. provider: 'Provider Git',
  3879. providerGitHub: 'GitHub',
  3880. providerGitLab: 'GitLab',
  3881. providerGitea: 'Gitea',
  3882. providerForgejo: 'Forgejo',
  3883. manualOnly: 'Solo manuale',
  3884. hourly: 'Ogni ora',
  3885. daily: 'Giornaliero',
  3886. weekly: 'Settimanale',
  3887. includeInBackup: 'Includi nel backup',
  3888. kProfiles: 'K-Profili',
  3889. kProfilesDescription: 'Calibrazione dell\'avanzamento pressione dalle stampanti connesse',
  3890. noPrintersConnected: 'Nessuna stampante connessa',
  3891. printersConnected: '{{connected}}/{{total}} connesse',
  3892. cloudProfiles: 'Profili Cloud',
  3893. cloudProfilesDescription: 'Preset di filamento, stampante e processo da Bambu Cloud',
  3894. appSettings: 'Impostazioni App',
  3895. appSettingsDescription: 'Configurazione Bambuddy (database completo)',
  3896. spoolInventory: 'Inventario bobine',
  3897. spoolInventoryDescription: 'Bobine di filamento, cronologia utilizzo e tracciamento costi',
  3898. printArchives: 'Archivi di stampa',
  3899. printArchivesDescription: 'Metadati della cronologia di stampa (nessun file gcode/3MF)',
  3900. lastBackupAt: 'Ultimo backup:',
  3901. noBackupsYet: 'Nessun backup ancora',
  3902. next: 'Prossimo:',
  3903. startingBackup: 'Avvio del backup...',
  3904. test: 'Test',
  3905. enableBackup: 'Abilita backup',
  3906. testConnection: 'Testa connessione',
  3907. enterRepoUrl: 'Inserisci l\'URL del repository',
  3908. enterRepoAndToken: 'Inserisci l\'URL del repository e il token di accesso',
  3909. repoRequired: 'L\'URL del repository è obbligatorio',
  3910. tokenRequired: 'Il token di accesso è obbligatorio',
  3911. githubBackupEnabled: 'Backup GitHub abilitato',
  3912. tokenUpdated: 'Token aggiornato',
  3913. settingsSaved: 'Impostazioni salvate',
  3914. failedToSave: 'Salvataggio fallito: {{message}}',
  3915. backupCompleteFiles: 'Backup completato - {{count}} file aggiornati',
  3916. backupSkippedNoChanges: 'Backup saltato - nessuna modifica',
  3917. backupFailed2: 'Backup fallito: {{message}}',
  3918. clearedLogs: '{{count}} log eliminati',
  3919. failedToClearLogs: 'Eliminazione log fallita: {{message}}',
  3920. // History
  3921. history: 'Cronologia',
  3922. clear: 'Cancella',
  3923. date: 'Data',
  3924. status: 'Stato',
  3925. commit: 'Commit',
  3926. // Local Backup
  3927. localBackup: 'Backup locale',
  3928. localBackupDescription: 'Crea un backup completo dei tuoi dati Bambuddy includendo database, archivi, upload e tutti i file.',
  3929. downloadBackupLabel: 'Scarica backup',
  3930. completeBackupZip: 'Backup completo: database + tutti i file (ZIP)',
  3931. download: 'Scarica',
  3932. preparingBackup: 'Preparazione del backup...',
  3933. creatingArchive: 'Creazione dell\'archivio di backup... Potrebbe richiedere del tempo per archivi di grandi dimensioni.',
  3934. downloadingFile: 'Download del file di backup...',
  3935. backupDownloaded: 'Backup scaricato con successo',
  3936. failedToCreateBackup: 'Creazione del backup fallita: {{message}}',
  3937. restore: 'Ripristina',
  3938. restoreReplacesAll: 'Il ripristino sostituisce tutti i dati.',
  3939. restoreReplacesAllDetail: 'Il database e i file attuali verranno completamente sostituiti. È necessario un riavvio dopo il ripristino.',
  3940. restoreConfirmTitle: 'Ripristina backup',
  3941. restoreConfirmMessage: 'Sei sicuro di voler ripristinare da "{{filename}}"? Questo sostituirà completamente il tuo database e tutti i file. L\'applicazione dovrà essere riavviata dopo il ripristino.',
  3942. restoreConfirmButton: 'Ripristina backup',
  3943. uploadingFile: 'Caricamento del file di backup...',
  3944. backupRestoredRestart: 'Backup ripristinato. Riavvia Bambuddy.',
  3945. failedToRestore: 'Ripristino del backup fallito. Controlla il formato del file.',
  3946. reloadNow: 'Ricarica ora',
  3947. creatingBackup: 'Creazione del backup',
  3948. restoringBackup: 'Ripristino del backup',
  3949. preparing: 'Preparazione...',
  3950. processing: 'Elaborazione...',
  3951. doNotClosePage: 'Non chiudere questa pagina e non navigare altrove. Questa operazione potrebbe richiedere diversi minuti per backup di grandi dimensioni.',
  3952. // RestoreModal
  3953. restoring: 'Ripristino in corso...',
  3954. restoreComplete: 'Ripristino completato',
  3955. restoreFailed2: 'Ripristino fallito',
  3956. importSettings: 'Importa impostazioni da un file di backup',
  3957. pleaseWaitRestoring: 'Attendere durante il ripristino dei dati',
  3958. selectBackupFile: 'Clicca per selezionare un file di backup (.json o .zip)',
  3959. duplicateHandling: 'Come funziona la gestione dei duplicati:',
  3960. matchPrinters: 'Stampanti',
  3961. matchPrintersBy: 'corrispondenza per numero di serie',
  3962. matchSmartPlugs: 'Smart Plug',
  3963. matchSmartPlugsBy: 'corrispondenza per indirizzo IP',
  3964. matchNotificationProviders: 'Provider di notifica',
  3965. matchNotificationProvidersBy: 'corrispondenza per nome',
  3966. matchFilaments: 'Filamenti',
  3967. matchFilamentsBy: 'corrispondenza per nome + tipo + marca',
  3968. matchArchives: 'Archivi',
  3969. matchArchivesBy: 'corrispondenza per hash del contenuto (sempre saltato)',
  3970. matchPendingUploads: 'Upload in sospeso',
  3971. matchPendingUploadsBy: 'corrispondenza per nome file',
  3972. matchSettingsTemplates: 'Impostazioni e modelli',
  3973. matchSettingsTemplatesBy: 'sempre sovrascritti',
  3974. replaceExisting: 'Sostituisci dati esistenti',
  3975. keepExisting: 'Mantieni dati esistenti',
  3976. overwriteDescription: 'Sovrascrivi gli elementi già esistenti con i dati del backup',
  3977. keepDescription: 'Ripristina solo gli elementi che non esistono ancora',
  3978. overwriteCaution: 'Attenzione:',
  3979. overwriteWarning: 'La sovrascrittura sostituirà le configurazioni attuali con i dati del backup. I codici di accesso delle stampanti non vengono mai sovrascritti per sicurezza.',
  3980. cancel: 'Annulla',
  3981. processingBackup: 'Elaborazione del file di backup...',
  3982. itemsRestored: 'Elementi ripristinati',
  3983. itemsSkipped: 'Elementi saltati',
  3984. restored: 'Ripristinati',
  3985. skippedAlreadyExist: 'Saltati (già esistenti)',
  3986. filesCategory: 'File (3MF, miniature, ecc.)',
  3987. andMore: '...e altri {{count}}',
  3988. newApiKeysGenerated: 'Nuove chiavi API generate',
  3989. keysShownOnce: 'Queste chiavi vengono mostrate solo una volta. Copiale ora!',
  3990. copy: 'Copia',
  3991. noDataFound: 'Nessun dato da ripristinare trovato nel file di backup.',
  3992. close: 'Chiudi',
  3993. // Scheduled local backups (#884)
  3994. scheduledBackup: 'Backup pianificati',
  3995. scheduledBackupDescription: 'Crea automaticamente snapshot di backup secondo una pianificazione. La directory di output può essere montata su un NAS o storage esterno.',
  3996. frequency: 'Frequenza',
  3997. backupTime: 'Tempo',
  3998. retention: 'Conservazione',
  3999. retentionDescription: 'Numero di backup da conservare',
  4000. outputPath: 'Percorso di output',
  4001. outputPathPlaceholder: 'Predefinito: {{path}}',
  4002. outputPathDescription: 'Lasciare vuoto per la posizione predefinita',
  4003. runNow: 'Esegui ora',
  4004. backupFiles: 'File di backup',
  4005. noScheduledBackups: 'Nessun backup ancora',
  4006. deleteBackup: 'Elimina',
  4007. deleteBackupConfirm: 'Eliminare questo file di backup?',
  4008. backupRunning: 'Backup in corso...',
  4009. scheduledBackupComplete: 'Backup completato con successo',
  4010. scheduledBackupFailed: 'Backup fallito',
  4011. nextBackup: 'Prossimo backup',
  4012. backupSize: 'Dimensione',
  4013. utc: 'UTC',
  4014. defaultPathLabel: 'Predefinito:',
  4015. // Category labels
  4016. categories: {
  4017. settings: 'Impostazioni',
  4018. notification_providers: 'Provider di notifica',
  4019. notification_templates: 'Modelli di notifica',
  4020. smart_plugs: 'Smart Plug',
  4021. printers: 'Stampanti',
  4022. filaments: 'Filamenti',
  4023. maintenance_types: 'Tipi di manutenzione',
  4024. archives: 'Archivi',
  4025. projects: 'Progetti',
  4026. pending_uploads: 'Upload in sospeso',
  4027. external_links: 'Link esterni',
  4028. api_keys: 'Chiavi API',
  4029. },
  4030. },
  4031. // Tags
  4032. tags: {
  4033. title: 'Tag',
  4034. addTag: 'Aggiungi tag',
  4035. editTag: 'Modifica tag',
  4036. deleteTag: 'Elimina tag',
  4037. tagName: 'Nome tag',
  4038. tagColor: 'Colore tag',
  4039. noTags: 'Nessun tag',
  4040. deleteConfirm: 'Sei sicuro di voler eliminare questo tag?',
  4041. manageTags: 'Gestisci tag',
  4042. },
  4043. // Upload modal (archives)
  4044. uploadModal: {
  4045. title: 'Carica file 3MF',
  4046. dragDrop: 'Trascina e rilascia file .3mf qui',
  4047. or: 'o',
  4048. browseFiles: 'Sfoglia file',
  4049. extractionInfo: 'Il modello stampante sarà estratto automaticamente dai metadati del file 3MF.',
  4050. uploaded: 'caricati',
  4051. failed: 'falliti',
  4052. uploading: 'Caricamento...',
  4053. upload: 'Carica',
  4054. uploadFailed: 'Caricamento fallito',
  4055. },
  4056. // Edit archive modal
  4057. // Edit Archive Modal
  4058. editArchive: {
  4059. title: 'Modifica archivio',
  4060. name: 'Nome',
  4061. namePlaceholder: 'Nome stampa',
  4062. printer: 'Stampante',
  4063. noPrinter: 'Nessuna stampante',
  4064. project: 'Progetto',
  4065. noProject: 'Nessun progetto',
  4066. itemsPrinted: 'Elementi stampati',
  4067. itemsPrintedHelp: 'Numero di elementi prodotti in questo job di stampa',
  4068. notes: 'Note',
  4069. notesPlaceholder: 'Aggiungi note su questa stampa...',
  4070. externalLink: 'Link esterno',
  4071. externalLinkPlaceholder: 'https://printables.com/model/...',
  4072. externalLinkHelp: 'Link a Printables, Thingiverse o altra fonte',
  4073. tags: 'Tag',
  4074. tagsPlaceholder: 'Aggiungi tag...',
  4075. addMoreTags: 'Aggiungi altri tag...',
  4076. matchingTags: 'Tag corrispondenti "{{query}}"',
  4077. existingTags: 'Tag esistenti',
  4078. clickToAdd: '(clicca per aggiungere)',
  4079. status: 'Stato',
  4080. failureReason: 'Motivo fallimento',
  4081. selectReason: 'Seleziona motivo...',
  4082. photos: 'Foto del risultato stampato',
  4083. photosHelp: 'Clicca + per aggiungere foto del risultato stampato',
  4084. printResult: 'Risultato stampa',
  4085. saving: 'Salvataggio...',
  4086. // Failure reasons
  4087. failureReasons: {
  4088. adhesionFailure: 'Fallimento adesione',
  4089. spaghettiDetached: 'Spaghetti / staccato',
  4090. layerShift: 'Spostamento layer',
  4091. cloggedNozzle: 'Ugello intasato',
  4092. filamentRunout: 'Filamento esaurito',
  4093. warping: 'Deformazione',
  4094. stringing: 'Filamento',
  4095. underExtrusion: 'Sotto-estrusione',
  4096. powerFailure: 'Mancanza corrente',
  4097. userCancelled: 'Annullato dall\'utente',
  4098. other: 'Altro',
  4099. },
  4100. // Archive statuses
  4101. statuses: {
  4102. completed: 'Completato',
  4103. failed: 'Fallito',
  4104. aborted: 'Annullato',
  4105. printing: 'In stampa',
  4106. },
  4107. },
  4108. // K-Profiles
  4109. kProfiles: {
  4110. title: 'Profili K',
  4111. noPrintersConfigured: 'Nessuna stampante configurata',
  4112. addPrinterInSettings: 'Aggiungi una stampante in Impostazioni per gestire i K-profiles',
  4113. noActivePrinters: 'Nessuna stampante attiva',
  4114. enablePrinterConnection: 'Abilita una connessione stampante per vedere i K-profiles',
  4115. loadingProfiles: 'Caricamento K-Profiles...',
  4116. printerOffline: 'Stampante offline',
  4117. printerOfflineDesc: 'La stampante selezionata non e connessa. Accendila per vedere i K-profiles.',
  4118. noMatchingProfiles: 'Nessun profilo corrispondente',
  4119. noMatchingProfilesDesc: 'Nessun profilo corrisponde ai criteri di ricerca',
  4120. noKProfiles: 'Nessun K-Profile',
  4121. noKProfilesDesc: 'Nessun profilo pressure advance per ugello da {{diameter}}mm',
  4122. createFirstProfile: 'Crea primo profilo',
  4123. // Controls
  4124. printer: 'Stampante',
  4125. nozzle: 'Ugello',
  4126. refresh: 'Aggiorna',
  4127. addProfile: 'Aggiungi profilo',
  4128. export: 'Esporta',
  4129. import: 'Importa',
  4130. select: 'Seleziona',
  4131. selectAll: 'Seleziona tutto',
  4132. delete: 'Elimina',
  4133. // Filters
  4134. searchPlaceholder: 'Cerca per nome o filamento...',
  4135. allExtruders: 'Tutti gli estrusori',
  4136. leftOnly: 'Solo sinistro',
  4137. rightOnly: 'Solo destro',
  4138. allFlow: 'Tutto flow',
  4139. hfOnly: 'Solo HF',
  4140. sOnly: 'Solo S',
  4141. sortName: 'Ordina: Nome',
  4142. sortKValue: 'Ordina: K-Value',
  4143. sortFilament: 'Ordina: Filamento',
  4144. // Dual extruder labels
  4145. leftExtruder: 'Estrusore sinistro',
  4146. rightExtruder: 'Estrusore destro',
  4147. // Modal
  4148. modal: {
  4149. addTitle: 'Aggiungi K-Profile',
  4150. editTitle: 'Modifica K-Profile',
  4151. profileName: 'Nome profilo',
  4152. profileNamePlaceholder: 'Il mio profilo PLA',
  4153. kValue: 'Valore K',
  4154. kValuePlaceholder: '0.020',
  4155. kValueHelp: 'Intervallo tipico: 0.01 - 0.06 per PLA, 0.02 - 0.10 per PETG',
  4156. filament: 'Filamento',
  4157. selectFilament: 'Seleziona filamento...',
  4158. noFilamentsHelp: 'Nessun filamento trovato. Crea prima un K-profile in Bambu Studio.',
  4159. flowType: 'Tipo flow',
  4160. highFlow: 'Alto flusso',
  4161. standard: 'Standard',
  4162. nozzleSize: 'Dimensione ugello',
  4163. extruder: 'Estrusore',
  4164. extruders: 'Estrusori',
  4165. left: 'Sinistra',
  4166. right: 'Destra',
  4167. notes: 'Note (salvate localmente)',
  4168. notesPlaceholder: 'Aggiungi note su questo profilo...',
  4169. notesHelp: 'Le note sono salvate in Bambuddy, non sulla stampante',
  4170. syncing: 'Sincronizzazione con stampante...',
  4171. savingExtruder: 'Salvataggio su estrusore {{current}}/{{total}}...',
  4172. pleaseWait: 'Attendere',
  4173. },
  4174. // Delete confirmation
  4175. deleteConfirm: {
  4176. title: 'Elimina profilo',
  4177. cannotUndo: 'Questo non può essere annullato',
  4178. message: 'Sei sicuro di voler eliminare "{{name}}" dalla stampante?',
  4179. },
  4180. // Bulk delete
  4181. bulkDelete: {
  4182. title: 'Elimina profili',
  4183. cannotUndo: 'Questo non può essere annullato',
  4184. message: 'Sei sicuro di voler eliminare {{count}} profili selezionati dalla stampante?',
  4185. },
  4186. // Toast
  4187. toast: {
  4188. profileSaved: 'K-profile salvato',
  4189. profilesSaved: 'K-profile salvato su {{count}} estrusori',
  4190. selectAtLeastOneExtruder: 'Seleziona almeno un estrusore',
  4191. profileDeleted: 'K-profile eliminato',
  4192. profilesDeleted: 'Eliminati {{count}} profili',
  4193. exportedProfiles: 'Esportati {{count}} profili',
  4194. importedProfiles: 'Importati {{count}} di {{total}} profili',
  4195. noProfilesToExport: 'Nessun profilo da esportare',
  4196. invalidFileFormat: 'Formato file non valido',
  4197. failedToParseImport: 'Parsing file import fallito',
  4198. failedToSaveBatch: 'Salvataggio K-profiles fallito',
  4199. noteSaved: 'Nota salvata',
  4200. failedToSaveNote: 'Salvataggio nota fallito',
  4201. },
  4202. // Permissions
  4203. permission: {
  4204. noRead: 'Non hai il permesso di aggiornare i profili',
  4205. noCreate: 'Non hai il permesso di aggiungere profili',
  4206. noUpdate: 'Non hai il permesso di aggiornare K-profiles',
  4207. noDelete: 'Non hai il permesso di eliminare K-profiles',
  4208. noExport: 'Non hai il permesso di esportare profili',
  4209. noImport: 'Non hai il permesso di importare profili',
  4210. },
  4211. },
  4212. // Virtual Printer
  4213. virtualPrinter: {
  4214. title: 'Stampante virtuale',
  4215. running: 'In esecuzione',
  4216. stopped: 'Ferma',
  4217. description: {
  4218. default: 'Abilita una stampante virtuale che appare in Bambu Studio e OrcaSlicer. I file inviati a questa stampante saranno archiviati senza stampare.',
  4219. proxy: 'Abilita un proxy che inoltra il traffico slicer a una stampante reale, permettendo la stampa remota su qualsiasi rete.',
  4220. },
  4221. enable: {
  4222. title: 'Abilita stampante virtuale',
  4223. visibleInSlicer: 'Visibile come "Bambuddy" nella ricerca slicer',
  4224. proxyingTo: 'In proxy verso {{name}}',
  4225. notActive: 'Non attivo',
  4226. },
  4227. model: {
  4228. title: 'Modello stampante',
  4229. description: 'Seleziona il modello stampante da emulare.',
  4230. restartWarning: 'Cambiare il modello riavviera la stampante virtuale',
  4231. },
  4232. accessCode: {
  4233. title: 'Codice accesso',
  4234. isSet: 'Codice accesso impostato',
  4235. notSet: 'Nessun codice accesso impostato - richiesto per abilitare',
  4236. placeholder: 'Inserisci codice 8 caratteri',
  4237. placeholderChange: 'Inserisci nuovo codice per cambiare',
  4238. hint: 'Deve essere esattamente 8 caratteri. Usato dagli slicer per autenticarsi.',
  4239. charCount: '({{count}}/8)',
  4240. },
  4241. targetPrinter: {
  4242. title: 'Stampante target',
  4243. configured: 'Target proxy configurato',
  4244. notConfigured: 'Nessuna stampante target selezionata - richiesta per modalita proxy',
  4245. placeholder: 'Seleziona una stampante...',
  4246. hint: 'Seleziona la stampante a cui fare proxy. La stampante deve essere in modalita LAN.',
  4247. noPrinters: 'Nessuna stampante configurata. Aggiungi una stampante per usare la modalita proxy.',
  4248. },
  4249. remoteInterface: {
  4250. title: 'Sovrascrittura interfaccia di rete',
  4251. configured: 'Sovrascrittura interfaccia attiva',
  4252. optional: 'Opzionale - usare se l\'IP rilevato automaticamente e sbagliato (es. piu NIC, Docker, VPN)',
  4253. placeholder: 'Rilevamento automatico (predefinito)...',
  4254. hint: 'Sovrascrive l\'indirizzo IP pubblicizzato via SSDP e usato nel certificato TLS. Utile quando Bambuddy ha piu interfacce di rete.',
  4255. },
  4256. mode: {
  4257. title: 'Modalita',
  4258. archive: 'Archivio',
  4259. archiveDesc: 'Archivia subito i file',
  4260. review: 'Revisione',
  4261. reviewDesc: 'Rivedi prima di archiviare',
  4262. queue: 'Coda',
  4263. queueDesc: 'Archivia e aggiungi alla coda',
  4264. proxy: 'Proxy',
  4265. proxyDesc: 'Inoltra a stampante reale',
  4266. },
  4267. autoDispatch: {
  4268. title: 'Avvio automatico',
  4269. description: 'Avvia automaticamente le stampe aggiunte alla coda. Se disattivato, le stampe attendono l\'avvio manuale.',
  4270. },
  4271. queueForceColorMatch: {
  4272. title: 'Forza corrispondenza colori',
  4273. description: 'Rifiuta di inviare a una stampante che non ha esattamente il tipo di filamento e il colore caricato. Disattivato per impostazione predefinita — senza questo, la coda usa solo la corrispondenza per modello e potrebbe scegliere una stampante con il colore sbagliato.',
  4274. },
  4275. tailscaleDisabled: {
  4276. title: 'Integrazione Tailscale',
  4277. description: 'Abilita per contrassegnare questo VP come esposto tramite Tailscale. Mostra l\'indirizzo Tailscale dell\'host così sai quale IP incollare nello slicer. Il passo di importazione CA è invariato — questo toggle non ha effetto sui certificati.',
  4278. },
  4279. setupRequired: {
  4280. title: 'Configurazione necessaria',
  4281. description: 'La stampante virtuale richiede configurazioni di sistema aggiuntive prima di funzionare. Include port forwarding, regole firewall e impostazioni specifiche della piattaforma.',
  4282. readGuide: 'Leggi la guida prima di abilitare',
  4283. },
  4284. howItWorks: {
  4285. title: 'Come funziona',
  4286. step1: 'Sulla stessa LAN, le stampanti virtuali appaiono automaticamente nel tuo slicer (Bambu Studio / OrcaSlicer). Da altre reti, aggiungile manualmente tramite indirizzo IP e codice di accesso.',
  4287. step2: 'In modalità Archivio, Revisione e Coda, usa il pulsante "Invia" nel tuo slicer per caricare file 3MF su Bambuddy. Lo slicer mostrerà "Stampa riuscita" — il file viene salvato, non stampato.',
  4288. step3: 'In modalità Proxy, la stampante virtuale inoltra tutto il traffico a una stampante reale — le stampe partono immediatamente come con una connessione diretta.',
  4289. },
  4290. status: {
  4291. title: 'Dettagli stato',
  4292. printerName: 'Nome stampante',
  4293. model: 'Modello',
  4294. serialNumber: 'Numero seriale',
  4295. mode: 'Modalita',
  4296. pendingFiles: 'File in sospeso',
  4297. targetPrinter: 'Stampante target',
  4298. ftpPort: 'Porta FTP',
  4299. mqttPort: 'Porta MQTT',
  4300. ftpConnections: 'Connessioni FTP',
  4301. mqttConnections: 'Connessioni MQTT',
  4302. },
  4303. toast: {
  4304. updated: 'Impostazioni stampante virtuale aggiornate',
  4305. failedToUpdate: 'Aggiornamento impostazioni fallito',
  4306. copyFailed: 'Copia non riuscita — seleziona il testo manualmente',
  4307. accessCodeRequired: 'Imposta prima un codice accesso',
  4308. targetPrinterRequired: 'Seleziona prima una stampante target',
  4309. bindIpRequired: 'Impostare prima un indirizzo IP',
  4310. accessCodeEmpty: 'Il codice accesso non può essere vuoto',
  4311. accessCodeLength: 'Il codice accesso deve essere esattamente 8 caratteri',
  4312. created: 'Stampante virtuale creata',
  4313. failedToCreate: 'Impossibile creare la stampante virtuale',
  4314. deleted: 'Stampante virtuale eliminata',
  4315. failedToDelete: 'Impossibile eliminare la stampante virtuale',
  4316. },
  4317. list: {
  4318. title: 'Stampanti virtuali',
  4319. add: 'Aggiungi',
  4320. addFirst: 'Aggiungi stampante virtuale',
  4321. empty: 'Nessuna stampante virtuale configurata. Aggiungine una per iniziare.',
  4322. },
  4323. bindIp: {
  4324. title: 'Interfaccia di rete',
  4325. placeholder: 'Seleziona interfaccia...',
  4326. hint: 'Interfaccia di rete a cui questa stampante virtuale si collega. Deve essere unica per stampante.',
  4327. },
  4328. proxy: {
  4329. accessCodeHint: 'In modalita proxy, usa il codice di accesso della stampante di destinazione nello slicer. La connessione viene inoltrata in modo trasparente alla stampante reale.',
  4330. },
  4331. addDialog: {
  4332. title: 'Aggiungi stampante virtuale',
  4333. name: 'Nome',
  4334. hint: 'Potrai configurare il codice di accesso, la stampante di destinazione e altre impostazioni dopo la creazione.',
  4335. create: 'Crea',
  4336. },
  4337. deleteConfirm: {
  4338. title: 'Elimina stampante virtuale',
  4339. message: 'Sei sicuro di voler eliminare "{{name}}"? Tutti i servizi di questa stampante verranno interrotti.',
  4340. },
  4341. archiveNameSource: {
  4342. title: 'Origine nome archivio',
  4343. description: 'Scegli come vengono nominati i nuovi archivi quando i file arrivano tramite la stampante virtuale. "Metadati" utilizza il titolo incorporato nello slicer dal 3MF (default). "Nome file" utilizza il nome che Bambu Studio ha inviato via FTP — utile se hai rinominato il job nella finestra "invia a stampante".',
  4344. metadata: 'Metadati',
  4345. filename: 'Nome file',
  4346. },
  4347. },
  4348. // Model Viewer
  4349. modelViewer: {
  4350. openInSlicer: 'Apri nello slicer',
  4351. tabs: {
  4352. model: 'Modello 3D',
  4353. gcode: 'Anteprima G-code',
  4354. },
  4355. notAvailable: 'non disponibile',
  4356. notSliced: 'non sezionato',
  4357. plates: 'Piatti',
  4358. allPlates: 'Tutti i piatti',
  4359. plateNumber: 'Piatto {{number}}',
  4360. plateCount: '{{count}} piatto',
  4361. plateCount_other: '{{count}} piatti',
  4362. objectCount: '{{count}} oggetto',
  4363. objectCount_other: '{{count}} oggetti',
  4364. filamentCount: '{{count}} filamento',
  4365. filamentCount_other: '{{count}} filamenti',
  4366. eta: 'ETA {{minutes}} min',
  4367. noPreview: 'Nessuna anteprima disponibile per questo file',
  4368. pagination: {
  4369. pageOf: 'Pagina {{current}} di {{total}}',
  4370. prev: 'Prec',
  4371. next: 'Succ',
  4372. },
  4373. errors: {
  4374. failedToLoad: 'Caricamento file fallito',
  4375. noMeshes: 'Nessuna mesh trovata nel file 3MF',
  4376. unsupportedFormat: 'Formato file non supportato',
  4377. },
  4378. },
  4379. // Maintenance type descriptions (built-in)
  4380. maintenanceDescriptions: {
  4381. lubricateCarbonRods: 'Applica lubrificante alle aste in carbonio per un movimento fluido',
  4382. lubricateRails: 'Applica lubrificante alle guide lineari per un movimento fluido',
  4383. cleanNozzle: 'Pulisci hotend e ugello per prevenire intasamenti',
  4384. checkBelts: 'Verifica tensione cinghie per stampe accurate',
  4385. cleanBuildPlate: 'Pulisci il piatto per migliorare l\'adesione',
  4386. checkExtruder: 'Ispeziona ingranaggi estrusore per usura',
  4387. checkCooling: 'Assicurati che le ventole di raffreddamento funzionino',
  4388. generalInspection: 'Ispezione generale stampante',
  4389. cleanCarbonRods: 'Pulisci le aste in carbonio per ridurre attrito',
  4390. lubricateSteelRods: 'Applica lubrificante alle aste in acciaio per un movimento fluido',
  4391. cleanSteelRods: 'Pulisci le aste in acciaio per ridurre attrito',
  4392. cleanLinearRails: 'Pulisci le guide lineari per rimuovere polvere e detriti',
  4393. checkPtfeTube: 'Ispeziona il tubo PTFE per usura o danni',
  4394. replaceHepaFilter: 'Sostituisci filtro HEPA per qualità aria',
  4395. replaceCarbonFilter: 'Sostituisci filtro a carbone attivo',
  4396. lubricateLeftNozzleRail: 'Lubrifica guida ugello sinistro (serie H2)',
  4397. },
  4398. // Smart Plugs
  4399. smartPlugs: {
  4400. offline: 'Offline',
  4401. admin: 'Amministrazione',
  4402. openPlugAdminPage: 'Apri pagina amministrazione presa',
  4403. deleteSmartPlug: 'Elimina presa smart',
  4404. turnOnSmartPlug: 'Accendi presa smart',
  4405. turnOffSmartPlug: 'Spegni presa smart',
  4406. turnOn: 'Accendi',
  4407. turnOff: 'Spegni',
  4408. addSmartPlug: {
  4409. scanningNetwork: 'Scansione rete...',
  4410. chooseEntity: 'Scegli un\'entità...',
  4411. connectionFailed: 'Connessione fallita',
  4412. searchEntities: 'Cerca entità...',
  4413. searchPowerSensors: 'Cerca sensori di potenza...',
  4414. searchEnergySensors: 'Cerca sensori di energia...',
  4415. placeholders: {
  4416. plugName: 'Presa soggiorno',
  4417. mqttStateOnValue: 'ON, true, 1',
  4418. mqttSameAsPower: 'Stesso del topic potenza, o diverso',
  4419. },
  4420. },
  4421. // SmartPlugCard
  4422. linkedTo: 'Collegato a:',
  4423. monitorOnly: 'Solo monitoraggio',
  4424. alerts: 'Avvisi',
  4425. scheduleOn: 'Alle {{time}}',
  4426. scheduleOff: 'Spento {{time}}',
  4427. on: 'On',
  4428. off: 'Spento',
  4429. power: 'Potenza',
  4430. kwhToday: 'kWh Oggi',
  4431. settings: 'Impostazioni',
  4432. automationSettings: 'Impostazioni automazione',
  4433. showInSwitchbar: 'Mostra nella barra interruttori',
  4434. quickAccessSidebar: 'Accesso rapido dalla barra laterale',
  4435. enabled: 'Abilitato',
  4436. enableAutomation: 'Abilita automazione per questa presa',
  4437. autoOn: 'Auto On',
  4438. autoOnDescription: 'Accendi quando inizia la stampa',
  4439. autoOff: 'Auto Off',
  4440. autoOffDescription: 'Spegni quando la stampa è completata (una tantum)',
  4441. autoOffPersistent: 'Mantieni attivo',
  4442. autoOffPersistentDescription: 'Resta attivo tra le stampe invece di una tantum',
  4443. autoOffAfterDrying: 'Spegni dopo asciugatura',
  4444. autoOffAfterDryingDescription: 'Spegni al termine dell\'asciugatura AMS',
  4445. delayAfterDryingMinutes: 'Ritardo dopo asciugatura (minuti)',
  4446. turnOffDelayMode: 'Modalità ritardo spegnimento',
  4447. time: 'Tempo',
  4448. temp: 'Temp.',
  4449. delayMinutes: 'Ritardo (minuti)',
  4450. tempThreshold: 'Soglia temperatura (°C)',
  4451. tempThresholdDescription: 'Si spegne quando l\'ugello si raffredda sotto questa temperatura',
  4452. edit: 'Modifica',
  4453. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"? Questa azione non può essere annullata.',
  4454. turnOnConfirm: 'Sei sicuro di voler accendere "{{name}}"?',
  4455. turnOffConfirm: 'Sei sicuro di voler spegnere "{{name}}"? Questo interromperà l\'alimentazione del dispositivo collegato.',
  4456. failedToTurn: 'Impossibile {{action}} "{{name}}"',
  4457. unknown: 'Sconosciuto',
  4458. // AddSmartPlugModal
  4459. addTitle: 'Aggiungi presa smart',
  4460. editTitle: 'Modifica presa smart',
  4461. stopScanning: 'Interrompi scansione',
  4462. discoverTasmota: 'Scopri dispositivi Tasmota',
  4463. foundDevices: '{{count}} dispositivo/i trovato/i - clicca per selezionare:',
  4464. noDevicesFound: 'Nessun dispositivo Tasmota trovato nella rete',
  4465. haNotConfigured: 'Home Assistant non è configurato. Configuralo in',
  4466. haSettingsPath: 'Impostazioni → Rete → Home Assistant',
  4467. selectEntity: 'Seleziona entità *',
  4468. ipAddress: 'Indirizzo IP *',
  4469. nameLabel: 'Nome *',
  4470. username: 'Nome utente',
  4471. password: 'Password',
  4472. authHint: 'Lascia vuoto se il tuo dispositivo Tasmota non richiede autenticazione',
  4473. linkToPrinter: 'Collega alla stampante',
  4474. noPrinter: 'Nessuna stampante (solo controllo manuale)',
  4475. linkingDescription: 'Il collegamento abilita accensione/spegnimento automatico all\'inizio/fine stampa',
  4476. powerAlerts: 'Avvisi potenza',
  4477. alertAbove: 'Avviso se sopra (W)',
  4478. alertBelow: 'Avviso se sotto (W)',
  4479. alertDescription: 'Ricevi notifiche quando il consumo supera queste soglie. Lascia vuoto per disabilitare quella direzione.',
  4480. dailySchedule: 'Programma giornaliero',
  4481. turnOnAt: 'Accendi alle',
  4482. turnOffAt: 'Spegni alle',
  4483. scheduleDescription: 'Accendi/spegni automaticamente la presa a questi orari ogni giorno. Lascia vuoto per saltare quell\'azione.',
  4484. showOnPrinterCard: 'Mostra sulla scheda stampante',
  4485. displayOnPrinterCard: 'Mostra pulsante sulla scheda stampante',
  4486. connectedResult: 'Connesso!',
  4487. deviceLabel: 'Dispositivo: {{name}} - ',
  4488. stateLabel: 'Stato: {{state}}',
  4489. test: 'Test',
  4490. delete: 'Elimina',
  4491. save: 'Salva',
  4492. add: 'Aggiungi',
  4493. cancel: 'Annulla',
  4494. failedToStartScan: 'Impossibile avviare la scansione',
  4495. nameRequired: 'Il nome è obbligatorio',
  4496. entityRequired: 'L\'entità è obbligatoria per le prese Home Assistant',
  4497. mqttTopicRequired: 'Almeno un topic MQTT deve essere configurato per potenza, energia o monitoraggio stato',
  4498. loadingEntities: 'Caricamento entità...',
  4499. loading: 'Caricamento...',
  4500. failedToLoadEntities: 'Impossibile caricare le entità: {{error}}',
  4501. noEntitiesMatching: 'Nessuna entità trovata corrispondente a "{{search}}"',
  4502. noEntitiesAvailable: 'Nessuna entità disponibile',
  4503. searchingEntities: 'Ricerca in tutte le entità ({{count}} trovate)',
  4504. showingEntities: 'Mostrando switch, light, input_boolean ({{count}} disponibili)',
  4505. energyMonitoringOptional: 'Monitoraggio energia (Opzionale)',
  4506. energyMonitoringHint: 'Cerca e seleziona i sensori che forniscono dati di potenza/energia.',
  4507. powerSensorW: 'Sensore potenza (W)',
  4508. energyTodayKwh: 'Energia oggi (kWh)',
  4509. totalEnergyKwh: 'Energia totale (kWh)',
  4510. noMatchingSensors: 'Nessun sensore corrispondente',
  4511. none: 'Nessuno',
  4512. mqttNotConfigured: 'Broker MQTT non configurato. Imposta l\'indirizzo del broker in',
  4513. mqttSettingsPath: 'Impostazioni → Rete → Pubblicazione MQTT',
  4514. mqttNotConfiguredSuffix: '(non è necessario abilitare la pubblicazione, basta inserire i dettagli del broker).',
  4515. mqttMonitorOnlyDescription: 'Le prese MQTT ricevono dati di potenza/energia tramite sottoscrizione MQTT. Il controllo on/off non è disponibile - usa il tuo broker MQTT o sistema domotico.',
  4516. powerMonitoring: 'Monitoraggio potenza',
  4517. energyMonitoring: 'Monitoraggio energia',
  4518. stateMonitoring: 'Monitoraggio stato',
  4519. optional: 'opzionale',
  4520. topic: 'Argomento',
  4521. jsonPath: 'Percorso JSON',
  4522. multiplier: 'Moltiplicatore',
  4523. onValue: 'Valore ON',
  4524. mqttPowerHint: 'Il percorso JSON estrae il valore dal payload JSON (es. "power_l1"). Lascia vuoto se il topic pubblica valori numerici grezzi.\nUsa moltiplicatore 0.001 per mW→W, 1000 per kW→W.',
  4525. mqttEnergyHint: 'Il percorso JSON estrae il valore dal payload JSON. Lascia vuoto per valori grezzi.\nUsa moltiplicatore 0.001 per Wh→kWh, 1000 per MWh→kWh.',
  4526. mqttStateHint: 'Il percorso JSON estrae il valore dal payload JSON. Lascia vuoto per valori grezzi.\nValore ON: la stringa esatta che significa "ON". Lascia vuoto per rilevamento auto (ON, true, 1).',
  4527. // REST smart plug
  4528. restControl: 'Controllo',
  4529. restOnUrl: 'URL accensione',
  4530. restOffUrl: 'URL spegnimento',
  4531. restOnBody: 'Corpo richiesta ON',
  4532. restOffBody: 'Corpo richiesta OFF',
  4533. restMethod: 'Metodo HTTP',
  4534. restHeaders: 'Custom Headers (JSON)',
  4535. restStatusUrl: 'URL stato',
  4536. restStatusPath: 'Percorso JSON stato',
  4537. restStatusOnValue: 'Valore ON',
  4538. restPowerUrl: 'URL potenza',
  4539. restPowerPath: 'Percorso JSON potenza',
  4540. restPowerMultiplier: 'Moltiplicatore potenza',
  4541. restEnergyUrl: 'URL energia',
  4542. restEnergyPath: 'Percorso JSON energia',
  4543. restEnergyMultiplier: 'Moltiplicatore energia',
  4544. restUrlRequired: 'È richiesto almeno un URL (ON o OFF) per le prese REST',
  4545. restHeadersHint: 'es. {"Authorization": "Bearer your-token"}',
  4546. restBodyHint: 'es. ON, {"state": "on"}',
  4547. restStatusHint: 'URL per recuperare lo stato attuale',
  4548. restPathHint: 'es. state o data.power.status',
  4549. restPowerUrlHint: 'URL separato per i dati di potenza (usa l\'URL di stato se vuoto)',
  4550. restEnergyUrlHint: 'URL separato per i dati di energia (usa l\'URL di stato se vuoto)',
  4551. restEnergyHint: 'Ogni valore può usare il proprio URL o ricadere sull\'URL di stato. Usa i moltiplicatori per la conversione delle unità (es. 0.001 per convertire Wh in kWh).',
  4552. testConnection: 'Testa connessione',
  4553. connectionSuccess: 'Connessione riuscita',
  4554. noSwitchesInSwitchbar: 'Nessun interruttore nella barra',
  4555. enableSwitchbarHint: 'Abilita "Mostra nella barra interruttori" in Impostazioni > Smart Plugs',
  4556. },
  4557. // Notifications
  4558. notifications: {
  4559. // Provider types
  4560. providerTypes: {
  4561. callmebot: 'CallMeBot/WhatsApp',
  4562. ntfy: 'ntfy',
  4563. pushover: 'Pushover',
  4564. telegram: 'Telegram',
  4565. email: 'E-mail',
  4566. discord: 'Discord',
  4567. webhook: 'Webhook',
  4568. homeassistant: 'Home Assistant',
  4569. },
  4570. // Provider descriptions
  4571. providerDescriptions: {
  4572. email: 'Notifiche email tramite SMTP',
  4573. telegram: 'Notifiche tramite bot Telegram',
  4574. discord: 'Invia a un canale Discord tramite webhook',
  4575. ntfy: 'Notifiche push gratuite e self-hostabili',
  4576. pushover: 'Notifiche push semplici e affidabili',
  4577. callmebot: 'Notifiche WhatsApp gratuite tramite CallMeBot',
  4578. webhook: 'POST HTTP generico verso qualsiasi URL',
  4579. homeassistant: 'Notifiche persistenti nella dashboard di Home Assistant',
  4580. },
  4581. // NotificationProviderCard
  4582. lastSuccess: 'Ultimo: {{date}}',
  4583. error: 'Errore',
  4584. printer: 'Stampante:',
  4585. allPrinters: 'Tutte le stampanti',
  4586. sendTestNotification: 'Invia notifica di prova',
  4587. eventSettings: 'Impostazioni eventi',
  4588. enabled: 'Abilitato',
  4589. sendFromProvider: 'Invia notifiche da questo provider',
  4590. // Event categories
  4591. printEvents: 'Eventi di stampa',
  4592. printerStatus: 'Stato stampante',
  4593. amsAlarms: 'Allarmi AMS',
  4594. amsHtAlarms: 'Allarmi AMS-HT',
  4595. printQueue: 'Coda di stampa',
  4596. // Event tags (badges)
  4597. start: 'Avvio',
  4598. plateCheck: 'Controllo piatto',
  4599. complete: 'Completato',
  4600. failed: 'Fallito',
  4601. stopped: 'Interrotto',
  4602. progress: 'Avanzamento',
  4603. offline: 'Offline',
  4604. lowFilament: 'Filamento scarso',
  4605. maintenance: 'Manutenzione',
  4606. amsHumidity: 'Umidità AMS',
  4607. amsTemp: 'Temp AMS',
  4608. amsHtHumidity: 'Umidità AMS-HT',
  4609. amsHtTemp: 'Temp AMS-HT',
  4610. bedCooled: 'Piatto raffreddato',
  4611. firstLayer: 'Primo strato',
  4612. quiet: 'Silenzioso',
  4613. digest: 'Riepilogo {{time}}',
  4614. // Event labels (expanded settings)
  4615. printStarted: 'Stampa avviata',
  4616. plateNotEmpty: 'Piatto non vuoto',
  4617. plateNotEmptyDescription: 'Oggetti rilevati prima della stampa',
  4618. printCompleted: 'Stampa completata',
  4619. bedCooledLabel: 'Piatto raffreddato',
  4620. bedCooledDescription: 'Piatto raffreddato sotto la soglia dopo la stampa',
  4621. firstLayerCompleteLabel: 'Primo strato completato',
  4622. firstLayerCompleteDescription: 'Notifica con foto al termine del primo strato',
  4623. missingSpoolAssignmentLabel: 'Assegnazione bobina mancante',
  4624. missingSpoolAssignmentDescription: 'Notifica quando una stampa parte e i vassoi richiesti non hanno una bobina assegnata',
  4625. printFailed: 'Stampa fallita',
  4626. printStopped: 'Stampa interrotta',
  4627. progressMilestones: 'Traguardi di avanzamento',
  4628. progressMilestonesDescription: 'Notifica al 25%, 50%, 75%',
  4629. printerOffline: 'Stampante offline',
  4630. printerError: 'Errore stampante',
  4631. lowFilamentLabel: 'Filamento scarso',
  4632. maintenanceDue: 'Manutenzione necessaria',
  4633. maintenanceDueDescription: 'Notifica quando è necessaria la manutenzione',
  4634. amsHumidityHigh: 'Umidità AMS elevata',
  4635. amsHumidityHighDescription: 'L\'umidità dell\'AMS standard supera la soglia',
  4636. amsTemperatureHigh: 'Temperatura AMS elevata',
  4637. amsTemperatureHighDescription: 'La temperatura dell\'AMS standard supera la soglia',
  4638. amsHtHumidityHigh: 'Umidità AMS-HT elevata',
  4639. amsHtHumidityHighDescription: 'L\'umidità dell\'AMS-HT supera la soglia',
  4640. amsHtTemperatureHigh: 'Temperatura AMS-HT elevata',
  4641. amsHtTemperatureHighDescription: 'La temperatura dell\'AMS-HT supera la soglia',
  4642. // Inventory stock alert events
  4643. inventoryAlerts: 'Avvisi di inventario',
  4644. stockReorderAlert: 'Avviso di riordino',
  4645. stockReorderAlertDescription: 'Il SKU ha raggiunto il punto di riordino',
  4646. stockBreakAlert: 'Avviso di esaurimento scorte',
  4647. stockBreakAlertDescription: 'Le scorte si esauriranno prima dell\'arrivo del rifornimento',
  4648. // Queue events
  4649. jobAdded: 'Lavoro aggiunto',
  4650. jobAddedDescription: 'Lavoro aggiunto alla coda',
  4651. jobAssigned: 'Lavoro assegnato',
  4652. jobAssignedDescription: 'Lavoro basato su modello assegnato alla stampante',
  4653. jobStarted: 'Lavoro avviato',
  4654. jobStartedDescription: 'Lavoro in coda avviato per la stampa',
  4655. jobWaiting: 'Lavoro in attesa',
  4656. jobWaitingDescription: 'Lavoro in attesa di filamento o stampante',
  4657. jobSkipped: 'Lavoro saltato',
  4658. jobSkippedDescription: 'Lavoro saltato (precedente fallito)',
  4659. jobFailed: 'Lavoro fallito',
  4660. jobFailedDescription: 'Avvio del lavoro fallito',
  4661. queueComplete: 'Coda completata',
  4662. queueCompleteDescription: 'Tutti i lavori in coda completati',
  4663. // Quiet hours
  4664. quietHours: 'Ore silenziose',
  4665. noNotificationsDuring: 'Nessuna notifica durante queste ore',
  4666. editProviderToChangeQuietHours: 'Modifica il provider per cambiare le ore silenziose',
  4667. // Daily digest
  4668. dailyDigest: 'Riepilogo giornaliero',
  4669. batchNotifications: 'Raggruppa le notifiche in un unico riepilogo giornaliero',
  4670. sendAt: 'Invia alle {{time}}',
  4671. editProviderToChangeDigestTime: 'Modifica il provider per cambiare l\'orario del riepilogo',
  4672. // Actions
  4673. edit: 'Modifica',
  4674. deleteProvider: 'Elimina provider di notifica',
  4675. deleteConfirm: 'Sei sicuro di voler eliminare "{{name}}"? Questa azione non può essere annullata.',
  4676. delete: 'Elimina',
  4677. // AddNotificationModal
  4678. addTitle: 'Aggiungi provider di notifica',
  4679. editTitle: 'Modifica provider di notifica',
  4680. nameLabel: 'Nome *',
  4681. namePlaceholder: 'Le mie notifiche',
  4682. providerTypeLabel: 'Tipo di provider *',
  4683. configuration: 'Configurazione',
  4684. testConfiguration: 'Testa configurazione',
  4685. printerFilter: 'Filtro stampante',
  4686. onlyFromPrinter: 'Invia notifiche solo per eventi da questa stampante',
  4687. quietHoursDnd: 'Ore silenziose (Non disturbare)',
  4688. quietStart: 'Inizio',
  4689. quietEnd: 'Fine',
  4690. dailyDigestLabel: 'Riepilogo giornaliero',
  4691. sendDigestAt: 'Invia riepilogo alle',
  4692. digestCollected: 'Gli eventi verranno raccolti e inviati come riepilogo unico a quest\'ora',
  4693. notificationEvents: 'Eventi di notifica',
  4694. progressPercent: '(25%, 50%, 75%)',
  4695. bedCooledAfterPrint: '(dopo il completamento della stampa)',
  4696. // Per-event ntfy priority (#990)
  4697. eventPriority: {
  4698. sectionTitle: 'Priorità ntfy',
  4699. helpNtfy: 'Scegli una priorità per ogni evento abilitato. ntfy le usa per intensificare gli avvisi (suono, visibilità, comportamento push). I livelli non impostati qui usano l\'impostazione predefinita del server ntfy.',
  4700. min: 'Min.',
  4701. low: 'Bassa',
  4702. default: 'Predefinita',
  4703. high: 'Alta',
  4704. urgent: 'Urgente',
  4705. },
  4706. cancel: 'Annulla',
  4707. save: 'Salva',
  4708. add: 'Aggiungi',
  4709. nameRequired: 'Il nome è obbligatorio',
  4710. fieldRequired: '{{field}} è obbligatorio',
  4711. // Config field labels
  4712. phoneNumber: 'Numero di telefono',
  4713. apiKey: 'Chiave API',
  4714. serverUrl: 'URL del server',
  4715. topic: 'Argomento',
  4716. authToken: 'Token di autenticazione',
  4717. userKey: 'Chiave utente',
  4718. appToken: 'Token applicazione',
  4719. priority: 'Priorità',
  4720. botToken: 'Token del bot',
  4721. chatId: 'ID chat',
  4722. smtpServer: 'Server SMTP',
  4723. smtpPort: 'Porta SMTP',
  4724. security: 'Sicurezza',
  4725. authentication: 'Autenticazione',
  4726. username: 'Nome utente',
  4727. password: 'Password',
  4728. fromEmail: 'Email mittente',
  4729. toEmail: 'Email destinatario',
  4730. webhookUrl: 'URL webhook',
  4731. payloadFormat: 'Formato payload',
  4732. authorization: 'Autorizzazione',
  4733. titleFieldName: 'Nome campo titolo',
  4734. messageFieldName: 'Nome campo messaggio',
  4735. // NotificationTemplateEditor
  4736. editTemplate: 'Modifica modello: {{name}}',
  4737. titleLabel: 'Titolo',
  4738. bodyLabel: 'Corpo',
  4739. titlePlaceholder: 'Titolo della notifica...',
  4740. bodyPlaceholder: 'Corpo della notifica...',
  4741. availableVariables: 'Variabili disponibili',
  4742. clickToInsert: 'Clicca per inserire alla posizione del cursore nel corpo',
  4743. livePreview: 'Anteprima live',
  4744. hide: 'Nascondi',
  4745. show: 'Mostra',
  4746. loadingPreview: 'Caricamento anteprima...',
  4747. enterTemplateContent: 'Inserisci il contenuto del modello per vedere l\'anteprima',
  4748. titlePreview: 'Titolo:',
  4749. bodyPreview: 'Corpo:',
  4750. resetToDefault: 'Ripristina predefinito',
  4751. titleRequired: 'Il titolo è obbligatorio',
  4752. bodyRequired: 'Il corpo è obbligatorio',
  4753. // NotificationLogViewer
  4754. notificationLog: 'Registro notifiche',
  4755. showFailedOnly: 'Solo fallite',
  4756. last24Hours: 'Ultime 24 ore',
  4757. last7Days: 'Ultimi 7 giorni',
  4758. last30Days: 'Ultimi 30 giorni',
  4759. last90Days: 'Ultimi 90 giorni',
  4760. justNow: 'Proprio ora',
  4761. noFailedNotifications: 'Nessuna notifica fallita',
  4762. noNotificationsLogged: 'Nessuna notifica registrata',
  4763. unknownProvider: 'Provider sconosciuto',
  4764. logTitle: 'Titolo',
  4765. logMessage: 'Messaggio',
  4766. logError: 'Errore',
  4767. logProvider: 'Provider: {{type}}',
  4768. logTime: 'Ora: {{time}}',
  4769. refresh: 'Aggiorna',
  4770. clearOld: 'Cancella vecchie',
  4771. statsSummary: 'Ultimi {{days}} giorni:',
  4772. statsNotifications: 'notifiche',
  4773. statsSent: '{{count}} inviate',
  4774. statsFailed: '{{count}} fallite',
  4775. // Event type labels (for log viewer)
  4776. eventTypes: {
  4777. print_start: 'Stampa avviata',
  4778. print_complete: 'Stampa completata',
  4779. print_failed: 'Stampa fallita',
  4780. print_stopped: 'Stampa interrotta',
  4781. print_progress: 'Avanzamento',
  4782. printer_offline: 'Stampante offline',
  4783. printer_error: 'Errore stampante',
  4784. filament_low: 'Filamento scarso',
  4785. maintenance_due: 'Manutenzione necessaria',
  4786. test: 'Prova',
  4787. },
  4788. // User email notification preferences
  4789. userEmail: {
  4790. title: 'Notifiche',
  4791. emailNotifications: 'Notifiche via e-mail',
  4792. emailNotificationsDesc: "Ricevi notifiche via e-mail per i tuoi lavori di stampa. Le e-mail vengono inviate tramite le impostazioni SMTP configurate nell'autenticazione avanzata.",
  4793. sendingTo: 'Le notifiche verranno inviate a',
  4794. noEmailWarning: "Il tuo account non ha un indirizzo e-mail. Contatta un amministratore per aggiungerne uno.",
  4795. printJobNotifications: 'Notifiche lavori di stampa',
  4796. printJobNotificationsDesc: 'Scegli quali eventi attivano le notifiche e-mail per i lavori di stampa che invii.',
  4797. printJobStarts: 'Inizio lavoro di stampa',
  4798. printJobStartsDesc: 'Ricevi una notifica quando il tuo lavoro di stampa inizia.',
  4799. printJobFinishes: 'Fine lavoro di stampa',
  4800. printJobFinishesDesc: 'Ricevi una notifica quando il tuo lavoro di stampa si completa correttamente.',
  4801. printErrors: 'Errori di stampa',
  4802. printErrorsDesc: 'Ricevi una notifica quando il tuo lavoro di stampa fallisce o incontra un errore.',
  4803. printJobStops: 'Lavoro di stampa interrotto',
  4804. printJobStopsDesc: 'Ricevi una notifica quando il tuo lavoro di stampa viene annullato o interrotto.',
  4805. saveSuccess: 'Preferenze di notifica salvate.',
  4806. saveError: 'Impossibile salvare le preferenze di notifica.',
  4807. },
  4808. },
  4809. // Rich Text Editor
  4810. richTextEditor: {
  4811. bold: 'Grassetto',
  4812. italic: 'Corsivo',
  4813. underline: 'Sottolineato',
  4814. bulletList: 'Elenco puntato',
  4815. numberedList: 'Elenco numerato',
  4816. alignLeft: 'Allinea a sinistra',
  4817. alignCenter: 'Allinea al centro',
  4818. alignRight: 'Allinea a destra',
  4819. addLink: 'Aggiungi link',
  4820. removeLink: 'Rimuovi link',
  4821. },
  4822. // External Links
  4823. externalLinks: {
  4824. noLinksConfigured: 'Nessun link esterno configurato',
  4825. deleteLink: 'Elimina link',
  4826. removeCustomIcon: 'Rimuovi icona personalizzata',
  4827. openInNewTab: 'Apri in nuova scheda',
  4828. placeholders: {
  4829. linkName: 'Il mio link',
  4830. },
  4831. },
  4832. // Keyboard Shortcuts Modal
  4833. keyboardShortcuts: {
  4834. title: 'Scorciatoie da tastiera',
  4835. navigation: 'Navigazione',
  4836. archivesSection: 'Archivi',
  4837. kProfilesSection: 'Profili K',
  4838. generalSection: 'Generale',
  4839. shortcuts: {
  4840. goToPrinters: 'Vai a Stampanti',
  4841. goToArchives: 'Vai ad Archivi',
  4842. goToQueue: 'Vai a Coda',
  4843. goToStats: 'Vai a Statistiche',
  4844. goToProfiles: 'Vai a Profili cloud',
  4845. goToSettings: 'Vai a Impostazioni',
  4846. focusSearch: 'Vai alla ricerca',
  4847. openUploadModal: 'Apri finestra di caricamento',
  4848. clearSelection: 'Cancella selezione / deseleziona input',
  4849. contextMenu: 'Menu contestuale sulle schede',
  4850. refreshProfiles: 'Aggiorna profili',
  4851. newProfile: 'Nuovo profilo',
  4852. exitSelectionMode: 'Esci dalla modalità selezione',
  4853. showHelp: 'Mostra questa guida',
  4854. },
  4855. footer: 'Premi Esc o clicca fuori per chiudere',
  4856. },
  4857. // Notification Log
  4858. notificationLog: {
  4859. title: 'Registro notifiche',
  4860. events: {
  4861. printStarted: 'Stampa avviata',
  4862. printComplete: 'Stampa completata',
  4863. printFailed: 'Stampa fallita',
  4864. printStopped: 'Stampa interrotta',
  4865. progress: 'Avanzamento',
  4866. printerOffline: 'Stampante offline',
  4867. printerError: 'Errore stampante',
  4868. lowFilament: 'Filamento in esaurimento',
  4869. maintenanceDue: 'Manutenzione in scadenza',
  4870. test: 'Test',
  4871. },
  4872. timeAgo: {
  4873. justNow: 'Adesso',
  4874. minutesAgo: '{{minutes}} min fa',
  4875. hoursAgo: '{{hours}} ore fa',
  4876. },
  4877. },
  4878. // Restore/Backup Modal
  4879. restoreBackup: {
  4880. title: 'Ripristina backup',
  4881. restoring: 'Ripristino...',
  4882. restoreComplete: 'Ripristino completato',
  4883. restoreFailed: 'Ripristino fallito',
  4884. importSettings: 'Importa impostazioni da un file di backup',
  4885. pleaseWait: 'Attendere il ripristino dei dati',
  4886. clickToSelect: 'Clicca per selezionare il file di backup (.json o .zip)',
  4887. howDuplicateHandling: 'Come funziona la gestione dei duplicati:',
  4888. categories: {
  4889. printers: 'Stampanti',
  4890. smartPlugs: 'Prese smart',
  4891. notificationProviders: 'Provider di notifica',
  4892. filaments: 'Filamenti',
  4893. archives: 'Archivi',
  4894. pendingUploads: 'Caricamenti in sospeso',
  4895. settingsTemplates: 'Impostazioni e modelli',
  4896. },
  4897. matchingInfo: {
  4898. printers: 'abbinati per numero di serie',
  4899. smartPlugs: 'abbinati per indirizzo IP',
  4900. notificationProviders: 'abbinati per nome',
  4901. filaments: 'abbinati per nome + tipo + marca',
  4902. archives: 'abbinati per hash del contenuto',
  4903. pendingUploads: 'abbinati per nome file',
  4904. settingsTemplates: 'sempre sovrascritti',
  4905. },
  4906. replaceExisting: 'Sostituisci dati esistenti',
  4907. keepExisting: 'Mantieni dati esistenti',
  4908. replaceDescription: 'Sovrascrivi gli elementi già esistenti con i dati del backup',
  4909. keepDescription: 'Ripristina solo gli elementi che non esistono già',
  4910. caution: 'Attenzione:',
  4911. cautionText: 'La sovrascrittura sostituirà le configurazioni attuali con i dati del backup. I codici di accesso delle stampanti non vengono mai sovrascritti per sicurezza.',
  4912. itemsRestored: 'Elementi ripristinati',
  4913. itemsSkipped: 'Elementi saltati',
  4914. restored: 'Ripristinati',
  4915. skipped: 'Saltati (già esistenti)',
  4916. filesLabel: 'File (3MF, miniature, ecc.)',
  4917. newApiKeysGenerated: 'Nuove chiavi API generate',
  4918. newApiKeysWarning: 'Queste chiavi vengono mostrate una sola volta. Copiale adesso!',
  4919. processingBackup: 'Elaborazione file di backup...',
  4920. noDataFound: 'Nessun dato trovato da ripristinare nel file di backup.',
  4921. failedToRestore: 'Impossibile ripristinare il backup. Verificare il formato del file.',
  4922. },
  4923. // Backup Export Modal
  4924. backupExport: {
  4925. title: 'Esporta backup',
  4926. selectData: 'Seleziona i dati da includere',
  4927. selectAll: 'Seleziona tutto',
  4928. selectNone: 'Deseleziona tutto',
  4929. categoryDescriptions: {
  4930. settings: 'Lingua, tema, preferenze di aggiornamento',
  4931. notifications: 'ntfy, Pushover, Discord, ecc.',
  4932. templates: 'Modelli di messaggi personalizzati',
  4933. smartPlugs: 'Configurazioni prese Tasmota',
  4934. externalLinks: 'Link della barra laterale a servizi esterni',
  4935. printers: 'Info stampanti (codici di accesso esclusi)',
  4936. plateDetection: 'Immagini di riferimento piatto vuoto',
  4937. filaments: 'Tipi di filamento e costi',
  4938. maintenance: 'Programmi di manutenzione personalizzati',
  4939. archives: 'Tutti i dati di stampa + file (3MF, miniature, foto)',
  4940. projects: 'Progetti, elementi BOM e allegati',
  4941. pendingUploads: 'Caricamenti della stampante virtuale in attesa di revisione',
  4942. apiKeys: 'Chiavi API webhook (nuove chiavi generate all\'importazione)',
  4943. },
  4944. requiresPrinters: 'Richiede la selezione di Stampanti',
  4945. zipFileWarning: 'Verrà creato un file ZIP.',
  4946. zipFileDescription: 'Include tutti i file 3MF, miniature, timelapse e foto. Potrebbe richiedere tempo e produrre un file di grandi dimensioni.',
  4947. includeAccessCodes: 'Includi codici di accesso',
  4948. includeAccessCodesDescription: 'Per il trasferimento su un\'altra macchina',
  4949. includeAccessCodesWarning: 'I codici di accesso saranno inclusi in testo semplice. Mantieni sicuro questo file di backup!',
  4950. categoriesSelected: '{{selectedCount}} categorie selezionate',
  4951. },
  4952. // Pending Uploads Panel
  4953. pendingUploads: {
  4954. placeholders: {
  4955. notes: 'Aggiungi note su questa stampa...',
  4956. },
  4957. discardUpload: 'Scarta caricamento',
  4958. archiveAllUploads: 'Archivia tutti i caricamenti',
  4959. discardAllUploads: 'Scarta tutti i caricamenti',
  4960. archive: 'Archivia',
  4961. timeAgo: {
  4962. justNow: 'Adesso',
  4963. minutesAgo: '{{minutes}} min fa',
  4964. hoursAgo: '{{hours}} ore fa',
  4965. daysAgo: '{{days}} giorni fa',
  4966. },
  4967. },
  4968. // API Browser
  4969. apiBrowser: {
  4970. placeholders: {
  4971. requestBody: 'Corpo della richiesta JSON...',
  4972. searchEndpoints: 'Cerca endpoint...',
  4973. },
  4974. },
  4975. // Configure AMS Slot Modal
  4976. configureAmsSlot: {
  4977. title: 'Configura Slot AMS',
  4978. slotConfigured: 'Slot configurato!',
  4979. configuringSlot: 'Configurazione slot:',
  4980. slotLabel: '{{ams}} – Slot {{slot}}',
  4981. searchPresets: 'Cerca preset...',
  4982. colorPlaceholder: 'Nome colore o hex (es. marrone, FF8800)',
  4983. clearCustomColor: 'Cancella colore personalizzato',
  4984. noCloudPresets: 'Nessun preset cloud. Accedi a Bambu Cloud per sincronizzare.',
  4985. noPresetsAvailable: 'Nessun preset disponibile. Accedi a Bambu Cloud o importa profili locali.',
  4986. noMatchingPresets: 'Nessun preset corrispondente trovato.',
  4987. custom: 'Personalizzato',
  4988. builtin: 'Integrato',
  4989. settingsSentToPrinter: 'Impostazioni inviate alla stampante',
  4990. filamentProfile: 'Profilo filamento',
  4991. kProfileLabel: 'Profilo K (Pressure Advance)',
  4992. filteringFor: 'Filtrando per: {{material}}',
  4993. noKProfile: 'Nessun profilo K (usa predefinito 0.020)',
  4994. noMatchingKProfiles: 'Nessun profilo K corrispondente. Verrà usato K=0.020 predefinito.',
  4995. selectFilamentFirst: 'Seleziona prima un profilo filamento',
  4996. kFromCalibration: 'K={{value}} dalla calibrazione stampante',
  4997. customColorLabel: 'Colore personalizzato (opzionale)',
  4998. presetColors: 'Colori {{name}}:',
  4999. showLessColors: 'Mostra meno colori',
  5000. showMoreColors: 'Mostra più colori',
  5001. clear: 'Cancella',
  5002. hexLabel: 'Hex – #{{hex}}',
  5003. resetting: 'Ripristino...',
  5004. resetSlot: 'Ripristina slot',
  5005. cancel: 'Annulla',
  5006. configuring: 'Configurazione...',
  5007. configureSlot: 'Configura slot',
  5008. },
  5009. // Git Backup Settings
  5010. githubBackup: {
  5011. title: 'Backup Git',
  5012. history: 'Cronologia',
  5013. downloadBackup: 'Scarica backup',
  5014. restoreBackup: 'Ripristina backup',
  5015. noBackupsYet: 'Nessun backup ancora',
  5016. },
  5017. // Email Settings
  5018. emailSettings: {
  5019. placeholders: {
  5020. fromName: 'Bambuddy',
  5021. },
  5022. },
  5023. // Tag Management Modal
  5024. tagManagement: {
  5025. searchTags: 'Cerca tag...',
  5026. renameTag: 'Rinomina tag',
  5027. deleteTag: 'Elimina tag',
  5028. },
  5029. // Notification Template Editor
  5030. notificationTemplates: {
  5031. placeholders: {
  5032. title: 'Titolo notifica...',
  5033. body: 'Corpo notifica...',
  5034. },
  5035. },
  5036. // Batch Tag Modal
  5037. batchTag: {
  5038. placeholders: {
  5039. newTag: 'Inserisci nuovo tag...',
  5040. },
  5041. },
  5042. // Photo Gallery Modal
  5043. photoGallery: {
  5044. deletePhoto: 'Elimina foto',
  5045. },
  5046. // Filament Hover Card
  5047. filamentHoverCard: {
  5048. copySpoolUuid: 'Copia UUID bobina',
  5049. },
  5050. // K Profiles View
  5051. kProfilesView: {
  5052. hasNote: 'Ha una nota',
  5053. copyProfile: 'Copia profilo',
  5054. },
  5055. // Layout/Navigation
  5056. layout: {
  5057. openMenu: 'Apri menu',
  5058. noPermissionSystemInfo: 'Non hai il permesso di visualizzare le informazioni di sistema',
  5059. },
  5060. // Dashboard
  5061. dashboard: {
  5062. dragToReorder: 'Trascina per riordinare',
  5063. hideWidget: 'Nascondi widget',
  5064. },
  5065. // Notification Provider Card
  5066. notificationProviderCard: {
  5067. deleteNotificationProvider: 'Elimina provider di notifica',
  5068. },
  5069. // File Manager Modal
  5070. fileManagerModal: {
  5071. closeFileManager: 'Chiudi gestore file',
  5072. sortFiles: 'Ordina file',
  5073. goToParentFolder: 'Vai alla cartella superiore',
  5074. threeView: 'Vista 3D',
  5075. },
  5076. // Embedded Camera Viewer
  5077. embeddedCameraViewer: {
  5078. refreshStream: 'Aggiorna stream',
  5079. close: 'Chiudi',
  5080. zoomOut: 'Rimpicciolisci',
  5081. resetZoom: 'Reimposta zoom',
  5082. zoomIn: 'Ingrandisci',
  5083. dragToResize: 'Trascina per ridimensionare',
  5084. },
  5085. // Timelapse Viewer
  5086. timelapseViewer: {
  5087. skipBack5s: 'Indietro 5s',
  5088. skipForward5s: 'Avanti 5s',
  5089. },
  5090. // Notification Providers
  5091. notificationProviders: {
  5092. descriptions: {
  5093. email: 'Notifiche email via SMTP',
  5094. telegram: 'Notifiche tramite bot Telegram',
  5095. discord: 'Invia a canale Discord tramite webhook',
  5096. ntfy: 'Notifiche push gratuite e self-hostabili',
  5097. pushover: 'Notifiche push semplici e affidabili',
  5098. callmebot: 'Notifiche WhatsApp gratuite tramite CallMeBot',
  5099. webhook: 'POST HTTP generico a qualsiasi URL',
  5100. },
  5101. },
  5102. // Log Viewer
  5103. logViewer: {
  5104. searchPlaceholder: 'Cerca messaggio o nome logger...',
  5105. noLogEntries: 'Nessuna voce di log trovata',
  5106. },
  5107. // Switchbar Popover
  5108. switchbarPopover: {
  5109. noSwitchesInSwitchbar: 'Nessun interruttore nella barra',
  5110. },
  5111. // Project Page Modal
  5112. projectPageModal: {
  5113. placeholders: {
  5114. title: 'Titolo',
  5115. designer: 'Designer',
  5116. license: 'Licenza',
  5117. description: 'Inserisci descrizione...',
  5118. profileTitle: 'Titolo profilo',
  5119. profileDescription: 'Descrizione profilo...',
  5120. },
  5121. },
  5122. // Spoolman Settings
  5123. spoolmanSettings: {},
  5124. // Time
  5125. time: {
  5126. unknown: '-',
  5127. waiting: 'In attesa',
  5128. justNow: 'Proprio ora',
  5129. now: 'Ora',
  5130. minsAgo: '{{count}}m fa',
  5131. inMins: 'tra {{count}}m',
  5132. hoursAgo: '{{count}}h fa',
  5133. inHours: 'tra {{count}}h',
  5134. daysAgo: '{{count}}g fa',
  5135. inDays: 'tra {{count}}g',
  5136. },
  5137. // SpoolBuddy Kiosk
  5138. spoolbuddy: {
  5139. nav: {
  5140. dashboard: 'Dashboard',
  5141. ams: 'AMS',
  5142. inventory: 'Inventario',
  5143. writeTag: 'Scrivi',
  5144. settings: 'Impostazioni',
  5145. },
  5146. status: {
  5147. nfcReady: 'NFC pronto',
  5148. nfcOff: 'NFC spento',
  5149. offline: 'Offline',
  5150. online: 'Online',
  5151. noPrinters: 'Nessuna stampante',
  5152. deviceOffline: 'Dispositivo offline',
  5153. waitingConnection: 'In attesa della connessione...',
  5154. systemReady: 'Sistema pronto',
  5155. status: 'Stato',
  5156. },
  5157. dashboard: {
  5158. readyToScan: 'Pronto per la scansione',
  5159. idleMessage: 'Posiziona una bobina sulla bilancia per identificarla',
  5160. nfcHint: 'Il tag NFC verrà letto automaticamente',
  5161. device: 'Dispositivo',
  5162. syncWeight: 'Sincronizza peso',
  5163. weightSynced: 'Sincronizzato!',
  5164. unknownTag: 'Tag sconosciuto',
  5165. newTag: 'Nuovo tag rilevato',
  5166. onScale: 'sulla bilancia',
  5167. linkSpool: 'Collega a bobina',
  5168. linkTagTitle: 'Collega tag a bobina',
  5169. linkTag: 'Collega tag',
  5170. selectSpool: 'Seleziona una bobina da collegare a questo tag:',
  5171. noUntagged: 'Nessuna bobina senza tag trovata',
  5172. tagDetected: 'Tag rilevato',
  5173. noTag: 'Nessun tag',
  5174. tagId: 'Etichetta',
  5175. grossWeight: 'Peso lordo',
  5176. spoolSize: 'Dimensione bobina',
  5177. close: 'Chiudi',
  5178. currentSpool: 'Bobina attuale',
  5179. plateReady: 'Piatto pronto: {{name}}',
  5180. plateReadyLabel: 'Piatti da liberare',
  5181. plateClearAction: 'Libera',
  5182. plateClearedToast: 'Piatto contrassegnato come liberato',
  5183. plateClearFailed: 'Impossibile contrassegnare il piatto come liberato',
  5184. },
  5185. modal: {
  5186. spoolDetected: 'Bobina rilevata',
  5187. assignToAms: 'Assegna all\'AMS',
  5188. syncWeight: 'Sincronizza peso',
  5189. weightSynced: 'Sincronizzato!',
  5190. syncing: 'Sincronizzazione...',
  5191. newTagDetected: 'Nuovo tag rilevato',
  5192. addToInventory: 'Aggiungi all\'inventario',
  5193. assignToAmsTitle: 'Assegna all\'AMS',
  5194. selectSlot: 'Seleziona uno slot',
  5195. assign: 'Assegna',
  5196. assigning: 'Assegnazione...',
  5197. assignSuccess: 'Assegnato!',
  5198. assignPendingInsert: 'Assegnato. Lo slot verrà configurato all\'inserimento della bobina.',
  5199. assignError: 'Impossibile assegnare la bobina. Riprovare.',
  5200. noPrinterSelected: 'Seleziona una stampante...',
  5201. noAmsDetected: 'Nessun AMS rilevato su questa stampante',
  5202. slot: 'Slot',
  5203. },
  5204. weight: {
  5205. noReading: 'Nessuna lettura',
  5206. stable: 'Stabile',
  5207. measuring: 'Misurazione...',
  5208. tare: 'Tara',
  5209. calibrate: 'Calibra',
  5210. },
  5211. spool: {
  5212. remaining: 'Rimanente',
  5213. material: 'Materiale',
  5214. brand: 'Marca',
  5215. color: 'Colore',
  5216. coreWeight: 'Nucleo',
  5217. labelWeight: 'Etichetta',
  5218. scaleWeight: 'Bilancia',
  5219. netWeight: 'Netto',
  5220. lastUsed: 'Ultimo utilizzo',
  5221. },
  5222. ams: {
  5223. noData: 'Nessun AMS rilevato',
  5224. connectAms: 'Collega un AMS per vedere gli slot',
  5225. noPrinter: 'Nessuna stampante selezionata',
  5226. selectPrinter: 'Seleziona una stampante dalla barra superiore',
  5227. printerDisconnected: 'Stampante disconnessa',
  5228. humidity: 'Umidità',
  5229. level: 'Livello',
  5230. active: 'Attivo',
  5231. slot: 'Slot',
  5232. empty: 'Vuoto',
  5233. },
  5234. inventory: {
  5235. search: 'Cerca bobine...',
  5236. empty: 'Nessuna bobina nell\'inventario',
  5237. noResults: 'Nessuna bobina corrispondente',
  5238. spools: 'bobine',
  5239. addSpool: 'Aggiungi bobina',
  5240. },
  5241. settings: {
  5242. // Tabs
  5243. tabDevice: 'Dispositivo',
  5244. tabDisplay: 'Display',
  5245. tabScale: 'Bilancia',
  5246. tabUpdates: 'Aggiornamenti',
  5247. // Device tab
  5248. nfcReader: 'Lettore NFC',
  5249. type: 'Tipo',
  5250. connection: 'Connessione',
  5251. notConnected: 'N/D',
  5252. deviceInfo: 'Info dispositivo',
  5253. hostname: 'Host',
  5254. uptime: 'Tempo di attività',
  5255. // Display tab
  5256. brightness: 'Luminosità',
  5257. saved: 'Salvato',
  5258. noBacklight: 'Nessuna retroilluminazione DSI rilevata. Il controllo luminosità richiede un display DSI.',
  5259. screenBlank: 'Timeout spegnimento schermo',
  5260. screenBlankDesc: 'Lo schermo si spegne dopo inattività. Tocca per riattivare.',
  5261. displayNote: 'La luminosità viene applicata come filtro software.',
  5262. // Scale tab
  5263. scaleCalibration: 'Calibrazione bilancia',
  5264. currentWeight: 'Peso attuale',
  5265. tareOffset: 'Tara',
  5266. calFactor: 'Fattore',
  5267. knownWeight: 'Peso noto',
  5268. calStep1: 'Rimuovere tutto dalla bilancia e premere Imposta zero.',
  5269. calStep2: 'Posizionare il peso noto sulla bilancia.',
  5270. setZero: 'Imposta zero',
  5271. calibrateNow: 'Calibra',
  5272. calibrated: 'Calibrato',
  5273. tareSet: 'Comando tara inviato. In attesa del dispositivo...',
  5274. tareFailed: 'Invio comando tara fallito',
  5275. zeroSet: 'Punto zero impostato. Posizionare il peso noto sulla bilancia.',
  5276. calibrationDone: 'Calibrazione completata!',
  5277. calibrationFailed: 'Calibrazione fallita',
  5278. lastCalibrated: 'Ultima calibrazione',
  5279. stable: 'Stabile',
  5280. settling: 'Stabilizzazione...',
  5281. firmware: 'Firmware',
  5282. scale: 'Bilancia',
  5283. noDevice: 'Nessun dispositivo SpoolBuddy trovato',
  5284. // Updates tab
  5285. daemonVersion: 'Versione daemon',
  5286. currentVersion: 'Attuale',
  5287. versionPending: 'In attesa del daemon...',
  5288. checking: 'Verifica...',
  5289. checkUpdates: 'Verifica aggiornamenti',
  5290. updateAvailable: 'Aggiornamento disponibile',
  5291. updateInstructions: 'Aggiorna via SSH: esegui lo script di installazione SpoolBuddy.',
  5292. upToDate: 'Aggiornato',
  5293. includeBeta: 'Includi versioni beta',
  5294. systemConfig: 'Backend & autenticazione',
  5295. backendUrl: 'URL backend Bambuddy',
  5296. apiToken: 'Token API',
  5297. apiTokenPlaceholder: 'Inserisci token API',
  5298. saveConfig: 'Salva configurazione',
  5299. systemQueued: 'Configurazione in coda.',
  5300. systemFieldsRequired: 'L\'URL del backend è obbligatorio.',
  5301. nfcDiagnostic: 'Diagnostica NFC',
  5302. scaleDiagnostic: 'Diagnostica bilancia',
  5303. readTagDiagnostic: 'Diagnostica lettura tag',
  5304. testNfc: 'Test lettore',
  5305. testScale: 'Test precisione',
  5306. testReadTag: 'Leggi tag',
  5307. },
  5308. writeTag: {
  5309. tabExisting: 'Bobina esistente',
  5310. tabNew: 'Nuova bobina',
  5311. tabReplace: 'Sostituisci tag',
  5312. searchPlaceholder: 'Cerca per materiale, colore, marca...',
  5313. noUntaggedSpools: 'Nessuna bobina senza tag',
  5314. noTaggedSpools: 'Nessuna bobina con tag',
  5315. selectSpool: 'Seleziona una bobina, poi posiziona un NTAG sul lettore',
  5316. placeTag: 'Posiziona un NTAG sul lettore',
  5317. tagReady: 'Tag rilevato — pronto per la scrittura',
  5318. writeTag: 'Scrivi tag',
  5319. replaceTag: 'Sostituisci tag',
  5320. writing: 'Scrittura tag...',
  5321. waiting: 'In attesa di SpoolBuddy...',
  5322. writeSuccess: 'Tag scritto con successo!',
  5323. writeFailed: 'Scrittura fallita',
  5324. queueFailed: 'Impossibile accodare il comando di scrittura',
  5325. tryAgain: 'Riprova',
  5326. cancel: 'Annulla',
  5327. replaceWarning: 'Il vecchio tag verrà scollegato. Il nuovo tag lo sostituirà.',
  5328. deviceOffline: 'SpoolBuddy è offline',
  5329. material: 'Materiale',
  5330. colorName: 'Nome colore',
  5331. color: 'Colore',
  5332. brand: 'Marca',
  5333. weight: 'Peso (g)',
  5334. createSpool: 'Crea bobina',
  5335. creating: 'Creazione...',
  5336. spoolCreated: 'Bobina creata! Pronto per la scrittura.',
  5337. createFailed: 'Impossibile creare la bobina',
  5338. incompleteDataWarning: 'Tag scritto con dati Spoolman incompleti',
  5339. },
  5340. quickMenu: {
  5341. printerPower: 'Alimentazione stampante',
  5342. systemControls: 'Sistema',
  5343. restartDaemon: 'Riavvia daemon',
  5344. restartBrowser: 'Riavvia browser',
  5345. reboot: 'Riavvia',
  5346. shutdown: 'Spegni',
  5347. swipeToClose: 'Scorri verso il basso per chiudere',
  5348. confirmTitle: 'Conferma',
  5349. confirmShutdown: 'Sei sicuro di voler spegnere lo SpoolBuddy? Avrai bisogno di accesso fisico per riaccenderlo.',
  5350. confirmReboot: 'Sei sicuro di voler riavviare lo SpoolBuddy?',
  5351. confirmRestartDaemon: 'Riavviare il daemon SpoolBuddy? NFC e bilancia saranno temporaneamente non disponibili.',
  5352. confirmRestartBrowser: 'Riavviare il browser kiosk? Lo schermo diventerà brevemente nero.',
  5353. confirm: 'Conferma',
  5354. confirmPlugOn: 'Accendere {{name}}?',
  5355. confirmPlugOff: 'Spegnere {{name}}?',
  5356. turnOn: 'Accendi',
  5357. turnOff: 'Spegni',
  5358. },
  5359. },
  5360. bugReport: {
  5361. title: 'Segnala un bug',
  5362. description: 'Descrizione',
  5363. descriptionPlaceholder: 'Cosa è andato storto? Descrivi il problema...',
  5364. email: 'Email (opzionale)',
  5365. emailPlaceholder: 'tua@email.it',
  5366. emailPrivacy: 'Se fornita, la tua email sarà inclusa in una sezione compressa dell\'issue GitHub per permettere al manutentore di contattarti.',
  5367. screenshot: 'Schermata',
  5368. uploadOrPaste: 'Carica, incolla o trascina un\'immagine',
  5369. dataCollectedSummary: 'Quali dati sono inclusi nel report?',
  5370. dataIncluded: 'Inclusi:',
  5371. dataIncludedList: 'Versione app, OS, architettura, versione Python, statistiche database (solo conteggi), modelli stampante, numero ugelli, versioni firmware, stato connessione, stato integrazioni (Spoolman, MQTT, HA), impostazioni non sensibili, conteggio interfacce di rete, dettagli Docker, versioni dipendenze.',
  5372. dataNeverIncluded: 'Mai inclusi:',
  5373. dataNeverIncludedList: 'Nomi stampanti, numeri di serie, codici di accesso, password, indirizzi IP, indirizzi email, chiavi API, token, URL webhook, nomi host o nomi utente.',
  5374. submit: 'Invia',
  5375. startLogging: 'Avvia registrazione debug',
  5376. stepEnableLogging: 'Registrazione debug attivata',
  5377. stepReproduce: 'Riproduci il problema ora',
  5378. stepStopLogging: 'Ferma & invia rapporto',
  5379. stopAndSubmit: 'Ferma & Invia',
  5380. maxDuration: 'Arresto automatico dopo {{minutes}} min',
  5381. stoppingLogs: 'Raccolta log & invio...',
  5382. submitting: 'Invio segnalazione bug...',
  5383. submitSuccess: 'Segnalazione bug inviata con successo!',
  5384. submitFailed: 'Impossibile inviare la segnalazione bug',
  5385. thankYou: 'Grazie!',
  5386. submitted: 'La tua segnalazione bug è stata inviata.',
  5387. viewIssue: 'Vedi issue',
  5388. unexpectedError: 'Si è verificato un errore imprevisto',
  5389. },
  5390. failureDetection: {
  5391. title: 'Rilevamento guasti con IA',
  5392. description: 'Monitora le stampe tramite un\'API ML Obico auto-ospitata e agisce automaticamente sui guasti rilevati.',
  5393. mlUrl: 'URL API ML Obico',
  5394. mlUrlHint: 'URL base del tuo container Obico ml_api auto-ospitato (es. http://192.168.1.10:3333).',
  5395. test: 'Prova',
  5396. testSuccess: 'API ML raggiungibile e funzionante.',
  5397. testFailed: 'Impossibile raggiungere l\'API ML.',
  5398. sensitivity: 'Sensibilità',
  5399. sensitivityLow: 'Bassa (meno falsi positivi)',
  5400. sensitivityMedium: 'Media (bilanciata)',
  5401. sensitivityHigh: 'Alta (rilevamento precoce, più falsi positivi)',
  5402. sensitivityHint: 'Regola le soglie di confidenza che attivano avvisi e guasti.',
  5403. action: 'Azione al guasto rilevato',
  5404. actionNotify: 'Solo notifica',
  5405. actionPause: 'Metti in pausa',
  5406. actionPauseOff: 'Pausa e stacca corrente',
  5407. pollInterval: 'Intervallo di controllo (secondi)',
  5408. pollIntervalHint: 'Frequenza di controllo di ogni stampante durante la stampa. Minimo 5s, massimo 120s.',
  5409. externalUrlMissing: 'URL esterno non impostato.',
  5410. externalUrlHint: 'L\'API ML recupera l\'istantanea della telecamera tramite URL. Imposta l\'URL esterno nelle impostazioni generali in modo che il container API ML possa raggiungere Bambuddy.',
  5411. perPrinterTitle: 'Stampanti monitorate',
  5412. perPrinterHint: 'Scegli quali stampanti il servizio di rilevamento deve monitorare.',
  5413. monitorAll: 'Monitora tutte le stampanti connesse',
  5414. statusTitle: 'Stato',
  5415. serviceRunning: 'Servizio in esecuzione',
  5416. thresholds: 'Soglie bassa / alta',
  5417. activePrinters: 'Stampe attive',
  5418. noActivePrints: 'Nessuna stampa in corso.',
  5419. historyTitle: 'Rilevamenti recenti',
  5420. noHistory: 'Nessun rilevamento finora.',
  5421. },
  5422. makerworld: {
  5423. title: 'MakerWorld',
  5424. description: 'Incolla un URL di un modello MakerWorld per importarlo e stamparlo direttamente da Bambuddy — senza passare dall\'app Bambu Handy.',
  5425. pasteUrlHeader: 'Importa da MakerWorld',
  5426. pasteUrlPlaceholder: 'https://makerworld.com/en/models/… o incolla qualsiasi link MakerWorld',
  5427. resolveButton: 'Risolvi',
  5428. signInRequiredTitle: 'Accesso Bambu Cloud richiesto per scaricare',
  5429. signInRequiredBody: 'Puoi consultare i dettagli del modello in modo anonimo, ma MakerWorld richiede un account Bambu Cloud per scaricare i file 3MF.',
  5430. openCloudSettings: 'Apri impostazioni Cloud',
  5431. untitledModel: 'Modello senza titolo',
  5432. byCreator: 'di {{name}}',
  5433. downloadsCount: '{{count}} download',
  5434. licensePrefix: 'Licenza',
  5435. alreadyImported: 'Già nella libreria',
  5436. openOnMakerworld: 'Apri su MakerWorld',
  5437. alreadyInLibrary: 'Questo modello è già nella tua libreria — lo trovi in Gestione file → MakerWorld',
  5438. importSuccess: '{{filename}} importato — salvato in Gestione file → MakerWorld',
  5439. platesHeader: 'Piatti ({{count}})',
  5440. plateDefaultName: 'Piatto {{n}}',
  5441. materialCount: '{{count}} filamenti',
  5442. amsRequired: 'AMS richiesto',
  5443. slicedFor: 'Sezionato per {{printer}}',
  5444. alsoCompatible: 'Anche contrassegnato come compatibile: {{printers}}',
  5445. importToLibrary: 'Salva',
  5446. sliceIn: 'Salva e affetta in {{slicer}}',
  5447. disclaimer: 'L\'integrazione MakerWorld utilizza endpoint API documentati dalla community. Bambuddy non è affiliato né approvato da MakerWorld o Bambu Lab.',
  5448. lastImportSuccess: 'Importato nella tua libreria',
  5449. lastImportAlreadyInLibrary: 'Già nella tua libreria',
  5450. viewInLibrary: 'Visualizza in Gestione file',
  5451. openInBambuStudio: 'Apri in Bambu Studio',
  5452. openInOrcaSlicer: 'Apri in OrcaSlicer',
  5453. importTo: 'Importa in Gestione file',
  5454. recentImportsHeader: 'Importazioni recenti',
  5455. phaseResolving: 'Risoluzione',
  5456. phaseDownloading: 'Download',
  5457. folderAuto: 'MakerWorld (predefinita)',
  5458. importAll: 'Importa tutto',
  5459. importAllProgress: 'Importazione {{current}}/{{total}}',
  5460. openGallery: 'Apri galleria immagini',
  5461. galleryPrev: 'Immagine precedente',
  5462. galleryNext: 'Immagine successiva',
  5463. deleteImport: 'Rimuovi dalla libreria',
  5464. importDeleting: 'Rimozione…',
  5465. importDeleted: 'Rimosso dalla libreria',
  5466. confirmDelete: 'Rimuovere {{filename}} dalla libreria? Il file locale verrà eliminato, ma il piatto può essere re-importato da MakerWorld.',
  5467. errors: {
  5468. resolveFailed: 'Impossibile risolvere questo URL MakerWorld.',
  5469. downloadFailed: 'Download non riuscito. Riprova.',
  5470. deleteFailed: 'Impossibile rimuovere il file dalla libreria.',
  5471. },
  5472. },
  5473. gcodeViewer: {
  5474. back: 'Indietro',
  5475. backToArchives: 'Torna agli archivi di stampa',
  5476. backToFiles: 'Torna al gestore file',
  5477. },
  5478. libraryTrash: {
  5479. title: 'Cestino',
  5480. headerButton: 'Cestino',
  5481. headerTooltip: 'Visualizza i file spostati nel cestino',
  5482. backToFiles: 'Torna al gestore file',
  5483. subtitleAdmin: 'I file eliminati restano qui per {{days}} giorni, poi vengono rimossi automaticamente. Questa vista mostra il cestino di tutti gli utenti.',
  5484. subtitleUser: 'I file eliminati restano qui per {{days}} giorni, poi vengono rimossi automaticamente.',
  5485. loading: 'Caricamento del cestino…',
  5486. loadError: 'Impossibile caricare il cestino.',
  5487. empty: 'Il cestino è vuoto.',
  5488. summary: '{{count}} file · {{size}}',
  5489. emptyTrash: 'Svuota cestino',
  5490. restore: 'Ripristina',
  5491. purgeNow: 'Elimina ora',
  5492. autoPurgeIn: 'Eliminazione automatica tra {{when}}',
  5493. days: 'giorni',
  5494. retentionLabel: 'Elimina automaticamente dopo',
  5495. selectAll: 'Seleziona tutto',
  5496. selectOne: 'Seleziona {{filename}}',
  5497. selectionCount: '{{count}} selezionati',
  5498. bulkRestore: 'Ripristina selezionati',
  5499. bulkPurge: 'Elimina selezionati',
  5500. col: {
  5501. filename: 'File',
  5502. folder: 'Cartella',
  5503. size: 'Dimensione',
  5504. deleted: 'Spostato nel cestino',
  5505. autoPurge: 'Eliminazione auto.',
  5506. owner: 'Proprietario',
  5507. actions: 'Azioni',
  5508. },
  5509. confirm: {
  5510. purgeTitle: 'Eliminare definitivamente?',
  5511. purgeBody: '{{filename}} verrà eliminato dal disco e non potrà essere ripristinato.',
  5512. emptyTitle: 'Svuotare il cestino?',
  5513. emptyBody: 'Tutti i {{count}} file verranno eliminati dal disco. Azione non annullabile.',
  5514. bulkPurgeTitle: 'Eliminare definitivamente i file selezionati?',
  5515. bulkPurgeBody: 'I {{count}} file selezionati verranno eliminati dal disco e non potranno essere ripristinati.',
  5516. cta: 'Elimina definitivamente',
  5517. },
  5518. toast: {
  5519. restored: 'File ripristinato.',
  5520. restoreFailed: 'Impossibile ripristinare il file.',
  5521. purged: 'File eliminato definitivamente.',
  5522. purgeFailed: 'Impossibile eliminare il file.',
  5523. emptied: '{{count}} file eliminati dal cestino.',
  5524. emptyFailed: 'Impossibile svuotare il cestino.',
  5525. retentionSaved: 'Eliminazione automatica impostata su {{days}} giorni.',
  5526. retentionFailed: 'Impossibile salvare l\'impostazione di conservazione.',
  5527. bulkRestored: '{{count}} file ripristinati.',
  5528. bulkPurged: '{{count}} file eliminati.',
  5529. },
  5530. },
  5531. libraryPurge: {
  5532. title: 'Elimina file vecchi',
  5533. headerButton: 'Elimina vecchi',
  5534. headerTooltip: 'Sposta in blocco i file vecchi nel cestino',
  5535. description: 'I file più vecchi della soglia verranno spostati nel cestino. Le cartelle esterne vengono ignorate. Puoi ripristinarli dal cestino prima dell\'eliminazione automatica.',
  5536. ageLabel: 'Sposta i file più vecchi di',
  5537. days: 'giorni',
  5538. includeNeverPrinted: 'Includi i file mai stampati',
  5539. effectsTitle: 'Cosa succede quando fai clic su Pulisci',
  5540. effect1: 'I file corrispondenti vengono spostati nel cestino — non sono ancora eliminati dal disco.',
  5541. effect2: 'Puoi ripristinarli dal cestino in qualsiasi momento fino alla scadenza del periodo di conservazione.',
  5542. effect3: 'Dopo il periodo di conservazione, lo spazzino del cestino li rimuove definitivamente.',
  5543. effect4: 'I file in cartelle esterne (collegate) vengono saltati — Bambuddy non elimina mai dati che non possiede.', previewLoading: 'Verifica quanti file corrispondono…',
  5544. previewFailed: 'Impossibile mostrare l\'anteprima.',
  5545. previewSummary: '{{count}} file · {{size}} verrebbero spostati nel cestino',
  5546. andMore: '…e altri {{count}}',
  5547. warning: 'I file vengono eliminati in modo soft — puoi ripristinarli dal cestino fino alla scadenza del periodo di conservazione.',
  5548. confirmCta: 'Sposta {{count}} nel cestino',
  5549. purging: 'Spostamento nel cestino…',
  5550. toast: {
  5551. success: '{{count}} file spostati nel cestino.',
  5552. failed: 'Impossibile eliminare i file.',
  5553. },
  5554. },
  5555. libraryAutoPurge: {
  5556. enableLabel: 'Elimina automaticamente i file vecchi',
  5557. enableDescription: 'Esegue l\'eliminazione amministrativa una volta al giorno. I file finiscono prima nel cestino — non vengono eliminati immediatamente.',
  5558. ageLabel: 'Elimina automaticamente i file più vecchi di',
  5559. ageDescription: 'Minimo 7 giorni, massimo 10 anni. Usa la stessa regola di età del pulsante Elimina manuale.',
  5560. days: 'giorni',
  5561. includeNeverPrinted: 'Includi i file mai stampati',
  5562. saveFailed: 'Impossibile salvare le impostazioni di eliminazione automatica.',
  5563. },
  5564. archivePurge: {
  5565. headerButton: 'Elimina vecchi',
  5566. headerTooltip: 'Eliminazione massiva vecchi archivi',
  5567. title: 'Elimina vecchi archivi',
  5568. description: 'Cancella la vecchia cronologia di stampa. Ogni archivio invecchia in base alla sua ultima stampa completata — ristampare azzera l\'età, quindi il lavoro attivo non viene mai eliminato.',
  5569. ageLabel: 'Elimina archivi non stampati negli ultimi',
  5570. days: 'giorni',
  5571. effectsTitle: 'Cosa succede quando fai clic su Pulisci',
  5572. effect1: 'Ogni archivio corrispondente viene nascosto dagli elenchi e i suoi file vengono rimossi dal disco (3MF, miniatura, timelapse, 3MF sorgente, F3D, foto).',
  5573. effect2: 'La riga dell\'archivio rimane nel database, così le Quick Stats conservano il contributo di filamento, tempo, costo ed energia — come il comportamento predefinito dell\'eliminazione singola.',
  5574. effect3: 'Spunta «Rimuovi anche dalle statistiche» qui sotto per eliminare anche il contributo dalle Quick Stats (equivalente all\'opzione dell\'eliminazione singola). Questo percorso è irreversibile.',
  5575. effect4: 'Ristampare un archivio azzera il suo conteggio dell\'età, quindi gli archivi attivi sono al sicuro.',
  5576. purgeStatsLabel: 'Rimuovi anche dalle statistiche',
  5577. purgeStatsHint: 'Rimuove gli archivi selezionati dalle Quick Stats (filamento, tempo, costo, energia). Senza questa opzione le Quick Stats conservano ogni contributo e solo i file vengono cancellati.',
  5578. previewLoading: 'Verifica del numero di archivi corrispondenti…',
  5579. previewFailed: 'Impossibile visualizzare l\'anteprima della pulizia.',
  5580. previewSummary: '{{count}} archivi · {{size}} verrebbero rimossi',
  5581. andMore: '…e altri {{count}}',
  5582. warning: 'I file vengono rimossi dal disco e non possono essere ripristinati. Scarica o aggiungi ai preferiti tutto ciò che vuoi conservare prima di continuare.',
  5583. confirmCta: 'Rimuovi {{count}} archivio(i)',
  5584. purging: 'Rimozione…',
  5585. toast: {
  5586. success: '{{count}} archivio(i) rimosso.',
  5587. failed: 'Impossibile eliminare gli archivi.',
  5588. },
  5589. },
  5590. archiveAutoPurge: {
  5591. enableLabel: 'Elimina auto. vecchi archivi',
  5592. enableDescription: 'Una volta al giorno nasconde dagli elenchi gli archivi non stampati entro la soglia e rimuove i loro file dal disco. Ristampare azzera il timer.',
  5593. ageLabel: 'Eliminazione auto. di archivi non stampati negli ultimi',
  5594. ageDescription: 'Minimo 7 giorni, massimo 10 anni. Basato sull\'ultima stampa completata — ristampare azzera l\'età. Rimuove 3MF, miniatura, timelapse, 3MF sorgente, F3D e foto.',
  5595. days: 'giorni',
  5596. purgeStatsLabel: 'Rimuovi anche dalle statistiche',
  5597. purgeStatsDescription: 'Quando abilitato, lo sweeper giornaliero elimina anche il contributo di ogni archivio purgato dalle Quick Stats (filamento, tempo, costo, energia). Disabilitato per impostazione predefinita — le Quick Stats mantengono il contributo e solo i file vengono cancellati.',
  5598. runNow: 'Elimina archivi ora',
  5599. saveFailed: 'Impossibile salvare le impostazioni di pulizia automatica.',
  5600. },
  5601. cameraTokens: {
  5602. title: 'Token API telecamera',
  5603. navTitle: 'Token API telecamera',
  5604. description:
  5605. 'Token a lunga durata per incorporare lo stream della telecamera in Home Assistant, Frigate, chioschi o qualsiasi altro strumento che richieda un URL stabile. Ogni token è limitato allo stream della telecamera e può essere revocato in qualsiasi momento.',
  5606. loading: 'Caricamento…',
  5607. confirmRevoke: {
  5608. title: 'Revocare questo token?',
  5609. body: 'Qualsiasi dispositivo che usa "{{name}}" perderà l\'accesso immediatamente. Non può essere annullato.',
  5610. cancel: 'Annulla',
  5611. confirm: 'Revoca',
  5612. },
  5613. create: {
  5614. title: 'Crea nuovo token',
  5615. nameLabel: 'Nome token',
  5616. namePlaceholder: 'es. Home Assistant',
  5617. daysLabel: 'Giorni alla scadenza',
  5618. submit: 'Crea',
  5619. hint:
  5620. 'Durata massima 365 giorni. Il valore del token viene mostrato solo alla creazione — copialo ora.',
  5621. },
  5622. created: {
  5623. title: 'Token creato – copialo ora',
  5624. warning:
  5625. 'Questa è l\'unica volta in cui questo token sarà visibile. Dopo la chiusura di questa finestra non potrai più visualizzarlo.',
  5626. copy: 'Copia',
  5627. dismiss: 'L\'ho salvato',
  5628. },
  5629. list: {
  5630. myTitle: 'I miei token',
  5631. allTitle: 'Tutti gli utenti (vista admin)',
  5632. empty: 'Nessun token ancora.',
  5633. name: 'Nome',
  5634. owner: 'Proprietario',
  5635. prefix: 'Prefisso',
  5636. created: 'Creato',
  5637. expires: 'Scade',
  5638. lastUsed: 'Ultimo uso',
  5639. revoke: 'Revoca',
  5640. expired: 'Scaduto',
  5641. },
  5642. toast: {
  5643. created: 'Token creato',
  5644. createFailed: 'Creazione token fallita',
  5645. revoked: 'Token revocato',
  5646. revokeFailed: 'Revoca token fallita',
  5647. loadFailed: 'Caricamento token fallito',
  5648. copied: 'Copiato negli appunti',
  5649. copyFailed: 'Copia non riuscita – seleziona e copia manualmente',
  5650. },
  5651. },
  5652. // Forecast & Inventory Intelligence
  5653. forecast: {
  5654. title: 'Previsione scorte',
  5655. noSpools: 'Nessuna bobina attiva trovata. Aggiungi bobine al tuo inventario per vedere i dati di previsione.',
  5656. noUsageData: 'Nessun dato di utilizzo disponibile — impossibile proiettare la timeline delle scorte.',
  5657. sku: 'SKU',
  5658. // Table headers
  5659. material: 'Materiale',
  5660. stock: 'Scorte',
  5661. dailyRate: 'Tasso',
  5662. daysLeft: 'Giorni rimanenti',
  5663. emptyBy: 'Esaurimento previsto',
  5664. reorderBy: 'Riordinare entro',
  5665. actions: 'Azioni',
  5666. // Rate tier badges
  5667. trend: 'Tendenza',
  5668. estimated: 'Stim.',
  5669. noData: 'Nessun dato',
  5670. // Timeframe
  5671. timeframe: 'Periodo',
  5672. // Chart
  5673. chartTitle: 'Stock proiettato — Top 5 materiali',
  5674. dashedLinesROP: 'Linee tratteggiate = punti di riordino',
  5675. stockLevel: 'Livello scorte',
  5676. reorderPoint: 'Punto di riordino',
  5677. safetyMargin: 'Margine di sicurezza',
  5678. trendLegend: 'Tendenza (basata su storico, livello servizio 95%)',
  5679. estimatedLegend: 'Stimata (delta peso)',
  5680. noDataLegend: 'Nessun dato',
  5681. ropLabel: 'PR',
  5682. ssLabel: 'SS',
  5683. safetyStockLegend: 'Scorta di sicurezza',
  5684. stockArrivalLegend: 'Arrivo merce',
  5685. stockoutLegend: 'Esaurimento scorte',
  5686. // Alerts toolbar
  5687. alertCount_one: '{{count}} avviso',
  5688. alertCount_other: '{{count}} avvisi',
  5689. order: 'Ordina',
  5690. // Settings
  5691. globalLeadTime: 'Lead time globale',
  5692. globalLeadTimeHint: 'Lead time globale minimo — usato nel calcolo del punto di riordino per tutti gli SKU',
  5693. save: 'Salva',
  5694. cancel: 'Annulla',
  5695. settingsSaved: 'Impostazioni salvate',
  5696. failedSaveSettings: 'Impossibile salvare le impostazioni',
  5697. globalLeadTimeSaved: 'Lead time globale salvato',
  5698. skuLeadTimeOverride: 'Override lead time SKU',
  5699. skuLeadTimeHint: '0 = usa lead time globale. Imposta >0 per sovrascrivere per questo SKU.',
  5700. safetyMarginLabel: 'Margine di sicurezza',
  5701. effectiveLeadTime: 'Lead time effettivo',
  5702. effectiveLeadTimeHint: 'max(globale {{global}}g, SKU {{sku}}g)',
  5703. reorderPointHint: 'd̄ × LT + safety margin — ordina quando le scorte raggiungono questo livello',
  5704. safetyMarginHint: 'Scorta di sicurezza statistica (z=1,65 × σ × √LT) + buffer definito dall\'utente',
  5705. safetyMarginHintDays: 'Buffer aggiunto sulla scorta di sicurezza statistica.{{approx}}',
  5706. safetyMarginHintDaysApprox: ' ≈ {{g}}g al tasso attuale.',
  5707. safetyMarginHintG: 'Buffer di peso fisso aggiunto sulla scorta di sicurezza statistica.{{approx}}',
  5708. safetyMarginHintGApprox: ' ≈ {{days}}g al tasso attuale.',
  5709. individualSpools: 'Bobine singole',
  5710. labelWeight: 'Etichetta',
  5711. spoolCount_one: '{{count}} bobina',
  5712. spoolCount_other: '{{count}} bobine',
  5713. // Alerts
  5714. stockBreakRisk: 'Rischio di rottura scorte',
  5715. stockBreakBefore: 'Rottura scorte prima del rifornimento',
  5716. stockBreakDetail: '{{days}}g rimanenti, lead time {{lt}}g.',
  5717. reorderNow: 'Riordina ora',
  5718. reorderTriggerPassed: 'La data di attivazione {{date}} è passata.',
  5719. // Shopping list
  5720. shoppingList: 'Lista della spesa',
  5721. shoppingListItems_one: '({{count}} articolo)',
  5722. shoppingListItems_other: '({{count}} articoli)',
  5723. shoppingListEmpty: 'La lista della spesa è vuota. Clicca sull\'icona del carrello in qualsiasi riga per aggiungere articoli.',
  5724. addToCart: 'Aggiungi alla lista della spesa',
  5725. alertsSnoozed: 'Silenzia avvisi per questo SKU',
  5726. alertsEnabled: 'Riattiva avvisi per questo SKU',
  5727. addedToCart: 'Aggiunto alla lista della spesa',
  5728. failedAddItem: 'Impossibile aggiungere l\'articolo',
  5729. listView: 'Lista',
  5730. logisticsView: 'Logistica',
  5731. qty: 'Qtà',
  5732. weight: 'Peso',
  5733. leadTime: 'Lead time',
  5734. expectedRestock: 'Rifornimento previsto',
  5735. status: 'Stato',
  5736. note: 'Nota',
  5737. pending: 'In attesa',
  5738. purchased: 'Acquistato',
  5739. received: 'Ricevuto',
  5740. markPurchased: 'Segna come acquistato',
  5741. markReceived: 'Segna come ricevuto — aggiunge bobine all\'inventario',
  5742. resetToPending: 'Ripristina in attesa',
  5743. remove: 'Rimuovi',
  5744. clearAll: 'Cancella tutto',
  5745. downloadCsv: 'CSV',
  5746. // Add to cart modal
  5747. addToCartTitle: 'Aggiungi alla lista della spesa',
  5748. byQuantity: 'Per quantità',
  5749. byDuration: 'Per durata',
  5750. numberOfSpools: 'Numero di bobine',
  5751. lastHowManyDays: 'Per quanti giorni deve durare?',
  5752. noUsageQty: 'Nessun dato di utilizzo — quantità impostata a 1.',
  5753. noteOptional: 'Nota (opzionale)',
  5754. notePlaceholder: 'es. per il progetto X, urgente…',
  5755. addNSpools_one: 'Aggiungi {{count}} bobina',
  5756. addNSpools_other: 'Aggiungi {{count}} bobine',
  5757. // Cart logistics
  5758. onArrival: 'All\'arrivo',
  5759. stockBreakIn: 'Rottura scorte tra {{days}}g.',
  5760. stockRunsOutBefore: 'Le scorte si esauriscono prima dello scadere del lead time di {{lt}}g.',
  5761. atRate: 'A {{rate}}g/giorno hai bisogno di',
  5762. moreSpools_one: '{{count}} bobina in più',
  5763. moreSpools_other: '{{count}} bobine in più',
  5764. bridgeGap: 'per colmare il divario.',
  5765. // Permissions
  5766. noReadAccess: 'Non hai il permesso di visualizzare le previsioni di inventario.',
  5767. noWriteAccess: 'Non hai il permesso di modificare le impostazioni di previsione.',
  5768. },
  5769. };