From 5d931d2236038ca27de8174acaf3643dfecf4e2a Mon Sep 17 00:00:00 2001 From: jaruba Date: Tue, 23 May 2023 20:48:00 +0000 Subject: [PATCH] deploy: 4ffa1a051cd42350e1948a517da3018721508d5d --- .nojekyll | 0 .../binaries/stremio_core_web_bg.wasm | Bin 0 -> 2845063 bytes .../favicons/favicon.ico | Bin 0 -> 32038 bytes .../favicons/icon-96.png | Bin 0 -> 1858 bytes .../fonts/Roboto-Bold.ttf | Bin 0 -> 170348 bytes .../fonts/Roboto-BoldItalic.ttf | Bin 0 -> 174520 bytes .../fonts/Roboto-Light.ttf | Bin 0 -> 170012 bytes .../fonts/Roboto-LightItalic.ttf | Bin 0 -> 176184 bytes .../fonts/Roboto-Medium.ttf | Bin 0 -> 171656 bytes .../fonts/Roboto-MediumItalic.ttf | Bin 0 -> 176428 bytes .../fonts/Roboto-Regular.ttf | Bin 0 -> 171272 bytes .../fonts/Roboto-RegularItalic.ttf | Bin 0 -> 173516 bytes .../images/anonymous.png | Bin 0 -> 8982 bytes .../images/default_avatar.png | Bin 0 -> 10094 bytes .../images/empty.png | Bin 0 -> 10018 bytes .../images/icon_x192.png | Bin 0 -> 14169 bytes .../images/icon_x512.png | Bin 0 -> 29180 bytes .../images/intro_background.jpg | Bin 0 -> 211556 bytes .../images/maskable_icon_x192.png | Bin 0 -> 5128 bytes .../images/maskable_icon_x512.png | Bin 0 -> 21700 bytes .../images/stremio_symbol.png | Bin 0 -> 7313 bytes .../manifest.json | 40 ++++++++++ .../scripts/main.js | 2 + .../scripts/main.js.map | 1 + .../scripts/worker.js | 2 + .../scripts/worker.js.map | 1 + .../styles/main.css | 70 ++++++++++++++++++ .../styles/main.css.map | 1 + index.html | 1 + service-worker.js | 2 + service-worker.js.map | 1 + workbox-ad8011fb.js | 2 + workbox-ad8011fb.js.map | 1 + 33 files changed, 124 insertions(+) create mode 100644 .nojekyll create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/favicons/favicon.ico create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/favicons/icon-96.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-MediumItalic.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Regular.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/anonymous.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/default_avatar.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/empty.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x512.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x192.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x512.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/images/stremio_symbol.png create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js.map create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js.map create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css create mode 100644 4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css.map create mode 100644 index.html create mode 100644 service-worker.js create mode 100644 service-worker.js.map create mode 100644 workbox-ad8011fb.js create mode 100644 workbox-ad8011fb.js.map diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 000000000..e69de29bb diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm b/4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm new file mode 100644 index 0000000000000000000000000000000000000000..b056fec4e167ed0dc6ddecb121f920e0923982d9 GIT binary patch literal 2845063 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�>PM9$|sU94-wg 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

vc?6e>z`e+~q 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�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

%3AVVby!>L)QzuGF;V8TaYM))dJihD`_>8spl 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

NoPf#`Y%jvn_}CZ*9r4Y?p?e7KLzRI^Z!R!U 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf new file mode 100644 index 0000000000000000000000000000000000000000..d998cf5b468413ca1c950096dc9d0f5dfdb1359f GIT binary patch literal 170348 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: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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf new file mode 100644 index 0000000000000000000000000000000000000000..b4e22103936078c50cdc7ddf7a3e2d51dd2d3c44 GIT binary patch literal 174520 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�alv#6BE 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf new file mode 100644 index 0000000000000000000000000000000000000000..35267989deca17116c70c987e90035303e2e3404 GIT binary patch literal 170012 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf new file mode 100644 index 0000000000000000000000000000000000000000..46e9bf7c95adb27c042d0646deb1f8a3beb8087e GIT binary patch literal 176184 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 z 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 E4`L@1umAu6 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf new file mode 100644 index 0000000000000000000000000000000000000000..f714a514d94e495095e2f1e525a341eade187c17 GIT binary patch literal 171656 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 XQ7xdb*Db4|xw|54t;TxnuVto}Tq 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%0Dx6y_9c8u3sy@X0Crn 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf b/4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf new file mode 100644 index 0000000000000000000000000000000000000000..5b390ff950e6539bdfd4d84265fdb01e0c35f291 GIT binary patch literal 173516 zcma%k2YeGp)Awz;J4=>rS+XVfg0W4P!61R@Ereb|Ck9OK7%;u}ZaSD^O6U+kKCmI! zv;-VTAefLR2_&SDgpgh!g}Ea`4{cItm-_5>sdf(c%zkkGD8 z+n3I?axM~Znn4iokapd=zT%EDeI(#|*@BRHv)wDbTK%x->wW@W-$W3?*LQuzR&U#) zf*t}kRfVez9y&fN8%^&UCt&L?xadnmr{yHj;@bBGTjWQ6@Og7)!`hK zjLe#nEd&T=xF38h7)FkpIpX&Pd)mWiwFLBg)ltL7&&U|iDGRQ@L=eP?QNy!_l^=Y6 zxPV;i;rsSc@CU;o(=Pa&{l4m`@i{ZnhkaNMpI;Y*u!iF%4$YcV@T|Llp1}C^apSXQ zWXsJ6hVyRl{e%fwcw;MivU z_=x}~LTIyo3dI8aQV~4|*>ecshXTFfsbcW_C5RuK*jNy3c$!u>F)=iegd!A*NFr*0 z5=k{z6MWUK{;ZxyhOaSERfJtG(fQ8-QFhJ6)1Qap8LokN;0ioYz(Q;H@8~I?L9oz5 z(S;b<*mZ2||1#1b7-5{x{GVgCrWiM=V{1$^;O^IHC_W?w0JrIcNWn>L3f2>LHEeUr zWlmyr29&{NiEOr7Ns`%$R=zT!+lpVE_)K2&Uz)bi8M8PLfYyn~oY$|h{v9^c;fmBY>Nz0tEd?DdAu*?}~D+uuU zG|=b_hCdperZQ)M(HX|SY$7OB|a+5{y5|kq-Y7&FLha{gadUKX^4K;kW+T zx_--}2={`&BakU?!}jNS8@FGL_-w()5x;HOSpT1e|DYY}2()7*8nPPgRR^mpS1zg}oM3_kIMEv!|q_rZ`~b9qF>gA}875RFWkNg%e4Vauxlm<8(t#s^g@IG2 z%|DLj^JhAtj@zZw z7*Vzrgiz-F0X2XesXz;$72)K7cbr!L z+h<}bvf`kb>jI>Z!nrdy21r3?TZ?U5v>6_#lUucJJ0cK&GA9@QTDV}wCO9a~#MZ4| z8p=OxH!RTgWGI<5R4k=O7j|BDjN;elwOD^bUD$mP#>2aJ=`;f45#3$?(Bt!3uRTTa zv4w3`pHvri%VK}-+L3+Q?T?q~sCJ;^GTh(M`>zBr8C;b8J!_z>@}@I zXZUfPCS07xRv@dDv0p+IV?U+3E{YvULUncssh+?NM$cy^&mqEd2scK+XU-^NL9Cba zl=#>ReN|xd{xz+x85oiCqm}WWEW>%aBwLeG8SO=j1Hm69i&?T-9iXgIlB!7ULT*p4 z`Er2a;{(f`0lJ%;o(-_>i{6p{PWzL0E<8df+@)-LL;KX$8e!b|yLKNZg#o<8sNTJ%`&yb{pNI=S+~& zV>A)1l$d=rdi0%Gq3@WQW9oBSrv;riimTLZ=yN93)Bf2*_|I1l;?C{!$3j(kKcl;I=p$1*&OjVb=o|WHL zuMNn~L8T~pa38q7d!1SxH&xEj8<;kiupp-jW_v15by!R$AR10eI;XmK#h^Y@ z>R|C*TlUWOlo)XPr)p>QKV7CEj2l1t4?1x^yNl{lkDklw4Ko;v2a#2vmxF}_k3yor z1e6O}S)^02ML2bE)Y&57j>!%Y6l1bgG|Pmfq6O*?ZIC5>>r2RHRBjffAP=D%+s;G~-_Uj~Ur1fc$5D2ml7h|>;^qJ)43MXM&I8janDkm}>jE|vJ z@#^$$McveC@n~g-A`)~;t&eV=LPt4W9thtHp9r!LAvgnU1=MTt*tG?q4@u?vPSTCa ziHRx*uc|)ixNhyXTBnhj}68xLv8M(tiq zHgaoj23mXcn&xYy)wL#}^z;K{@cy|{ZE$deQSNVPP4R{hDkKUoE7mGWOv0?p=KhQ2 z(7Y5zR*QE!VC4$pyr*e(MbK_Q7n4vSdzdj0S8+tLn!o@!(8uS_1z=s(G!*>c{8^dk zk{YN_3xkn(dCiF`HQ{(^>51ep>iW6E%TJI4)f4GoKXiQg2lcF4MwZTOt;*uP$LeP} z?bW|zsq7)p?-_VuJ;k%&gJpOI&IzZfa&6!W6+|{cYAYb#0V|lWzk(Z;WELIC>G;*6 z57oKxI3|JKT;Y5Ru5JZkttq|@{z-3zL`7GwPAIHS=!-Y;Gnu$dA)%4%o}tD9o%fz_ z3RYLKMlwf{IdBfd^$@d}ax+{(IPm0(%Cjsua>!9rQ1*z$PV?!Y)n6?w{7*>e%~#c0 z_|jUe&pNtp!fHzQtwGCfPbBp2k;@-ss;!ycsPBGE6JgZVghfg~^%|9<4u(+&Yope5 zvm!(VvtbH0<+gw_l|2HQq}bTIK?0iW3^o?XKBEsdI`z!EDX8ZCqY_q)`L3X!ov~$1 zODB3i1CF=WV|td)&t8?!Phx(8M42tLdJG|ao{IL)SW*}ils$Ix9@FVi6nf$8onYOX zIYWm87}alY6n_>_D9xC>;FuwB(ZbcF9$Gy;XDP-jbI_SDF?~=t@>s)aCvvX+O6eB` zD0?NPI~Gn~N)d3n2x}M%a-jz;)Zt&4o2w*dmynLKX&_qx_D+Dg@Q8VSN`MpyA1gup zTQD!?!ZCG%(orI)tbSLc-)dac*fl4dB$SpvLC!_7=(}y|Nz`LH`L?_fzF7lSW->_K z7#K^eFjk3{kLJC=jfkX9RLob7%@{uUL%BBThzm59`8 zY)BEzH}=er%b_+u&W0ZU%2zomvcMTpw!xg(y8^4vRDcf?yr)2ZIZ2|j-5Q50=9B_z zClRGcAvjE%T?#2SCS6y*?y{n2%7M;?F!hIbUMmX;NNkI?p$xS&>sTEb*BjDm=7~^! zjVw{gr@wv==6m+N#ShdkCHm;f=+kH_TII^dIsIFA@3EsB5-;xTzqJpnV?OZI8dyh3 zNdFhD!&j3{Q1o9wp+emtl*H@+omKu_DKWbOB1nnY?4LKqh&)hcLQ9ZdJ9t`FAxW?a zla=VSx{R99Ji36_Y85mM2c8MnXv*C##>BP5xo=acc~7h9R!$o@ARt72_|An-Ljrd!?b0zI z7)h5--c%nOW=x*r3^vT1IL|pGaCBDoj-bG?S>t!orsGdFvKNlM@*SlQPt7gPupb!s z#@CeIFLzGbM)AJ+IcqT8NfL*zqIgrzsAU*$U{-6hTcu{8O$6w+QHqJ{HmAwxjI5wZ zAkZXGqlp<#%#0?)%p{jZm;&MN%*KLn?~EbT^i$n|e&pfwNUeh%Tsd1U5Soh+%h{`@ zTI|g+i+z|sX|)hXheJK4?C)p@TJgz}lcfP9rjgW)Fzz_${+(O`yB8r;6$UAB$ti5r zAvV!haEBiXphd$4FgKuMc^I*}DQT?{5mjN(Ajcs+BAj}YxHfm#Or?>;6+cv@)rB&OP*!)^C<0Lp! zZO$~0&!>5g-oTd2KpMxF4E*3Uz*iyS$KJ3u%~%lSbDC-_sN!=9iY&wD)L<-V={@Cs z9}lk_b`uc7N~CZJjE&ijK{_ZVk_qGkOnp*HRoo!OB!DuZrtmN%pw+oMNuCLxIs(c{l0Ysbbebo}$rf=z!6$Jd<4;AvL@kFV7U2yH|7AmuE;G=}XtqdI_t&Ui1Qyi?<=gt6yGO-cCqPEoI{gRMNiT#8ZIxh) zm8}wZ&G>&?pMoIoXc_%|j8j@&Mt^FO!R{oQiM5{KfRHLB6{tQ-K`7g*uceMrZ$*~A z@c~M$l@u7_+zg~v)VJSkufC}+6;01qBNXuH+`^rwD5EkPUjd9SQ0VRed@~$BSKa*&T!7 zjx*igixOCeL?K6s=kc!R#(qF?C4U(W9Gd}6=ZlL1WBIyOiJmVd+Rj``yq$?L9TxDn+0QLc}89-B%Jvua5vFT8z@7nX2nZYUP1mF}p zt7NLH(bN)G$#`5k{sJuYAkpc{#go}cAcunyjD$ec!*B7gDvDn)9noS}F?<&Zde8

EK?Zus+Rgd+HC4|&POgwJ!xCDAb`bgtV}x14Dq)9k zOgJwDWGanVG%bnD6tpngrI)1M(gP9T_$j_%xMYM043ps|MUb>&cTm< zcMU+-?%@5GRB%#Ujqx>CPWh)5qa{p=MZmhf%l6^`ePuVTZZeb2bY#Z6W6BS?F64tK zdiX>-3-5x3e*Z#ezoqiB2AH@2ph$p51TI312uNV!3XvQ?==lLAXGZBTJu_H30!N(e z#=HJ<6%U*48n<38@1IrTf)yD^Uju8`0(W>mjqY=;aovSM`S7t$=%gS$^WOhudH7(o z+553`r95Mi`#&;2FlO^0u8en!Tz_A^;3~qpYsGZT^Q|zJ4Rj*&C#So=6@wt!FbP!{ zMwV0+?#?hWU4<_HcPY~U9~hZO2{^z}0z?c$`09zPFr)`S6)>-<`|4ZMB&pSFIr%sK z^QVrcFCOkh!P3^v%kC~W5h-uOg=f{n!pMSWJ7=O{D6V%7rRtY|j8;q3?*|?r+pgWC zG*7+rxaHN)s0eP7FptfJ>HQ}_Qa$8YyDIvya5fh`b7?*F&0!^y)3Q+%{B`);n%cr3x^`j^171UyV#XrPPA2U@@)puaYRykElsw8+E zz-wSf36EVly&1tBcCz~3YPCa$m1R>TspanMz3;6pn=BE%q1k9TZzCrxv(-wNQKPL zevT#%Q_Or_JR|qx{&-lPc%}hxJj1XVXF*;FM8Stqm}e8=T^?t=(OI<&UJFvZe}oCx zZMZ56wgK5mtw0&#F(tv61>t}fQac%MDLIj$erncl{B6aO+vB7Q`ZbGIo(m3pcS}bU z6&|?$uiTYiO_NJ>dr*}UG<|P}=8;Q(n|XdXA=x+Pp=FyeUNU)0=LQLj+`{bBLkOC3 zeLh;Woi1Yf<_IJcb+BHtW_SGjqe|5;8GV&2aA^hQnH~R0ZTw~Nmulk}+Ez6E^RsB$ z4c8qBx+DRvYZ96&Ar-k67Ap8r(F9a9X-uxE+k#*}@(}LJI>7LHyjQcBaHNV_^3A%t z!$Oa|aX56R0L$N@jnaOYWB^Z$Cw)g1zKZ7|8*cVHS);5*jLk90053 zSx-L<($D%;Dp3J3rwFFXqn32s40rv&Wjv(byM_=w^$)Y3NO(&Sg7uF~W4 zXbm;(_~f(bit}~yq+B?3gFN`B8?8Mo=lNG`obC^R4mIIjpfL7d2;jFa+EQ>+%Y6Yh zGyyRy*Fv{U*eVYEcD-^3r{`{l!3Kj0c<8Qj7B18AxD;0`+BCC?rFE~;_8FUvzlg@?9) z@rYjjRCJ=ur|AG^!@=+#`Fm0&=K1qzQtC3qko!^j`8(*0-H`cmyVdJ>zq9}(ttwAz z0Tt&7h;&<)(*JJDU_|gtFDhI zMq-Jy;P037q!n=YuJ|4afxClj`pJ}+^~<1EhDQ`|E0JjnHXkVcFsM%p(7rkQchfi2 z1pJY!I*e|ido-~?)e(VgJD-RqfW8C*)CI_kpO-I-CbPC}V|-FZ@8g<~UnYPY!<3W| zgfaor@+4XziNTS*Ga-egLllfC*n{K`{q%zyZv(Fa8X8tDgl(Oljbd zAjSpMIUSPp5GPfp#)vFgd!PV6)&tnQS?{?sR}2MSgR^pdU0SbDgnBx9H~h zqa`7IMI4OPT77mlOkH`r$e`;N8`B8jFT*hAOg zKAk^DDIS|f=jdi;}0B_RcIS2&O# zSboOGS~KJA6HdaCNEjxb3T8W+Sjz zQh1*pMPn9I^6{HdE!s?7!PcZBe}tShlzw%ov1Q$EEFVNqH&e3w3CyXj z`+M>Q$ek6CuW^dWgX{U^H26|z6ViekB_@E`6DT}7b1CL_41f(jUIN2*ef%yZ%=6uV z7ZyxR!2n@1#FjCdoXGqMaIho-YbJu+p(pQrZ4yKCA1*$8QAgxJS5wo{C3{zlYV%QO z_TjoXm>MUAQB>t&&3#C}oX`)?wru&zruQh_+;_-Ca*OQVg^cq6y98tpR8lu75|GQ` ziezOfz{7DoX%%0gQMiuNrpX;4?L?b1%hUK2Q?N9a@1#M&LHS)c=vG!}m(IX>Ydxrq zVVXi_$=c}$4o4m`MGYIhKfQ}3t?t07!NxBlzt~TXuUoMH)xkJ)n;uWi8oRE%7vnUl zcBR!oN@5|xUZw=rsL7}eb$%(ne!Dh8F74V04~ESZv*JpVsYZ#ic`L>U1G^BwO1=wZ z;U6+>>8lrk6aDle)ci0`bX4FQsSa2#5IKp%Nn zkbMhJ$A&E_7`~+k#b?RrF|SSS)g*t@g-{${fW*0kuA2G$!R==f9@b~#1_)!;3|>OX z$hT%R4qKN`>3;OvW{LiNm#t+ytmRi+D|S#&g&%A3NFH|+G%9EgoWC{{a0r_|*jj(c z2Igg92neqhfj8jSP0D>EZ^#q-ZC_x849GhRy zK&x@%G+PszF|Zlj$sMM?g#H6}GC-E8ndeS?!L@mF^#iN#SMvdtz}7OS)mC8i=9)m; z6NzbiSjKt|v)K;(Y6+LXs->W-Gy(I|BbrOcm&c1?1#pZiJOc_P{86lT z1U-1S6(9dMgjFi(D?lu;T+Ay6?`D5)3$|u^C!z&Es3E9#DS9$rT_XwQW3tg;HQlud zM$FdjXBhE+d2JvvY*|qHS7(sE5Wa!H3JcO0ZntJA79YFir#Sp3$rXpTFk1N`pRu1^ zhy%waj>#yBV;&mB8XUCu$9kc_7gkJWjB54cR>=4P--0nyT%(RsID+YvVX z44^pXJwx|dXBW)~${ccZ*vi5Z+IZ%Aiu?CaD1E=c)d=6HUvmY)^GCYs;_DM!+`Y^<#hHm22&`3+60PVjSnz(~b=BL^4~ z1pKnce*i@X1!F*IaC$uH4lqf0#)>yHL$G=4&$-Lr>K_!6_sbWute-i&f8MB&0MRgO z_?oL$+6Aw7ZME!n=Tf}>?=44=VUz1z^ET7g5HjfU)K{C&TtmsjvrLXZQU{ZAPTx3T zv_d`J9e5J475d%Jwd06R0sxf;^D%+9%JEE(pM=|=9h`VrEk844(d&6dvh>pGi?>BGan$x{16yrf zSwg$g`4j$0!E_GA4=>L_=366N=X!3~hv`-vwi-OZ3d@5(pglpmwNpqCD-iNb>Ax38 zo1eBg42MF&mAP&Oq6PRha9nB?CIM_I>RIvSUMGhwEi5?|J!My71F}VzU+xC&KW`fi zVRx?sUUL!c1~nKX6br9!^4#4|;lzR_iDjCE#BxtLFd&u@9~`d`FQ+p%#>e4Q5xN}F0MO^aq(8v9V)xiYPTO)Gcs+*+bV%uJo~ z76=gZ^m+~%ssmCSyh{SP>RgMwI*DMpOQIvVW$SU{3==LzUaBLuQ2$xy8Wd&eqTgo1 zJ0ad*2Z>!6^8knn;y^8#A)-MX+4igrhwijta`mX4_?bVgPKdcBeo8W#@iIr+xGrMv zlJI-;ukPGp&MBNK60uX8H^;0fEIB?Fig-SJ0~fnm)vEDw4bk`w2$& zuUMNl7%q9*371L6LIN)ihp>ucTa0yuPqab{HX?y! zJTE2n%HN|I<@ZSn%-wwz=Kd5$7bv{qSq{Hp`AKc1pfVLz89EDk9y&{&!@uHagyU%F zSCsOZ+64t%JFVV+fG)X(QtX7ny)Rsk&}MZUu7x50>prNqB|pM=LZH_Pig+sZ2lrGp znrK=O$j?315Tg_E6r&FZd#C|InCbwX?Qj70xF0RN?wYsk{p6R8w%&8oS{7eGp``kA zlllx2C|gC^YtS5;1Y`IKXaXd90cX>0u5qP*(Eb05v*E$f@Z38iG zUjsbYP~AkrrREUH*c5|Sb82%2+Y}uyxSYf4?|qw^AYNojAEpW1&&+QsFX~RVN}$qZ zuu~zBN3o*Mc5gPvfOEddcrPKoF&Y&8LG3Du%1Aw-fG>qEQ#UpE<@MWjYpe*^p#R}( z^vdw5FR6e0dVOH$+*&oCw2R-=A_!~AN_;g7yW6JQJ=1qY;- zK-Yl6Pf7{FcJMDj(WgV54Sf*&)|z>C)3+8s(VUuimF1o$<-sd;E0)b$a_=q9r+6E59ah~nG4#~7P6?lG-~Sj%1m9)g@c zc=RGVl`*(6D?Dq8Uw{6i*wxmIHmjZ17$fGH_HYN1Ct?cteLWSK=R`f??H99aLhRQ{ zCmWqmBnYn%f&su0UIulWtok&@yJ8hE5`;m#Z;U$Q*q>%hS88tB^Iy{Fy^uTFg0MAJ}@=3PXPD= z1$nGzFsMuk_x#4>S6~XO4V;$@0J+ufaB!%C*Tq+4yW~U}or?+Ui{Fhc507mg< z^se|wWVw9gazL>>WcY*~#sp-K#uGl+K9c0`!qp$Vm+!jyr$p}*pfR&3J+Sb3KKOwq z_c!8N`Wwi7ZK0)7vyP38zUB*+Vk};Oy75qse^>EwQUKkn;XQ?AVf-nlG8r;CK=Cmi zby%4;z_L|FlIE;)$WJ0)7himPMgI6bae8yVQB&7WK3!C@^3=o=2?kU5p;OkCKMd)x zXWZ0}HW-83?;bbp40>8rKeSB1DGVj`a|3dD0R%XgWH3Y4FISCvRf<=xx+% zUR#9iL)&(q*e_+ukLN~?IW+EsEe+FeO6P5*cB$kN9efn3TMib>r79zZ?ez(`#$x(`%s20tqIin)@dsC z1C`1vdO?@guG0+Or`fn(CBhJ>Px}cfAXxuuhOo?|RO`SJ*3p>R0VfU~UO4zV5Zjp$ z5>IfZqOap%3!}H45%fkq{2`dPQWu2!@H2!Rk=|1!nx|5o4v50NeX34a@D%T9g6()#4B>(C1avl$ruPB^1kcR@erGiV~)&tkRdZ4L-kR!`@(h*zNq>ozgm~ zZT~^@V-c3SwmFvMstxjRu^4qe8)k6}S1zchiw0P}Mg!keP)u&P^=tJ=iTCNAxNhz|e}f@M+QoRx}oB)rWd0YXM?fm~fD4%tzps5|lT1MTDP2ipK&n;WbT) zNyk2z<1|6rA`mmq`w@ep6aB~rWhYe_)3XE?C{BPcQavPO8LZ@bp!UJULH=qQeRcBa z8B{!fc%lvho?Z?6gzO4*E}p$qZ>K0gE$%oVCbRFT0MU*wb?7}iYswr@{1IIVs@pJd z{CrHe%ux>lAI)mBje&P1D%L^%+i1RR@WOahM0NK9fMW!MT5e7Lkm0@qQAMrXY; zXFc9!-OBqh&(3(c4w%ltYJ7kv>wtSsu?Wh!q85gEdseHQ1Rfyhnp7*3)s)nvX`Ja! zq3BH(>m&8x<6TC`- z(k(fy&E|D457+5i_FIGB_b}fj_27-0YW_QvUP1%wEdF#Fp`W5TZ!P^e2XZ9p;)&`> z(jAElCua<=KcXj#X&{4u$JKd#VQ6_o-!oMbBmS}VlnXWtkM;ZI5~;}RJ96j0#I z{p9V@Khk|8vw+w3j2NMbqyT-iGp@2ju}BU&TA|Bk>aG@opZD^(!Oe7-cwM z^;Rz(oUC!vS`qs}4|OHMmB0{QK^VqAsRRk+bUCseL6;V_sd?EZQkW5B8*=L|Sf!D+XK$qkrdZr{k{AhjwsA4RL z^Zo>8;}M9YDzJZp9ohqdwOI)nutI}$0Gb#tK!;|ZF0C?Usad`3*j<5p=FZC%<-BQB zEL=K$%eGb-Ee6OzYx~d<2sgFYt(!S~CYhEsy;aSH6BlAUXIwo;iv}a0&>so^fhvVV zfZOmY1q@XRm{%#ll+G~qf-_l?hLlBuMrLi{fGMI&->UEJkp%TV^V+`wd@~thXtU5? z3GzXE{19h9)PrZXHE6REu3}h&<{mPP%BT7RZp-jzuyHIna!9FFQXxh{yCJyMZ#Uz)7JwX7RRjZD5)TV< zE9a1Gxi(m~X;URn#(qHgV$_`|x;yxFW?-R97v4-~wvc0^{#n+1WN z;RSy*0%^Gs1qJaQ04Q~nC9fD5BoBBBn|%O-$l%-oXE+XrFQnw;R(i;27*(f^BX-${ z$z+@~yq!T>%EtT|$l*lra3zRDkWbAS53c-Z!I<2qS=-B_mCf2^8_qg!dGdokIhR?U~Et zze@-1ymlXe{CBqIvcuhu`j=b@k=JQ!tr4 zs{4rX80QQFyBs3qk=~>b?DD1{D3C*&&>(^J_PqfZUb=WfNJXVW7n}#j%_vj|fVR5? zd>PgV)|fG>MkvEIfj$F!tN_I1kC_8dL{X{)U72Fn9i&-SC?=pkLVa z*RbE<1QH2LBjb2sKi;X`Cjq>o1pXU{D(}4wweC3oACTI~*Qs18?jOGjEymfDrg)!z-h+rUwNL%p9`RbjJL&;Kap{kV`oO zBL8e`OKXgp)B!*G==goZ227bUBnRV31JU7kDShYA*;6BWZ9y$qUbI7vH{2%m7jG@As}Jt|a8I^67>eIYJMStguT_Oqr-81{9VTCLRkMWCZaW_zf0Tu4A@W8R zp|cLUg`8PO)i&ytRyO1w_X=4vN)*)}pI%1ox^yXDl>wFYDJXao^SWTaFggUdi*@F` zsu(#E;WT=?1T+=Ixl1!R&?&)z2&mH22Xf7%2cO)JZCKXICnRS!$qMQz7$+rzTWi+( z@X!zGKbQR&61eu~4eED}BG>3a;HbVC8oY3t=u|&J=&O=N*Ty3CZ8&S~`V4KKKO>g{ z7sbI&1d&p>P)o>E5^A$>(nm0~k^!FQ(FCJ%83QG@6^%2@57biP!!&E*w>=b;R`AAY zW-BDttPjdH)d3|BU^iG(HDPWzxKMWsFPf&EpSkB`knS~u&b~2&=pUa@CN~~4Y53|u z*|DjqBsOf>C_vw-`{)(nw9m5l#$c*!9`v-6W8CIRO%4=O+ zZTXh_0Mq-l;VU&f-vxZJw$Fv3R8VP7WLqhBJGeqxi(yy=PGGQ8OtX+uOX& ziJ_wMD8=(0teV!Q#n`zBH?ggpu?4qp^fQ_?phF+hfaLE^aMbJeD#+2Rkj3jM)dY0E zn$SbBcsf8Vo{B3#`I&C!)l?dDY7nzx4CYuBxNyFj1OTmMUrHepgx)Os?&;*WR-l={ ziViE`bn}=bvb&&OP(=Qhi%PyQ2e0~U$&QJ1%rA{^k5FFvbnBgrZyO$4f7KkaAbWmM zyl7VMscQ!uR{vZ|C^Fwz|6~QF6N|QQ9yhOd{rrY27L9i~=85#(qpORF_z4(u0)5*@ zX&rh2-UWjWZQXeCa0i>wCN81!eNz}!Blj#?gPw!2B|;T2=yy*QFlctz z{|#QXy(hSEXp&OtFvjq}L#gVCKdN&54qWZKDj*KYWh`LvVRhzq!6Gm$*|S2a9-NtV z>w+83^?Py(*X}SuJa6QH5lhxjka2){&#$@tGDj>~J59zCu8QnVeL8yA(IWp2?nC0$ zhV>e)xe*^kyWyH!(CtN~j^4Y}XDcvH+JbJ)xz)6Z5zJq@YwVH%_QCklZC#zL zn0#6ct{HZJ0dWQecZ$`T4)UorjR9@(Z}q?bS6#^eN8v9keA5bleak}1!`8ez=lpOe z3wh=$Hdc>x`DMtpd@z?gEitLstkB6A!d@b+tW?Yy z>6Z|o&`#!rX+1k)k0 zV1+1*$)`mBI{Tl4=7r~1pE45?U|x57USU>!)gA4QE{s0={1-A|_x)7Vo23N_pm2hr)N2xWLac>IYgHb_M=rOI6{4r#k*xEuZmcibAfbyWyve9_w(`E z>PxEQJ&b-yz(RJAsz9NmXKXyU*DO?JD1kiQ_y0IHNWburzHg@GT#eD zvhd~ww-{E^x2g~ZD}(-kVq))*E31mlXrX1zrTyE(=UOgpZO}TtL7g=Tb0iXcV9%u7 zBB*uT2}PM-T_|@QI*-G48L#1I_O!hsU0Hq?Bm@gR-9O300bR8~G`v*__v|hc?&&?K z#F8|c|7!rmMMo>}VMfr$y;n@0sK{jV+i(EPr%$aIo2;+40dLT+yf86QmQ%pNF`I;V zTp4D*QPh8R~qY}oL8Z>Lpv#tl04 zW1>wj>vK(r?nb6Ps3tO@4j7wZ^M-s^c?1cf>qGIA57ZC3bXg3&M?`4nek47luRv8m zy3kZOs6;kv&K3*we{F6B92Gt`2QoAT=53plvf!=F5 zSc1mrJylGe??!sQ8|}AAof91CH1Btv^_j$jXYA)Cv+f6GhFD2`h4%qpVf#F>+5<^u zZZmX7z*q3RnHOs+_vSh~gqmHQ0wn#^!LP4x+UEL{ITvajf4a1!ml6Dt+W9gSrwm{5 zRumSej9+ubN_z}H=s>C%AP0?vQq`QH4+v}mwPIG&7ULEYY2y5rtpLgxbWg&$&$bwm zi0Zq}Hfu9=9T7h*w)9zdfQsK1qHScyHWbsKZr1@IQ|Ul@y%YtpXDuK7t?3`lF=JU6 zAMs`l5_VSdD5tRA2$KG;rF6G#Xkx8eeWr%qqQ{S4#g=sjJaNSHp3FjacYi0=fZTEv z@O@9uUHl3pv_MG_1ru9x(FVmGzV-bqocC#SVk_a}67m=ZsO_O^YKkXO#x^`*i9`ro zM3y7A;I1cs8X6Tw%1F2_|`C~amZ#)o&k09H{ zIm9q@@UAxq>Ak^bC-}5_v2^Hl_1v+&;vc`Gq<-BNGSuDOUVVw!fPS$;j$+bkqae`W zfv-kJzXCD87?CqG(^C-s`Svct41L)YYz&xv*eBXQWCjLIVrq)T!=PE27vQK^7r^1= zbiDX#epvCg2F+p`)L4;_f5>tuIJ`73{nc1UwKK6n*U0hb<%iFMOl~y3N7QwbPF=>~ zTMQ3|vNap&{!WUP9DJX&ihW-G6?Rq(0>_06wgQtEYGo?cN3XE;^J}XYS#}K^HORbK zA?9#k5rhO|$~Q8A?VdQe2YvOp#cF7&7o)3OL*a+NSvG8nd0&$Hb(AP|enb5g^^~@3 zxu~X?5$tSmwY-Wcj4b|R*Z9M?QOmuAZr3kefYhQ^qethdlhlv)lC4)irXs{!>im~4 zeFf-?O6Ze7S}dO$W;Rcs5*Vf**!0pR zUi1dc$drOzAZ*7L2t=5o0Iw7;x;nFC5A%BC%xNa7&sCouTyd$dkyJtTkIa~`_C~Z! zb<;*nI5_}noL2@9oxAx!LdTA8t4A+Tn)~;ba245IgV*e%;#W7Cx1G6`(sh3`TR9RC ziyg29ZA%=SfPB z<&$sNc>B8_i(Tjju!(G5p-OXbC^ zM)%{hl{LBn2T9m6x#vQr1$5BUbBcSx6}zcu<#OC$YaWxo3axD3VUmkZm0B+5*_*{R zsIjUl)aE{)aHxa}=3Tl1xU?D6j(<+OfHXqQ+`srfmDTpayv&}}Gy*I7%%0U3`0mFJ zP=}9v0&Q69L}kO@%n%%hbdqbJA90FQwK4oZ+m3NYI6)Kpn+0HN-%O_QA4k!1}1H5eZ~ zLW~INbWtk(iY$~6TpRX`hDrqt7#&=QcP%S|XD3of_8|4)g!i_J zy^oL}^%rCe#*it|^5~KPE+|}Erf-u@;>Qs0K!-H!2N^;jNYQz-q@Gc;2!d_$%!@MF z9<@x~Nhibc1+zEdP4dEaJq+SUb2m}EaVFYGQLmP8NC0+y_OBR%3wbaa z;9zL(3g$ciHMZ4iCiY}`3f5hQG2|&=4~5hCfYcqXVP$(N0>}U*lHnj00gSNxi3^Mq zLcFJNX}dkW9_t%p^(H=9dqnWUem$nZOV24osJ&*Lu8_5_QKy?YW5B$eUj61w?p3FG zyLxq6wFmw`1iAr=dO zH4camV9df}Wx&Hh1qA!t9h_gY&naxG#!KKo z@v{tbGox)|>PGiY5Fboj7M~J_$as0e8XVfvgjm+_OW!NPLc+Io?|DB9x zEDVu7u)7xZvZ2alk-+E`nQDk?lklUD)zZ`TZ>fLn5#8z?uvB*dP5Mq9gBrNm9_3bc zmxzk}GFt=+#7GiI8fihqOb>MnbR7BftT#+L+XLL;JlHZ>yV{mLrj|!YbQ%KpM%437h~i`U)B_ z7S#Hym)2hQY!3jx{DIzgzp4F_?U}$Th|Ywdc=Te*9%NFz|5&}TR}zr=31m54f$-Z; zVZCMHU^yTaaJ4_^$8Nhc1w7Z<0`$>Ws0*9i9Mpwk;LTK!DP}c71(G-W48sBw?64;} zc!`4S`omIvtUhpO$f7kwe$7DdZKwKH?Z%M7-515aEa37_=-2LL;?I0-9WTz;vzA;b z6@^Igl1+kI3eZ%nX4>eau&$J^E8ARz5o6Vv=ij3%d#-#)zealXPo#%=lozXeT_+21C4}u722ZE~ z5>(bg06@6G`Ff7jTs;NfenNjDKg0eL9yA%a3bys+i|FBC#-k9p4q`LR9^C>eDp?z|-HumX+^|Y5MHvH|G=YKR^|hKq@)Z)$ql;nD^xy^}yWx zK~IL=r+^;@jxspXCf0%v5s&9_Du8=?oM^M1oKkhs=r47~-M{o=TB}TycJYHhb+9{C z{F~~xs3&c*V(1mOP}RuX==0C3hv7|mw!UT66Ud><#wSUp-&xc~31mNVd$r zG@OX)d+OggtuKE`W!N1I!R}zZSBFjldP>?3GnI8?4B61oLrx3LnNtM5HyDr;Qrb-I z{pdP+2fL3T=}o%)`AkMpre$FJVY-a3lngS`!$VK*1OC@q`7AwST`r!AO#}<=vl9z5 z3O=zFJQ9IHb`}4sk=&T_$=~2lqg_c2VcW^_W%>D}c|Hl=4LsNeklt(u^ zDf&+b)F2}$Ob7DwY-R}m?)n4&7E>MPBZv~?N=H3$nd?@59`1nKE#K|>kkJ`7 zEfA-`-NPY&mLv@H%#eq%8lAaCXR(kujK_RtX6TeaJx}JsUM*mQ0Z;OEGhv%--|#4b z138IogglW;S&s(9M0R^sXwhIuy;+h(NasQ#isWzjWQ@^xLjC?w)r(a(d@|N(d>us` zO1a?53}3%L*ZGL#gm2oLd*&hiBVg^54SUPi(o+S}nx~ugl;_enTv10#gGr$D!Tv)x z4CQ|Wzzh*oL<=I@voI1e)_R|3G4RFGCh3QD@^qp0NoD5U3cI{QxWSSh(39_vROr~` zKxwncNMIOjMU=#X4R~sZd)KYlS4%Q$s&D<$=0e-DkD~jQ^wY`u>BA0PzyXnW_v1*{ zCqJlPTGg#+TpY4L#KErL+O{0CHi8^rGXR4@?*oFE0%)z^(?iN1#h{Io&p->7k^vJ- zh7(`a!G;YFS@5YsVde__vLsJlA=z%?HLfWVX2S+na$x9wf@q!9#xh6AAt&P5d8H|# z0c6#RBah%QE~5uUs#Rh>+*ds;t`G(6o?n`ylbiPIHvQumwfeq96!F*0vB$1b@tN9w z-j-7lujOMzQ2ixmP+}e-(>`B4O5L?}`9Q+DPF{wHydHGvMnFV9M+r|!WwZvARNF;} z?^>?~hJ1mvlS(j}sT_@2eXH^mLpWnx#mWy(2!ebb2L$(cA$aE%eCgno0>A?Qc$z*-2sak;O}HBThtM;w^iso{<_MN!b# z_(Mi)LrhjDAiC!$B`D_Gj?YlMDCOt6PIq6j6_bnT%4u2r=_c5xU)2S)6RfluYWYVg z(VpEyVDEl&8ShwQGvo?KTl7li4D*zQK+l*@f)vtqTu31(^p!`DR-gI-U|jAKu@`u> z1{5qp;RP=U+(L=@^ zHRo1e(SGrHWALb~ZPDUY`q811$#u@peOIM4Q>`x+Og=xxwE-_2pS6(UbrZ|qYTOVX zUOH)yh+tPQVF_eSfmjf|!R~TC&$IDs{^Y4rZQZr_8aB>i#oG{0`u|xxY+C+oc#bF1e$Qt07tUM5f9m*;d0Ivy>8B!u}4A+ zjq1~@t4AHs>%VQ)nM(IdYM=ZMQSg+ZebDY=5!-v8IM<^} zPV3bt^hk8BMIAHAfbJV5w3$(15lCDUunsXoW5rz28wz1X7-)GPVe^w82w(t^_2CCt zV|d;H_qsh0e^l0SbadN#OY*k&tJy@dd7`Hh;Ik7X z=U8pM{7_84$^y+kz|J1L>;+ibuW4P&e|b04F{4G{xy6UJg%=kV!`4>^k4{*@vR!Ov zkGof%AE!O+HrPn|X!*||w%|!jaeo8PJbDM}9-;y9AFV`sGF_0#0mB2YnkLuEOT7eU z&V`9XSe_;sz$$!p2xD0RUxoc5+6t&LSSg1cHfRUh!*=IDa`yN!(9&W>6_Xi#I`d#h zO1cbLk4Vuu3G1Lm_d9h9j?jhRz;i23RY%WV-&qJ5*8k~%Ff#9_ZBx)^d%lyX`sYs_ z+n!Ymq4%P3qsbjms7xRKTDD;LnoY!jc>VoS_fy0O5UlN}?6(5{W{!YcxX81;3mA`> z(M{ONMe16mzM)++*t1|cn2e92EFFkG&xCQ_5>HqBS@*BxviKu-F+tAG~rH6(DU6JIXDp_AsoG*(AkP z>oz1|t~&G%cGM58nG_LeNE3fN`TY1R1nDR&(-4S< z>Il7*NLw0c01jTnd4^mI{F7Q>#C*MEMOTaO@&_PTpijar&R7uYJyntewH|YL0w1%; zR+(#vI4Vn;YROr`wm3Y>SUiQ zJIc}t8@8Je&RdGtmJcHPwzF9HQ`pJo8Dw6~U<-RFA$(^fR%2oXUxVpB99KTU9#cU|)iC=7l#FmJH1* zLbjIMSDv-#tt3M1VQ$)6*Eiz+OWd-z(~RJFs-gJm&YSC z+41b-*YwBaQNtHsh^BFVH=6Nod67X{}ltpP(AZHEZ2oDt`V(|0dZ> z30d?VlZEB(AE^;!Aynw75ECP|ho86s(&kX9v!D*jm;L><7Gr-%e}*u|Pb6{}&oWv?uo6kQ1lwcN&&6k3HiC_W2Y*^wL~5^i z{u%T+B0DtVrhx9p_=_)N!w%;5UO3wvylnjJpp6sey_p#tt-h|7_bNn5SALS@8AF?x zLSj*)N3cOw{}p5YA8B6!AH}t{zvs-%ZhSW$l8_K0iw7D=aCdht)&%$98rYzavU=p5Xwtfbe8oaLwwt}HoCJzA4KMvt zDZ#j_z~+vrTJ6PDW3WRtD04BlI0(2nzC$`S(cu#7IoiEzLC4xbzSU18dihWIeB0Qp zpt+xoSl>)iK9K8WEMm`gd1Wk-d{K_kgxyW7KPH1(NTqjgf)3{_{D=+uP^JsUKD9^_ zZ_g)#NHx%7H`qnvly{)HB?8qVp{B5l5^NAU>gg3=cbeI$aUe&fD4|PMN;ISwp%l_r zeFH2>AC9cVwLo;%%CA<&wy+4`v6woaXJ85!Z>pRSmUl9)&>Aa6c!@ZO1WfM{wTDF8 z7tTL9>v&IVa$&N?;ytR@^vsZ`3%C8K-@98jWCk?oob3G4Yy7+h$g6HUz>B5__@1~u zd7>gsEzTgFDLY!XPVY2H+Ohs%0tvcm%Xw3lZ|-F~z5Phn`KRJZ-?nQg9o3KX4tQSf zD;IG}+dE7VJTYHg4TJAU6j^FZ<2IN~DoU&|g+@)_gr`Vk(ZnWLgu#kw!O}tXWGJmp zswdCv(zIz}`QYZsZ1m96!(I<>U`+^4ZrmZQg5*J-5ARDOGd*b!=NRXEv@M<8P9h%J z)UY+CzgjqV1s|SFHy7AKHk+D_HC=&}e|Tg3Z*G zXrOY(5m%1CjU9|d1VBfwP`)hOOKp!gyJ#9Yxh~>1+vi)-FE5#p88Gj`(1mr)mX=MY zMk=qdW0H5tov!UHN~7i<)=fBJH(R>*KG?9ll>2i3Vz%_OOc#y$(;}sRJa^026KFPb z^dCT0J;}*ftN4+Tf0ndbyb3<>&bipL+|pl_S;F6!rf!zOoo6UbaZ4c}sOt0MNU=i> z63Qsz$Ph_-eH0t2(?>CP(IFEGf((rr`X=8@a3u&R`3bZ1-ZSm}pV7+V)8D)^Pg(s| zESa-^R?$N?E>do%1R&E~qQBg{`=gu%OtPgLs8qw*kHh|B7Bip`l)@7fXPThS!VpW) zyuzH_`@5s(u)pcVep0P9kj6hbmDtw#-B=n^KLc*C*R83iTN8MPp5~R)zPSJ-?BNIW#Ny)oEhdE0IPWkKr96CA5=H) z@#8ZyB=CrUm$m?!7H&Ae4i{1`@F-*-k!cSK#!~3~R6MIs&y*43(@_m4Xow=+QXuKt zy#iz%Ju&{wXp-{YFIInc|7+(rQ=ILloOKq_9|w?jt1kFk=gyVt(do{eggiL&<_~nc zGYyM@ur1k?F@70lOhgsxZp=8;#DU*=UlVnv8nA|#k70Mk8gN?)d7FCcl^;_N0lIbCvhXLmw7obBl0;WJ^(>dP5LkJ#i$xh>9Pm&#QB?lu&H zw^}84>mf;1oQ>2j9L-s_G9F|0Mpr7Wh{HgQ27#dEmW!EaJVtNo=83-IB6D97aUs&A z=pjAv=!}zfZhW>0Yl0})4@%&(t}L5C1X1Kym}E2zcMyFdls4$&*E}LF$gtJ9Q9AfFpHs8JRu)X?rAj$W?_qVb8-#Q;7s#@~?5Ym3l z1%JOebFg$B33+t>&EK)vHs=GfbJ4WrX!KCJiscAi?1yppaiEhkE+ z^ZWGJH5NC%{6Myi3}ZRK;y6g=b*8UA`$3ZAsmwc_9Rz)rf)!b&Vy%Ns%T&TNIIIk8 zSSYR9vb)F5XJsG(x6FZ`8K%4q9NC5#{VhD{Hz-d=vuLdn8cPJvDNm=zmhj4lSU6_j z;N}G%Y6*nAW&7l!DcMfvQ#z7eeUEtU8-Hf}M)K9S=nT^R6Po25$sdvzea*R?&Jd3_ zPEURU<4d2&S&%JNG)x=Aq%=zzvc=$vfT%$!3LJS=iu0-@>Qw=)p)THot`1YWfr zF8r5B~3k7$~p2O`81*$Ktkj^wyEb5 z&n=$&JPSN!j%JOVh(Lf1BuVm-OU^SFOV(X>7NJxKO=NmMKZLr5L!8Rq#%P9t%53oG zA$;NHf`&mE0_bHd@gLA}20@44=d2D6MOA*Kqy#F%N}zIh>~HqyaG!v6wF`~Vjlp$Jsb(__<&@Bu zkieBhmy-LBoQ=92pVcriq+e>Qxccnl>oiU3_`Lb1nUs2FnN#Zym#e^wJfQT7@)`V` zTnDHEEjCKnUc4KxH@6&Ib!UK>6~Ou-;335bi8*|$3f2P8J!ljuU?5f>R37pddbbpp zAi5lKjV4STqVz0F?8GR8oQ#3SSj7Ov;1j7%7yIRuaqZJCi`>y0rp)s zxpH+Y@p*L*v2B-cmV9>du@99-Nl*VQ$&`M7>-?7%z7x$@t}+fg;caU8Ur3x63K=t> zlPY95Nyd=Is*riOW%QxO&!4(v%rDHuAti|ECMdEcelft*&d_Pfpn-@V()L~>Pc)3- z0oFM{3JUwD&qM`w7J+eY(}EgXI*TUcU;pI&(2hkNJUqf~<$gYwlOugOh0^ctkvCc0 zR(1ACQZfbJHUVao$x>IW10*l!tcC+3^k8i`h9j&AL4$`3c@tt$B(CD95AysWdHnFq zBk~AY8P6=}C@3VakiPg?J_432Mqov*1n*7re;9;j4F2aJcnKLOl?soBHX5-@f%*|W zS~qHUqi0q1qxzb85p>DqTEPnJ*nGU?TES2U+^g6G?)LL_X$6L*(iX%8%`Ng3jh2lO z#u$d9Q855hd4XcEm$n~4l0W*^-=BT>jq|HVES-G8^@8)z3uZ$bc!Q9~XRrUFggFnm z^#aM%3Yh#{pW$5vLroJL0cw9cXa?qDt{()uW?&G#1_jYzzG?y%kz--6nv5X?7_K^$ z4IB#hJd)gPi8;eYYgD&}^L0tlLbrZHFQC1sH0VE79A`6iCz7F`EpW}Jiwj+d^C0q~ zd1yob{~7JFe;MhE1_>ITBC^xoMjp8f#ZI^aw1ZRTxe{&l^thy8jUva^k?6rS7Cad= zG6XMl$|Jl7@K|Ggxse!v%AA-o$!}7#NRUPXv2Q0eEo;^u`98&YBa&A3q*C^VbysVh zsX-cjvijz9i@C$cuTGeI?{5!sYyWoCY)9zNs$rE6#DH^Og~FR(>Y9sVk|2t2634gF80+pqwdX8{3Ok?w@L zLS2jjn4;n?bZ~>s2$LD=DfBtC-clqkFO@)q<)o-oc9G4zLyFQzdIyl&-;?*8&O+Og zxujeg%ef|c)lIDbRz~s9z^IabowGwGv@yxy``H@)$X;fD#O13(Ln^1@2?zz#qy^_S zg~(y@P}5uz9TBSekK{NVh6A^Ms~R*?QTD*S98G9|308hek{^}LmgLX`K(VPF4(u0Q zGb_Khj}*l|cyH;Yel}UL6Z@}|GRtl8>adcXzTNa-PDWvbMUrNYU2!JdZ{AF)gwFeX zS?KRby`XD;Sr=6u-q+V^1;)|(viYlvztkg96IXeA4IRq9`gGAo@8Iu$K}!R&Y4x_=VGDY0 z+)v5J>@*qBt!)=+3+di@t%ZQcpe9^egt-`Vbv6IK+d6{xL1&bLSqKAI8o|ov78cPQ zDYs-W{t?)YYuF{ZF<$zaf=oRf0l~u1hiu?obfMVs(<-cP?HAlSknW%7>1~iGKKxtU z?_n?;;oT7yqtKTD_{a@MT7AOu3O(s-yO(u8p5ly8Dd<7s$QO&*`Iap=4=;IxY%Lkc zs*=X+61j&&;J?@z#_O0$_d%ZdVXVQX4LX}q8<|i8v?W=JjZ0MkKc&$?(}8o~eENuk}A}`}@eji(X!rI6ukKvi(uGLuOhaAA@GaAAU( zq#JnrivbtTt>^~$hpyvE-nULh2E4BWT=>cP0nWf%7;!zUlRvj;b#Y(Aa%m=mSV&DJ zTBYJa>gZGvM_1odPRl1+4gQBb)8ILY?j}#a zDk@mUs?952d%WoJpHd6#ty1z_s#bCr199zcGG2O{R;jxyeoWg?!O64>O#p~t2qF-= zir{F#ZkyoA@iRPcd7}KKi6^%9mgi@lbdtmBNz#w+@;u64m*O-01~#9+O5|Ue;F;k` z)AdeCcb2+p8qF%`#-jO_cO##7FCaJBOMus?O77`SgfS!je;)9^WyDLf3wE=p-33Kb zM;GfyHVq`nH&`8u)|1V!I_^V;e^SrtWt3QP-d zwRdmUr=VY_Zugo+QV&}3my>-ub}i`EuFd*gP{4eueW>o=t1>n}r6I z{A8o_%|hQgjccB_&;ThgfZn(zsFoKg5FJam?^MhXU=<(AKSgcWX%yKHe`{eD-F zOCIhn*gY?8cioaFV1@&wJrKE-NHfqKkWpom$dYO2@Y7{L8bqpKD%t=vcH{6Psygon z?Ma8{B52;sWe5g=$TN3PBuOm`JItQuI1~I*K@vK8>>R)1l|r&2hSHBtk%sJY?dqG& zQZ$Wlony0yILCVLg!b!#ooE*Z0@662p6~L)mH+TgyqZfgatn5odAkdXo_$fIEr_&7 zwDQ54#If^=6C<#iI=a;&1L6MrApXreA&ME?E)thhV(V^_f#XEx?k?QDIdxCn=aOzP z>JDKP)YKb$G#jt}N1ueYCfYLm|M(gaAD0DSg|2tMYBExU)B=E zVTyCDntRaP0ih0BI3Nc9kbeooKFd;y3I@0a-KP)T2sTWwQgSAH-*qGw z{q7#OlS9m4)gj}g^RBUXaaaVR515hL6J$6P|5yLRiw65I1AWmL`8lbLT=Of?8e_Dc z=>`SH9pA$`={Y(OvB1=YI|$E)2sUm;!5<7&GK#B`{Ha0|nWXpiLKJXq5h#+peg&4d zNvA6!JfECE8>D6h9rjvueeBr1sh)~iD$ni}?|a+huzAdoDS5Tn#0aw3W3qID&KN|} z4i6?$>Y3@ynw5Lbt|{^-2gtA$vXcKs)&}8=s|o*u1@$YzsM49Q%5+1zg@F~iC(PA; zE%(A<3J4Y!9?EJR^HIckyeZJf>A>S%ArR>#z3l>n#^8m3Wn=I{kfdbpZ{f+%JgbJo z*~5vA&Tpd1fIDEYGNkM8%}MNq<>&iY0SNZ){dpG$db83V=weE`C}hU?RqsSt6kt%S zek+_#cuY)+yzW_+Co5rZD|GSaO9`tCQY@}geGO13z61)zj5R=`ILR%y^Pt93@M&(< zraFRD??X@-H5&Mn#-hbJa_h_i!rDdjTdx?RNwP?wf)LdOu(8jWpXPr^7T$VzAJC7u zw5YHhU}?|aB7=K%HG4lh$^P={-I-Ku^5>|vTw5gj*Z^|1%JzZVPO>AN`pSfiAappV z*J$+o`T|-)tZ9)6T?fi^FO72vwNcXmL>(5iGROHCu3qscD}SmO9>aBuibfX-4Hvx( z;6kyLX#(6hHDsU&Bd8+BPZTPRFnJ_1Gy{8z0DW;O1_A>P$u%+b4Erv5?dhBifeS(| zY^mNMx>l`Ku?x&VZs0v|Z|@4<6^+i zc_rDm6S@xiH+G*G2B zNwM?)Rd$JvB6)G9zJ&KbGfmtq6`3YFv&JpKXoipTUAB(UasAr&SGatDHEHgGx$`WO zc`wK^5jwTD!3K58ZBKGmrKOxWh`(?H0tWyL8onldLIEgQzZU;=6^ir{-TXOga?8Me z2Piv!FdD$Bqs!~KPCE!+rJNoC#yke^t+?;Gj2$k9i(k^q-* zC53@8{l`IlkG)sxpFOJYtcq9}RZxLcm(Q`k{-am5d@l3wVVuiEw%w&~w>AOyLeQpx zY7M%c#!JP=G)+sdaB{{eLQkB11`?>6(7cP-$tK4evwW9!_xu{$PSQX*#54ifgN@UmTApJvDlJg;fs@9}hfUbWD*g-CK>@?q6`}n9ra=X={TE5o&*MYe*b%KBMy-1ARntdyjs(`6hDWGN%={TXJ7Dgu=mh@oo-!jR@0gUsF- z?Hz3%{20J%p_>gdA^w|bD4)$L_uxqX<F1=<1 z%mRs5%6nI)omyofO?4mr(3y~s(6p;0&lp2LawZI)PNk{i=tnr^HA+jQ%jOVq%BMJj z)m$>fWVpxFeSEdrMs4Vh04q0*xTw|XUJgmUt72Lp^bUm!xi^@jJ^>4PggQPa1eJQS z?J*iQDZs~7{g%GZuGe?&EAsJsUcl-UosKwJudp7e%ldaJ9l6%Ww@+^{vpizHvNP|V zEZ5H@t=Jjo0@jMs*`o$b=g8wc!gCDuWmQcp9bqCKpw6l)Hl(UXWx`XST~xw5m9)rC z1zc3%XWUe^5}z-+rI|%W3)~2L_Jwl{Lmn!Iu85OMwF*WBv;r5HoeGMBsE?Ccb`Lw%$$#S!sPFNXOhm1#$OQWlH?2a+$@u@$6dQd5@#PCg(RkG zK+{?SxgBSE(;Kh*rRjTW$|&^-v``Q9iVq<0 zbjQXKs{XdkrTHM=f>V@U84yK8s;ZzaYsdU%q}=8G@6tmP2hRmq;~Nodpmo}`;o0Fw ztjpdVbN=JN3mhw!j`+ERD+TD~C>=bMxwSx|QwNh_2L}V0Ebta#HF5rF>1o)nJ+PeK zh&%LAmrsZaji%h*Cw`y|E<(+};qVph?g37tKTzB~?(TIF5)LtYZs|$c4z4muJ z*=g&i*XgtUf1PCEWa$7>$lCLVNQ~%D+i?A5H?-;;jFIxdT+yN^e2;I?T+ZhxlF*9u&{;xAL*#!C}*byl8_zMLH7}k89^hC3YWjWtp~j z30ybE-bEopV1~m_bY}%n0;~^pBSnL9Z6k#nL}MC;BcMSsI3oN+9&?1)E&!_PQ?HSi z1w@1BVkBSv19<^}Wc);Pjmgem*twa?Z^R`f0o4=_xw-HCdtnXFHuA6pU!NW|?rgew ze)fT|Mn#RHi0!X9Rw6HTHnftF&U=#mt753Y=`Cu%D$#gnCY=!|(d8T13Nq>A&*&2B zoI}1LpxVmVTW{=bB&r}?s69e)(zesh6y-?K#uZts*cHIh0|yB+ffA@MRYt#0StLQC z8nQx}b%*$C3gmCBR#3;kOF>Vm z{-SMRk>n50@7S(Gw?FVCpRy?LFR$+1*C^?Lg@&-Mq{x%dg=o?KG9hg+qqcz8>yN#R zLuLOqM+H&Y59#GbI1uh1Z7+p-uU!aDPTN?6`si+T&bgj@Nl+`u49kFYn89q^WQfFxQY-emyq?_-y*>rjk zrHi(paY2eb8EaN>K?i&vz*Z1o#^jfB)@!RF9% zEh$=b>>mgR`c1yD5B^T!<11K&zIvKI8 z8cE5V)@l~#)#M0^YEH2|K1Jb>LOizt{cYg$0m6obr=cV#seK3$5(e^HFeGlBP;zY3 zd7IC~$yWAG1c{n;d8mg!`*C!dr`M|Q*VOLT&um-UZQK}1IeW0e>I+uCr5mR4w$zhXYR};3dxdQbK^)t zX1~qaO4;U@a1v{o_M7r*sHS=yt?m^IJzC($xRGe1{?#@ckwo3Wax=M)W z;c}AWJiolfUk$E=P_9mIby(GY4G@^RQkT3MHgz43TWdzw#M)M_!Rzz$sut%}En8bG zEmjpP%Ae)fSl!a{#a9*>)(|Y%iJ=pWR6?ggD)^;B; z35`lmuFm!j{%dapX(Avuv8Z%p?;cG$NhF&ndl$BwmJ~a!L)I~6@|borlXC~nT{*bh zRx{Q!s%$;WP}aB~gJVp1s2CG)F+oV;xx7nW8R*k}L_v}|&x9ky1v!D{?_A&47oH+b z*ucI~Kl@L>HPoF-BEJpgy(z$%2nwOiIn-K8n<1pqi883QTKRuApv;3xS#0MUf7ExP z5Hl-?AUDlbp~qXxmTgI5aV^ z?SER!Uy#fhC+j-%eC80#%oBBJC(ArqVJ9)K0|;@+*3cb{0gf0L#cYOhFmL@u=_TpV z?)8P-K6#z%Q9uN@a`aBOL8`G4gXyMC2nfZZX$FimkFtI@U;w~l!Xf94SuHr+Nz~J$ zA(`85+vucVuaT{sm-hc~g^ZuRRH}GrEMwNe_2yBsTpW~28>-ZhDYzeE~5DOV7F^fZmC&E9*< zS{PIilJjnyzh}@_AqAnCS1LyPELc#1RCqW(2U2=y^mH=I&OZNS)^7HM9hJ@#snIKB zct!U2z4T#hTk8>IxSd!&z0PH7%hKg?b-55)v)$B5oufF3ni$nq78A(>dM2`Ey^8gw zAfKQPQGz>>5krXQMz@$7B07k0ptC$jQbI~)KplYX^NB(tnuCKdRhk@H5SF_;ghrNL z4J`=WxieUbD!H{Hr+us7f{;mTLaAkCNP*mH5}B01KDrtDG5e&#STa6=#J(N!1&Jvc zl}JLaq^*xiC23XP-VmHruejL=XbTduX}>b(SbBq}w}iiFhdMVycCveJAvSKXU~V3O z%<~l~Y~U?=Pd^G2bQKAX*bvc#72F=JU(jX@|3JgyyoQNrJdjsAG5;kU(sgZHUP^IZ zN@9Lf-OYx!ytc)8Z4>i47Uy;3+#Kv%z;-97&a@P0U8v4AOYTDJGM^gM(gb^;#hwrs z%hd|N7=bTH=vIsM2AEEh!+D`E2hO=TYwVub{B>^nL1hna;$;dl%t-1UUgnw zaeKT>2X@Yvm4~MiXwU1DCdxZ4?1uAR^_TjMk(Jf+$m^`fRG@xrSx;LezSL`^nOt2! z&9fTR2_SJ}(-mYc_-oo6wK%PWRHs%4^C~_=%dB+L*SgyCW1>jq=tfu zZClJbA1BNMz9}L<7z>`{dJ&jX8#_`%5{YmB*bsS2PF6sbh!6L^vNmRJQP$4DYUMw8 z!~c}MvLrQcHeiu|!tproeto)646H8C`N6Ai_x!%q>$JvBQ12z<68oI%MO_V%G^Ej^+y4PCGEP0LC#ZiqO@-$};(i73 zEM})_gZUM86R#wUta#VN?f=uX1wtsMt$a2+^wY!VTFySVZP$x^&m|uRNkKMtE_7cg zcS9e&AuH?Pg}%G%-@MSod(4>m^C4-6v&HhSz<-Jaj}&;(FdPlWrrTWw`GzcA$Tywt zl82C)PTXNLf%BmByEAn2yc4Xn= zkSg+;IkVYfG9Eb9zMFqPPwbnJJ^#mt+Yigq_(v<)ubuZ@k&)_T>ckdGUjkdL+&@RF zZPEWaT4Oul*g)t}Xv)lemmI^6HyXu2$+rcqN3E>yCkJLeUcT?T$075W!P)OnY4q^% zY#~W6xB1b+syS?>EPpDp3(V}}FPHBDq&-I16q?IPr7@&wpc@KOb2VXkfPw{oBFgRf z0}dfv(`qH%OP=JB_~+dj@pbkr`Sl39TiWXxIdLTYAUj9498Nz(rXHShh;(E_4^KLX zUn%)Ueyy}vDM98P(CCrGB9##segqOB2BN^38@js+^$y5QP-5qjZ^x4Rz~%NQ zgD^VaatEO94pJ{MU(vBZL=fPqLmo$9*-iYTjYW4-E^Ne(T2h=1o6Z)c1s8Iq_Jeg?onLoF;c z=x9WIC*^T^W_msT=>|$@X*ccDJhlNfihtV9IWAk+rfYD1m=fA{W(E{Rk7sp}=Dk_r zow!4h36Kc<^){v+ropBRQ(lwAybg(ZeG)Z;SSW1ZVfmikZXEBtCW5k?*z#NHZo+TW zL16TBu;q8t-H$2G>mztqA6x!F-Tmstu!ZyMmEFN`A(ul!g6+v%`NeDC_>0#PG-CBW zR8jY5^sm*=>%Xgg9^ZBSn-wk2ODHq>+2uK@f8Wt#mG0dm{5^1c&hK}RV$HoK_ZMI78Nt?jP89dM_l!vJnB0%w?%pFp{;l6ILWcJx z!|8DLr0;Mts<(LQ(Q5=5hP!Fbzxs@z>Pz+oK1=ysI$SAN_L_P0#lP{-PxC$Ng6MD$ z*cdYMwf#ViVL%?L2n`g9KJqv~n5f``TQWhl#0|bMp}|GC3W3CdhglA#IuuT-Ks%%c zK~JH0{69q@De<8Su_*TVK)VElh|oZbNkCpByFZzZxExutRi-}+homMOdRd;Tq{|3ALP8K3wTpBZ-u>y#CY8^j}gRA5JTGvKy(`Ea}x z^HK^tQ~guV0vlt+jWoZ2MXyXAJ^uiyTgNwG={$BIl{6gGztWyhjHv+E-0>wKzw zL}sp+<h=FwFzYzz6;nk&+895>@N`%nBEvMr>}s zJ3M&0f8HSl3v&b#jH46jnwuaZZ>Vunk4*r)0G1S(7}ywWRUq&poqfCQeeKC;|48=b zcYd1+LPPc+Jq92b-YkJ75_xT@X+LvflpCd+Z(hDlh;t~0%U6Uwl#r4jM(*>1k!#fT zZzHGb$Z_)jfvbe`uTucU0&=GmY<#0gSu1tfjWl2Xr;fOpJ8jmL8MAt-g=6eX zBG0(9_#i7y*jiyn#){oCVdXK@($dl+EL&iDB$z$|-?Pwe=9(sce;>;hbz2FhAJzNv zAN;a z+!Vt%+imSY1Gd7u%VX)c@T7O0JBZpr7MhL7ud7+hlOpN|{awWVcvTm?PD)#6390n? zqwZBVR7*=QDmgnbt@?%)ZQ-EY+ zGJZT+P@RmuY%*Z%DMa4H`Vi&AGcVaU#10jGUWX=ZsA?w&!a9EkE5AW5UsBt>-ur-% zclZvRK?LVr?0}zEmuBDrVgfJR0nJn6@G$c#Er?8Ask1&x4(_3gayfhm59)wS`6h5Q zN)?nvT9QBM>?4*G0Z@_^^yNRDuaL9%=~^s(SeA1hUFb}9hGVo-KrgGY_I{>?>e`FZ z8kSqTFwl!OTG&U(>Otg9t>_U2KB(=%+N+g7yu^o>2Bqt{24{eVDG2}fe@ub?y0R;Z zt0qR$mb}{Q3Fzu&QSAlXSkYgXmwVwXGyo-XGcsJ9 z5lC6f=lHxY(wPOP6Eo8`#c)Q%YG{E-H}Mff!?8OA(IGGk-AoW9*B=f@oPBDUfH{Vm#yI?4Xj>Ll(il9J?s`*x#NGLj zBt%4bk>?4~uMg*8#r4UL@M#*EcTxzrtXt-YGs3q+A)}qd67Ci{yI)^0#oZA_YHDWh zmb#_Rh1;_86|GAOmpkTW*r6~UrFZ2%8uIeop)Q2 z)a#s}8zFJbMv23z=<}_sJ{aZa|A!-P{#L7P!-_Y0qOvRsa$V|3mk??C-Ni>BbSmzi zv3NfhI<87KYMNB~g>q0JE!9IG5<&F>Y(b-Xw{C)LDJpYJP>#z1&;`F@Lpe9J3%$=6 zR8qYx8saENtK*xFO4S7i!yK#V<``|uuU&QtbB23{YKW{fLjU%W zr4rN<5(+pGAZo!Vhgohxh&A}eo^896 zohh-z)%k1C6z8vA*&o-c;3s>p8@WEJqE~sjRdXsW{5j|4A$v(U>7?vaN*-M5ed-~l zwy#O@gJ+};T4r3I-lX0)?2W5Il;poZJ%=>B*{|yt7Ww+cPnttV9}LW@{&Fu^IxlG} zDdNuB88xnClxrmc802frs=-R?lhd)1y2WyY(JFi;7}Hou-T@Sa7kIx8)=`op_AOexaQqu-=+ZiI|JZ;bGi(yAF}z)DTYevD;e=W#dB@b!_jg^jRF^E7xgG34mIs5X;Fi(oW^(wYo!g^(Mrp@aKLv zepBRguXb7T@eV5`2X4>k{P29`LkKDU0Nv&;_;XdkpBuXP@M)p*Tw&SL?}9(Stlp<6 z<^!iV!g9^2_5mZhEtWmqpIFf`;I>e1CDfo=lcE&8})T$b3fF_EF{X*kV~_+>eHgrc{( zq9Re+lbKoayH=A3DR>jB%u$mPOb^x7l;edIoDC_+YZVhrf4f#6_p!=XAo=Uz^W}iK zZqac3!E*myVbrGMFq^nLd=Bi8FfRNd&2^Th(52w=<|Y_cRd~5kNos*+#Z#!sqYj=P zKI6wU*jV?KwQ~U2IDYEf8XIfey&c*?$zv(4>vZjICduqQ-xzv=V==}0{Pe`~=stOq zj~VSJ(3_37Oi_`ze5W8}&&Gk8d}0XgDL zqN*U?2&IgJ6fYtI;ObFjY@GX3bbO2RBJLf>PV=Utp`wHa$TJp1H?*insF}nI1CXfd8&4p>?I`XN#u+PPtFzAV38%p=_v z@a;CpU5G}cd#Ji0f}pj->Yjg`pzgdlBpt`yibH1^J#k|h;%s@yx5F~%au@h{Hs)z? zw>w`2Oj~3Qi#34jJtP?`V-CdJU47WQE_tUuCKDO0xMe}#fOZU!Cvopb%2`(fei(^VYI>2*x)+n7WA_}g`Tv$5myzjfUA-w!n15Z#%_nq7g>QE6`!#-Rbk2l~ z^$Jl9K=L-XzI$3omHv(zCe#7W|#9g{=Eky)V5CKPUIUv=QifLA=6E zUrD3!3C*7`w#}W%M*=vXm;*B;%n{9%`ypf^SM=9IgXgNIzK#GIve6U6B?|{d)GGM6 zZ9+=YX~E<(?C)}yw$x}BRkzaW*cr|a6V3wg%{iWK{JZ4!lQbyX|2BQwnStqHS8IGP2!7Z(eOLG1bUFLn`G%fS?Ug-HQ__4}s>3Z zAxYj(s-K@D`J@ineoB&hZ%9mjc3Ju3R}$N=>w*oSjE2Y(1L7Vs<3>8l2_OBxnc3X3 zhT^MtD5`A7p-?Whd8=Y1MW74@b;f$9Jd&Tv8K%osCVq}p9G)bV(Q+qaiZsW$AyVod z%3_aS@$+8)>zZ>9d`^4J9>3_k&41yl&5^)WUdrNZU!7j`)>ujY{`8bhvb;58HQHjo z3M`otHc767-3&*MHpNxN=Yn3;Eb|u)KipgB?cs@B0p)RJ4b}Xg;brte)QJ&QClwRn zJ;)ML3=^s5+#Mlx3}$vXw*1+>kIp{uIqorM;?m1j+wzs0Bj6RuU?BmI3aqkb2JPe1840zdxz**`rie z2n0ymtl83J+6ZM8=I<`w_|;jN)+ITMr|&Rhj4zcka}vfFimZs29bszsAtVWFaSM0o zipxz6V#Q$&6{*zl!~^F-x|iKC*e?&%4%TdXTBpmML^6S+Y2Nj!Xc9 zpE3Ht*At^>b*nwI&C9Z~n1o(PO-oCCpY1wN>49yS`^eHS zD`5U{vT%e{5`K=5M1zO|4d~J)9r3~x!a2YOL;u&vACtoc$7kj@<5M7);H|KPSm*|i z?xVMcg;zRg^$eKwc>UbDW)JWD`{fQ#UF{Wom;D*^*NHd1JhB^SS?~0amEG%i?jW5z zZ)YFoN_0+or`28nQSH}lmpA?>`_``LQXcI*iRmbNU)rJ^#T@&Yc=(+kYJ*Q+BYz-w z3IG*ijH)75q;umr{8e-acy~fI4i8#a=fZbYOosbj0ICGf48(6rET|kaPOu-1*tEaM z%6Iddh#wz3_V-?~c)d-wgqjb9#+@43CvixOf~Eq#BSzDinPk<18S`ZV7sUOdN&6c# zJ)Bf$c^FyqU~|V2)2p_LZ?b*zT3(s@D!V34!w$ys*+KZYXQydmqI`-IFp2x`X9sNR zkQdHQ%gg7sjeB-{H(xDxW!hSxHjZGQM-Y#KH_?zReY#CC`)muTSTtf#wU;ZK{jK@r zWG3m`qg!uD-J-6us#l*^xl#wR_Tw!bC(o|hbKNdaNZ`*(A6pvWM8-h^$LeZH4F@v@ z2Qx-vT5iWU&ZADX;AVi{a~xw(s8A_pR?nrb=LP`YVqDpJdWMydBF|@4r`wzSaH4~M z(!3p2%dMB%6oE-KOWAc91&l|*q*gHJ-dA_{qwU6nBK9$RDsPv39{jwP9(sN-Hm-3y zFr`K$Mlhuh*{c_1^QD8B>qn)J%?kF9&lO$0FdiKf()RGbovV&c^Zqf{@E8{lGNL}{ z=UT>kq;BlZ?gHN~Fd=PT1>aZb_SpanYLT)cS0Vlfd=-zGU#{P_!=EERxFGKiUT#l5 zaz@3*H|<2sB!S3-@ZS}7EKim%908p+DE-R9d!0sU^_imfL{omn5!5c+WjvggHQPb& zJ9Bsk2<8KkjqJq8L`P{POuxbW2~{Al1o=~RBw`$0@TB)%g9pEGbJbuCtR$uHX-u?v zon2QDlFRdzv8n8}?c045oqb^$ot;b%AdvZdKi^N{L7I>#v7a9UHA0fF93*ybDsk%x zGmb^gI5HP8<2CA*8WR15j-l|6snVhiAFk=C-XU1eo`ID8SC+;#IH6x7E#o=<5&!*u z*!4%7vUgZr=!<~q@BC{nLdE8?3h8%8@ONt%Rvl@ruEz%<3Y0&A00$e6Jg%8mz>RVC(j>PA{ zbE^3i$kXR5)u8p^eBmqh~3 zpy?z+YqO|I$q1GdDG!chRdYRBv>3CepG0hL_({s(L7N|Bz3L0gYG+BCSH@9!Jt>zb z&PD;dK60N-FQc^yG0g>4EXSD$N3N4*Tk%t_8CGJg-2*n-iFt6}!nDGebq0dNM!Du) zHfF3Tl638ERU5hnxzF~6OOwLct3!oWxnz%73fS-GX`A%LrkowV0B79lJPx(70|=Sk z>DGmG>9U*Mf0fWHqA$g0Sn;ulqg6xASGeeFrjmq#fw@&Bor~Y$6(LkcBpV=WzpAnP zFsNEpjN1{degsF=2%@E0Hc*;U%rFb#SxgqT1pJD~OA%SUP%W@Qp%!}MY_Xp;Z^xF0 z!9{+%*x%c-f0^PHOkNtCrg&^7*8NNGPgBk)+m~z~Gu`Hwz3q4;&03c+b(KUn%_fU4 z4wvZI)3ZubYrZ;g{>4#L8df-+j9aYGrfoAO%_3x{@Nc!!`?qLMIZjxBZ^6E7hrLWN z3I7&FwXm=Nf0fgvj>`MUinYPMLX^Z|^@WQ{a5L2d#A{NplOk6(FbVCeC6pY9V}Z?j zvgbTuPy0UF>+9v=k35eh{ZMcO1cZDK^&@qjpUVEffemrneYpPm(R2>IO1eT=Se3oA~TbZRbf zAe2ocv6z2In-&)82#k|M+HYF9Xy!xc8Cd{}eqt)Xcf+{X5hX8Wxx(<5@=RpO^=&0} za#%otHI_Z@uzuC(A)nxv@5-U%G=ABeXF9_fA~q9qb!{7G&LlU)+si9q^av<@!DiEv zPOaOtYBhRCty=T3?uBwKsWIlA08l%OpDZRwiN^gca)^WvNf?Ei#N3zIcFe!$-}%r^c~|y5=B{oDvaryqtabh$-Pw1?BAQc8AQ&!`pw! z?2xnh@b;hiYEFlzq8qrTw}!i8F#81wX!2Q@3)+QSKEp83>zaZ+@%`t?1}OsENUqCf zZYpgC7H@4aB1 zS|nPpEpbo2UI|9{4&F6??jz^eGJ!lCrj6M(ZXO<$POxds3Y)WeVPwH9@yutiGK@`| zNmjBU1H)lN=Hj-tV4FwcY@^%FxYMcPP%#KZ=4WMU&q ztdaK6#D>*y|Ph=RL1w!9Yjur0s6?k%K?bSt|AnL*AagJ*JZNl0el zP=Otm%sryw4vu7FD%lBg0PrdB1=ycZIuyf|@jbag^NCTzm(6I~+QaO7V&Rs?X-j5o z;4fLNIcq)4*21|nH+on+`mJg7iZtmJ_PV8I^VX@}o|fhn`py^vncJ;YhH`BuTy2pY?&U;XujsCR7*ab(P`-+nI4(fvDdne&knYg zN461ZVdr(?sc#QUOxK6K6LOVxnfP6s&ePzBCgthqjz% zQ|UJPm6C^+julLk={7Al-mMG!;_&ft%%iKM_R48UGJUnGMq37TP6WS#Au+h#Bv=+M z97Gc3YVe-=7@Xvx{LERvky5bx{4ZGV%S$Jv`}BCNlOzvMZ82p3D&@$WmAf}EnLKDd zPofi?H>3&}Qz>E@@(N&H*-e{O?j-awZA_Yobl6qbryWj{vf3JMca^EzW`+ zj&boETbvi0SZIxnj!le}2Ij}(`2s;);+LQNNZce2;w$p^-He~Mdxkqn2HOueilQA=8dH>v_bC)BD0^V(txj8s@ z1T2JDaH`6tV=q`E;Y!sOOz?KiU*Qh+*nEWJ*p`U21oRd;ZVieKq66WxMKBsQ0C{09 z35W7yLo@{31S=?kmAhviHG8{Mm@*PV#l;dt~f_<=0% zf9Cm*B&Fqj^2Iyh>^_@0vkz@pezbHXYjYM0Bj4}`UQ*dvLgkX;&6_u8oh$iZKh9pg z(jUz6Sj7rhzt!sc349k#&i#9mpk{$_Fr4UOgFc30KAjGZ^h^+(BPK+2X^BZREF!*) zo`K~PQRu91DG1t%R0z*ri?Q`dPd1+U;liCbeNvDxir@5|{DwREXa$GdsU zF=KtkFPOllTum)-l2>LNAE2yHEU0nyd8@n`+gkVp7G0GNJBNgacJj&!Aau)ex)XRn z&UcXQFTK2fA|Yn>jBO-z^p!COJ&-3|YN}uQt>p<;CxK^pL(cV)(TNj(JwbaY0~M5K zN2PI1R3p?UR!3D8O}?r?C&qI{*c{yZ&!4M{=Q`p!*%c2Eddv%{(~UXmp@!t3W52s|5etdLsIwF(s#0~$t%K$rm~Qvt<_NDy2$cpX*jsG$Dqpjvzmqs4bH zTD(pWuPceyRY2CZ{OTf_7IQ!1_kNC=;%km15AM!%)KUKtRG=nv$QDOEag8k$sp%Sh z`*RuxZQJosTaggZI_O(GK;RZje2OL5A~m5F>77RhE*_sB{%ZT{5nrD;{@}o|fUhIo zGUrCjx1LbGeeJ08+L%@j+Gs?pBkbA%lFEKE*CxSqwvuE!ok+ctrMu)47MFD?i$#$~ z{DGJJ4*8_y?MwVWmSgq0d&h@(ze_I>@BOebsVTa&MB#a5e&8rB6i7k*+DULT4{NbL z*_Bu51A9yf;C80bEcWK|0LuV%0F=vPPw`T01Vwk4FV;z^SRgYdk?pTso)@B4pmcU8KneIFLA62G@gxY>;ZOwVoEArRjs` zDCyH5{aE36$dPidhwN)i8hq1lbH&lAxp!)iSs`q77@11Tw{J6JsU%g*Est*B$xq3g z6?2I%iJ(z?<0yUm(%coO`)dK=@Em8e9K3$9sJOnOE{CD`SVTa%Ai%^cl?BXHo)0rK z&K6f8u4bIi>(k_GZu!a-X4Jn z);BhZGos8`AYpj!A#YfT7g%y|LmXTjKk!5dBT1aeP`;LBvLQuzDI_$>Vz0@#gUHVmzYX@xvu2*=D zUQyT7P}A=|A7}upbH8zS15|I3Cd7p$oO8NVac;$eT>Oyhl&JTEVaA9>K`x@LITSeO-FdWamSL1phn+x+OeD@>1}-Nc3zFimXBI3$0dD zmE6f*T;J6a?Hwj-B={Q?Z+(248?|5`;hbh+^*AWf`SE^*X$Jwq7zB-lS&2BgwRbttm@GA^r1N;R%b;zljytgrKS&Wo+4Gr z=-BJJ>E+jFV%b1QSICC5xx8v!a@3YF>|gtK8d>Z)FhYohSYQ?B368 zUl>qre0{g7C`KX>~#vI0???W<;?z!RHedKaj~_29pc zfNqw8>hlezyt;{b^;OH)5I&7XATE~g7DkLSCV^ZfE}9GDp_sHXNdp~zUfi!-SlO?h zUpqf(AU>GyUuMgK)8vQgE}{F2s1A&P{OY><0BfyXc8M)EgSGRxYBGGj!Y2x+DffwD zDfCt_(w_`AFIwq^(#Jl#CQn}OY4$xl2enemq~xZ}UWUK1Zo`J1eM#}`b+CF17R-e4 z>vOz`(xQ3Wp)hk>G;cNB+xc6XG$~b%n!FAM?7SAM5bszwiPY}|K(W^CN6-!p*cAC- zMvFB^@%H?dt6padyAFlz+PMoiR)=@{gIl*;;&&+h4tU9-I013|40x&wD~Mgo(Qtcq zkocu{;NZX`PNIhl^At=Q31Jn>2utw*)t5lt5vzno6j-8QtOq~U&cVY8nfJDe7Rur<^^5)21U?38bf0WuS@dL zWzlc4HIq{7ywvLzg$|xTy!MV$%#T4i@Zec~Qm(=>_J?L)Me8zU2btJ4b+a-qDr*P^hcyN~l@ z@eUHuRPC|r#)YZ z=;1PXCZ~WW(pLF(@DU&6Q;t{ph%lNxW$9D0u%9d+s?uW%JbzNQXvYk49K0~6AgqhgWm2!zQ@S*FV}9}rr)5^t!_^m z)R&E3+qGYpb$(<9igK4yvVl#c<=AAh#`!gQi`6A>b>nkb2zfR~RDee!eofWtb!hh? z#p;9%K1|JV>InC8rOM@7g?~`!^)L$Z1IsQQ!Rm*=D?-Zd@>CKWdW1s)L?i@`N;tPt zB)B$W0u!XXljjx}r}_Cgh`e(Cxgp+)GpNDfb%)-+xjZL{dM6DWI7Oy8gs#{~{LzSF z<@1fTSm6lSk|9-<=CCIudMvlQ3QB)hrYPG?c5=>xAErA7QQ>P|` zHFkt&$(c5m{%*D@g(f?VHf7Sy{5u4d3;a70{%YURzzW27*5Ny5WiP%HW130ViSNKC zExxn1>^nkT)PCn2##SW06Kh)M`cA0pJ1xt;Q#Lm2Q77bPrYPS-=cvZ<-gsUq2ucgG zL6Qm&1YB6)A9_gy9-|XI-2bA>_5uxY2c#(GGK2Yo1tSlfr*@&QDPo)nW>xp2s;Ra|LRr8Ulz z1$wtIRxwNWfdT^&f>)o)1P&>xG)auytl&py#~%s+@>~9%^24)0GxrXna{D*=wm6|F z?#68HAOWP7zL^-}H~+AOE&QOtOBIts2*-LNQWs}`DK+BxnQ;0ps~#pjk0|*N(8$f5 z?Xt4yyY%+5EN4s1<1l=IzaT~>K{kl366Yoq;bvV)u#1(wUve)(s!CV!*itj-C4LyK zhpCZ6^5hcOl;^6p)M!Zjb8h{_m2`@o~~SQGLqCFQSwF< z=S<1LxH=)1BNwN>9JqS}_{GIPt2qSoOe*t%>Y2zjZUOv z=bC$!W?|T8`dOpcThH!IAKmltib!C{)$KfJ)V^1gTe38HRL=uz%UjHymUUTkB{W!m zbJz8KlKl9@5z-&*`&#am!;-w|`5KfdoFeb8*iY&BO9QL4KTyA$EHC=g+GAa=Oh;WF zQn}07$+GhGF-|Mt$fvcK!-0j-#6d+jbah!o;6{_^V(AgMF^F@7XLNbaHEV_PRj{XE zW~$VN!3ucCUjk2Usnaa7cDe0QmjkcvNPf9u%}OU?$Lx8XBB$MtSgtER2d+>Oyw3MA z&U`HrELWF)gN|C+G{KZt&LucqF*7h|NC=RtKJ^0ZS8qM|3Bv+lXR3z`FW_=CqGkgM zP0teYD%#*?(&}nzv1*w!4noX z7*gw{p4~H6)E&R(r5<-X%~~8ZVPUoQANCwOvAVQ$T-E6EmFu=SJAqa%ADNi()p!y< zBco^n4Vl$10qYMN}q11}6iIp!1KT;OEa3k|D zSSTz&oLVV|Nyi2(*&FFR`~P_R4)Ca|?cdq^lu0t_y+A?|AT$XONa!7;_ZA@(={2EO z=^(xL5;{l^ha}RJq9}q23U;oba_#LZUN4e4^L}feIg@jc`~L5J@B5y9OfoY&`|P#$ z+N-a%^$BIzcbEIFJ5yHw`2rfZul}vssokDEOm6nt9uFjk=Z=F*Z^_La!yM(p1~qlm z+lGkdNl#_>R7i+8oVIV}4)`u5a-#3MaqcPDEu38G4oMpNUPTT#1AY!gRxY99)UFBr7T!img&FoO8V+TMx7VR!jAa@9@uZ(I*-9>raAVr zU*$jH+Yg7&LZc{}<1@tdxg(EH=Tl*sQ8c`QLBisR!V^WYR&Qtv?g5z3Dh$U6QY7&2 zuVtN<-Cx#u8K2HB>rL2YIu&1e2CxvvFPIB)W5a<+k!CYW+j?-{=#XRniF?}3oZhX; zZIZs!onW*Y2d`&4$TKG-Z~}gEM;{m^3O&ih;{Tgpb!f;p%6LR z=E8;Y^t6Rr<<1i&u(0@@MC70c95K~ct>M}SKSjO>{Ghw$H5fcCB>aoG`}>OaABsB| z9{=&dv1bPAMat0V+yN7@QY?SYp>v#9iTtY)aF0Dvd#eecma2|z#;S!FG*>M!Y`!T6 zoxPk1LKVEJV!ja;fC-OJwI^jnm;>|;T)oz2(G_ly)GjCd7ucI8s+{1pw-`ZUt0)9S zU}C2T_+;_Ux^X1%Y4fHM;9)U$c4xMau2D04GLrBY1jm0<)MjbR^oh9-Qi48?`)FU$ zKK+G#axRkLfRO1gT|&wDmHs zB9M({5=yc(mB>20?2KWn>a>rpU#aip&@i?zB<{l_y~bbEi+-Qi@ST+4FXHbR$RR>0 z?%#7R9YnnZ#RyBtOG8qIe8LFt zq|^#%-fSGgJD1`wX0#gBb3*t#;^2hET+KiBK|@<$XZw7fznUeN=c7kH?hf=!JMbEp zhUqApVUEh4@6;*Cg6ZhEU|^vQz-wb-p&8yZGhwwAKUT*#)lKT~aRs<8JJ>^Cu$63{ zCL!(G*i$N#npG!rv6;h$Xqj{ZX}96xl(n!xaNyFD&t^3}0@vm=}# z|JZQ&RAkWW2(Z0Sdx*qbTOv4H^I~~EZ*{M#RaQyT(sd1vHf`8#DCd3KkL;L`T{wg; zTfe$J2Y0Ra?l|$8>OC(F+|ZpR&1|xGAD7=h(%a#P_8iqG__bC}AfKcRw5Ym{#^}%4 z4js^YJNhEuV6bC26>41x;=hGzu*kd#hmN zt%9Mq3Ywx-aOkNvmcavW74*AR&<7nP>8pZ4w+eD@6=b8)GyKY-r@C350y}bQ>08i? zY7mOC=@AjM_0Zmtayzu)qKIg_|+;F10V zB%YPlnMK!Lq@Pjh)^E@&FvwYNT2GgBYfyuL(H*-DW7%?_YW4gd4bI9fe=$<_L|!UC zHtSJQE%r?0tBJ~Ik*s>Hv5AkrP0Y;=4(i6*MX``5_qZq)9Ocf9VnI>wM6!@b_qa$F z9O=%DWI>UvPw$yQ0j-kzm%N+%Om0+ewcL~V>2!>(Ha2SPGh zKL+Y&cm*c4YhI&XRM|c?k~_()eGBm2PHiSM=_Yq=#X9SYI`{3?lMmpmZsn5etikp1 z=5QK`01%=OEi(+!o72%Njm7)uk;HoD%uF8 zCc}^i7zVi-w2b~W$voYCE|Lu%9O$f5qj{I$ZLSk@r!80fHaC5p&78!l^k`Qjld<-V z+2oC!&mK1Og^ab31fwAiN~9>{D`gmxKzMAPT%RU0@4Y{#q|yb6?iJ3g3K?wrwh?z@ z*^nsSv+j%Ip{JGg{L1G^6(|GF(MAgu9X^l?;;U%xgXD8RP1ueoZ zH+}5bF^I{EA+T?wk?>h={=C4Th~rD=%?k{UI9gjCyr^s>lZP%W8xbfMZk=)Bj4T&z zop+>=*PJCuub=TDhc#Ts(oP0XS_4%*t`D0zcg>9IKMf)`?A|VH)qIZm;b0i zLpQhe8`?R0Zh+sQF3-)E1{Vyfydrz#j&2gyR=+m9(wvSP&v6AQF5O3Po;RS!^PG?2 zqdN>3))W5>3*8~B^2#S@-o%ON94Mg5xaQjkFJ)GgI)tU^t7p#JzV&!esHbT1kU%G=Vhvee?*5o}XES1n9Py`IQ(rGa|VmvuyFk;B$_Gq3juBQ?cl^)s0z_G81bTMT_)N&3+Qk> zs3OQ`UBX@Q33-(;tc|$!KdST4Epn%-L!^iU0{Mo(w=Qa7j6XVW& zD)Zv?$7Q~B(({m8tq?E$6Nlmupa?*Ai#NaCcG?B&qtl=&;*6ufTDoP+WPnlYN0vE) z*&qawu!an4I6RUgoZNjR;c)fh>h9~|{M1!k1ZdQD(58fWql z&SWLW5`#Jf@=Q$nN}e6@qF@7wpcm;5^plQ@xct2E9vm2SEYXJ*KXRe&p;;bKYHctA zJR_tF>at{XXc3hJb;XN}ER_A*qI1k!2TaP3SDHA1eB-=|PCA7Cv@|w&+@vi5{sa5v zyck*({P4ul%dUXCy*jJTnYSh%zNws+D%PGbdV?#Oi@Qi)(UPLKVAT7%o_YT6>VBT13BT^F~#B?ncYP91vL))xWLjxq7A4nY@ zL3$5V+z@WC3ASrDV#CguRQHv&$HM|#QK=;h)IL4OZAeH~)INR3Zb%4~Z=Gt?_38CybG^bFwU00qobyH`w){uMM!#c zGfmcN<9sqVxP;C5ulcLga}k-$q*W8Yb>8Qj5=!R9N>T3R3DSU=&6^iVxm)KGKZjRH z9*SrC!Ds34#vAC_HYR0Th*_P0s%-Clk~qUKx$#=U)_>@})2gVw{{1E19x)LIVvWc7 zeZUBnK^}|epiV<`1kw#P2Ep2%BdlT*VDmXb4u};HdodoWsg`HM4*;>kGI%96=z$)| zQr`MN-|!XtkN)j7{u$HUh3<>&oZg!EBZ1k2;BjtsV*wZ)Plmv>kIaV7PJ`=F~r?)Zyep~l*LA?32gbEt}KalKdVO_ zc}~{RA?pyU*sZxVwPbOlep27Z6Qzv-u97kGO6sOG0~p(ib<)l#mYuOJ%C>eN4`zN| zaqC?{7JJ`Wjoo<5J>&4NMXY?^LDJyI6OE^|LU*m+*q1QsPfZ(dJ22)RSlc5I3lAd} zE}^Ck3JIdm#+itadoPI7zrS|zlZXYU7Y0q9G~;m8LV0D$ALl-o<-4b)z>?o5&y(c& zGo>Kfhp~XKIi4&!W7CsG?8(Ho01O*Wktdrwgq}?4GazfZqCUHzs6d}xMmj4!ED0nv z0)5!P5q^?)!q4fwSk0N}t1#@{64?(WR^B_3+}*p^8gzS$xe6=IxeYAQvfk@!ggYA2VxioambnOT`q zVDbFVnrFRvKTv|H-1NbkH~NIDRp$E79=Gvk*(g8%Sz|Z8n-tw_|FEkriIx2}tq!Wb zTdVR~-JM?x*^6aoESHs!ix&=i4h$_f7$#%_EMSPqyyX2ZKl zQK9l$Che$-q}pdyd6mAavi_@HBt=Yvu=}WZ(STViW#zpK3vf<}lD7fF{*VaFBJ~7a zm_+h)Ac$L-3_{}y>1Uc#{2*0<&`a4r(#_*~yKO}`jlp-DhNg_D1xQB zIE3Uo|KKsdTrYffl>48HzU`>T$OoazpS(Wcy=ac8)w?N=KAc$1tr_5)=x5-Ncm_CW;kSXs+ zQ^gO!=OlEC;w(tvD+Nu9ZWIn!$6ou%{WhERHdi<5tL2sM`%Bqo_pfg3yXW8F&)cz% zV89jl-*9g-2WvV!o<*KTgTazn!yml7BKpUdj$iRB3cS{Lb{J53b>Hi(nMG%@36!VmMgn6#uHYw= zJ~j(=Ua^G({qp?K`C+#oEEDm2jy1nqXu2fbaHTO3aA7a^nchHXHgEG>5&KPtmgshK z32=4r{46)a=}$tB$V74W4Ye^f4 zYf5%DV9_j7l`oxSxBZlBXLb#ku|!fj{k+CY?Oy`d{*Jbq)4~m&O6{7TA>2>_Z4quH z&n(s)$VKQ0q6{`!_X8gJUkUE>P1qy$yB;L3+^SP@mm}O0A^oCEL|#>%R?gBHz@`YL z!s$lov6`GJ%v|(pDH1&4psHG z-t}q|pL(?k|IbfWTU&MQPSw;WoX`Ez=4znd?U$>qduHz$d_3EtQ7kAg$$ph7C=Kz!%B{ms8{{;Ke zDQ#UffnbXRZ1+G}F^*i#;q6~feA{Mu_?WmOkR&*=Fh$lkYNn)Hvmk3?3q%3(#|d|{ z5x_1G5f$+U3M1Zw3KZd^k*G5=&%F_?d;G## zNVNWET2Y$*?XI21>QhHG2~V7$uS zXWDp}PwIHE3TzF-as?lBq!KkU}8!w>NhN;7&qV ziv7k6#MXIk<7K1RKPTkWaIb9*RMP1S@FLVEuuNfRl{+*TnN?0ie4N1VJ-k@Gkz^%V zl1gc>vy#K`kE}3smi15If4Y|?@F_FIuUpv6EvzlsVx;3O#_F7ornrQLIHv)>&D1j& zWP_jBiKXz#Cm55Z3&jQQw?V{GzL$uB=MR8|&+(i`m~o~_U3OA<=f#bSfx_l0HeP4}PTKCb_q#3uzEn#Dqr+$(~pC)8{} z`UfD5cjRbs-p;B%h1`V92BygJFuxIEl_Y7bBqXU(8;vSJ>mK+KMCB>59WX&1A~Qrd z8b}3+$Uvvaqz1K%>Xg^NzF)Vv?&jjiprG2twf#9Ck~6=UovqKF$K`F;{?tE<)$g(7 z=u6uM48;d;Hf=UxZ4AFd+!T#U2)T+)Fu0iA! zOSfd+(n*3$C};RcDwL1##u`;;Omqy~aa6%inX%!xOB>~P$-E~^s;xvUT(R|bbRc8F zM`HDMWeyKy@&*=u=-PK^lv(+XmY}!Y(SofkfA|eae&_h4dX>M-+PRspx_XCY9>rY^ z|GAxBO@DW%MES#GJU__aVs~P3TZ=P}B1})=IKH3*?VFiH4z6$GsS0WlL|Z0m&;m!f zC7})?&l-v#=|U&P468V^;2i;+*g1ApKa?QlCg{8BZ`^qHYGAPE+YlBL7nCz$cJZ)6 zIBd4+AJ&%Tch6jSlW$hO8#kXzwcPIjj%QJmnkDqxv0B9cq~C)77lep>A*(M3vKZ$h zI$gULO)>*7Ha`Qba%)O6Mkf)~!Glw(?b7AH&_n>6VFG7KU#IFnU0Zg!S6E;LR`33q z5ByFmW2ddTQk|Vm(7XAme$$6P?!ac8zb(rv9&hObKSK>w{-Aimd|5jC$`<4w&6WNB zg7xls9bU+nuus&zc82C>bgzXb5$9#uqDIc7LsRn-9MX4#6K-^~FlBP1gqAAzT8tWn z&ByNAN)EwQEkPqM+mKVi$YEK5c~H79^-e@rR-+b8dFI4Bt{`2%u4kUq$4<<=zN1BS z%HVm);bZxuj`3}A<4}H(YsfJEp?q=Yk+-FX?(5&(Vf**LIvO21+HKLZ*{or`M=D;A zidrN%WP;;GjTv`9LQ{%-nx=;XbjA1Y&nWtjIWawIu%Wd3^^PTDSUI)qCp7 z>f7Z-Sg*^`!e{Z)6`NSHO=Le+p@7oyq(+GK5QgdBd3|N$qQ?5N8-)eDPC=o*ogwT{ z;*$O#+DP&|mOjIC1Ce>(UyBf#_ms*jd1=F@5sHVC_XWFYQ35q?q+Fx2%xaE7b$MdT zy&I1H&B?gqmN-=fNxJO5RExzOe>E~%|KYOU;X40KuRMN(%qI-jJ?*4F_4`bIHUId# z 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 z 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 n+%(cQeJzILiBkG!fPbklV6DT04V7zX|ig#LmW literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/default_avatar.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/default_avatar.png new file mode 100644 index 0000000000000000000000000000000000000000..0b9abec7f2f0dd7fecb9f3fdf99b74bb82199814 GIT binary patch literal 10094 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/empty.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/empty.png new file mode 100644 index 0000000000000000000000000000000000000000..f16d1a43b09422fdefb535b6db8e3cb8bab217e4 GIT binary patch literal 10018 zcmV+-C*9bIP)%M?_FjP%G-Kkf5#A z_TOF?z*elqrB)K$Z?*Q;lE7`>so4)lUXHp_Y&^n#`r z1F|{L3mVxh>ut~rnqCaZ=0GoKWV5WdK`&@}F(8`*y`YiJvfc*0py|bcY!38-MmEcO z8}x#v7Xz|6&S^-q=+7W^eHGw!BN zpZe>;ERD)^Mi7K?4=x;A-A!b~WLQOlrlhRqZ=9okSyBE2F`1tO6Q4tCqJ!n`*lo}GdkmXy|1f?)!Y#2u=Omo3iSqagBRk)lk{ zl-0Zq;76QuBNK4>(nSUPWX(!pl~kMf7ze;z)y0|D~#lj z4|6*WsJ(yU&WKrJLj4|F*80(_*t+%-9sA+El z12Q~m=L`$r;I}fc+NDML_xGfEDF!sewBoXw55UsrA2uk^dtrs zm)4XshMB%Ja}F>DSfT0jaN(G9J!wvg0u3>)q_p~V4&*V$asx23MXkog_y0KmNKat$ zvt@e**df#fqLuV416sk^i;OuAE-5T1>j`rr8Wjhcm9HJhVQNb`1I7eoBF6zkd!I{J z{4B?)bS4*<);!7>9t%zq*c zfkv+4`48Pu5YX5R*FIjKuloBpeYmx~L2Ca!ZCgQkpjll#g$Z~EU|CX_&VgOa3iHK1 z9i^1w(wbi|hX0XD4+oxJR+#@Asr9?Np5j153@ItAp)G?{>CEB#I7cG@fiWfkTmWYR zXJFu5aQ!>ySOU9~%_rKKeij5BH?7EZ0j{}ca9O-r*6A2r;PoRUmi z8x))t`v90uI-P-Qa^U!~!u*gnT(o1vvb|D4(`DNQ4QCo)G#FttnDEV4Ux(!F1zCNN zGoU{P4H=At#DrL`1KBoLEL~LKxv3f3{$tqNe>`Z2mzH)5Hf`7ltJM~iwW(=om^^)Q z?7`A8BIo>>Wkm%`Vz{<(>q>E;dHSuxX)2SUDQ+_k(DC7K55Z!wp-=V&s6Bcd$B!O& z*HUXVqIA*elQ8(gK}bqYiVJByNku6RG@(N8aak>&PD$!~w)ImqH+5!WOrJFa=^5#9 zAD%gc%a$x2TNU?#q8vbRpjoxLW;7QN+PH{v(o&j#z3%`HA3Ow`)rvk@eK2{(6e-Q3 ztiwu{7UnIBvXi(sR~%?ouGu?Y;9S`ZOZCS^jGoQcf7!-F!K4CR)lW=Y1csqH+>hDMyPKkV+W`CKPWo`a-h?rflB~0gjKueO(A3Cy!L2{`h{F4bf*y5^!>cPeAs-T=!yzqk%qe zZ9It+hbmEDyH5m6v_+kmRADu@mfG$1^%WHrU25A&rCo8LDK6VPmx2E)*aVEN=Wt-x zKhaPZJZ+f1#p;B>;S-z1BrbHYqSk2fgYok*a75^Mq19r-fvWW)aD(@ih?LBMK|eRO zo`cyK7#E!LCV;Kjym`|LQWvwU>M0L2rPa4H#{M3N0VG|jK6)88tJ(c=_Mlv3_8kEN zN@l+iviL>-BqOtz47nn%u&^-V(Vhzz79 zB_K690WED79IS1|{zHvuw>l(&dRO_Yx1T-v?XMX_0X5*9uiL!2{6{aq+apvZM-u<(f%@ke%uI1$K^b@OTThRGoB#hm7j&A3Q4p zhYaOuH!b%f6~{SL+Y)wJIq;ih zh51j3Mu4@1UGmCUvo z6Z+%QF?~YTZ@1X-an&j8KkPJQ>kd_6|Bg4rzbDMP*9)M#EB=ZzwfjLTY36NDiFHzw zG$_1&BoY%;Vd>gleFodB>%-LJpD!&exPmIpoH=U`NgU2`bo1s-L&FZx1r?MBnzEYL z7;vZO-1mO=I!+$hB}$o@xB3a8pll*laqH}1lGsSVDf`z!x5U}F)`?qEgCh!NyZhMs z?vtVv8a#Rm#!L{8W{G3aSW=4bIKkSe1$EB-3okl#<(0FF1Ocm^_4thP^70BP##}rZ*i>@Dqv}8@Vs_xHgPaE*&N6wt}@;4ra&C)K$ zPw2;0>JC+cj$b*!GzYoEGjPqM;2u(-!AV7}+j1--M6sL+x1kF|eUi!!N?e_iFhvLbIL8+KOLw>fwpWitkN}EsD7sJpJSdDPb zF`~c;8Y${85S^>m>`RBOlM}hO- z-`scvwe^Oe^l`vqH22A%Qx`L5Ue(ALO9y&E6OduWrPU`GV>zB5Zhmt)Y!t;a?G4G zMz$KHAm2-`?+-TxGJVf3S(KkWYu43bRIt|&4#2XKvc35L_q$rm1)7Y$!*SWwKbOF4 zXYAzen@3Bk>#9TsFi8NH;q6jEo}JK6_O|z&ZvW^B^N@GxOcdTQDxiuAHn_A{jkERf zgWGTZdgnXuIRCHL<@Vz#9hBqT@uBYrhpIQ?aLq?Z$ryl%bEV&?Cf67yJEOX~+8s#D z{o!o^H!fY#X_tzk;30WYQc6RkS(Ii{OYOm(Yroq0_Cl&}vss5$R8$<5+BRPG6y-gw zDyuH!V1A+U`r~`uHioad2*;RU-i>d&FTOsDEmf!Biuls!S1x!W;NF&}ikfis&&7Nk zDXupGX2Ykopx;uPQ4-!?QZ;_*tJllGJ zcx!q2rs)#aH11Ut1)Acrnim=H%RsYs*%@-8!k+!mLXI7gi9!9G;eHC|Qv`V5q4VzD zXP50npHG?pF!U+G4|yJ{{t$<2oJX}Uo?axTMYsyZZL%|U&?cyG=DaCnJSNl%JHh#6 zM=A)vzr4Ks`M4uO!T^c_O-WhJI&ePEbt>MI{;#Xni5?9lNs-s$N|lr_M@dyYRiG3v z%~RTtZ8LH1gU|#?{E|dKfJ!G0S7G0F=f=~j(F`y|~Q=P;e>@Z{K8;HrCszXk^ zM#_Rw-#b2dR{TcOrs&l9(m?5H+vE(JfV@e8leVPL5K6jc4IE>Az4XNxpU#VvDg}Us zE;2l3+*icGe;*7muIahdM=Yfc<f>EDM|g*iUqlr$d@}dExT3Hl$7ngk#omN#@I;rbUN-83np!LY=G(;VD8AF&SNOP zw9u)`5u-Zuk!g`DH~x?4O;Mrr&mm(XJ10eHq`SBL)u}2qiI{rRZ~bf~4sK&$&!}`6 zk3Fzpkn_w=7nUvuP4U|5OJHYjGlqcKQ6U74n=P)SEcypZ$;_L0tE}`-XD;xY?xQaR z7}{fUfsYQ#d0qzKyynb#8>g#Gnm!p>*`2qc_yUJ)98y{U;b@c-sT?(4w)nAQdf^{ti^Nwzb*MYFfo%ei%|Jry0hia3$${9Xh zJhv3gRVELK7RK{18>uAP$@Y|1hBgDXY}z88uB74%8oE7VN`MoWzQ7^d>%xnsiOFNG z#B<-7QF0m4MV^xDltm|Cyf*tgXyFZvu|oj9h61oyA3qOtM~VVV0)f{ z-RfeT6x9?6MU)7B{J^%5hu}QHl09&&pL7Y-F9D}w(-t>q(lbH>#-nKwaPAvJB^A-yOr3m0vNk9)E(cA?>V3Cy!M>J(sl$_}j2dL$WMyY# zY(bz))Zb9fNyU1M?gveW z3l}1O1W4*#L?vLE>ou7S3Ti zygNx=0=EOgEtHHNPrBj`nw6`ouMilvfidZ)*5Wy1iG6Ee!p4m|(9+y_jhaTI#%;Gu zL#s{3ZM71|3tLSRXaF%<%rJZDqJpq@{Dd7dNQJn9hIX#uU|&nQvK|td66r+cw9`0R zk*+i1f7fpJYqn?sJxQg;Idgj4Zu$&FYbaybw?4i7sZyyX#w$`BU(l4*{29PcD<+F)^t-Ug`DXEN4UW`;6^n;T&n=ZWlemHA znX)~j>|FR-svW~Y*NMlC9Et1zHom_RCZn{cqbN4nQrix`a4;^p>{6-KyQN+{UaE-;Xq+39wr>OJT7cDnp`C$i z0d{$}a5BiCzPsDuXbZM+8LnNVpNpIA9dBQXe{y^T#$I9$_&xc<84?)y0Du{m7UlUr zyc#JH@k;kBDXV#$b6gGqm5iefjGttJ`tXB4zUXUuiK2LQ^&AN7RR#=>g7%mlO6$krOSLD`o z8EC{HpTH>a(Pd*wUj2@Wl;*i%z4T|lFP?A-h76T|agtoR{A|OZOyqV3_4Fl$xt~Tm zMyU2(vVh@&e6bcZ$w>)F(su@+`(|}sO5|dOUav;7-v3mH`1X@A_+>-X-e54}#K}es z9X=E)Rp;f5^$nf&sMYGg`KI`!?}qj?`C0Bz=Pg^Ddpcgg=_=3!wPWPE+I_Q}CnQ}! z$nN8OUmz(-0|JW@OPj$0L&tr^XU;lfKrVnaHk)Cw(3L#$3q8fiIIrfw0I<#%?ikpX zrGB&gXYy&cWGJ@6LyfB&4DkNL)b0|>>DfWm#Kh&hMP-L5HMU4AtPOj z1PNEJM#qlsX-%MMY%-(GXo1ma6D3qrvl#@oP=#~sTvn9-!>*<}?w|=ap^~!dH2_;k zK*;Wsgv@juNNRka!6A2XU0@>V6c9+9TMb9^wcq>9y++Q{%?8XrQrq}y)&=?mC8-qd zaKO=VcFDECf+i76P)UW8xIn&0+*%{_J zz~?hyTr>m+YRm05IBd@2CJv9sHaPto?@XU1KoBruSqM-BEO%i7n7Y#l7c|bBKLxc0 zOcnbKSF^=-RF|MBRdKA(PG);zIk#Ya#SJv4O#DL5F^_Xz6fIC(5`a5wAb_~Q5DyT< zo9S%^1EA7?2`Xr`Itb!#JrZ#;A{l~4S|P1M1T^(q;-0S5tMaIU@!F7v6x?r zA2ZMpSh$`44h)iSYZ4`h#nb^33+(OjiEBi_@VGUhD`_njc^5xulT$?iCF+xrn3O6{ zB5_nO6?-g};E5VEWY`*wj_0IG76JwVgZTPX!~+}zv@YsYclNXa7UlbDQRn}L365&7jecro|N(D0~xF~Q!DJomj7s= zcyfj$3`v@J6#`IFMi!DYv!PD#@aTL7WSlMTpX`5&s#Lln0!=8uh+t`J5&_d&yg3kw zJrgMplQXiAlGQ&bc%lK0Y|x0Vw1fM-5n(vfV7J@R*ckmo@6qs=?4ACj3j8Ea zPLd!S1F{-?x%2Ry{qlys=1DxMBWr8di`{4#*p+R`V`^$@0s*JHOKNrw(y}|BRwR1V zoLww;`#~0Hc7D8X-QdeFn%4^&>C4}pYRQ+%K%hCib>F5b*XCa>eMT};FAr`wn0Uh4 z*fi>@@m_E5^{S`f?54;sc}z+u!PL{Pzi&0%@Y5Oosf{6smMm$uuB*HijJ?q}cL-AZ zd%tr{_KdaZOs^sA!RUC$WaI#mBFGs7hx!@94Tn$T$o2zBNKs9@?#I)%N$pcQXx59* zsokK_CE~(KWBvN?b-6oPVlWtBGAUypEtJc>=e?b1Z!;r7tKN29(bQ=%1x@wF>ZB%< zr4bBbqDWd!A7oz?I1B$jIk-o$7*ap2e|UheR7DP@yySX$jEJSUe-_eKz4i^UtdLI7isC z*Ccf^hW3X(BSrETt|um8QIL+nA~%srGE)Lnj3x=I<#ZEH>^&Axy7&&I(`i=DDV*}_ zaI}U6&DQmml>n3c77c+XrGKVm$>U2PC1z2Yr_$0rNexk&X0!=Zp%%n5-BX>Y6;nSW zP4^^s`s|TTPDgS-N)U=T z&sFT%GqD_YJ7|NHP8q~Iv7A&70fnSWtZWt+FetH{03m2J;)^S>NGvxrwuwM#Jl+sg z4TS$TtE~Jz2-LWu)mBP+-QcC z+?EX4mii{N);FWEt^v08*v5oZ8db{;cTG!+2sB&Xs~jf?Y`5guL|BnPq{~P}Lb4XR zj1(j$>%+S65f0VknvsiaJl}?v`bHR=jA*TIj5$aGF-4c8zI4vQsX;I532M_+tgk9& zz|!vEG^sOy@ZgZ@#u@ z>Q%w|3J#iem9>nqfw3SWmVJT`uGk4nD z(CEw)q#Z=5X|EDv8-rEuoG!^TGg1VxvOH#SU zN+e*ZybtlaBv>T$xFmvSTW)uty|r^2fh302yA&{&L36)xlhYCQO$PAe&-@<8>W+y$cuJE%fO_pWSv3#*OK`#I*KQEou%_eL2jrh!bQ;NbgAnY zWApy-ND0Q}l9uWj#aHF%b$Yz?)bk>6mOcKkTTQuUb8q3@UeYJpSyC>!#b`m{1B<=7 z8rW|jmf!32+V*_C2d}=-ndI*asAy@3cYCYdf}*9jf^)|@lc`mF+=@VxuGgoD>FJ|K zjKOnHycBObV%C2k<95-4JCLN)=9WRsk000KfNkl&{KqpSuVL<qt+oSVW+3LX#OJn@ZyO9)zPR6M}drAli8?v&*{{;Iz0W#V>o-B zk{kjSZZtLvAwlD6_T%|Qm^1Zy2#}|mn82V?F$gM>M)WtSHzrCZA&xJbEPd=@96#X< z@C7OZ`VPdsx8D=-A_lTkp1ki#>^ZQ<3rw!D$@pC~zfiFf#?Ec{%bPD_TjiFp-*Ka{ znFUo(zO8AI7vFL>ri`BfjVd-TxCtsIX4DDf#4!#g{w708{Hx<{`o#iDEiy<+jX1;~ z2e{q&x39-SU6E=aX+Yn6&lpNrE(NF%sDF|sJ9h8z@|1j=&YeCN*Ugw4$&hhrW3igC zdFMv_ZCx4YnzwL;bGkvLSx<)W3V{7CTm#R~XHA)d>t@VHpY*;uqMMA* z!uf>}OBP?=P_T}qjk&$^*z?2pEXUg)zUAjB`L^{`Wpa2PySf}_8c*Y$58uS6RrJ<| zbQ^+m$5xZ6b$Ul|FYPE}kp1kdHZc)5UvoPqT{;zMNylfoYzQps2e9JK=x7JH_jmV%?1Jp7NA7(jW@^%NFq^}QlV|Gi#lA{>v~2@gd`^lw zZ5DabrK5i@z<7bCqe8k)m$oiY+$LIv4jwoZ^er1bEEm}q^n+HTi?&O}wGRfG%=Apr z04GB@78{lv90pS>PMtl81Bdrx^JgES;oKQNeh^Stba9U+hok*^iUNCf9?%NX=~C}w zjID@9T}fHd3Hg^JcT_%x4IYlH%zjALCHH8FKjgmVQ)k#$g@w*xnsR+gVJ}fP^NRbUY~j&!0wATczlVPG=2((4Hq&q~u-4a-~nM|$p_C?S@mz3_)b-L6d0#76!R=CN^`8+|BfMJ72 zV%VTz$mu%}WPB&-lcCeuF(DBeO#%|s38KV`QZ&mU&CAeqa1N{83ahmp=5`ZW zjV)+18PMEv9*s>+XgFVwGiOiZWc^8;YYG~Dl`uXB=guXJ0w}ZrYXcmgg#(L=ASs}6 z6R+2&%;%gHQSOa|87ZPlR%SNnCp9GJvJp-I-hiuwtK;oi{_L4Z~8_ed` zpU9zA7HB*=PSK$e^+WA`tP5-1=wL((G_%i%pAr|RKHIpZzp8{+w z!1}ok-Z|aBh_s>-Ry8UbeCHl3^%97v4v;he{BygVzu^kVMKuAR#xVztFL7F}b~0n? z1%NP_F*dZr6Z0C^n~A;~XK^Pn3VsHr)is}Zg2RL8CeHbHobxXMYpHKcC5p)fZQ3m> zLO=r4(-~t|0c;e&QhMr9;CL)b5D7w8OEdxeTL3#aw|>wS00~4(w}2)Xqn%PoH69Qs zlQ4q-#TcW|G3|*diq<%Qg~V1f=bXSnz-R;Mn2un`4h!h)z(^bcBwBeJr&@ z?YZWtB!G!P@NjX@0{n#Y{~h9k>UKLj6%V^34xn~-*`q)c2_tm65*0cKY8dXg}($F$^ZZW07*qoM6N<$f|lN7e*gdg literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png new file mode 100644 index 0000000000000000000000000000000000000000..d379e0cbdbc20f0ab1124e40f0f2850433b3b6ae GIT binary patch literal 14169 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 Vms|328g)1fP*v1YsFkyb_&*KgB;)`9 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x512.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x512.png new file mode 100644 index 0000000000000000000000000000000000000000..ee0e4bf0ff6aabb2fa0b1703b5c181139237eb2f GIT binary patch literal 29180 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
18rX>mmmR3{RM~^lLTsM)lF)K1;OV0NgjI9 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 z zv=nl|mX1t+TYvV4#yo0?>Y>iDa|BNs0I-?cU>u@|4uYE3AS`;Krml$f@o*qY^87f- zx3$koB$zsZ4xv63%vS!HS_AIq%wsXS^SMrW$;-p7k*J&FQ4AzW)QW!)-4duoAEVV@PO^JMCpgE0z^2;(OhS-@ z&!{3Q**Y4!y9Suw;Ei=pXi>JNSWfrzwB4IOqS!W3b+qKyFE~!nESV+S<1Or2LC@}& zs|532QI|fR>qsBpf2GQO7fl3;o5sgi914 zwpZUtPaVca58=8)Itw0GO1*|}hlBB@!&_hkUA&2ZdUO-tZ(n)6s8x}Ws|I}g z;2;Wt`!dkEfk9OFzOh33?n*?B`;1I8VcSlQXH`Qihvci7;Zh%R-42WN^w3?X3^K|p zJ~>z`K4B#$g~sF0_WN-H-zaUsPW5CTQ6ZS2s6ZAw=Y`v6O-vHDk4?Z^`WDuPCj;Ql zOz~xMXU{wr{y4w+?c=;u*h`*RGm*n)rOpE(%=O%v>yyp5)-D^6|*Q$?f zPz%*#5|+>6o|?d4&p z{doTaneRYb`{>@Hk+a-B&lq^?Vg2jDi-=`HE&0%NQaj9VE+5!n(}y<*{4}O<{~TQG zae!zh46AecsHMZIj|`G}?PJ$v)W8!S-nw=2r7JW_?I`r5yZV*gi`I}8Mm5dk5GPFc zF)=ri9+BTy`tc+B_dSWj(Ef{cPuW4Ti@uJ{V#q?h7rb{yW*}1XoYtA@Z&C)SD`O?; zEB1K9DW^Xt7kD;r7tr_>km=L{sPT}KW z|3%LE-g6}-Sc9K^$QO6ty{zIuVOe#+OOzV@li63ojX>3(d`hd+Pg(SVpTARz{~WT* zt$VeXPtX+qvEuQXD8m{2?6vRlv0UZoliTgibMxkS$$Fga1pt_SUrCTFyscuS^Q4L( z0l%f9V8J%ud$nEOvIJ#yYO2T*716HepKZ2ADOSzKkE(M7L&+oM+4rMmgkr zV90B6hbfWM9~ySm##@U?H@(Kw{G>CL#=I@z3J1 zX89yrK63@&2W^QceSt4Z0k5d;U7(%Ik|2M*xplSVJSUbB)zkJR(JKs0z@ajzfp8hr zZK;=bB_IH!%8+eINmafcIB!YzYcBGrC<;y$f65DwXy&qBCfwdJMq)C-56aj9t*fm^ zjzKdx*A+g@HB%^D)ElH{DosZi8v5>9E4Kf$qcjwz zNX1tYXiljwG;-4unf{?H_V8u^6%F?q_~u(k8hR>-}NGXfho zVBWkVP3R4vPek;CABkxu=NKy_eEw`F_gg(#;!MI&&9T7z^K%tZ^CZ{<8;cpXoaL09 zaF_la&~JK4L8`UB!RRN+_vvj7$oH7|!LY~R@nlUYJ)VpF^>*=z(zkDCN}0gL?eTs~ zo8CKb-ZCxG0@p$5HeqJQqWKKf&8Mdf|tCkd8BFq{_Cz3y=};i2V9NeP|z zqYP0}_u7|M_xwo`Sb1I6`&Ga%K}1S3`oAkhyyBQROFR4Y%!TdY2gUkj0XTrJpvS%< zV>CkISsTwtl{^2J@gu{N|5MU+2SWMA@w;9nW`sKCiBF(;CG#;W1U0RPS!230eK zD1!Sa;{mIAwy@uiryAG0utcmI0c%;%C;yQ&CX4Gl9V~7oastnpnK*ohss#~8fnt^b z7r{Vp;0%cB9=9rpt;htA`kp#tL#hwlkPIN*)@RZF@I$KdBUbHC``DMQP03xa5gv6` zQR>36ATQ6Pub?K5MnYVO`BcYOgjz9T_!qT!7H9_yMh1?b-hP9%eY;yW@ zB)7P`YIs0o^{HNA$e-b9I9Y!(~@x3?}Q&3;E?qX?qk zig3y-+5rL1dy)=Vjv$*yR`fN^eG44-DmyAMIyvEXf8LsBuL4libGr>sR-5+i)S`K= zg|UH<)42Y?((4pWL$rH4CKJN@G*+t1xdK~~bzLuHu3!R9>4J{nDe{zio?>OWjZ4{^ zClgL&RKG;n?;+5lEYTB|cy%~PZ}^9PTXdJc?B6>au^sFSBPqu!-krF=-}(jZu|#%# z@S3)|bS6@1*@Dk+tF1<-OxX_O{yN=+v-?-v6}zP_DQYedL2d0c6s^`ef2%f^9UblP zpYgMaRCU%@@~)wh z^&Q%?Jxa!6pWh| z2IPW@%R&!vAGKqDKT;84kmn6&+*`+ryde?pu2EYDm?GB(4OlMdP&yjchy4H ze()-gLlpUKROp)-8(n~Nw1N5DLtc5X``grA=HxfyJsa?T`>7|a^777X3WKkOhUorA zEjK>PzdjyzIFFsMtWQ1C^WGS{2@o;)B8X%;_JDnfZ+u@M-r_+}vf=uGruuA5LrY;##S;+$dywiz z-kI!Qr}bGgXVN8fg1+-?5e=`86{OLO}K zFa8WG2+xvhq{7(b1KNgY|N3bLc6P_TO5as0oFWXqJD`aQ5glD?gq6GNR)(XJDSwHd z{P@iB?;TJhri^~BLV^Oz-BC;6m9UNj1C&GV03X1%ui<$WS$#EkUbttjNWQ&b=09xR zjY;&Lg*&HypkZd4hApO4WA_B6Z%F;&<_XMHv6VcfFvW8=s$k`ljbR>tquRXJR}QN> zOUS2SPiHj{7jbC?vCIU6lC}#NMZwM}sYYy~=zZ7a* zA6-pY`+a!$tkebXK;*UEP~>FvGS+8l*R_j$DctMqJtpWY2{(ZY>Iv&sM%!Gm>uD5o zxuwtI&8r-*@;c-!@cv(PI?ZFe@EYVN3c{~ z_EDYNHqTZxPJ49t>PX#`vi8EJJrPWj_%*#oCNm(`P{#%tagPs_KWlP0s}jP^wha^3 zX9h1OF3nB)qHjdw;`qs?F=`IvRyU1H)o8|hb-8+_v}1jTPu zXzM;Z$NKE{0tYPPOxFjtL9HZ}y5Hx%9gb=_4!JRAi?w_5zS!u?_+xdlT7i2z%c9HC z^DBvg#4Q4AxQ595t)`CFp2JwPOWps*N+Axgbbk#fYMt4(=+d7}%?UUj)m_c?#?gf( z&P_C>APq?7c5=*-GvE6bIGZ<`j985j<+n`=Oh1dEWp3(t|99sL*w>gKT6Aqx@J>_j zvA@he5B%ki1g9t8y*Zcb<~NAPe#X+2F3E+}_@0WMXbeW`lAHoE*8Tam{0NUWU0PBA z+A0cPsluk&q6MI{`HYRu9epYFBtQPOKb3i(yvyK+;fXh8>RxK97EW_UHZYl|aULwk z?eM^>v6}sB5?CJ?`|O0#D*v~QxQ5Bh4my%`8)4l@ z=EvH_S_W&UR!VWp!Nh31R6dQ6P2GoyOAmjtQ~3RS=7e~lj*e;`R~~uCLJ3V@+r%2vZ)wX#vQ&1o57rPy^&0gc?SNvPsL6lyFwSk8Mf zTb(53`i*8j7i9RaF5|3J^IFdg8Uhh8oTCJQxJ&XTIo|c1>3^6(lwlSB=!Fc(^INd`~Uny2`{r+RUPCs@)R`J&6McF0l@*}G($sN;kku$!1ivr}% z*SoL~QAjTx7827bopnxr_&R>a9dL|XIoQe1v%O*eiVi|l+7`>+p-_^{=CByh#!5s@ z<3?i$q@4F9J1$Y2l=uQ}vzeX>YRw=C&7k23J?iTS1S6~>G4#4kRY$)o%3;i*{!bEr z=Rm@QFLyMVem~A({AEFpa0U>dLL%}`LP7-nljkCcivaD;NmXmA*~+Rx{6G#eNn&V8xl5YWOshWo2h;w*F4DTD zHylonN9hL++@IwWLu*q9<-V#MHAn8Xk?}C@Sl=3w6u58eGaHyd$>c`Yk^hEXWyI{A zv}!B6hA-k?C7zxm7GXqY7(5ss>t-*40FW`C79}~q$tT8AFLG)2znxawWojY+h#~NW z&VJsWTZvnMh!}ACew6KbC0%FfT95SWp1j@Cs%RSCHtC1 zl>iPj@n54NFjMS+n1lfZzm@juKAg1_;($j8!c@OxY>55_q|7i?Z zo+OSGo|5N?nW^c6w#vM$R!jLSQG#E9D{K+dD*NmyG--nxiGZT9Btt=d9Rwk_WP;l_ zlt`;lciN-cN}(1?Q4G1V@D%X};{jsQ2?iROJk2 zV{^bO0<|KH@^X-lEH>b(1g(5pZOJO?o3?dGL z!~Rule^-uMM@DatgzV%vV$!O8dcwhL6K7(#?HhWespp@vI(o0tLd~xHyQIOY6C2ndH9X1y-xoURgbX(LoJ4^WZ_Vt?7I- zE^oS~*J)R9TjO|wUetT(Ct5~K#cgjPjvJ;%l|=X)F>dUWAq)r%7K|cg^l&ICjnHT! z0IysXYb|G-am&5>4$$);#s0}#_^VR_@JPM8_Z@*1M3YmG`r^A@WZn*!5GpYIRRnZ- zPXs~fiXJ*)Cj0D#B^NpxcZ1Zf)xjeh+b1*=13ec3MUZ!Xyc4fk(4&Ys2LAj& zy+6n+_m@heo|k&|bSsu(?*lqLXxd5re4YN;zluEU;+06e9^<36Y1mR{$LZT3%=_gPWL} z$>8y|X7V+S3*I;tXz|QIo68s(KlVQ3`Fjzl$s{*UT$x0+qqZzSTUAzAQP9zX!@HM+ z9!=9DRYuH%Fz%k540v?|FT(#kyp$Clb0o(gnz=#N)|hJ}7;fSK+#Nu) z9C^$#WvOj@10IYjz+;B_@e!R-1Z?MN95e(lg1`_TZZqIwsD%*`fi4ulE%E-yvZ6Wdb;?SqMiLF_Bhb<#%}59ApAxY>sE%P29z2&g_SmOXNZNY#{e_N#0mGRp-stmR z5)UW^UFL$Ek|w}?26QLRi*RCP#4`S_I$+wM<01%EGX;v*Z@hhqtH1&(+yxkbD8eKW zCGLQK@M&Te>>wqQT);oq`9yHxyh|H2#Td7l3E}GFD#YunRBP8&5rVi8_QNVYl9%hy z8=2#m2=kaF#f!T=C5&ICl0w)Q>wJ2a3JCG9E|F`1rGH5$EmE@p-XU-=W{e^(3&W&{ z4lQO(E8rhE(LY7ramEL?yp&N| zLq&GQ5|-%Hh<=4)9Kuo7JYx$gfS6@;2IQT;HLDo7yc{JF7q1~8F4|$C7?vR>jlH0c zEccV==9?4EH^S&z}@mMsyibC z4i#{pjlzH$h&U_^mt0g1r0h)6`yC2cu%In*e*uT0nN;NIvMo-JG`Uyy9<2e^;e$oy zHvamKnrji91-314Z69~xT!Uq-SUd)!QIKnT?7h%+z#8POwG$E|>DfW8({tLV8E$_8 zo{pR%-_ySkZqU`AK_f)8C+a{NfU5YYR_nWMzf)4dJbqiL4C2~FSj3TW?{&t&ux&3Q z&#_FOKV;|t?v^DH3HZUs03_r!gc!QgQyV6rv#)5c_A(BT3MpY|9#;4lU}cToGO4d+ zDc^CwBWoGk&V!2M+- zmgg$%-{&x9p8Zz%eS1Qg|N7gYQ{o0)ssy9PSxAW^u9?9+cijoI*msqL;F4v|{O{TW1hF$u)nIDE)!~}`M3xJcD-lI6=AFZ(4ZhG;HR*hG! z8cy)34KCVkX^2gVfrD8Tv9T%{u;a_O4P9@og4^K`iI)l74FSefqYulp53@=r2hvh0 z**-0@1*jz=BN!schnYRNhZzCKhn0T8ZiBm)-k^%&tVe3T$C)^armx2P2|Bn+42_c~ z6lwzN@dqHsIn3hSr%0nl6c@l<0P8LT)~zn|ZU5o19teCusd_R*0O{w%;9|}V)C)qA zNEhQtg;HoG5(RqqHNjNRE>aUXv14zkDxiX|n}&&=+OG;fnAg^`8`l){Jbu|8H$nzP zG5d&poS8atUR?-;I1raU4pshSEg26!I8fn#gmY3S>Ya`MI{#2%K?U(@3e9!n@6TR3 z*~}iJ4LCE zkMG@%Y2mMm`du%IjlPsVScvQ?mgJb)fn046=YZQ^W4A>!)JNtt5w09bwN2!kdZd{@pGtH6QJI;rQH;kYvHq)%OJKFP@xoJzX6i4a_(D|bx@=L@^4seF zY#e-60uCA|IiLvFhDtR)Ukt#{YZU4p1xJ#GKlbP}7EZtJ&?)!>1wUZTQ(vO+1K=c1 zAbDy{H^>Cg0(C>*2VO4m7&h57&29F(1GUFQW&aAKOnkgJ&8G6{Fd|v;{(|f&bQGYx z0_(}=LMUsSWGAqHVi88D+BM<6@P&{a)L#Z(eY_$0Z^&y-2uK$MOkN%_bb8Ro9Jsz+ z>b#@qSxYVzsTT%2gJ8>nYe5A1S2+4q|K?dR%s zAH02+D(GhPt2D-%)?3VD=hl94VBS}I71_K?6QbtZc|qI0%7f1(Uw7D9`WhXID`#`4 zWhH^Xlhwb6>Ng%V{PNMk;+G6V2g4+}Om#TzRcP!c%f*6rlK(mt3T8H$mwR=uXyS3( zo7m86i`m-2_&gSzvki}%%1Mbzk<@$3l3x@pj^JRnVbld-tv`vj1FZMeG!OI_h(VIC z4Ut1qq@qeaswb}4rWt#J*JNObBB&cBtZpp4;uO~G&7CvgLAcYypD>fvc~=~HSLPz# zw#!d!Gz;5cYxgLSu#N^)xx{LtMpQ7ro5Rls1*^)V}GBXc3Bz1wz|iM_6-=CnPEx;w0MWySXUZH@3spC8@OVqIgFi=}GC|TZ12R6&`7T-BBTF)Zzb}p|<;pO12 z9kL{Z9H2k!`;BsSN-VcV;n4EKGr+l`d#1O zB-K|7PP5pSV;Q$H6wY~^P0@Ui?s&^-bbJ2yZDjvaopXCQjxpO?l7HpA^yye0=iafl z>VG;R%pel^sVV+!MQ;#(S)K#lrcFBUGO?q=awX6rhmdl}JV^(3O)jsjoKw+Y5*O!8 zLCSU4F?7g~gl{d3p03v=i|o1_FH%9Cx(N_K=~R?lj>a6q2uz0iJjXvKq#&0rYYpp0 zE{0N303-$8^fTBnKSCL-HJ%@COk9Lj?D{JH`)^@Hd^^(i99*_a96_=? z+6613vdB4B`902f0&U@dnvz}(KNl;`Ft|r(w!WH8GI?j#R}lzt?GZoxXRz|EzLHjM zrI2*ra@G^9L^mZr3Qty(Q!yzAa3l;*r9gc_NQ+nEEq=RFJ4Ibq4pF?`$Le`{>{Ktu z1!s!5*N#Tsp&o}6><5xGsg^GfE9!Q5OvyT5u{NI#$ZPwuHKg92y-!Syif5`B9QLfa zc2dt)hAF11%_e9tC=$Uha3F z^p#KI$Fl&>Q(pSFQ85@l_~$l$uh8nKw<%+w`%qyDM-5Kb@l|Wzxg%hu6UC@yZAM(QtE#liUYmQF{gJINZ(| zNRqHY4*2qcjM4?jOLRzI73Z#flP}J3YIqGrZ|TET3S>%sEIe0LWJp}*XCa2dy2DUU zZKc*dVdaIeW4Dp&Csspi8;WmKbV3GQQ#j+zll9$VG7G!9S<9&egU!_f*QcqQXFG7g zG{>7_Wu0?8Y9m?NVkWFdwYWu#J1jxfA6l>O zNLvJqLH+`tAA|?4_TxvZYncYS^HFpxaG^=^tkP0iLlyD(bURKL)A$z~B3b$2+Tt~| zg(>1B&(mbaAdUx}Xa8-&92s(spHa|2mnQ~T=K+?XLzLts-KkeB_|kOB0`e9eq4~L2 z4~&7Xg&LiYR3FKbtzI88>_P@?=N_<;V-py%J)JnoeQjzcq+(%3>;e1l=CrWul@(_hUvTj literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg b/4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg new file mode 100644 index 0000000000000000000000000000000000000000..7bfc44df1f79abfa1879596021dd930eac23528d GIT binary patch literal 211556 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�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,O)LqcYWqqA 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 literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x192.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x192.png new file mode 100644 index 0000000000000000000000000000000000000000..f3e21ead53fc3f66bed107fc1e737451d321b0c9 GIT binary patch literal 5128 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 E0d-t&rT_o{ literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x512.png b/4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x512.png new file mode 100644 index 0000000000000000000000000000000000000000..846728b42c054225a71039e048d8d48f50cd7c98 GIT binary patch literal 21700 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�RkJ)Rizv5{^<4diIi8#6DqIUN;Soc?><(9 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 W_|kVc8oV)@gat;D62LO*o? literal 0 HcmV?d00001 diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json b/4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json new file mode 100644 index 000000000..3eed1569b --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json @@ -0,0 +1,40 @@ +{ + "short_name": "Stremio", + "name": "Stremio Web", + "description": "Freedom To Stream", + "icons": [ + { + "src": "favicons/favicon.ico", + "sizes": "64x64 32x32 24x24 16x16", + "type": "image/x-icon" + }, + { + "src": "images/icon_x192.png", + "type": "image/png", + "sizes": "192x192" + }, + { + "src": "images/icon_x512.png", + "type": "image/png", + "sizes": "512x512" + }, + { + "src": "images/maskable_icon_x192.png", + "type": "image/png", + "sizes": "192x192", + "purpose": "maskable" + }, + { + "src": "images/maskable_icon_x512.png", + "type": "image/png", + "sizes": "512x512", + "purpose": "maskable" + } + ], + "start_url": "https://web.stremio.com", + "scope": "https://web.stremio.com", + "display": "standalone", + "orientation": "natural", + "theme_color": "#2a2843", + "background_color": "#161523" +} \ No newline at end of file diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js new file mode 100644 index 000000000..bcfd5f9ec --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js @@ -0,0 +1,2 @@ +(()=>{var e={7228:e=>{e.exports=function(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{e.exports=function(e){if(Array.isArray(e))return e},e.exports.default=e.exports,e.exports.__esModule=!0},8926:e=>{function t(e,t,o,a,n,r,i){try{var s=e[r](i),E=s.value}catch(e){return void o(e)}s.done?t(E):Promise.resolve(E).then(a,n)}e.exports=function(e){return function(){var o=this,a=arguments;return new Promise((function(n,r){var i=e.apply(o,a);function s(e){t(i,n,r,s,E,"next",e)}function E(e){t(i,n,r,s,E,"throw",e)}s(void 0)}))}},e.exports.default=e.exports,e.exports.__esModule=!0},4575:e=>{e.exports=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")},e.exports.default=e.exports,e.exports.__esModule=!0},3913:e=>{function t(e,t){for(var o=0;o{e.exports=function(e,t,o){return t in e?Object.defineProperty(e,t,{value:o,enumerable:!0,configurable:!0,writable:!0}):e[t]=o,e},e.exports.default=e.exports,e.exports.__esModule=!0},5318:e=>{e.exports=function(e){return e&&e.__esModule?e:{default:e}},e.exports.default=e.exports,e.exports.__esModule=!0},3884:e=>{e.exports=function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null!=o){var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r}},e.exports.default=e.exports,e.exports.__esModule=!0},521:e=>{e.exports=function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")},e.exports.default=e.exports,e.exports.__esModule=!0},6479:(e,t,o)=>{var a=o(7316);e.exports=function(e,t){if(null==e)return{};var o,n,r=a(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r},e.exports.default=e.exports,e.exports.__esModule=!0},7316:e=>{e.exports=function(e,t){if(null==e)return{};var o,a,n={},r=Object.keys(e);for(a=0;a=0||(n[o]=e[o]);return n},e.exports.default=e.exports,e.exports.__esModule=!0},3038:(e,t,o)=>{var a=o(2858),n=o(3884),r=o(379),i=o(521);e.exports=function(e,t){return a(e)||n(e,t)||r(e,t)||i()},e.exports.default=e.exports,e.exports.__esModule=!0},8:e=>{function t(o){return"function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?(e.exports=t=function(e){return typeof e},e.exports.default=e.exports,e.exports.__esModule=!0):(e.exports=t=function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},e.exports.default=e.exports,e.exports.__esModule=!0),t(o)}e.exports=t,e.exports.default=e.exports,e.exports.__esModule=!0},379:(e,t,o)=>{var a=o(7228);e.exports=function(e,t){if(e){if("string"==typeof e)return a(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);return"Object"===o&&e.constructor&&(o=e.constructor.name),"Map"===o||"Set"===o?Array.from(e):"Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o)?a(e,t):void 0}},e.exports.default=e.exports,e.exports.__esModule=!0},7757:(e,t,o)=>{e.exports=o(5666)},6553:(e,t,o)=>{"use strict";var a=o(5318),n=a(o(7757)),r=a(o(8926));e.exports=function(e,t){t.addEventListener("message",(function(){var o=(0,r.default)(n.default.mark((function o(a){var r,i,s,E,_,T,l;return n.default.wrap((function(o){for(;;)switch(o.prev=o.next){case 0:if(r=a.data.request){o.next=3;break}return o.abrupt("return");case 3:if(i=r.id,s=r.path,E=r.args,o.prev=4,"function"!=typeof(_=s.reduce((function(e,t){return e[t]}),e))){o.next=13;break}return l=s.slice(0,s.length-1).reduce((function(e,t){return e[t]}),e),o.next=10,_.apply(l,E);case 10:T=o.sent,o.next=16;break;case 13:return o.next=15,_;case 15:T=o.sent;case 16:t.postMessage({response:{id:i,result:{data:T}}}),o.next=22;break;case 19:o.prev=19,o.t0=o.catch(4),t.postMessage({response:{id:i,result:{error:o.t0}}});case 22:case"end":return o.stop()}}),o,null,[[4,19]])})));return function(e){return o.apply(this,arguments)}})()),this.call=(function(){var e=(0,r.default)(n.default.mark((function e(o,a){var r;return n.default.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return r=Math.random().toString(32).slice(2),e.abrupt("return",new Promise((function(e,n){t.addEventListener("message",(function o(a){var i=a.data.response;i&&i.id===r&&(t.removeEventListener("message",o),"error"in i.result?n(i.result.error):e(i.result.data))})),t.postMessage({request:{id:r,path:o,args:a}})})));case 2:case"end":return e.stop()}}),e)})));return function(t,o){return e.apply(this,arguments)}})()}},5796:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(1785),i=a.forwardRef((function(e,t){var o=r[e.icon];return o?a.createElement("svg",Object.assign({viewBox:o.viewBox},e,{ref:t}),o.paths.map((function(e,t){return a.createElement("path",{key:t,d:e})}))):null}));i.displayName="Icon",i.propTypes={icon:n.oneOf(Object.keys(r))},e.exports=i},2601:(e,t,o)=>{var a=o(5796);e.exports=a},792:(e,t,o)=>{var a=o(6729),n=o(9657);function r(e){var t=(e=e||{}).containerElement;if(!(t instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var o=e.chromecastTransport;if(!o)throw new Error("Chromecast transport required");var r=o.getCastDevice();if(null===r)throw new Error("Chromecast session must be started");var i=document.createElement("div");i.style.display="flex",i.style.flexDirection="row",i.style.alignItems="center",i.style.justifyContent="center",i.style.width="100%",i.style.height="100%",i.style.backgroundColor="black";var s=document.createElement("div");s.style.flex="none",s.style.maxWidth="80%",s.style.fontSize="5vmin",s.style.lineHeight="1.2em",s.style.maxHeight="3.6em",s.style.textAlign="center",s.style.color="#FFFFFF90",s.innerText="Casting to "+r.friendlyName,i.appendChild(s),t.appendChild(i),o.on("message",u),o.on("message-error",S);var E=new a,_=!1,T={stream:!1,loaded:!1,paused:!1,time:!1,duration:!1,buffering:!1,buffered:!1,audioTracks:!1,selectedAudioTrackId:!1,subtitlesTracks:!1,selectedSubtitlesTrackId:!1,subtitlesOffset:!1,subtitlesSize:!1,subtitlesTextColor:!1,subtitlesBackgroundColor:!1,subtitlesOutlineColor:!1,volume:!1,muted:!1,playbackSpeed:!1,extraSubtitlesTracks:!1,selectedExtraSubtitlesTrackId:!1,extraSubtitlesDelay:!1,extraSubtitlesSize:!1,extraSubtitlesOffset:!1,extraSubtitlesTextColor:!1,extraSubtitlesBackgroundColor:!1,extraSubtitlesOutlineColor:!1};function l(e,t){E.emit("error",Object.assign({},n.CHROMECAST_SENDER_VIDEO.MESSAGE_SEND_FAILED,{error:e,action:t}))}function S(e){E.emit("error",Object.assign({},n.CHROMECAST_SENDER_VIDEO.INVALID_MESSAGE_RECEIVED,{error:e}))}function u(e){if(e&&"string"==typeof e.event){var t=Array.isArray(e.args)?e.args:[];E.emit.apply(E,[e.event].concat(t))}else S(new Error("Invalid message: "+e))}function d(e,t){T[e]&&E.emit("propChanged",e,t)}this.on=function(e,t){if(_)throw new Error("Video is destroyed");E.on(e,t)},this.dispatch=function(e){if(_)throw new Error("Video is destroyed");if(e)switch(e.type){case"observeProp":return n=e.propName,T.hasOwnProperty(n)&&(T[n]=!0),void o.sendMessage(e).catch((function(t){l(t,e)}));case"setProp":return void o.sendMessage(e).catch((function(t){l(t,e)}));case"command":return a=e.commandName,e.commandArgs,"destroy"===a&&(_=!0,d("stream",null),d("loaded",null),d("paused",null),d("time",null),d("duration",null),d("buffering",null),d("buffered",null),d("audioTracks",[]),d("selectedAudioTrackId",[]),d("subtitlesTracks",[]),d("selectedSubtitlesTrackId",null),d("subtitlesOffset",null),d("subtitlesSize",null),d("subtitlesTextColor",null),d("subtitlesBackgroundColor",null),d("subtitlesOutlineColor",null),d("volume",null),d("muted",null),d("playbackSpeed",null),d("extraSubtitlesTracks",[]),d("selectedExtraSubtitlesTrackId",null),d("extraSubtitlesDelay",null),d("extraSubtitlesSize",null),d("extraSubtitlesOffset",null),d("extraSubtitlesTextColor",null),d("extraSubtitlesBackgroundColor",null),d("extraSubtitlesOutlineColor",null),E.removeAllListeners(),o.off("message",u),t.removeChild(i)),void o.sendMessage(e).catch((function(t){l(t,e)}))}var a,n;throw new Error("Invalid action dispatched: "+JSON.stringify(e))}}r.canPlayStream=function(){return Promise.resolve(!0)},r.manifest={name:"ChromecastSenderVideo",external:!0,props:["stream","loaded","paused","time","duration","buffering","buffered","audioTracks","selectedAudioTrackId","subtitlesTracks","selectedSubtitlesTrackId","subtitlesOffset","subtitlesSize","subtitlesTextColor","subtitlesBackgroundColor","subtitlesOutlineColor","volume","muted","playbackSpeed","extraSubtitlesTracks","selectedExtraSubtitlesTrackId","extraSubtitlesDelay","extraSubtitlesSize","extraSubtitlesOffset","extraSubtitlesTextColor","extraSubtitlesBackgroundColor","extraSubtitlesOutlineColor"],commands:["load","unload","destroy","addExtraSubtitlesTracks"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded","audioTrackLoaded","extraSubtitlesTrackLoaded","implementationChanged"]},e.exports=r},3153:(e,t,o)=>{var a=o(792);e.exports=a},1431:(e,t,o)=>{var a=o(6729),n=o(7631),r=o(3465),i=o(2682),s=o(6767),E=o(9657),_=o(8973),T=o(1566);function l(e){var t=(e=e||{}).containerElement;if(!(t instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var o=document.createElement("style");t.appendChild(o),o.sheet.insertRule("video::cue { font-size: 4vmin; color: rgb(255, 255, 255); background-color: rgba(0, 0, 0, 0); text-shadow: rgb(34, 34, 34) 1px 1px 0.1em; }");var l=document.createElement("video");l.style.width="100%",l.style.height="100%",l.style.backgroundColor="black",l.controls=!1,l.onerror=function(){!(function(){if(d)return;var e;switch(l.error.code){case 1:e=E.HTML_VIDEO.MEDIA_ERR_ABORTED;break;case 2:e=E.HTML_VIDEO.MEDIA_ERR_NETWORK;break;case 3:e=E.HTML_VIDEO.MEDIA_ERR_DECODE;break;case 4:e=E.HTML_VIDEO.MEDIA_ERR_SRC_NOT_SUPPORTED;break;default:e=E.UNKNOWN_ERROR}m(Object.assign({},e,{critical:!0,error:l.error}))})()},l.onended=function(){u.emit("ended")},l.onpause=function(){R("paused")},l.onplay=function(){R("paused")},l.ontimeupdate=function(){R("time"),R("buffered")},l.ondurationchange=function(){R("duration")},l.onwaiting=function(){R("buffering"),R("buffered")},l.onseeking=function(){R("time"),R("buffering"),R("buffered")},l.onseeked=function(){R("time"),R("buffering"),R("buffered")},l.onstalled=function(){R("buffering"),R("buffered")},l.onplaying=function(){R("time"),R("buffering"),R("buffered")},l.oncanplay=function(){R("buffering"),R("buffered")},l.canplaythrough=function(){R("buffering"),R("buffered")},l.onloadedmetadata=function(){R("loaded")},l.onloadeddata=function(){R("buffering"),R("buffered")},l.onvolumechange=function(){R("volume"),R("muted")},l.onratechange=function(){R("playbackSpeed")},l.textTracks.onchange=function(){R("subtitlesTracks"),R("selectedSubtitlesTrackId"),N(),Array.from(l.textTracks).forEach((function(e){e.oncuechange=N}))},t.appendChild(l);var S=null,u=new a,d=!1,c=null,I=0,A={stream:!1,loaded:!1,paused:!1,time:!1,duration:!1,buffering:!1,buffered:!1,subtitlesTracks:!1,selectedSubtitlesTrackId:!1,subtitlesOffset:!1,subtitlesSize:!1,subtitlesTextColor:!1,subtitlesBackgroundColor:!1,subtitlesOutlineColor:!1,audioTracks:!1,selectedAudioTrackId:!1,volume:!1,muted:!1,playbackSpeed:!1};function O(e){switch(e){case"stream":return c;case"loaded":return null===c?null:l.readyState>=l.HAVE_METADATA;case"paused":return null===c?null:!!l.paused;case"time":return null!==c&&null!==l.currentTime&&isFinite(l.currentTime)?Math.floor(1e3*l.currentTime):null;case"duration":return null!==c&&null!==l.duration&&isFinite(l.duration)?Math.floor(1e3*l.duration):null;case"buffering":return null===c?null:l.readyState0?e.lang:"string"==typeof e.name&&e.name.length>0?e.name:String(e.id),label:"string"==typeof e.name&&e.name.length>0?e.name:"string"==typeof e.lang&&e.lang.length>0?e.lang:String(e.id),origin:"EMBEDDED",embedded:!0})})):[];case"selectedAudioTrackId":return null!==S&&null!==S.audioTrack&&isFinite(S.audioTrack)&&-1!==S.audioTrack?"EMBEDDED_"+String(S.audioTrack):null;case"volume":return d||null===l.volume||!isFinite(l.volume)?null:Math.floor(100*l.volume);case"muted":return d?null:!!l.muted;case"playbackSpeed":return d||null===l.playbackRate||!isFinite(l.playbackRate)?null:l.playbackRate;default:return null}}function N(){Array.from(l.textTracks).forEach((function(e){Array.from(e.cues||[]).forEach((function(e){e.snapToLines=!1,e.line=100-I}))}))}function m(e){u.emit("error",e),e.critical&&p("unload")}function R(e){A[e]&&u.emit("propChanged",e,O(e))}function p(e,a){switch(e){case"load":p("unload"),a&&a.stream&&"string"==typeof a.stream.url?(c=a.stream,R("stream"),R("loaded"),l.autoplay="boolean"!=typeof a.autoplay||a.autoplay,l.currentTime=null!==a.time&&isFinite(a.time)?parseInt(a.time,10)/1e3:0,R("paused"),R("time"),R("duration"),R("buffering"),R("buffered"),R("subtitlesTracks"),R("selectedSubtitlesTrackId"),R("audioTracks"),R("selectedAudioTrackId"),_(c).then((function(e){c===a.stream&&("application/vnd.apple.mpegurl"===e&&n.isSupported()?((S=new n(T)).on(n.Events.AUDIO_TRACKS_UPDATED,(function(){R("audioTracks"),R("selectedAudioTrackId")})),S.on(n.Events.AUDIO_TRACK_SWITCHED,(function(){R("audioTracks"),R("selectedAudioTrackId")})),S.loadSource(c.url),S.attachMedia(l)):l.src=c.url)})).catch((function(){c===a.stream&&(l.src=c.url)}))):m(Object.assign({},E.UNSUPPORTED_STREAM,{critical:!0,stream:a?a.stream:null}));break;case"unload":c=null,Array.from(l.textTracks).forEach((function(e){e.oncuechange=null})),null!==S&&(S.removeAllListeners(),S.detachMedia(l),S.destroy(),S=null),l.removeAttribute("src"),l.load(),l.currentTime=0,R("stream"),R("loaded"),R("paused"),R("time"),R("duration"),R("buffering"),R("buffered"),R("subtitlesTracks"),R("selectedSubtitlesTrackId"),R("audioTracks"),R("selectedAudioTrackId");break;case"destroy":p("unload"),d=!0,R("subtitlesOffset"),R("subtitlesSize"),R("subtitlesTextColor"),R("subtitlesBackgroundColor"),R("subtitlesOutlineColor"),R("volume"),R("muted"),R("playbackSpeed"),u.removeAllListeners(),l.onerror=null,l.onended=null,l.onpause=null,l.onplay=null,l.ontimeupdate=null,l.ondurationchange=null,l.onwaiting=null,l.onseeking=null,l.onseeked=null,l.onstalled=null,l.onplaying=null,l.oncanplay=null,l.canplaythrough=null,l.onloadeddata=null,l.onvolumechange=null,l.onratechange=null,l.textTracks.onchange=null,t.removeChild(l),t.removeChild(o)}}this.on=function(e,t){if(d)throw new Error("Video is destroyed");u.on(e,t)},this.dispatch=function(e){if(d)throw new Error("Video is destroyed");if(e)switch((e=i(r(e))).type){case"observeProp":return t=e.propName,void(A.hasOwnProperty(t)&&(u.emit("propValue",t,O(t)),A[t]=!0));case"setProp":return void(function(e,t){switch(e){case"paused":null!==c&&(t?l.pause():l.play(),R("paused"));break;case"time":null!==c&&null!==t&&isFinite(t)&&(l.currentTime=parseInt(t,10)/1e3,R("time"));break;case"selectedSubtitlesTrackId":if(null!==c){Array.from(l.textTracks).forEach((function(e,o){e.mode="EMBEDDED_"+String(o)===t?"showing":"disabled"}));var a=O("subtitlesTracks").find((function(e){return e.id===t}));a&&(R("selectedSubtitlesTrackId"),u.emit("subtitlesTrackLoaded",a))}break;case"subtitlesOffset":null!==t&&isFinite(t)&&(I=Math.max(0,Math.min(100,parseInt(t,10))),N(),R("subtitlesOffset"));break;case"subtitlesSize":null!==t&&isFinite(t)&&(o.sheet.cssRules[0].style.fontSize=Math.floor(Math.max(0,parseInt(t,10))/25)+"vmin",R("subtitlesSize"));break;case"subtitlesTextColor":if("string"==typeof t){try{o.sheet.cssRules[0].style.color=s(t).rgb().string()}catch(e){console.error("HTMLVideo",e)}R("subtitlesTextColor")}break;case"subtitlesBackgroundColor":if("string"==typeof t){try{o.sheet.cssRules[0].style.backgroundColor=s(t).rgb().string()}catch(e){console.error("HTMLVideo",e)}R("subtitlesBackgroundColor")}break;case"subtitlesOutlineColor":if("string"==typeof t){try{o.sheet.cssRules[0].style.textShadow=s(t).rgb().string()+" 1px 1px 0.1em"}catch(e){console.error("HTMLVideo",e)}R("subtitlesOutlineColor")}break;case"selectedAudioTrackId":if(null!==S){var n=O("audioTracks").find((function(e){return e.id===t}));S.audioTrack=n?parseInt(n.id.split("_").pop(),10):-1,n&&(R("selectedAudioTrackId"),u.emit("audioTrackLoaded",n))}break;case"volume":null!==t&&isFinite(t)&&(l.muted=!1,l.volume=Math.max(0,Math.min(100,parseInt(t,10)))/100,R("muted"),R("volume"));break;case"muted":l.muted=!!t,R("muted");break;case"playbackSpeed":null!==t&&isFinite(t)&&(l.playbackRate=parseFloat(t),R("playbackSpeed"))}})(e.propName,e.propValue);case"command":return void p(e.commandName,e.commandArgs)}var t;throw new Error("Invalid action dispatched: "+JSON.stringify(e))}}l.canPlayStream=function(e){return!e||e.behaviorHints&&e.behaviorHints.notWebReady?Promise.resolve(!1):_(e).then((function(e){return!!document.createElement("video").canPlayType(e)||"application/vnd.apple.mpegurl"===e&&n.isSupported()})).catch((function(){return!1}))},l.manifest={name:"HTMLVideo",external:!1,props:["stream","loaded","paused","time","duration","buffering","buffered","audioTracks","selectedAudioTrackId","subtitlesTracks","selectedSubtitlesTrackId","subtitlesOffset","subtitlesSize","subtitlesTextColor","subtitlesBackgroundColor","subtitlesOutlineColor","volume","muted","playbackSpeed"],commands:["load","unload","destroy"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded","audioTrackLoaded"]},e.exports=l},8973:e=>{e.exports=function(e){return e&&"string"==typeof e.url?e.behaviorHints&&e.behaviorHints.proxyHeaders&&e.behaviorHints.proxyHeaders.response&&"string"==typeof e.behaviorHints.proxyHeaders.response["content-type"]?Promise.resolve(e.behaviorHints.proxyHeaders.response["content-type"]):fetch(e.url,{method:"HEAD"}).then((function(e){if(e.ok)return e.headers.get("content-type");throw new Error(e.status+" ("+e.statusText+")")})):Promise.reject(new Error("Invalid stream parameter!"))}},1566:e=>{e.exports={debug:!1,enableWorker:!0,lowLatencyMode:!1,backBufferLength:30,maxBufferLength:50,maxMaxBufferLength:80,maxFragLookUpTolerance:0,maxBufferHole:0,appendErrorMaxRetry:20,nudgeMaxRetry:20,manifestLoadingTimeOut:3e4,manifestLoadingMaxRetry:10}},9222:(e,t,o)=>{var a=o(1431);e.exports=a},8879:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(9657);function s(e){var t=(e=e||{}).containerElement;if(!(t instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var o=document.createElement("iframe");o.style.width="100%",o.style.height="100%",o.style.border=0,o.style.backgroundColor="black",o.allowFullscreen=!1,o.allow="autoplay",t.appendChild(o);var s=new a,E=!1,_={stream:!1,loaded:!1,paused:!1,time:!1,duration:!1,buffering:!1,buffered:!1,volume:!1,muted:!1,playbackSpeed:!1};function T(e){if(e.source===o.contentWindow){var t=e.data||e.message;if(t&&"string"==typeof t.event){var a=t.event,n=Array.isArray(t.args)?t.args:[];s.emit.apply(s,[a].concat(n))}}}function l(e){o.contentWindow.postMessage(e,"*")}function S(e,t){_[e]&&s.emit("propChanged",e,t)}function u(e,a){switch(e){case"load":return u("unload"),a&&a.stream&&"string"==typeof a.stream.playerFrameUrl?(window.addEventListener("message",T,!1),o.onload=function(){l({type:"command",commandName:e,commandArgs:a})},o.src=a.stream.playerFrameUrl):(n=Object.assign({},i.UNSUPPORTED_STREAM,{critical:!0,stream:a?a.stream:null}),s.emit("error",n),n.critical&&u("unload")),!0;case"unload":return window.removeEventListener("message",T),o.onload=null,o.removeAttribute("src"),S("stream",null),S("loaded",null),S("paused",null),S("time",null),S("duration",null),S("buffering",null),S("buffered",null),S("volume",null),S("muted",null),S("playbackSpeed",null),!0;case"destroy":return u("unload"),E=!0,s.removeAllListeners(),t.removeChild(o),!0}var n}this.on=function(e,t){if(E)throw new Error("Video is destroyed");s.on(e,t)},this.dispatch=function(e){if(E)throw new Error("Video is destroyed");if(e)switch((e=r(n(e))).type){case"observeProp":return t=e.propName,_.hasOwnProperty(t)&&(_[t]=!0),void l(e);case"setProp":return void l(e);case"command":return void(u(e.commandName,e.commandArgs)||l(e))}var t;throw new Error("Invalid action dispatched: "+JSON.stringify(e))}}s.canPlayStream=function(e){return Promise.resolve(e&&"string"==typeof e.playerFrameUrl)},s.manifest={name:"IFrameVideo",external:!0,props:["stream","loaded","paused","time","duration","buffering","buffered","audioTracks","selectedAudioTrackId","subtitlesTracks","selectedSubtitlesTrackId","subtitlesOffset","subtitlesSize","subtitlesTextColor","subtitlesBackgroundColor","subtitlesOutlineColor","volume","muted","playbackSpeed","extraSubtitlesTracks","selectedExtraSubtitlesTrackId","extraSubtitlesDelay","extraSubtitlesSize","extraSubtitlesOffset","extraSubtitlesTextColor","extraSubtitlesBackgroundColor","extraSubtitlesOutlineColor"],commands:["load","unload","destroy","addExtraSubtitlesTracks"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded","audioTrackLoaded","extraSubtitlesTrackLoaded","implementationChanged"]},e.exports=s},7685:(e,t,o)=>{var a=o(8879);e.exports=a},8945:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(9657),s=.0066,E={stream:null,paused:"pause",time:"time-pos",duration:"duration",buffering:"buffering",volume:"volume",muted:"mute",playbackSpeed:"speed",audioTracks:"audioTracks",selectedAudioTrackId:"aid",subtitlesTracks:"subtitlesTracks",selectedSubtitlesTrackId:"sid",subtitlesSize:"sub-scale",subtitlesTextColor:"sub-color",subtitlesBackgroundColor:"sub-back-color",subtitlesOutlineColor:"sub-border-color"};function _(e){var t=(e=e||{}).shellTransport,o={};Object.keys(E).forEach((function(e){E[e]&&(o[E[e]]=e)})),t.send("mpv-command",["stop"]),t.send("mpv-observe-prop","path"),t.send("mpv-observe-prop","time-pos"),t.send("mpv-observe-prop","volume"),t.send("mpv-observe-prop","pause"),t.send("mpv-observe-prop","seeking"),t.send("mpv-observe-prop","eof-reached"),t.send("mpv-observe-prop","duration"),t.send("mpv-observe-prop","metadata"),t.send("mpv-observe-prop","video-params"),t.send("mpv-observe-prop","track-list"),t.send("mpv-observe-prop","paused-for-cache"),t.send("mpv-observe-prop","cache-buffering-state"),t.send("mpv-observe-prop","aid"),t.send("mpv-observe-prop","vid"),t.send("mpv-observe-prop","sid"),t.send("mpv-observe-prop","sub-scale"),t.send("mpv-observe-prop","sub-pos"),t.send("mpv-observe-prop","speed"),t.send("mpv-observe-prop","mpv-version"),t.send("mpv-observe-prop","ffmpeg-version");var _=new a,T=!1,l=null,S={},u=0,d=0,c={};function I(t){for(var o=t?"":"transparent",a=e.containerElement;a;a=a.parentElement)a.style.background=o}var A=0;function O(e){return E[e]?c[E[e]]:(console.log("Unsupported prop requested",e),null)}function N(e){_.emit("error",e),e.critical&&R("unload")}function m(e){S[e]&&_.emit("propChanged",e,O(e))}function R(o,a){switch(o){case"load":if(R("unload"),a&&a.stream&&"string"==typeof a.stream.url){l=a.stream,m("stream"),u=null!==a.time&&isFinite(a.time)?parseInt(a.time,10)/1e3:0,I(!1),t.send("mpv-set-prop",["no-sub-ass"]);var n="Win32"===navigator.platform?"direct3d":"opengl",r=e.mpvSeparateWindow?n:"opengl-cb",s=e.mpvSeparateWindow?"yes":"no";t.send("mpv-set-prop",["vo",r]),t.send("mpv-set-prop",["osc",s]),t.send("mpv-set-prop",["input-defalt-bindings",s]),t.send("mpv-set-prop",["input-vo-keyboard",s]),t.send("mpv-command",["loadfile",l.url]),t.send("mpv-set-prop",["pause",!1]),t.send("mpv-set-prop",["speed",c.speed]),t.send("mpv-set-prop",["aid",c.aid]),t.send("mpv-set-prop",["mute","no"]),m("paused"),m("time"),m("duration"),m("buffering"),m("volume"),m("muted"),m("subtitlesTracks"),m("selectedSubtitlesTrackId")}else N(Object.assign({},i.UNSUPPORTED_STREAM,{critical:!0,stream:a?a.stream:null}));break;case"unload":c={mute:!1,speed:1,subtitlesTracks:[],buffering:!0,aid:null,sid:null},u=0,d=0,t.send("mpv-command",["stop"]),m("stream"),m("paused"),m("time"),m("duration"),m("buffering"),m("volume"),m("muted"),m("subtitlesTracks"),m("selectedSubtitlesTrackId"),I(!0);break;case"destroy":R("unload"),T=!0,_.removeAllListeners()}}t.on("mpv-prop-change",(function(e){switch(e.name){case"mpv-version":case"ffmpeg-version":c[e.name]=(function(e){console.log(e.name+": "+e.data)})(e);break;case"duration":var a=0|e.data;c[e.name]=e.data>=30&&(!d||a===d)?Math.round(1e3*e.data):null,d=d?d+a>>1:a;break;case"time-pos":c[e.name]=Math.round(1e3*e.data),u&&(t.send("mpv-set-prop",["time-pos",u]),c[e.name]=Math.round(u),u=0);break;case"sub-scale":c[e.name]=Math.round(e.data/s);break;case"paused-for-cache":case"seeking":c.buffering!==e.data&&(c.buffering=e.data,m("buffering"));break;case"aid":case"sid":case"vid":c[e.name]=(function(e){return e.data?"EMBEDDED_"+e.data.toString():null})(e);break;case"track-list":c.audioTracks=e.data.filter((function(e){return"audio"===e.type})).map((function(e,t){return{id:"EMBEDDED_"+e.id,lang:void 0===e.lang?"Track"+(t+1):e.lang,label:void 0===e.title||void 0===e.lang?"":e.title||e.lang,origin:"EMBEDDED",embedded:!0,mode:e.id===c.aid?"showing":"disabled"}})),m("audioTracks"),c.subtitlesTracks=e.data.filter((function(e){return"sub"===e.type})).map((function(e,t){return{id:"EMBEDDED_"+e.id,lang:void 0===e.lang?"Track "+(t+1):e.lang,label:void 0===e.title||void 0===e.lang?"":e.title||e.lang,origin:"EMBEDDED",embedded:!0,mode:e.id===c.sid?"showing":"disabled"}})),m("subtitlesTracks");break;default:c[e.name]=e.data}var n="time-pos"===e.name?Math.floor(c["time-pos"]/1e3):null;n&&A===n||!o[e.name]||(n&&(A=n),m(o[e.name]))})),t.on("mpv-event-ended",(function(e){e.error?N(e.error):_.emit("ended")})),this.on=function(e,t){if(T)throw new Error("Video is destroyed");_.on(e,t)},this.dispatch=function(e){if(T)throw new Error("Video is destroyed");if(e)switch((e=r(n(e))).type){case"observeProp":o=e.propName,_.emit("propValue",o,O(o)),S[o]=!0;break;case"setProp":return void(function(e,o){switch(e){case"paused":null!==l&&t.send("mpv-set-prop",["pause",o]);break;case"time":null!==l&&null!==o&&isFinite(o)&&t.send("mpv-set-prop",["time-pos",o/1e3]);break;case"playbackSpeed":null!==l&&null!==o&&isFinite(o)&&t.send("mpv-set-prop",["speed",o]);break;case"volume":null!==l&&null!==o&&isFinite(o)&&(c.mute=!1,t.send("mpv-set-prop",["mute","no"]),t.send("mpv-set-prop",["volume",o]),m("muted"),m("volume"));break;case"muted":null!==l&&(t.send("mpv-set-prop",["mute",o?"yes":"no"]),c.mute=o,m("muted"));break;case"selectedAudioTrackId":if(null!==l){var a=o.slice("EMBEDDED_".length);t.send("mpv-set-prop",["aid",a])}break;case"selectedSubtitlesTrackId":null!==l&&(o?(a=o.slice("EMBEDDED_".length),t.send("mpv-set-prop",["sid",a]),_.emit("subtitlesTrackLoaded",o)):(t.send("mpv-set-prop",["sid","no"]),c.sid=null)),m("selectedSubtitlesTrackId");break;case"subtitlesSize":t.send("mpv-set-prop",[E[e],o*s]);break;case"subtitlesOffset":t.send("mpv-set-prop",[E[e],o]);break;case"subtitlesTextColor":case"subtitlesBackgroundColor":case"subtitlesOutlineColor":var n=o.replace(/^#(\w{6})(\w{2})$/,"#$2$1");t.send("mpv-set-prop",[E[e],n]);break;default:console.log("Unhandled setProp for",e)}})(e.propName,e.propValue);case"command":return void R(e.commandName,e.commandArgs)}var o}}_.canPlayStream=function(){return Promise.resolve(!0)},_.manifest={name:"ShellVideo",external:!1,props:Object.keys(E),commands:["load","unload","destroy"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded"]},e.exports=_},2024:(e,t,o)=>{var a=o(8945);e.exports=a},8117:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(2081),s=o(9657);function E(){var e=null,t=new a,o=!1;this.on=function(e,a){if(o)throw new Error("Video is destroyed");t.on(e,a)},this.dispatch=function(a,E){if(o)throw new Error("Video is destroyed");if(!a)throw new Error("Invalid action dispatched: "+JSON.stringify(a));if(E=E||{},"command"===(a=r(n(a))).type&&"load"===a.commandName&&a.commandArgs){var _=i(a.commandArgs,E);if(null!==e&&e.constructor!==_&&(e.dispatch({type:"command",commandName:"destroy"}),e=null),null===e){if(null===_)return void t.emit("error",Object.assign({},s.UNSUPPORTED_STREAM,{error:new Error("No video implementation was selected"),critical:!0,stream:a.commandArgs.stream}));(e=new _(E)).on("ended",(function(){t.emit("ended")})),e.on("error",(function(e){t.emit("error",e)})),e.on("propValue",(function(e,o){t.emit("propValue",e,o)})),e.on("propChanged",(function(e,o){t.emit("propChanged",e,o)})),e.on("subtitlesTrackLoaded",(function(e){t.emit("subtitlesTrackLoaded",e)})),e.on("audioTrackLoaded",(function(e){t.emit("audioTrackLoaded",e)})),e.on("extraSubtitlesTrackLoaded",(function(e){t.emit("extraSubtitlesTrackLoaded",e)})),_.manifest.external?e.on("implementationChanged",(function(e){t.emit("implementationChanged",e)})):t.emit("implementationChanged",_.manifest)}}if(null!==e)try{e.dispatch(a)}catch(t){console.error(e.constructor.manifest.name,t)}"command"===a.type&&"destroy"===a.commandName&&(e=null)},this.destroy=function(){o=!0,null!==e&&(e.dispatch({type:"command",commandName:"destroy"}),e=null),t.removeAllListeners()}}E.ERROR=s,e.exports=E},5010:(e,t,o)=>{var a=o(8117);e.exports=a},2081:(e,t,o)=>{var a=o(3153),n=o(2024),r=o(9222),i=o(5682),s=o(8846),E=o(7685),_=o(3142),T=o(5690),l=o(4282);e.exports=function(e,t){return e.stream&&"string"!=typeof e.stream.externalUrl?t.chromecastTransport&&t.chromecastTransport.getCastState()===cast.framework.CastState.CONNECTED?a:"string"==typeof e.stream.ytId?l(_):"string"==typeof e.stream.playerFrameUrl?E:t.shellTransport?T(l(n)):"string"==typeof e.streamingServerURL?void 0!==o.g.tizen?T(l(i)):void 0!==o.g.webOS?T(l(s)):T(l(r)):"string"==typeof e.stream.url?void 0!==o.g.webOS?l(s):void 0!==o.g.tizen?l(i):l(r):null:null}},5071:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(6767),s=o(9657);function E(e){var t=!0,o=1,E=null,_=null,T=(e=e||{}).containerElement;if(!(T instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var l,S=!1,u=100,d=0,c="rgb(255, 255, 255)",I="rgba(0, 0, 0, 0)",A="rgb(34, 34, 34)",O=document.createElement("object");O.type="application/avplayer",O.style.width="100%",O.style.height="100%",O.style.backgroundColor="black";var N=!1;function m(){if(l){var e=l.duration-(v("time")-l.now);e>0&&R(e,l.text)}}function R(e,t){if(!N){for(l={duration:e,text:t,now:v("time")},p&&(clearTimeout(p),p=!1);f.hasChildNodes();)f.removeChild(f.lastChild);f.style.bottom=d+"%";var a=document.createElement("span");a.innerHTML=t,a.style.display="inline-block",a.style.padding="0.2em",a.style.fontSize=Math.floor(u/25)+"vmin",a.style.color=c,a.style.backgroundColor=I,a.style.textShadow="1px 1px 0.1em "+A,f.appendChild(a),f.appendChild(document.createElement("br")),e&&(p=setTimeout((function(){for(;f.hasChildNodes();)f.removeChild(f.lastChild)}),parseInt(e*o)))}}var p=!1,h={onbufferingstart:function(){t=!0,P("buffering")},onbufferingprogress:function(){t=!0,P("buffering")},onbufferingcomplete:function(){t=!1,P("buffering")},oncurrentplaytime:function(){P("time")},onerror:function(){!(function(){if(C)return;var e;e=s.UNKNOWN_ERROR,y(Object.assign({},e,{critical:!0,error:e}))})()},onsubtitlechange:function(e,t){R(e,t)},onstreamcompleted:function(){L.emit("ended")}};window.webapis.avplay.setListener(h),T.appendChild(O);var f=document.createElement("div");f.style.position="absolute",f.style.right="0",f.style.bottom="0",f.style.left="0",f.style.zIndex="1",f.style.textAlign="center",T.style.position="relative",T.style.zIndex="0",T.appendChild(f);var L=new a,C=!1,D=null,g={stream:!1,paused:!1,time:!1,duration:!1,buffering:!1,subtitlesTracks:!1,selectedSubtitlesTrackId:!1,subtitlesOffset:!1,subtitlesSize:!1,subtitlesTextColor:!1,subtitlesBackgroundColor:!1,subtitlesOutlineColor:!1,audioTracks:!1,selectedAudioTrackId:!1,playbackSpeed:!1};function v(e){switch(e){case"stream":return D;case"paused":if(null===D)return null;var a=!("PAUSED"!==window.webapis.avplay.getState());return!a&&S&&(window.webapis.avplay.setSelectTrack("AUDIO",parseInt(S.replace("EMBEDDED_",""))),S=!1),a;case"time":var n=window.webapis.avplay.getCurrentTime();return null!==D&&null!==n&&isFinite(n)?Math.floor(n):null;case"duration":var r=window.webapis.avplay.getDuration();return null!==D&&null!==r&&isFinite(r)?Math.floor(r):null;case"buffering":return null===D?null:t;case"subtitlesTracks":if(null===D)return[];for(var i=window.webapis.avplay.getTotalTrackInfo(),s=[],T=0;T{var a=o(5071);e.exports=a},4333:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(9657);function s(e,t,o,a){t&&(e.onSuccess=t||function(){}),e.onFailure=function(){o&&o()},window.webOS.service.request(a||"luna://com.webos.media",e)}function E(e,t){window.webOS.service.request("luna://com.webos.applicationManager",{method:"launch",parameters:{id:e.need,params:{payload:[{fullPath:e.url,artist:"",subtitle:"",dlnaInfo:{flagVal:4096,cleartextSize:"-1",contentLength:"-1",opVal:1,protocolInfo:"http-get:*:video/x-matroska:DLNA.ORG_OP=01;DLNA.ORG_CI=0;DLNA.ORG_FLAGS=01700000000000000000000000000000",duration:0},mediaType:"VIDEO",thumbnail:"",deviceType:"DMR",album:"",fileName:e.name,lastPlayPosition:e.position}]}},onSuccess:function(){},onFailure:function(){"com.webos.app.photovideo"===e.need?(e.need="com.webos.app.smartshare",E(e)):"com.webos.app.smartshare"===e.need?(e.need="com.webos.app.mediadiscovery",E(e)):"com.webos.app.mediadiscovery"===e.need&&t()}})}var _=["black","white","yellow","red","green","blue"],T={"rgba(0, 0, 0, 255)":"black","rgba(255, 255, 255, 255)":"white","rgba(255, 255, 0, 255)":"yellow","rgba(255, 0, 0, 255)":"red","rgba(0, 255, 0, 255)":"green","rgba(0, 0, 255, 255)":"blue","rgba(0, 0, 0, 1)":"black","rgba(255, 255, 255, 1)":"white","rgba(255, 255, 0, 1)":"yellow","rgba(255, 0, 0, 1)":"red","rgba(0, 255, 0, 1)":"green","rgba(0, 0, 255, 1)":"blue","rgba(0, 0, 0)":"black","rgba(255, 255, 255)":"white","rgba(255, 255, 0)":"yellow","rgba(255, 0, 0)":"red","rgba(0, 255, 0)":"green","rgba(0, 0, 255)":"blue","#000000FF":"black","#FFFFFFFF":"white","#FFFF00FF":"yellow","#FF0000FF":"red","#00FF00FF":"green","#0000FFFF":"blue","#000000":"black","#FFFFFF":"white","#FFFF00":"yellow","#FF0000":"red","#00FF00":"green","#0000FF":"blue"};function l(e){var t=(e=e||{}).containerElement;if(!(t instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var o=!1,l=75,S=!0,u=!1,d=!1,c=!1,I=[],A=[],O=0,N=function(e){if(!u){u=!0;var t=!1;s({method:"subscribe",parameters:{mediaId:o,subscribe:!0}},(function(a){if(a.sourceInfo&&!t){t=!0;var n=a.sourceInfo.programInfo[0];!(function(e){if(I=[],e.numSubtitleTracks){for(var t=0;t=h.HAVE_METADATA&&null!==t&&isFinite(t))try{h.currentTime=parseInt(t,10)/1e3}catch(e){}break;case"selectedSubtitlesTrackId":if(null!==y)if(0===(t||"").indexOf("EMBEDDED_")){S&&R(!0),d=t;var a=parseInt(t.replace("EMBEDDED_",""));s({method:"selectTrack",parameters:{type:"text",mediaId:o,index:a}},(function(){var e=M("subtitlesTracks").find((function(e){return e.id===t}));I=I.map((function(e){return e.mode=e.id===d?"showing":"disabled",e})),e&&(g.emit("subtitlesTrackLoaded",e),G("selectedSubtitlesTrackId"))}))}else t||R(!1);break;case"subtitlesOffset":if(null!==t&&isFinite(t)){B=Math.max(0,Math.min(100,parseInt(t,10)));var n=0===(O=5)?-3:O<=2?-2:O<=3?-1:O<=5?0:O<=10?1:O<=25?2:O<=50?3:O<=100&&4;!1===n&&(n=0),s({method:"setSubtitlePosition",parameters:{mediaId:o,position:n}},(function(){})),G("subtitlesOffset")}break;case"subtitlesSize":if(null!==t&&isFinite(t)){l=Math.max(0,parseInt(t,10));var r=(u=l)<=75?1:u<=100?2:u<=150?3:u<=250&&4;!1===r&&(r=2),s({method:"setSubtitleFontSize",parameters:{mediaId:o,fontSize:r}},(function(){})),G("subtitlesSize")}break;case"subtitlesTextColor":if("string"==typeof t){var i="white";T[t]&&_.indexOf(T[t])>-1&&(i=T[t]),s({method:"setSubtitleCharacterColor",parameters:{mediaId:o,charColor:i}},(function(){})),f=t,G("subtitlesTextColor")}break;case"subtitlesBackgroundColor":"string"==typeof t&&(T[t]&&_.indexOf(T[t])>-1?s({method:"setSubtitleBackgroundColor",parameters:{mediaId:o,color:T[t]}},(function(){C||s({method:"setSubtitleBackgroundOpacity",parameters:{mediaId:o,bgOpacity:255}},(function(){C=255}))})):s({method:"setSubtitleBackgroundOpacity",parameters:{mediaId:o,bgOpacity:0}},(function(){C=0})),L=t,G("subtitlesBackgroundColor"));break;case"selectedAudioTrackId":if(0===(t||"").indexOf("EMBEDDED_")){c=t;a=parseInt(t.replace("EMBEDDED_",""));if(s({method:"selectTrack",parameters:{type:"audio",mediaId:o,index:a}},(function(){var e=M("audioTracks").find((function(e){return e.id===t}));A=A.map((function(e){return e.mode=e.id===c?"showing":"disabled",e})),e&&(g.emit("audioTrackLoaded",e),G("selectedAudioTrackId"))})),h.audioTracks){for(var E=0;E4&&(clearInterval(s),r())}),300)}else W(Object.assign({},i.UNSUPPORTED_STREAM,{critical:!0,stream:a?a.stream:null}));break;case"unload":y=null,P=null,Array.from(h.textTracks).forEach((function(e){e.oncuechange=null})),h.removeAttribute("src"),h.load(),G("stream"),G("paused"),G("time"),G("duration"),G("buffering"),G("buffered"),G("subtitlesTracks"),G("selectedSubtitlesTrackId"),G("audioTracks"),G("selectedAudioTrackId");break;case"destroy":k("unload"),v=!0,G("subtitlesOffset"),G("subtitlesSize"),G("subtitlesTextColor"),G("subtitlesBackgroundColor"),G("volume"),G("muted"),G("playbackSpeed"),g.removeAllListeners(),h.onerror=null,h.onended=null,h.onpause=null,h.onplay=null,h.ontimeupdate=null,h.ondurationchange=null,h.onwaiting=null,h.onseeking=null,h.onseeked=null,h.onstalled=null,h.onplaying=null,h.oncanplay=null,h.canplaythrough=null,h.onloadeddata=null,h.onloadedmetadata=null,h.onvolumechange=null,h.onratechange=null,h.textTracks.onchange=null,t.removeChild(h),t.removeChild(p)}var r,s}this.on=function(e,t){if(v)throw new Error("Video is destroyed");g.on(e,t)},this.dispatch=function(e){if(v)throw new Error("Video is destroyed");if(e)switch((e=r(n(e))).type){case"observeProp":return t=e.propName,void(b.hasOwnProperty(t)&&(g.emit("propValue",t,M(t)),b[t]=!0));case"setProp":return void F(e.propName,e.propValue);case"command":return void k(e.commandName,e.commandArgs)}var t;throw new Error("Invalid action dispatched: "+JSON.stringify(e))}}l.canPlayStream=function(){return Promise.resolve(!0)},l.manifest={name:"WebOsVideo",external:!1,props:["stream","paused","time","duration","buffering","buffered","audioTracks","selectedAudioTrackId","subtitlesTracks","selectedSubtitlesTrackId","subtitlesOffset","subtitlesSize","subtitlesTextColor","subtitlesBackgroundColor","volume","muted","playbackSpeed"],commands:["load","unload","destroy"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded","audioTrackLoaded"]},e.exports=l},8846:(e,t,o)=>{var a=o(4333);e.exports=a},9736:(e,t,o)=>{var a=o(6729),n=o(3465),r=o(2682),i=o(9657);function s(e){var t=null!==(e=e||{}).timeChangedTimeout&&isFinite(e.timeChangedTimeout)?parseInt(e.timeChangedTimeout,10):100,o=e.containerElement;if(!(o instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var s=document.createElement("script");s.type="text/javascript",s.src="https://www.youtube.com/iframe_api",s.onload=function(){if(d)return;if(!YT||"function"!=typeof YT.ready)return void O();YT.ready((function(){d||(YT&&YT.PlayerState&&"function"==typeof YT.Player?T=new YT.Player(E,{width:"100%",height:"100%",playerVars:{autoplay:1,cc_load_policy:3,controls:0,disablekb:1,enablejsapi:1,fs:0,iv_load_policy:3,loop:0,modestbranding:1,playsinline:1,rel:0},events:{onError:N,onReady:m,onApiChange:R,onStateChange:p}}):O())}))},s.onerror=O,o.appendChild(s);var E=document.createElement("div");E.style.width="100%",E.style.height="100%",E.style.backgroundColor="black",o.appendChild(E);var _=window.setInterval((function(){L("time"),L("volume"),L("muted")}),t),T=null,l=!1,S=null,u=new a,d=!1,c=null,I=null,A={stream:!1,loaded:!1,paused:!1,time:!1,duration:!1,buffering:!1,volume:!1,muted:!1,subtitlesTracks:!1,selectedSubtitlesTrackId:!1};function O(){d||f(Object.assign({},i.YOUTUBE_VIDEO.API_LOAD_FAILED,{critical:!0}))}function N(e){if(!d){var t;switch(e.data){case 2:t=i.YOUTUBE_VIDEO.INVALID_PARAMETER;break;case 5:t=i.YOUTUBE_VIDEO.HTML5_VIDEO;break;case 100:t=i.YOUTUBE_VIDEO.VIDEO_NOT_FOUND;break;case 101:case 150:t=i.YOUTUBE_VIDEO.VIDEO_NOT_EMBEDDABLE;break;default:t=i.UNKNOWN_ERROR}f(Object.assign({},t,{critical:!0,error:e}))}}function m(){d||(l=!0,null!==S&&(C("load",S),S=null))}function R(){d||("function"==typeof T.loadModule&&T.loadModule("captions"),"function"==typeof T.setOption&&T.setOption("captions","track",{}),L("paused"),L("time"),L("duration"),L("buffering"),L("volume"),L("muted"),L("subtitlesTracks"),L("selectedSubtitlesTrackId"))}function p(e){switch(L("buffering"),e.data){case YT.PlayerState.ENDED:u.emit("ended");break;case YT.PlayerState.CUED:case YT.PlayerState.UNSTARTED:case YT.PlayerState.PAUSED:case YT.PlayerState.PLAYING:L("paused"),L("time"),L("duration")}}function h(e){switch(e){case"stream":return c;case"loaded":return null!==c||null;case"paused":return null===c||"function"!=typeof T.getPlayerState?null:T.getPlayerState()!==YT.PlayerState.PLAYING;case"time":return null!==c&&"function"==typeof T.getCurrentTime&&null!==T.getCurrentTime()&&isFinite(T.getCurrentTime())?Math.floor(1e3*T.getCurrentTime()):null;case"duration":return null!==c&&"function"==typeof T.getDuration&&null!==T.getDuration()&&isFinite(T.getDuration())?Math.floor(1e3*T.getDuration()):null;case"buffering":return null===c||"function"!=typeof T.getPlayerState?null:T.getPlayerState()===YT.PlayerState.BUFFERING;case"volume":return null!==c&&"function"==typeof T.getVolume&&null!==T.getVolume()&&isFinite(T.getVolume())?T.getVolume():null;case"muted":return null===c||"function"!=typeof T.isMuted?null:T.isMuted();case"subtitlesTracks":return null===c||"function"!=typeof T.getOption?[]:(T.getOption("captions","tracklist")||[]).filter((function(e){return e&&"string"==typeof e.languageCode})).map((function(e,t){return Object.freeze({id:"EMBEDDED_"+String(t),lang:e.languageCode,label:"string"==typeof e.displayName?e.displayName:e.languageCode,origin:"EMBEDDED",embedded:!0})}));case"selectedSubtitlesTrackId":return null===c?null:I;default:return null}}function f(e){u.emit("error",e),e.critical&&C("unload")}function L(e){A[e]&&u.emit("propChanged",e,h(e))}function C(e,t){switch(e){case"load":if(C("unload"),t&&t.stream&&"string"==typeof t.stream.ytId)if(l){c=t.stream,L("stream"),L("loaded");var a="boolean"!=typeof t.autoplay||t.autoplay,n=null!==t.time&&isFinite(t.time)?parseInt(t.time,10)/1e3:0;a&&"function"==typeof T.loadVideoById?T.loadVideoById({videoId:t.stream.ytId,startSeconds:n}):"function"==typeof T.cueVideoById&&T.cueVideoById({videoId:t.stream.ytId,startSeconds:n}),L("paused"),L("time"),L("duration"),L("buffering"),L("volume"),L("muted"),L("subtitlesTracks"),L("selectedSubtitlesTrackId")}else S=t;else f(Object.assign({},i.UNSUPPORTED_STREAM,{critical:!0,stream:t?t.stream:null}));break;case"unload":S=null,c=null,L("stream"),L("loaded"),I=null,l&&"function"==typeof T.stopVideo&&T.stopVideo(),L("paused"),L("time"),L("duration"),L("buffering"),L("volume"),L("muted"),L("subtitlesTracks"),L("selectedSubtitlesTrackId");break;case"destroy":C("unload"),d=!0,u.removeAllListeners(),clearInterval(_),l&&"function"==typeof T.destroy&&T.destroy(),o.removeChild(s),o.removeChild(E)}}this.on=function(e,t){if(d)throw new Error("Video is destroyed");u.on(e,t)},this.dispatch=function(e){if(d)throw new Error("Video is destroyed");if(e)switch((e=r(n(e))).type){case"observeProp":return t=e.propName,void(A.hasOwnProperty(t)&&(u.emit("propValue",t,h(t)),A[t]=!0));case"setProp":return void(function(e,t){switch(e){case"paused":null!==c&&(t?"function"==typeof T.pauseVideo&&T.pauseVideo():"function"==typeof T.playVideo&&T.playVideo());break;case"time":null!==c&&"function"==typeof T.seekTo&&null!==t&&isFinite(t)&&T.seekTo(parseInt(t,10)/1e3);break;case"volume":null!==c&&null!==t&&isFinite(t)&&("function"==typeof T.unMute&&T.unMute(),"function"==typeof T.setVolume&&T.setVolume(Math.max(0,Math.min(100,parseInt(t,10)))),L("muted"),L("volume"));break;case"muted":null!==c&&(t?"function"==typeof T.mute&&T.mute():"function"==typeof T.unMute&&T.unMute(),L("muted"));break;case"selectedSubtitlesTrackId":if(null!==c){I=null;var o=h("subtitlesTracks").find((function(e){return e.id===t}));"function"==typeof T.setOption&&(o?(I=o.id,T.setOption("captions","track",{languageCode:o.lang}),u.emit("subtitlesTrackLoaded",o)):T.setOption("captions","track",{})),L("selectedSubtitlesTrackId")}}})(e.propName,e.propValue);case"command":return void C(e.commandName,e.commandArgs)}var t;throw new Error("Invalid action dispatched: "+JSON.stringify(e))}}s.canPlayStream=function(e){return Promise.resolve(e&&"string"==typeof e.ytId)},s.manifest={name:"YouTubeVideo",external:!1,props:["stream","loaded","paused","time","duration","buffering","volume","muted","subtitlesTracks","selectedSubtitlesTrackId"],commands:["load","unload","destroy"],events:["propValue","propChanged","ended","error","subtitlesTrackLoaded"]},e.exports=s},3142:(e,t,o)=>{var a=o(9736);e.exports=a},9657:e=>{e.exports={CHROMECAST_SENDER_VIDEO:{INVALID_MESSAGE_RECEIVED:{code:100,message:"Invalid message received"},MESSAGE_SEND_FAILED:{code:101,message:"Failed to send message"}},YOUTUBE_VIDEO:{API_LOAD_FAILED:{code:90,message:"YouTube player iframe API failed to load"},INVALID_PARAMETER:{code:91,message:"The request contains an invalid parameter value"},HTML5_VIDEO:{code:92,message:"The requested content cannot be played in an HTML5 player"},VIDEO_NOT_FOUND:{code:93,message:"The video requested was not found"},VIDEO_NOT_EMBEDDABLE:{code:94,message:"The owner of the requested video does not allow it to be played in embedded players"}},HTML_VIDEO:{MEDIA_ERR_ABORTED:{code:80,message:"Fetching process aborted"},MEDIA_ERR_NETWORK:{code:81,message:"Error occurred when downloading"},MEDIA_ERR_DECODE:{code:82,message:"Error occurred when decoding"},MEDIA_ERR_SRC_NOT_SUPPORTED:{code:83,message:"Video is not supported"}},WITH_HTML_SUBTITLES:{LOAD_FAILED:{code:70,message:"Failed to load external subtitles"}},WITH_STREAMING_SERVER:{CONVERT_FAILED:{code:60,message:"Streaming server failed to convert torrent stream"}},UNKNOWN_ERROR:{code:1,message:"Unknown error"},UNSUPPORTED_STREAM:{code:2,message:"Stream is not supported"}}},1654:(e,t,o)=>{var a=o(5010);e.exports=a},5015:e=>{var t,o=[{codec:"h264",mime:'video/mp4; codecs="avc1.42E01E"'},{codec:"h265",mime:'video/mp4; codecs="hev1.1.6.L150.B0"',aliases:["hevc"]},{codec:"vp8",mime:'video/mp4; codecs="vp8"'},{codec:"vp9",mime:'video/mp4; codecs="vp9"'}],a=[{codec:"aac",mime:'audio/mp4; codecs="mp4a.40.2"'},{codec:"mp3",mime:'audio/mp4; codecs="mp3"'},{codec:"ac3",mime:'audio/mp4; codecs="ac-3"'},{codec:"eac3",mime:'audio/mp4; codecs="ec-3"'},{codec:"vorbis",mime:'audio/mp4; codecs="vorbis"'},{codec:"opus",mime:'audio/mp4; codecs="opus"'}];function n(e,t){return t.mediaElement.canPlayType(e.mime)?[e.codec].concat(e.aliases||[]):[]}e.exports=(t=document.createElement("video"),{formats:["mp4"],videoCodecs:o.map((function(e){return n(e,{mediaElement:t})})).reduce((function(e,t){return e.concat(t)}),[]),audioCodecs:a.map((function(e){return n(e,{mediaElement:t})})).reduce((function(e,t){return e.concat(t)}),[]),maxAudioChannels:(function(){if(/firefox/i.test(window.navigator.userAgent))return 6;if(!window.AudioContext)return 2;var e=(new AudioContext).destination.maxChannelCount;return e>0?e:2})()})},9490:e=>{e.exports=function(e,t){if(tt?a=r-1:(e[r]{var a=o(4253);e.exports=a},6950:e=>{function t(e){for(var t="",o=(e=e.replace(/<[a-zA-Z/][^>]*>/g,"")).split(/\n/);o.length>3;){for(var a=3;a\s*(\d+):(\d+):(\d+)(?:,(\d+))?/);return r?(t+=r[1]+":"+r[2]+":"+r[3]+"."+r[4]+" --\x3e "+r[5]+":"+r[6]+":"+r[7]+"."+r[8]+"\n",o[n+=1]&&(t+=o[n]+"\n\n"),t):""}e.exports={convert:function(e){if(e.includes("WEBVTT"))return e;try{return(function(e){var o=e.replace(/\r+/g,""),a=(o=o.replace(/^\s+|\s+$/g,"")).split("\n\n"),n="";if(a.length>0){n+="WEBVTT\n\n";for(var r=0;r{var a=o(8369),n=o(9490);e.exports={parse:function(e){return new Promise((function(t,o){var r=new a.WebVTT.Parser(window,a.WebVTT.StringDecoder()),i=[],s=[],E={};r.oncue=function(e){var t={startTime:1e3*e.startTime|0,endTime:1e3*e.endTime|0,text:e.text};s.push(t),E[t.startTime]=E[t.startTime]||[],E[t.endTime]=E[t.endTime]||[]},r.onparsingerror=function(e){0===e.code?(r.oncue=null,r.onparsingerror=null,r.onflush=null,o(e)):(console.warn("Subtitles parsing error",e),i.push(e))},r.onflush=function(){E.times=Object.keys(E).map((function(e){return parseInt(e,10)})).sort((function(e,t){return e-t}));for(var e=0;e{var a=o(8369),n=o(9490);e.exports={render:function(e,t){var o=[],r=n(e.times,t);if(-1!==r)for(var i=e[e.times[r]],s=0;s{var a=o(6729),n=o(3465),r=o(2682),i=o(6767),s=o(9657),E=o(1494),_=o(2913),T=o(6950);e.exports=function(e){function t(t){var o=new e(t=t||{});o.on("error",(function(e){c.emit("error",e),e.critical&&P("unload")})),o.on("propValue",D.bind(null,"propValue")),o.on("propChanged",D.bind(null,"propChanged")),e.manifest.events.filter((function(e){return!["error","propValue","propChanged"].includes(e)})).forEach((function(e){o.on(e,(function(e){return function(){c.emit.apply(c,[e].concat(Array.from(arguments)))}})(e))}));var l=t.containerElement;if(!(l instanceof HTMLElement))throw new Error("Container element required to be instance of HTMLElement");var S=document.createElement("div");S.style.position="absolute",S.style.right="0",S.style.bottom="0",S.style.left="0",S.style.zIndex="1",S.style.textAlign="center",l.style.position="relative",l.style.zIndex="0",l.appendChild(S);var u={time:null},d=null,c=new a,I=!1,A=[],O=null,N=null,m=100,R=0,p="rgb(255, 255, 255)",h="rgba(0, 0, 0, 0)",f="rgb(34, 34, 34)",L={extraSubtitlesTracks:!1,selectedExtraSubtitlesTrackId:!1,extraSubtitlesDelay:!1,extraSubtitlesSize:!1,extraSubtitlesOffset:!1,extraSubtitlesTextColor:!1,extraSubtitlesBackgroundColor:!1,extraSubtitlesOutlineColor:!1};function C(){for(;S.hasChildNodes();)S.removeChild(S.lastChild);null!==d&&null!==u.time&&isFinite(u.time)&&(S.style.bottom=R+"%",_.render(d,u.time+N).forEach((function(e){e.style.display="inline-block",e.style.padding="0.2em",e.style.fontSize=Math.floor(m/25)+"vmin",e.style.color=p,e.style.backgroundColor=h,e.style.textShadow="1px 1px 0.1em "+f,S.appendChild(e),S.appendChild(document.createElement("br"))})))}function D(e,t,o){if("time"===t)u.time=o,C();c.emit(e,t,v(t,o))}function g(e){L[e]&&c.emit("propChanged",e,v(e,null))}function v(e,t){switch(e){case"extraSubtitlesTracks":return I?[]:A.slice();case"selectedExtraSubtitlesTrackId":return I?null:O;case"extraSubtitlesDelay":return I?null:N;case"extraSubtitlesSize":return I?null:m;case"extraSubtitlesOffset":return I?null:R;case"extraSubtitlesTextColor":return I?null:p;case"extraSubtitlesBackgroundColor":return I?null:h;case"extraSubtitlesOutlineColor":return I?null:f;default:return t}}function y(e,t){switch(e){case"selectedExtraSubtitlesTrackId":d=null,O=null,N=null;var a=A.find((function(e){return e.id===t}));return a&&(O=a.id,N=0,fetch(a.url).then((function(e){if(e.ok)return e.text();throw new Error(e.status+" ("+e.statusText+")")})).then((function(e){return T.convert(e)})).then((function(e){return E.parse(e)})).then((function(e){O===a.id&&(d=e,C(),c.emit("extraSubtitlesTrackLoaded",a))})).catch((function(e){O===a.id&&(function(e){c.emit("error",e),e.critical&&(P("unload"),o.dispatch({type:"command",commandName:"unload"}))})(Object.assign({},s.WITH_HTML_SUBTITLES.LOAD_FAILED,{error:e,track:a,critical:!1}))}))),C(),g("selectedExtraSubtitlesTrackId"),g("extraSubtitlesDelay"),!0;case"extraSubtitlesDelay":return null!==O&&null!==t&&isFinite(t)&&(N=parseInt(t,10),C(),g("extraSubtitlesDelay")),!0;case"extraSubtitlesSize":return null!==t&&isFinite(t)&&(m=Math.max(0,parseInt(t,10)),C(),g("extraSubtitlesSize")),!0;case"extraSubtitlesOffset":return null!==t&&isFinite(t)&&(R=Math.max(0,Math.min(100,parseInt(t,10))),C(),g("extraSubtitlesOffset")),!0;case"extraSubtitlesTextColor":if("string"==typeof t){try{p=i(t).rgb().string()}catch(e){console.error("withHTMLSubtitles",e)}C(),g("extraSubtitlesTextColor")}return!0;case"extraSubtitlesBackgroundColor":if("string"==typeof t){try{h=i(t).rgb().string()}catch(e){console.error("withHTMLSubtitles",e)}C(),g("extraSubtitlesBackgroundColor")}return!0;case"extraSubtitlesOutlineColor":if("string"==typeof t){try{f=i(t).rgb().string()}catch(e){console.error("withHTMLSubtitles",e)}C(),g("extraSubtitlesOutlineColor")}return!0;default:return!1}}function P(e,t){switch(e){case"addExtraSubtitlesTracks":return t&&Array.isArray(t.tracks)&&(A=A.concat(t.tracks).filter((function(e,t,o){return e&&"string"==typeof e.id&&"string"==typeof e.url&&"string"==typeof e.lang&&"string"==typeof e.label&&"string"==typeof e.origin&&!e.embedded&&t===o.findIndex((function(t){return t.id===e.id}))})),g("extraSubtitlesTracks")),!0;case"load":return P("unload"),t.stream&&Array.isArray(t.stream.subtitles)&&P("addExtraSubtitlesTracks",{tracks:t.stream.subtitles.map((function(e){return Object.assign({},e,{origin:"EXCLUSIVE",exclusive:!0,embedded:!1})}))}),!1;case"unload":return d=null,A=[],O=null,N=null,C(),g("extraSubtitlesTracks"),g("selectedExtraSubtitlesTrackId"),g("extraSubtitlesDelay"),!1;case"destroy":return P("unload"),I=!0,g("extraSubtitlesSize"),g("extraSubtitlesOffset"),g("extraSubtitlesTextColor"),g("extraSubtitlesBackgroundColor"),g("extraSubtitlesOutlineColor"),o.dispatch({type:"command",commandName:"destroy"}),c.removeAllListeners(),l.removeChild(S),!0;default:return!1}}this.on=function(e,t){if(I)throw new Error("Video is destroyed");c.on(e,t)},this.dispatch=function(e){if(I)throw new Error("Video is destroyed");if(e)switch((e=r(n(e))).type){case"observeProp":if((function(e){switch(e){case"extraSubtitlesTracks":case"selectedExtraSubtitlesTrackId":case"extraSubtitlesDelay":case"extraSubtitlesSize":case"extraSubtitlesOffset":case"extraSubtitlesTextColor":case"extraSubtitlesBackgroundColor":case"extraSubtitlesOutlineColor":return c.emit("propValue",e,v(e,null)),L[e]=!0,!0;default:return!1}})(e.propName))return;break;case"setProp":if(y(e.propName,e.propValue))return;break;case"command":if(P(e.commandName,e.commandArgs))return}o.dispatch(e)}}return t.canPlayStream=function(t){return e.canPlayStream(t)},t.manifest={name:e.manifest.name+"WithHTMLSubtitles",external:e.manifest.external,props:e.manifest.props.concat(["extraSubtitlesTracks","selectedExtraSubtitlesTrackId","extraSubtitlesDelay","extraSubtitlesSize","extraSubtitlesOffset","extraSubtitlesTextColor","extraSubtitlesBackgroundColor","extraSubtitlesOutlineColor"]).filter((function(e,t,o){return o.indexOf(e)===t})),commands:e.manifest.commands.concat(["load","unload","destroy","addExtraSubtitlesTracks"]).filter((function(e,t,o){return o.indexOf(e)===t})),events:e.manifest.events.concat(["propValue","propChanged","error","extraSubtitlesTrackLoaded"]).filter((function(e,t,o){return o.indexOf(e)===t}))},t}},7054:(e,t,o)=>{var a=o(9566),n=o(7190);e.exports=function(e,t,o){return new Promise((function(r,i){if("string"!=typeof t.url)"string"!=typeof t.infoHash?i(new Error("Stream cannot be converted")):n(e,t.infoHash,t.fileIdx,t.announce,o).then((function(e){r(e)})).catch((function(e){i(e)}));else if(0===t.url.indexOf("magnet:")){var s;try{if(!(s=a.decode(t.url))||"string"!=typeof s.infoHash)throw new Error("Failed to decode magnet url")}catch(e){return void i(e)}var E=Array.isArray(s.announce)?s.announce.map((function(e){return"tracker:"+e})):[];n(e,s.infoHash,null,E,o).then((function(e){r(e)})).catch((function(e){i(e)}))}else r(t.url)}))}},7190:(e,t,o)=>{var a=o(8575);function n(e,t,o,n){var r=Array.isArray(n)&&n.length>0?"?"+new URLSearchParams(n.map((function(e){return["tr",e]}))):"";return a.resolve(e,"/"+encodeURIComponent(t)+"/"+encodeURIComponent(o))+r}e.exports=function(e,t,o,r,i){if((!Array.isArray(r)||0===r.length)&&null!==o&&isFinite(o))return Promise.resolve(n(e,t,o,r));var s={torrent:{infoHash:t}};return Array.isArray(r)&&r.length>0&&(s.peerSearch={sources:["dht:"+t].concat(r).filter((function(e,t,o){return o.indexOf(e)===t})),min:40,max:200}),null!==o&&isFinite(o)?s.guessFileIdx=!1:(s.guessFileIdx={},i&&(null!==i.season&&isFinite(i.season)&&(s.guessFileIdx.season=i.season),null!==i.episode&&isFinite(i.episode)&&(s.guessFileIdx.episode=i.episode))),fetch(a.resolve(e,"/"+encodeURIComponent(t)+"/create"),{method:"POST",headers:{"content-type":"application/json"},body:JSON.stringify(s)}).then((function(e){if(e.ok)return e.json();throw new Error(e.status+" ("+e.statusText+")")})).then((function(a){return n(e,t,s.guessFileIdx?a.guessedFileIdx:o,s.peerSearch?s.peerSearch.sources:[])}))}},5690:(e,t,o)=>{var a=o(7746);e.exports=a},7746:(e,t,o)=>{var a=o(6729),n=o(8575),r=o(542),i=o(3465),s=o(2682),E=o(5015),_=o(7054),T=o(9657);e.exports=function(e){function t(o){var l=new e(o=o||{});l.on("error",(function(e){I.emit("error",e),e.critical&&h("unload")})),l.on("propValue",N.bind(null,"propValue")),l.on("propChanged",N.bind(null,"propChanged")),e.manifest.events.filter((function(e){return!["error","propValue","propChanged"].includes(e)})).forEach((function(e){l.on(e,(function(e){return function(){I.emit.apply(I,[e].concat(Array.from(arguments)))}})(e))}));var S=this,u=null,d=!1,c=[],I=new a,A=!1,O={stream:!1};function N(e,t,o){I.emit(e,t,p(t,o))}function m(e){O[e]&&I.emit("propChanged",e,p(e,null))}function R(e){I.emit("error",e),e.critical&&(h("unload"),l.dispatch({type:"command",commandName:"unload"}))}function p(e,t){return"stream"===e?null!==u?u.stream:null:t}function h(e,o){switch(e){case"load":return o&&o.stream&&"string"==typeof o.streamingServerURL?(h("unload"),l.dispatch({type:"command",commandName:"unload"}),u=o,m("stream"),_(o.streamingServerURL,o.stream,o.seriesInfo).then((function(e){var a=Array.isArray(o.formats)?o.formats:E.formats,i=Array.isArray(o.videoCodecs)?o.videoCodecs:E.videoCodecs,s=Array.isArray(o.audioCodecs)?o.audioCodecs:E.audioCodecs,_=null!==o.maxAudioChannels&&isFinite(o.maxAudioChannels)?o.maxAudioChannels:E.maxAudioChannels,T=Object.assign({},o,{formats:a,videoCodecs:i,audioCodecs:s,maxAudioChannels:_});return(o.forceTranscoding?Promise.resolve(!1):t.canPlayStream({url:e},T)).catch((function(e){return console.warn("Media probe error",e),!1})).then((function(t){if(t)return{url:e};var a=r(),E=new URLSearchParams([["mediaURL",e]]);return o.forceTranscoding&&E.set("forceTranscoding","1"),i.forEach((function(e){E.append("videoCodecs",e)})),s.forEach((function(e){E.append("audioCodecs",e)})),E.set("maxAudioChannels",_),{url:n.resolve(o.streamingServerURL,"/hlsv2/"+a+"/master.m3u8?"+E.toString()),subtitles:Array.isArray(o.stream.subtitles)?o.stream.subtitles.map((function(e){return Object.assign({},e,{url:"string"==typeof e.url?n.resolve(o.streamingServerURL,"/subtitles.vtt?"+new URLSearchParams([["from",e.url]]).toString()):e.url})})):[],behaviorHints:{headers:{"content-type":"application/vnd.apple.mpegurl"}}}}))})).then((function(e){o===u&&(l.dispatch({type:"command",commandName:"load",commandArgs:Object.assign({},o,{stream:e})}),d=!0,(function(){for(;c.length>0;){var e=c.shift();S.dispatch.call(S,e)}})())})).catch((function(e){o===u&&R(Object.assign({},T.WITH_STREAMING_SERVER.CONVERT_FAILED,{error:e,critical:!0,stream:o.stream,streamingServerURL:o.streamingServerURL}))}))):R(Object.assign({},T.UNSUPPORTED_STREAM,{critical:!0,stream:o?o.stream:null,streamingServerURL:o&&"string"==typeof o.streamingServerURL?o.streamingServerURL:null})),!0;case"addExtraSubtitlesTracks":return u&&o&&Array.isArray(o.tracks)&&(d?l.dispatch({type:"command",commandName:"addExtraSubtitlesTracks",commandArgs:Object.assign({},o,{tracks:o.tracks.map((function(e){return Object.assign({},e,{url:"string"==typeof e.url?n.resolve(u.streamingServerURL,"/subtitles.vtt?"+new URLSearchParams([["from",e.url]]).toString()):e.url})}))})}):c.push({type:"command",commandName:"addExtraSubtitlesTracks",commandArgs:o})),!0;case"unload":return u=null,d=!1,c=[],m("stream"),!1;case"destroy":return h("unload"),A=!0,l.dispatch({type:"command",commandName:"destroy"}),I.removeAllListeners(),!0;default:return!d&&(c.push({type:"command",commandName:e,commandArgs:o}),!0)}}this.on=function(e,t){if(A)throw new Error("Video is destroyed");I.on(e,t)},this.dispatch=function(e){if(A)throw new Error("Video is destroyed");if(e)switch((e=s(i(e))).type){case"observeProp":if("stream"===(t=e.propName)&&(I.emit("propValue",t,p(t,null)),O[t]=!0,1))return;break;case"command":if(h(e.commandName,e.commandArgs))return}var t;l.dispatch(e)}}return t.canPlayStream=function(t,o){return e.canPlayStream(t).then((function(e){if(!e)throw new Error("Fallback using /hlsv2/probe");return e})).catch((function(){var e=new URLSearchParams([["mediaURL",t.url]]);return fetch(n.resolve(o.streamingServerURL,"/hlsv2/probe?"+e.toString())).then((function(e){return e.json()})).then((function(e){var t=o.formats.some((function(t){return-1!==e.format.name.indexOf(t)})),a=e.streams.every((function(e){return"audio"===e.track?e.channels<=o.maxAudioChannels&&-1!==o.audioCodecs.indexOf(e.codec):"video"!==e.track||-1!==o.videoCodecs.indexOf(e.codec)}));return t&&a}))}))},t.manifest={name:e.manifest.name+"WithStreamingServer",external:e.manifest.external,props:e.manifest.props.concat(["stream"]).filter((function(e,t,o){return o.indexOf(e)===t})),commands:e.manifest.commands.concat(["load","unload","destroy","addExtraSubtitlesTracks"]).filter((function(e,t,o){return o.indexOf(e)===t})),events:e.manifest.events.concat(["propValue","propChanged","error"]).filter((function(e,t,o){return o.indexOf(e)===t}))},t}},3746:function(e){"undefined"!=typeof self&&self,e.exports=(function(e){var t={};function o(a){if(t[a])return t[a].exports;var n=t[a]={i:a,l:!1,exports:{}};return e[a].call(n.exports,n,n.exports,o),n.l=!0,n.exports}return o.m=e,o.c=t,o.d=function(e,t,a){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:a})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var a=Object.create(null);if(o.r(a),Object.defineProperty(a,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)o.d(a,n,function(t){return e[t]}.bind(null,n));return a},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=1)})([function(e,t,o){"use strict";var a=o(3);function n(e){return!0===a(e)&&"[object Object]"===Object.prototype.toString.call(e)}e.exports=function(e){var t,o;return!1!==n(e)&&"function"==typeof(t=e.constructor)&&!1!==n(o=t.prototype)&&!1!==o.hasOwnProperty("isPrototypeOf")}},function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.VERSION=t.PALETTE_MATERIAL_CHROME=t.PALETTE_MATERIAL_500=t.COLOR_NAMES=t.getLuminance=t.intToRgb=t.rgbToInt=t.rgbToHsv=t.rgbToHsl=t.hslToRgb=t.rgbToHex=t.parseColor=t.parseColorToHsla=t.parseColorToHsl=t.parseColorToRgba=t.parseColorToRgb=t.from=t.createPicker=void 0;var a=(function(){function e(e,t){for(var o=0;o-1,S="undefined"!=typeof window&&window.navigator.userAgent.indexOf("rv:")>-1,u={id:null,attachTo:"body",showHSL:!0,showRGB:!0,showHEX:!0,showAlpha:!1,color:"#ff0000",palette:null,paletteEditable:!1,useAlphaInPalette:"auto",slBarSize:[232,150],hueBarSize:[150,11],alphaBarSize:[150,11]},d="COLOR",c="RGBA_USER",I="HSLA_USER";function A(e,t,o){return e?e instanceof HTMLElement?e:e instanceof NodeList?e[0]:"string"==typeof e?document.querySelector(e):e.jquery?e.get(0):o?t:null:t}function O(e){var t=e.getContext("2d"),o=+e.width,a=+e.height,i=t.createLinearGradient(1,1,1,a-1);return i.addColorStop(0,"white"),i.addColorStop(1,"black"),{setHue:function(e){var n=t.createLinearGradient(1,0,o-1,0);n.addColorStop(0,"hsla("+e+", 100%, 50%, 0)"),n.addColorStop(1,"hsla("+e+", 100%, 50%, 1)"),t.fillStyle=i,t.fillRect(0,0,o,a),t.fillStyle=n,t.globalCompositeOperation="multiply",t.fillRect(0,0,o,a),t.globalCompositeOperation="source-over"},grabColor:function(e,o){return t.getImageData(e,o,1,1).data},findColor:function(e,t,i){var s=(0,r.rgbToHsv)(e,t,i),E=n(s,3),_=E[1],T=E[2];return[_*o,a-T*a]}}}function N(e,t,o){return null===e?t:/^\s*$/.test(e)?o:!!/true|yes|1/i.test(e)||!/false|no|0/i.test(e)&&t}function m(e,t,o){if(null===e)return t;if(/^\s*$/.test(e))return o;var a=e.split(",").map(Number);return 2===a.length&&a[0]&&a[1]?a:t}var R=(function(){function e(t,o){if(_(this,e),o?(t=A(t),this.options=Object.assign({},u,o)):t&&(0,i.default)(t)?(this.options=Object.assign({},u,t),t=A(this.options.attachTo)):(this.options=Object.assign({},u),t=A((0,r.nvl)(t,this.options.attachTo))),!t)throw new Error("Container not found: "+this.options.attachTo);!(function(e,t){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:"acp-";if(t.hasAttribute(o+"show-hsl")&&(e.showHSL=N(t.getAttribute(o+"show-hsl"),u.showHSL,!0)),t.hasAttribute(o+"show-rgb")&&(e.showRGB=N(t.getAttribute(o+"show-rgb"),u.showRGB,!0)),t.hasAttribute(o+"show-hex")&&(e.showHEX=N(t.getAttribute(o+"show-hex"),u.showHEX,!0)),t.hasAttribute(o+"show-alpha")&&(e.showAlpha=N(t.getAttribute(o+"show-alpha"),u.showAlpha,!0)),t.hasAttribute(o+"palette-editable")&&(e.paletteEditable=N(t.getAttribute(o+"palette-editable"),u.paletteEditable,!0)),t.hasAttribute(o+"sl-bar-size")&&(e.slBarSize=m(t.getAttribute(o+"sl-bar-size"),u.slBarSize,[232,150])),t.hasAttribute(o+"hue-bar-size")&&(e.hueBarSize=m(t.getAttribute(o+"hue-bar-size"),u.hueBarSize,[150,11]),e.alphaBarSize=e.hueBarSize),t.hasAttribute(o+"palette")){var a=t.getAttribute(o+"palette");switch(a){case"PALETTE_MATERIAL_500":e.palette=r.PALETTE_MATERIAL_500;break;case"PALETTE_MATERIAL_CHROME":case"":e.palette=r.PALETTE_MATERIAL_CHROME;break;default:e.palette=a.split(/[;|]/)}}t.hasAttribute(o+"color")&&(e.color=t.getAttribute(o+"color"))})(this.options,t),this.H=0,this.S=0,this.L=0,this.R=0,this.G=0,this.B=0,this.A=1,this.palette={},this.element=document.createElement("div"),this.options.id&&(this.element.id=this.options.id),this.element.className="a-color-picker",this.element.innerHTML=s.default,t.appendChild(this.element);var a=this.element.querySelector(".a-color-picker-h");this.setupHueCanvas(a),this.hueBarHelper=O(a),this.huePointer=this.element.querySelector(".a-color-picker-h+.a-color-picker-dot");var n=this.element.querySelector(".a-color-picker-sl");this.setupSlCanvas(n),this.slBarHelper=O(n),this.slPointer=this.element.querySelector(".a-color-picker-sl+.a-color-picker-dot"),this.preview=this.element.querySelector(".a-color-picker-preview"),this.setupClipboard(this.preview.querySelector(".a-color-picker-clipbaord")),this.options.showHSL?(this.setupInput(this.inputH=this.element.querySelector(".a-color-picker-hsl>input[nameref=H]")),this.setupInput(this.inputS=this.element.querySelector(".a-color-picker-hsl>input[nameref=S]")),this.setupInput(this.inputL=this.element.querySelector(".a-color-picker-hsl>input[nameref=L]"))):this.element.querySelector(".a-color-picker-hsl").remove(),this.options.showRGB?(this.setupInput(this.inputR=this.element.querySelector(".a-color-picker-rgb>input[nameref=R]")),this.setupInput(this.inputG=this.element.querySelector(".a-color-picker-rgb>input[nameref=G]")),this.setupInput(this.inputB=this.element.querySelector(".a-color-picker-rgb>input[nameref=B]"))):this.element.querySelector(".a-color-picker-rgb").remove(),this.options.showHEX?this.setupInput(this.inputRGBHEX=this.element.querySelector("input[nameref=RGBHEX]")):this.element.querySelector(".a-color-picker-rgbhex").remove(),this.options.paletteEditable||this.options.palette&&this.options.palette.length>0?this.setPalette(this.paletteRow=this.element.querySelector(".a-color-picker-palette")):(this.paletteRow=this.element.querySelector(".a-color-picker-palette"),this.paletteRow.remove()),this.options.showAlpha?(this.setupAlphaCanvas(this.element.querySelector(".a-color-picker-a")),this.alphaPointer=this.element.querySelector(".a-color-picker-a+.a-color-picker-dot")):this.element.querySelector(".a-color-picker-alpha").remove(),this.element.style.width=this.options.slBarSize[0]+"px",this.onValueChanged(d,this.options.color)}return a(e,[{key:"setupHueCanvas",value:function(e){var t=this;e.width=this.options.hueBarSize[0],e.height=this.options.hueBarSize[1];for(var o=e.getContext("2d"),a=o.createLinearGradient(0,0,this.options.hueBarSize[0],0),n=0;n<=1;n+=1/360)a.addColorStop(n,"hsl("+360*n+", 100%, 50%)");o.fillStyle=a,o.fillRect(0,0,this.options.hueBarSize[0],this.options.hueBarSize[1]);var i=function(o){var a=(0,r.limit)(o.clientX-e.getBoundingClientRect().left,0,t.options.hueBarSize[0]),n=Math.round(360*a/t.options.hueBarSize[0]);t.huePointer.style.left=a-7+"px",t.onValueChanged("H",n)},s=function e(){document.removeEventListener("mousemove",i),document.removeEventListener("mouseup",e)};e.addEventListener("mousedown",(function(e){i(e),document.addEventListener("mousemove",i),document.addEventListener("mouseup",s)}))}},{key:"setupSlCanvas",value:function(e){var t=this;e.width=this.options.slBarSize[0],e.height=this.options.slBarSize[1];var o=function(o){var a=(0,r.limit)(o.clientX-e.getBoundingClientRect().left,0,t.options.slBarSize[0]-1),n=(0,r.limit)(o.clientY-e.getBoundingClientRect().top,0,t.options.slBarSize[1]-1),i=t.slBarHelper.grabColor(a,n);t.slPointer.style.left=a-7+"px",t.slPointer.style.top=n-7+"px",t.onValueChanged("RGB",i)},a=function e(){document.removeEventListener("mousemove",o),document.removeEventListener("mouseup",e)};e.addEventListener("mousedown",(function(e){o(e),document.addEventListener("mousemove",o),document.addEventListener("mouseup",a)}))}},{key:"setupAlphaCanvas",value:function(e){var t=this;e.width=this.options.alphaBarSize[0],e.height=this.options.alphaBarSize[1];var o=e.getContext("2d"),a=o.createLinearGradient(0,0,e.width-1,0);a.addColorStop(0,"hsla(0, 0%, 50%, 0)"),a.addColorStop(1,"hsla(0, 0%, 50%, 1)"),o.fillStyle=a,o.fillRect(0,0,this.options.alphaBarSize[0],this.options.alphaBarSize[1]);var n=function(o){var a=(0,r.limit)(o.clientX-e.getBoundingClientRect().left,0,t.options.alphaBarSize[0]),n=+(a/t.options.alphaBarSize[0]).toFixed(2);t.alphaPointer.style.left=a-7+"px",t.onValueChanged("ALPHA",n)},i=function e(){document.removeEventListener("mousemove",n),document.removeEventListener("mouseup",e)};e.addEventListener("mousedown",(function(e){n(e),document.addEventListener("mousemove",n),document.addEventListener("mouseup",i)}))}},{key:"setupInput",value:function(e){var t=this,o=+e.min,a=+e.max,n=e.getAttribute("nameref");e.hasAttribute("select-on-focus")&&e.addEventListener("focus",(function(){e.select()})),"text"===e.type?e.addEventListener("change",(function(){t.onValueChanged(n,e.value)})):((l||S)&&e.addEventListener("keydown",(function(i){"Up"===i.key?(e.value=(0,r.limit)(+e.value+1,o,a),t.onValueChanged(n,e.value),i.returnValue=!1):"Down"===i.key&&(e.value=(0,r.limit)(+e.value-1,o,a),t.onValueChanged(n,e.value),i.returnValue=!1)})),e.addEventListener("change",(function(){var i=+e.value;t.onValueChanged(n,(0,r.limit)(i,o,a))})))}},{key:"setupClipboard",value:function(e){var t=this;e.title="click to copy",e.addEventListener("click",(function(){e.value=(0,r.parseColor)([t.R,t.G,t.B,t.A],"hexcss4"),e.select(),document.execCommand("copy")}))}},{key:"setPalette",value:function(e){var t=this,o="auto"===this.options.useAlphaInPalette?this.options.showAlpha:this.options.useAlphaInPalette,a=null;switch(this.options.palette){case"PALETTE_MATERIAL_500":a=r.PALETTE_MATERIAL_500;break;case"PALETTE_MATERIAL_CHROME":a=r.PALETTE_MATERIAL_CHROME;break;default:a=(0,r.ensureArray)(this.options.palette)}if(this.options.paletteEditable||a.length>0){var n=function(o,a,n){var r=e.querySelector('.a-color-picker-palette-color[data-color="'+o+'"]')||document.createElement("div");r.className="a-color-picker-palette-color",r.style.backgroundColor=o,r.setAttribute("data-color",o),r.title=o,e.insertBefore(r,a),t.palette[o]=!0,n&&t.onPaletteColorAdd(o)},i=function(o,a){o?(e.removeChild(o),t.palette[o.getAttribute("data-color")]=!1,a&&t.onPaletteColorRemove(o.getAttribute("data-color"))):(e.querySelectorAll(".a-color-picker-palette-color[data-color]").forEach((function(t){e.removeChild(t)})),Object.keys(t.palette).forEach((function(e){t.palette[e]=!1})),a&&t.onPaletteColorRemove())};if(a.map((function(e){return(0,r.parseColor)(e,o?"rgbcss4":"hex")})).filter((function(e){return!!e})).forEach((function(e){return n(e)})),this.options.paletteEditable){var s=document.createElement("div");s.className="a-color-picker-palette-color a-color-picker-palette-add",s.innerHTML="+",e.appendChild(s),e.addEventListener("click",(function(e){/a-color-picker-palette-add/.test(e.target.className)?e.shiftKey?i(null,!0):n(o?(0,r.parseColor)([t.R,t.G,t.B,t.A],"rgbcss4"):(0,r.rgbToHex)(t.R,t.G,t.B),e.target,!0):/a-color-picker-palette-color/.test(e.target.className)&&(e.shiftKey?i(e.target,!0):t.onValueChanged(d,e.target.getAttribute("data-color")))}))}else e.addEventListener("click",(function(e){/a-color-picker-palette-color/.test(e.target.className)&&t.onValueChanged(d,e.target.getAttribute("data-color"))}))}else e.style.display="none"}},{key:"updatePalette",value:function(e){this.paletteRow.innerHTML="",this.palette={},this.paletteRow.parentElement||this.element.appendChild(this.paletteRow),this.options.palette=e,this.setPalette(this.paletteRow)}},{key:"onValueChanged",value:function(e,t){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{silent:!1};switch(e){case"H":this.H=t;var a=(0,r.hslToRgb)(this.H,this.S,this.L),i=n(a,3);this.R=i[0],this.G=i[1],this.B=i[2],this.slBarHelper.setHue(t),this.updatePointerH(this.H),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"S":this.S=t;var s=(0,r.hslToRgb)(this.H,this.S,this.L),E=n(s,3);this.R=E[0],this.G=E[1],this.B=E[2],this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"L":this.L=t;var _=(0,r.hslToRgb)(this.H,this.S,this.L),T=n(_,3);this.R=T[0],this.G=T[1],this.B=T[2],this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"R":this.R=t;var l=(0,r.rgbToHsl)(this.R,this.G,this.B),S=n(l,3);this.H=S[0],this.S=S[1],this.L=S[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"G":this.G=t;var u=(0,r.rgbToHsl)(this.R,this.G,this.B),A=n(u,3);this.H=A[0],this.S=A[1],this.L=A[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"B":this.B=t;var O=(0,r.rgbToHsl)(this.R,this.G,this.B),N=n(O,3);this.H=N[0],this.S=N[1],this.L=N[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case"RGB":var m=n(t,3);this.R=m[0],this.G=m[1],this.B=m[2];var R=(0,r.rgbToHsl)(this.R,this.G,this.B),p=n(R,3);this.H=p[0],this.S=p[1],this.L=p[2],this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case c:var h=n(t,4);this.R=h[0],this.G=h[1],this.B=h[2],this.A=h[3];var f=(0,r.rgbToHsl)(this.R,this.G,this.B),L=n(f,3);this.H=L[0],this.S=L[1],this.L=L[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case I:var C=n(t,4);this.H=C[0],this.S=C[1],this.L=C[2],this.A=C[3];var D=(0,r.hslToRgb)(this.H,this.S,this.L),g=n(D,3);this.R=g[0],this.G=g[1],this.B=g[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case"RGBHEX":var v=(0,r.cssColorToRgb)(t)||[this.R,this.G,this.B],y=n(v,3);this.R=y[0],this.G=y[1],this.B=y[2];var P=(0,r.rgbToHsl)(this.R,this.G,this.B),B=n(P,3);this.H=B[0],this.S=B[1],this.L=B[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B);break;case d:var b=(0,r.parseColor)(t,"rgba")||[0,0,0,1],M=n(b,4);this.R=M[0],this.G=M[1],this.B=M[2],this.A=M[3];var U=(0,r.rgbToHsl)(this.R,this.G,this.B),W=n(U,3);this.H=W[0],this.S=W[1],this.L=W[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case"ALPHA":this.A=t}1===this.A?this.preview.style.backgroundColor="rgb("+this.R+","+this.G+","+this.B+")":this.preview.style.backgroundColor="rgba("+this.R+","+this.G+","+this.B+","+this.A+")",o&&o.silent||this.onchange&&this.onchange(this.preview.style.backgroundColor)}},{key:"onPaletteColorAdd",value:function(e){this.oncoloradd&&this.oncoloradd(e)}},{key:"onPaletteColorRemove",value:function(e){this.oncolorremove&&this.oncolorremove(e)}},{key:"updateInputHSL",value:function(e,t,o){this.options.showHSL&&(this.inputH.value=e,this.inputS.value=t,this.inputL.value=o)}},{key:"updateInputRGB",value:function(e,t,o){this.options.showRGB&&(this.inputR.value=e,this.inputG.value=t,this.inputB.value=o)}},{key:"updateInputRGBHEX",value:function(e,t,o){this.options.showHEX&&(this.inputRGBHEX.value=(0,r.rgbToHex)(e,t,o))}},{key:"updatePointerH",value:function(e){var t=this.options.hueBarSize[0]*e/360;this.huePointer.style.left=t-7+"px"}},{key:"updatePointerSL",value:function(e,t,o){var a=(0,r.hslToRgb)(e,t,o),i=n(a,3),s=i[0],E=i[1],_=i[2],T=this.slBarHelper.findColor(s,E,_),l=n(T,2),S=l[0],u=l[1];S>=0&&(this.slPointer.style.left=S-7+"px",this.slPointer.style.top=u-7+"px")}},{key:"updatePointerA",value:function(e){if(this.options.showAlpha){var t=this.options.alphaBarSize[0]*e;this.alphaPointer.style.left=t-7+"px"}}}]),e})(),p=(function(){function e(t){_(this,e),this.name=t,this.listeners=[]}return a(e,[{key:"on",value:function(e){e&&this.listeners.push(e)}},{key:"off",value:function(e){this.listeners=e?this.listeners.filter((function(t){return t!==e})):[]}},{key:"emit",value:function(e,t){for(var o=this.listeners.slice(0),a=0;a1&&void 0!==arguments[1]&&arguments[1];o.onValueChanged(d,e,{silent:t})},get all(){if(i){var e=[o.R,o.G,o.B,o.A],t=o.A<1?"rgba("+o.R+","+o.G+","+o.B+","+o.A+")":r.rgbToHex.apply(void 0,e);(s=(0,r.parseColor)(e,s)).toString=function(){return t},i=!1}return Object.assign({},s)},get onchange(){return a.change&&a.change.listeners[0]},set onchange(e){this.off("change").on("change",e)},get oncoloradd(){return a.coloradd&&a.coloradd.listeners[0]},set oncoloradd(e){this.off("coloradd").on("coloradd",e)},get oncolorremove(){return a.colorremove&&a.colorremove.listeners[0]},set oncolorremove(e){this.off("colorremove").on("colorremove",e)},get palette(){return Object.keys(o.palette).filter((function(e){return o.palette[e]}))},set palette(e){o.updatePalette(e)},show:function(){o.element.classList.remove("hidden")},hide:function(){o.element.classList.add("hidden")},toggle:function(){o.element.classList.toggle("hidden")},on:function(e,t){return e&&a[e]&&a[e].on(t),this},off:function(e,t){return e&&a[e]&&a[e].off(t),this},destroy:function(){a.change.off(),a.coloradd.off(),a.colorremove.off(),o.element.remove(),a=null,o=null}};return o.onchange=function(){for(var e=arguments.length,t=Array(e),o=0;ostyle[data-source="a-color-picker"]')){var f=o(5).toString(),L=document.createElement("style");L.setAttribute("type","text/css"),L.setAttribute("data-source","a-color-picker"),L.innerHTML=f,document.querySelector("head").appendChild(L)}t.createPicker=h,t.from=function(e,t){var o=(function(e){return e?Array.isArray(e)?e:e instanceof HTMLElement?[e]:e instanceof NodeList?[].concat(T(e)):"string"==typeof e?[].concat(T(document.querySelectorAll(e))):e.jquery?e.get():[]:[]})(e).map((function(e,o){var a=h(e,t);return a.index=o,a}));return o.on=function(e,t){return o.forEach((function(o){return o.on(e,t)})),this},o.off=function(e){return o.forEach((function(t){return t.off(e)})),this},o},t.parseColorToRgb=r.parseColorToRgb,t.parseColorToRgba=r.parseColorToRgba,t.parseColorToHsl=r.parseColorToHsl,t.parseColorToHsla=r.parseColorToHsla,t.parseColor=r.parseColor,t.rgbToHex=r.rgbToHex,t.hslToRgb=r.hslToRgb,t.rgbToHsl=r.rgbToHsl,t.rgbToHsv=r.rgbToHsv,t.rgbToInt=r.rgbToInt,t.intToRgb=r.intToRgb,t.getLuminance=r.getLuminance,t.COLOR_NAMES=r.COLOR_NAMES,t.PALETTE_MATERIAL_500=r.PALETTE_MATERIAL_500,t.PALETTE_MATERIAL_CHROME=r.PALETTE_MATERIAL_CHROME,t.VERSION="1.2.1"},function(e,t,o){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.nvl=t.ensureArray=t.limit=t.getLuminance=t.parseColor=t.parseColorToHsla=t.parseColorToHsl=t.cssHslaToHsla=t.cssHslToHsl=t.parseColorToRgba=t.parseColorToRgb=t.cssRgbaToRgba=t.cssRgbToRgb=t.cssColorToRgba=t.cssColorToRgb=t.intToRgb=t.rgbToInt=t.rgbToHsv=t.rgbToHsl=t.hslToRgb=t.rgbToHex=t.PALETTE_MATERIAL_CHROME=t.PALETTE_MATERIAL_500=t.COLOR_NAMES=void 0;var a=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return(function(e,t){var o=[],a=!0,n=!1,r=void 0;try{for(var i,s=e[Symbol.iterator]();!(a=(i=s.next()).done)&&(o.push(i.value),!t||o.length!==t);a=!0);}catch(e){n=!0,r=e}finally{try{!a&&s.return&&s.return()}finally{if(n)throw r}}return o})(e,t);throw new TypeError("Invalid attempt to destructure non-iterable instance")},n=(function(e){return e&&e.__esModule?e:{default:e}})(o(0));function r(e){if(Array.isArray(e)){for(var t=0,o=Array(e.length);to?o:e}function E(e,t){return null==e?t:e}function _(e,t,o){var a=[s(e,0,255),s(t,0,255),s(o,0,255)];return"#"+("000000"+((e=a[0])<<16|(t=a[1])<<8|(o=a[2])).toString(16)).slice(-6)}function T(e,t,o){var a=void 0,n=void 0,r=void 0,i=[s(e,0,360)/360,s(t,0,100)/100,s(o,0,100)/100];if(e=i[0],o=i[2],0==(t=i[1]))a=n=r=o;else{var E=function(e,t,o){return o<0&&(o+=1),o>1&&(o-=1),o<1/6?e+6*(t-e)*o:o<.5?t:o<2/3?e+(t-e)*(2/3-o)*6:e},_=o<.5?o*(1+t):o+t-o*t,T=2*o-_;a=E(T,_,e+1/3),n=E(T,_,e),r=E(T,_,e-1/3)}return[255*a,255*n,255*r].map(Math.round)}function l(e,t,o){var a=[s(e,0,255)/255,s(t,0,255)/255,s(o,0,255)/255];e=a[0],t=a[1],o=a[2];var n=Math.max(e,t,o),r=Math.min(e,t,o),i=void 0,E=void 0,_=(n+r)/2;if(n==r)i=E=0;else{var T=n-r;switch(E=_>.5?T/(2-n-r):T/(n+r),n){case e:i=(t-o)/T+(t>16&255,e>>8&255,255&e]},t.cssColorToRgb=u,t.cssColorToRgba=d,t.cssRgbToRgb=c,t.cssRgbaToRgba=I,t.parseColorToRgb=function(e){return Array.isArray(e)?e=[s(e[0],0,255),s(e[1],0,255),s(e[2],0,255)]:u(e)||c(e)},t.parseColorToRgba=A,t.cssHslToHsl=O,t.cssHslaToHsla=N,t.parseColorToHsl=function(e){return Array.isArray(e)?e=[s(e[0],0,360),s(e[1],0,100),s(e[2],0,100)]:O(e)},t.parseColorToHsla=m,t.parseColor=function(e,t){if(t=t||"rgb",null!=e){var o=void 0;if((o=A(e))||(o=m(e))&&(o=[].concat(r(T.apply(void 0,r(o))),[o[3]])))return(0,n.default)(t)?["rgb","rgbcss","rgbcss4","rgba","rgbacss","hsl","hslcss","hslcss4","hsla","hslacss","hex","hexcss4","int"].reduce((function(e,t){return e[t]=R(o,t),e}),t||{}):R(o,t.toString().toLowerCase())}},t.getLuminance=function(e,t,o){return.2126*(e=(e/=255)<.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=(t/=255)<.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*((o/=255)<.03928?o/12.92:Math.pow((o+.055)/1.055,2.4))},t.limit=s,t.ensureArray=function(e){return e?Array.from(e):[]},t.nvl=E},function(e,t,o){"use strict";e.exports=function(e){return null!=e&&"object"==typeof e&&!1===Array.isArray(e)}},function(e,t){e.exports='
'},function(e,t,o){var a=o(6);e.exports="string"==typeof a?a:a.toString()},function(e,t,o){(e.exports=o(7)(!1)).push([e.i,"/*!\n * a-color-picker\n * https://github.com/narsenico/a-color-picker\n *\n * Copyright (c) 2017-2018, Gianfranco Caldi.\n * Released under the MIT License.\n */.a-color-picker{background-color:#fff;padding:0;display:inline-flex;flex-direction:column;user-select:none;width:232px;font:400 10px Helvetica,Arial,sans-serif;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,.05),0 2px 4px rgba(0,0,0,.25)}.a-color-picker,.a-color-picker-row,.a-color-picker input{box-sizing:border-box}.a-color-picker-row{padding:15px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;user-select:none}.a-color-picker-row-top{padding:0}.a-color-picker-row:not(:first-child){border-top:1px solid #f5f5f5}.a-color-picker-column{display:flex;flex-direction:column}.a-color-picker-cell{flex:1 1 auto;margin-bottom:4px}.a-color-picker-cell:last-child{margin-bottom:0}.a-color-picker-stack{position:relative}.a-color-picker-dot{position:absolute;width:14px;height:14px;top:0;left:0;background:#fff;pointer-events:none;border-radius:50px;z-index:1000;box-shadow:0 1px 2px rgba(0,0,0,.75)}.a-color-picker-a,.a-color-picker-h,.a-color-picker-sl{cursor:cell}.a-color-picker-a+.a-color-picker-dot,.a-color-picker-h+.a-color-picker-dot{top:-2px}.a-color-picker-a,.a-color-picker-h{border-radius:2px}.a-color-picker-preview{box-sizing:border-box;width:30px;height:30px;user-select:none;border-radius:15px}.a-color-picker-circle{border-radius:50px;border:1px solid #eee}.a-color-picker-hsl,.a-color-picker-rgb,.a-color-picker-single-input{justify-content:space-evenly}.a-color-picker-hsl>label,.a-color-picker-rgb>label,.a-color-picker-single-input>label{padding:0 8px;flex:0 0 auto;color:#969696}.a-color-picker-hsl>input,.a-color-picker-rgb>input,.a-color-picker-single-input>input{text-align:center;padding:2px 0;width:0;flex:1 1 auto;border:1px solid #e0e0e0;line-height:20px}.a-color-picker-hsl>input::-webkit-inner-spin-button,.a-color-picker-rgb>input::-webkit-inner-spin-button,.a-color-picker-single-input>input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.a-color-picker-hsl>input:focus,.a-color-picker-rgb>input:focus,.a-color-picker-single-input>input:focus{border-color:#04a9f4;outline:none}.a-color-picker-transparent{background-image:linear-gradient(-45deg,#cdcdcd 25%,transparent 0),linear-gradient(45deg,#cdcdcd 25%,transparent 0),linear-gradient(-45deg,transparent 75%,#cdcdcd 0),linear-gradient(45deg,transparent 75%,#cdcdcd 0);background-size:11px 11px;background-position:0 0,0 -5.5px,-5.5px 5.5px,5.5px 0}.a-color-picker-sl{border-radius:3px 3px 0 0}.a-color-picker.hide-alpha [show-on-alpha],.a-color-picker.hide-hsl [show-on-hsl],.a-color-picker.hide-rgb [show-on-rgb],.a-color-picker.hide-single-input [show-on-single-input]{display:none}.a-color-picker-clipbaord{width:100%;height:100%;opacity:0;cursor:pointer}.a-color-picker-palette{flex-flow:wrap;flex-direction:row;justify-content:flex-start;padding:10px}.a-color-picker-palette-color{width:15px;height:15px;flex:0 1 15px;margin:3px;box-sizing:border-box;cursor:pointer;border-radius:3px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}.a-color-picker-palette-add{text-align:center;line-height:13px;color:#607d8b}.a-color-picker.hidden{display:none}",""])},function(e,t){e.exports=function(e){var t=[];return t.toString=function(){return this.map((function(t){var o=(function(e,t){var o=e[1]||"",a=e[3];if(!a)return o;if(t&&"function"==typeof btoa){var n=(function(e){return"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,"+btoa(unescape(encodeURIComponent(JSON.stringify(e))))+" */"})(a),r=a.sources.map((function(e){return"/*# sourceURL="+a.sourceRoot+e+" */"}));return[o].concat(r).concat([n]).join("\n")}return[o].join("\n")})(t,e);return t[2]?"@media "+t[2]+"{"+o+"}":o})).join("")},t.i=function(e,o){"string"==typeof e&&(e=[[null,e,""]]);for(var a={},n=0;n{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(1341);e.exports=a},9239:(e,t,o)=>{var a=o(7294),n=o(3662).useServices,r=o(6590).useToast;e.exports=function(){var e=n(),t=e.core,o=e.dragAndDrop,i=r();return a.useEffect((function(){var e=function(e){var t=e.event,o=e.args;switch(t){case"Error":if("UserPulledFromAPI"===o.source.event&&null===o.source.args.uid)break;if("LibrarySyncWithAPIPlanned"===o.source.event&&null===o.source.args.uid)break;if("Other"===o.error.type&&3===o.error.code&&"AddonInstalled"===o.source.event&&o.source.args.transport_url.startsWith("https://www.strem.io/trakt/addon"))break;i.show({type:"error",title:o.source.event,message:o.error.message,timeout:4e3,dataset:{type:"CoreEvent"}});break;case"TorrentParsed":i.show({type:"success",title:"Torrent file parsed",timeout:4e3});break;case"MagnetParsed":i.show({type:"success",title:"Magnet link parsed",timeout:4e3});break;case"PlayingOnDevice":i.show({type:"success",title:"Stream opened in ".concat(o.device),timeout:4e3})}},a=function(e){var t;i.show({type:"error",title:e.message,message:null===(t=e.file)||void 0===t?void 0:t.name,timeout:4e3})};return t.transport.on("CoreEvent",e),o.on("error",a),function(){t.transport.off("CoreEvent",e),o.off("error",a)}}),[]),null}},4008:(e,t,o)=>{var a=o(5677);e.exports=a},9884:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(9872),E=o(8135),_=function(e){var t=e.className,o=e.id,n=e.name,_=e.version,T=e.logo,l=e.description,S=e.types,u=e.transportUrl,d=e.official,c=a.useCallback((function(){return a.createElement(i,{className:E.icon,icon:"ic_addons"})}),[]);return a.createElement("div",{className:r(t,E["addon-details-container"])},a.createElement("div",{className:E["title-container"]},a.createElement(s,{className:E.logo,src:T,alt:" ",renderFallback:c}),a.createElement("div",{className:E["name-container"]},a.createElement("span",{className:E.name},"string"==typeof n&&n.length>0?n:o),"string"==typeof _&&_.length>0?a.createElement("span",{className:E.version},"v. ",_):null)),"string"==typeof l&&l.length>0?a.createElement("div",{className:E["section-container"]},a.createElement("span",{className:E["section-label"]},l)):null,"string"==typeof u&&u.length>0?a.createElement("div",{className:E["section-container"]},a.createElement("span",{className:E["section-header"]},"URL: "),a.createElement("span",{className:r(E["section-label"],E["transport-url-label"])},u)):null,Array.isArray(S)&&S.length>0?a.createElement("div",{className:E["section-container"]},a.createElement("span",{className:E["section-header"]},"Supported types: "),a.createElement("span",{className:E["section-label"]},1===S.length?S[0]:S.slice(0,-1).join(", ")+" & "+S[S.length-1])):null,d?null:a.createElement("div",{className:E["section-container"]},a.createElement("div",{className:r(E["section-label"],E["disclaimer-label"])},"Using third-party add-ons will always be subject to your responsibility and the governing law of the jurisdiction you are located.")))};_.propTypes={className:n.string,id:n.string,name:n.string,version:n.string,logo:n.string,description:n.string,types:n.arrayOf(n.string),transportUrl:n.string,official:n.bool},e.exports=_},5368:(e,t,o)=>{var a=o(5471);e.exports=a},8029:(e,t,o)=>{var a=["remoteAddon","localAddon"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(8253),_=o(6672).withCoreSuspender,T=o(3662).useServices,l=(function(e){var t=function(t){var o=t.remoteAddon,s=t.localAddon,E=r(t,a),_=null!==o&&"Ready"===o.content.type?o.content.content:null!==s?s:null;return null===_?null:i.createElement(e,n({},E,{id:_.manifest.id,name:_.manifest.name,version:_.manifest.version,logo:_.manifest.logo,description:_.manifest.description,types:_.manifest.types,transportUrl:_.transportUrl,official:_.flags.official}))};return t.displayName="withRemoteAndLocalAddon",t})(o(5368)),S=o(9208),u=o(355);var d=function(e){var t=e.transportUrl,o=e.onCloseRequest,a=T().core,n=S(t),r=i.useMemo((function(){var e={className:u["cancel-button"],label:"Cancel",props:{onClick:function(e){"function"==typeof o&&o({type:"cancel",reactEvent:e,nativeEvent:e.nativeEvent})}}},r=null!==n.remoteAddon&&"Ready"===n.remoteAddon.content.type&&n.remoteAddon.content.content.manifest.behaviorHints.configurable?{className:u["configure-button"],label:"Configure",props:{onClick:function(e){window.open(t.replace("manifest.json","configure")),"function"==typeof o&&o({type:"configure",reactEvent:e,nativeEvent:e.nativeEvent})}}}:null,i=null!==n.localAddon?{className:u["uninstall-button"],label:"Uninstall",props:{onClick:function(e){a.transport.dispatch({action:"Ctx",args:{action:"UninstallAddon",args:n.localAddon}}),"function"==typeof o&&o({type:"uninstall",reactEvent:e,nativeEvent:e.nativeEvent})}}}:null!==n.remoteAddon&&"Ready"===n.remoteAddon.content.type?{className:u["install-button"],label:"Install",props:{onClick:function(e){a.transport.dispatch({action:"Ctx",args:{action:"InstallAddon",args:n.remoteAddon.content.content}}),"function"==typeof o&&o({type:"install",reactEvent:e,nativeEvent:e.nativeEvent})}}}:null;return null!==i?r?[e,r,i]:[e,i]:[e]}),[n,o]);return i.createElement(E,{className:u["addon-details-modal-container"],title:"Stremio addon",buttons:r,onCloseRequest:o},null===n.selected?i.createElement("div",{className:u["addon-details-message-container"]},"Loading addon manifest"):null===n.remoteAddon||"Loading"===n.remoteAddon.content.type?i.createElement("div",{className:u["addon-details-message-container"]},"Loading addon manifest from ",n.selected.transportUrl):"Err"===n.remoteAddon.content.type&&null===n.localAddon?i.createElement("div",{className:u["addon-details-message-container"]},"Failed to get addon manifest from ",n.selected.transportUrl,i.createElement("div",null,n.remoteAddon.content.content.message)):i.createElement(l,{className:u["addon-details-container"],remoteAddon:n.remoteAddon,localAddon:n.localAddon}))};d.propTypes={transportUrl:s.string,onCloseRequest:s.func};var c=function(e){var t=e.onCloseRequest;return i.createElement(E,{className:u["addon-details-modal-container"],title:"Stremio addon",onCloseRequest:t},i.createElement("div",{className:u["addon-details-message-container"]},"Loading addon manifest"))};c.propTypes=d.propTypes,e.exports=_(d,c)},8512:(e,t,o)=>{var a=o(8029);e.exports=a},9208:(e,t,o)=>{var a=o(7294),n=o(1535);e.exports=function(e){var t=a.useMemo((function(){return"string"==typeof e?{action:"Load",args:{model:"AddonDetails",args:{transportUrl:e}}}:{action:"Unload"}}),[e]);return n({model:"addon_details",action:t})}},7458:(e,t,o)=>{var a=["className","href","disabled","children"];function n(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function r(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(4520),S=E.forwardRef((function(e,t){var o=e.className,n=e.href,i=e.disabled,_=e.children,S=s(e,a),u=E.useCallback((function(e){"function"==typeof S.onKeyDown&&S.onKeyDown(e),"Enter"!==e.key||e.nativeEvent.buttonClickPrevented||e.currentTarget.click()}),[S.onKeyDown]),d=E.useCallback((function(e){"function"==typeof S.onMouseDown&&S.onMouseDown(e),e.nativeEvent.buttonBlurPrevented||(e.preventDefault(),document.activeElement instanceof HTMLElement&&document.activeElement.blur())}),[S.onMouseDown]);return E.createElement("string"==typeof n&&n.length>0?"a":"div",r(r({tabIndex:0},S),{},{ref:t,className:T(o,l["button-container"],{disabled:i}),href:n,onKeyDown:u,onMouseDown:d}),_)}));S.displayName="Button",S.propTypes={className:_.string,href:_.string,disabled:_.bool,children:_.node,onKeyDown:_.func,onMouseDown:_.func},e.exports=S},6851:(e,t,o)=>{var a=o(7458);e.exports=a},2734:e=>{var t={movie:10,series:9,channel:8,tv:7,music:6,radio:5,podcast:4,game:3,book:2,adult:1,other:-1/0},o=new Map([["movie","ic_movies"],["series","ic_series"],["channel","ic_channels"],["tv","ic_tv"],["book","ic_book"],["game","ic_games"],["music","ic_music"],["adult","ic_adult"],["radio","ic_radio"],["podcast","ic_podcast"],["other","ic_movies"]]);e.exports={CHROMECAST_RECEIVER_APP_ID:"1634F54B",SUBTITLES_SIZES:[75,100,125,150,175,200,250],SUBTITLES_FONTS:["Roboto","Arial","Halvetica","Times New Roman","Verdana","Courier","Lucida Console","sans-serif","serif","monospace"],SEEK_TIME_DURATIONS:[5e3,1e4,15e3,2e4,25e3,3e4],NEXT_VIDEO_POPUP_DURATIONS:[0,5e3,1e4,15e3,2e4,25e3,3e4,35e3,4e4,45e3,5e4],CATALOG_PREVIEW_SIZE:10,CATALOG_PAGE_SIZE:100,NONE_EXTRA_VALUE:"None",SKIP_EXTRA_NAME:"skip",META_LINK_CATEGORY:"meta",IMDB_LINK_CATEGORY:"imdb",SHARE_LINK_CATEGORY:"share",WRITERS_LINK_CATEGORY:"Writers",TYPE_PRIORITIES:t,ICON_FOR_TYPE:o}},3064:(e,t,o)=>{var a=["className","checked","children"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(2601),T=o(6851),l=o(1726),S=i.forwardRef((function(e,t){var o=e.className,s=e.checked,S=e.children,u=r(e,a);return i.createElement(T,n({},u,{ref:t,className:E(o,l["checkbox-container"],{checked:s})}),s?i.createElement("svg",{className:l.icon,viewBox:"0 0 100 100"},i.createElement(_,{x:"10",y:"10",width:"80",height:"80",icon:"ic_check"})):i.createElement(_,{className:l.icon,icon:"ic_box_empty"}),S)}));S.displayName="Checkbox",S.propTypes={className:s.string,checked:s.bool,children:s.node},e.exports=S},9666:(e,t,o)=>{var a=o(3064);e.exports=a},4750:(e,t,o)=>{var a=["className","value","dataset","onChange"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(3746),S=o(1468).useTranslation,u=o(6851),d=o(8253),c=o(4024),I=o(7711),A=o(5461),O=function(e){var t=l.parseColor(e,"hexcss4");return"string"==typeof t?t:"#ffffffff"},N=function(e){var t=e.className,o=e.value,i=e.dataset,_=e.onChange,l=s(e,a),N=S().t,m=r(c(!1),3),R=m[0],p=m[1],h=m[2],f=r(E.useState((function(){return O(o)})),2),L=f[0],C=f[1],D=E.useMemo((function(){return{backgroundColor:o}}),[o]),g=E.useMemo((function(){return O(o).endsWith("00")}),[o]),v=E.useCallback((function(e){"function"==typeof l.onClick&&l.onClick(e),e.nativeEvent.openModalPrevented||p()}),[l.onClick]),y=E.useCallback((function(e){e.nativeEvent.openModalPrevented=!0}),[]),P=E.useMemo((function(){return[{label:"Select",props:{"data-autofocus":!0,onClick:function(e){"function"==typeof _&&_({type:"change",value:L,dataset:i,reactEvent:e,nativeEvent:e.nativeEvent}),h()}}}]}),[L,i,_]),B=E.useCallback((function(e){C(O(e.value))}),[]);return E.useLayoutEffect((function(){C(O(o))}),[o,R]),E.createElement(u,n({title:g?N("BUTTON_COLOR_TRANSPARENT"):o},l,{style:D,className:T(t,A["color-input-container"]),onClick:v}),g?E.createElement("div",{className:A["transparent-label-container"]},E.createElement("div",{className:A["transparent-label"]},N("BUTTON_COLOR_TRANSPARENT"))):null,R?E.createElement(d,{title:"Choose a color:",buttons:P,onCloseRequest:h,onClick:y},E.createElement(I,{className:A["color-picker-container"],value:L,onInput:B})):null)};N.propTypes={className:_.string,value:_.string,dataset:_.object,onChange:_.func,onClick:_.func},e.exports=N},3378:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(3746),s=o(4809),E=function(e){return i.parseColor(e,"hexcss4")},_=function(e){var t=e.className,o=e.value,n=e.onInput,_=a.useRef(null),T=a.useRef(null);return a.useLayoutEffect((function(){_.current=i.createPicker(T.current,{color:E(o),showHSL:!1,showHEX:!1,showRGB:!1,showAlpha:!0});var e=T.current.querySelector(".a-color-picker-clipbaord");e instanceof HTMLElement&&(e.tabIndex=-1)}),[]),a.useLayoutEffect((function(){return"function"==typeof n&&_.current.on("change",(function(e,t){n({type:"input",value:E(t)})})),function(){_.current.off("change")}}),[n]),a.useLayoutEffect((function(){var e=E(o);e!==E(_.current.color)&&(_.current.color=e)}),[o]),a.createElement("div",{ref:T,className:r(t,s["color-picker-container"])})};_.propTypes={className:n.string,value:n.string,onInput:n.func},e.exports=_},7711:(e,t,o)=>{var a=o(3378);e.exports=a},8809:(e,t,o)=>{var a=o(4750);e.exports=a},6672:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o1&&void 0!==arguments[1]?arguments[1]:function(){};return function(o){var n=i().core,T=_(),l=a(r.useState(null===T),2),S=l[0],u=l[1],d=r.useRef({}),c=r.useRef({}),I=r.useCallback((function(e){return d.current[e]||(d.current[e]=E(n.transport.getState(e))),d.current[e].read()}),[]),A=r.useCallback((function(e){return c.current[e]||(c.current[e]=E(n.transport.decodeStream(e))),c.current[e].read()}),[]),O=r.useMemo((function(){return{getState:I,decodeStream:A}}),[]);return r.useLayoutEffect((function(){S||u(!0)}),[]),S?r.createElement(r.Suspense,{fallback:r.createElement(t,o)},r.createElement(s.Provider,{value:O},r.createElement(e,o))):null}},useCoreSuspender:_}},7473:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(7473);e.exports=a},9504:(e,t,o)=>{var a=["className","src","alt","fallbackSrc","renderFallback"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=function(e){var t=e.className,o=e.src,i=e.alt,_=e.fallbackSrc,T=e.renderFallback,l=s(e,a),S=r(E.useState(!1),2),u=S[0],d=S[1],c=E.useCallback((function(e){"function"==typeof l.onError&&l.onError(e),d(!0)}),[l.onError]);return E.useLayoutEffect((function(){d(!1)}),[o]),!u&&"string"==typeof o&&0!==o.length||"function"!=typeof T&&"string"!=typeof _?E.createElement("img",n({},l,{className:t,src:o,alt:i,onError:c})):"function"==typeof T?T():E.createElement("img",n({},l,{className:t,src:_,alt:i}))};T.propTypes={className:_.string,src:_.string,alt:_.string,fallbackSrc:_.string,renderFallback:_.func,onError:_.func},e.exports=T},9872:(e,t,o)=>{var a=o(9504);e.exports=a},859:(e,t,o)=>{var a=["_id","removable"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var _=o(7294),T=o(3662).useServices,l=o(5697),S=o(8277),u=o(6073).t,d=[{label:"LIBRARY_PLAY",value:"play"},{label:"LIBRARY_DETAILS",value:"details"},{label:"LIBRARY_RESUME_DISMISS",value:"dismiss"},{label:"LIBRARY_REMOVE",value:"remove"}],c=function(e){var t=e._id,o=e.removable,r=E(e,a),s=T().core,l=_.useMemo((function(){return d.filter((function(e){switch(e.value){case"play":return r.deepLinks&&"string"==typeof r.deepLinks.player;case"details":return r.deepLinks&&("string"==typeof r.deepLinks.metaDetailsVideos||"string"==typeof r.deepLinks.metaDetailsStreams);case"dismiss":return"string"==typeof t&&null!==r.progress&&!isNaN(r.progress);case"remove":return"string"==typeof t&&o}})).map((function(e){return i(i({},e),{},{label:u(e.label)})}))}),[t,o,r.progress,r.deepLinks]),c=_.useCallback((function(e){if("function"==typeof r.optionOnSelect&&r.optionOnSelect(e),!e.nativeEvent.optionSelectPrevented)switch(e.value){case"play":r.deepLinks&&"string"==typeof r.deepLinks.player&&(window.location=r.deepLinks.player);break;case"details":r.deepLinks&&("string"==typeof r.deepLinks.metaDetailsVideos?window.location=r.deepLinks.metaDetailsVideos:"string"==typeof r.deepLinks.metaDetailsStreams&&(window.location=r.deepLinks.metaDetailsStreams));break;case"dismiss":"string"==typeof t&&s.transport.dispatch({action:"Ctx",args:{action:"RewindLibraryItem",args:t}});break;case"remove":"string"==typeof t&&s.transport.dispatch({action:"Ctx",args:{action:"RemoveFromLibrary",args:t}})}}),[t,r.deepLinks,r.optionOnSelect]);return _.createElement(S,n({},r,{options:l,optionOnSelect:c}))};c.propTypes={_id:l.string,removable:l.bool,progress:l.number,deepLinks:l.shape({metaDetailsVideos:l.string,metaDetailsStreams:l.string,player:l.string}),optionOnSelect:l.func},e.exports=c},5748:(e,t,o)=>{var a=o(859);e.exports=a},3364:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2935),s=i.VerticalNavBar,E=i.HorizontalNavBar,_=o(9684),T=[{id:"board",label:"Board",icon:"ic_board",href:"#/"},{id:"discover",label:"Discover",icon:"ic_discover",href:"#/discover"},{id:"library",label:"Library",icon:"ic_library",href:"#/library"},{id:"settings",label:"SETTINGS",icon:"ic_settings",href:"#/settings"},{id:"addons",label:"ADDONS",icon:"ic_addons",href:"#/addons"}],l=a.memo((function(e){var t=e.className,o=e.route,n=e.query,i=e.children;return a.createElement("div",{className:r(t,_["main-nav-bars-container"])},a.createElement(E,{className:_["horizontal-nav-bar"],route:o,query:n,backButton:!1,searchBar:!0,addonsButton:!0,fullscreenButton:!0,navMenu:!0}),a.createElement(s,{className:_["vertical-nav-bar"],selected:o,tabs:T}),a.createElement("div",{className:_["nav-content-container"]},i))}));l.displayName="MainNavBars",l.propTypes={className:n.string,route:n.string,query:n.string,children:n.node},e.exports=l},1297:(e,t,o)=>{var a=o(3364);e.exports=a},3037:(e,t,o)=>{var a=["className","type","name","poster","posterShape","playIcon","progress","options","deepLinks","dataset","optionOnSelect"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(7280).Z,S=o(2601),u=o(6851),d=o(9872),c=o(3981),I=o(926),A=o(4024),O=o(2734).ICON_FOR_TYPE,N=o(4661),m=E.memo((function(e){var t=e.className,o=e.type,i=e.name,_=e.poster,m=e.posterShape,R=e.playIcon,p=e.progress,h=e.options,f=e.deepLinks,L=e.dataset,C=e.optionOnSelect,D=s(e,a),g=r(A(!1),3),v=g[0],y=g[1],P=g[2],B=E.useMemo((function(){return f?"string"==typeof f.player?f.player:"string"==typeof f.metaDetailsStreams?f.metaDetailsStreams:"string"==typeof f.metaDetailsVideos?f.metaDetailsVideos:null:null}),[f]),b=E.useCallback((function(e){"function"==typeof D.onClick&&D.onClick(e),e.nativeEvent.selectPrevented&&e.preventDefault()}),[D.onClick]),M=E.useCallback((function(e){e.nativeEvent.selectPrevented=!0}),[]),U=E.useCallback((function(e){"function"==typeof C&&C({type:"select-option",value:e.value,dataset:L,reactEvent:e.reactEvent,nativeEvent:e.nativeEvent})}),[L,C]),W=E.useCallback((function(){return E.createElement(S,{className:N["placeholder-icon"],icon:O.has(o)?O.get(o):O.get("other")})}),[o]),G=E.useCallback((function(){return E.createElement(S,{className:N.icon,icon:"ic_more"})}),[]);return E.createElement(u,n({title:i,href:B},l(D),{className:T(t,N["meta-item-container"],N["poster-shape-poster"],N["poster-shape-".concat(m)],{active:v}),onClick:b}),E.createElement("div",{className:N["poster-container"]},E.createElement("div",{className:N["poster-image-layer"]},E.createElement(d,{className:N["poster-image"],src:_,alt:" ",renderFallback:W})),R?E.createElement("div",{className:N["play-icon-layer"]},E.createElement(I,{className:N["play-icon"]})):null,p>0?E.createElement("div",{className:N["progress-bar-layer"]},E.createElement("div",{className:N["progress-bar"],style:{width:"".concat(100*Math.max(0,Math.min(1,p)),"%")}})):null),"string"==typeof i&&i.length>0||Array.isArray(h)&&h.length>0?E.createElement("div",{className:N["title-bar-container"]},E.createElement("div",{className:N["title-label"]},"string"==typeof i&&i.length>0?i:""),Array.isArray(h)&&h.length>0?E.createElement(c,{className:N["menu-label-container"],renderLabelContent:G,options:h,onOpen:y,onClose:P,onSelect:U,tabIndex:-1,onClick:M}):null):null)}));m.displayName="MetaItem",m.propTypes={className:_.string,type:_.string,name:_.string,poster:_.string,posterShape:_.oneOf(["poster","landscape","square"]),playIcon:_.bool,progress:_.number,options:_.array,deepLinks:_.shape({metaDetailsVideos:_.string,metaDetailsStreams:_.string,player:_.string}),dataset:_.object,optionOnSelect:_.func,onClick:_.func},e.exports=m},8277:(e,t,o)=>{var a=o(3037);e.exports=a},4902:(e,t,o)=>{var a=["className","icon","label"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(2601),T=o(6851),l=o(5883),S=function(e){var t=e.className,o=e.icon,s=e.label,S=r(e,a);return i.createElement(T,n({title:s},S,{className:E(t,l["action-button-container"])}),"string"==typeof o&&o.length>0?i.createElement("div",{className:l["icon-container"]},i.createElement(_,{className:l.icon,icon:o})):null,"string"==typeof s&&s.length>0?i.createElement("div",{className:l["label-container"]},i.createElement("div",{className:l.label},s)):null)};S.propTypes={className:s.string,icon:s.string,label:s.string},e.exports=S},217:(e,t,o)=>{var a=o(4902);e.exports=a},8049:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(6851),E=o(7621),_=function(e){var t=e.className,o=e.label,n=e.links,_=i().t;return a.createElement("div",{className:r(t,E["meta-links-container"])},"string"==typeof o&&o.length>0?a.createElement("div",{className:E["label-container"]},_("LINKS_".concat(o.toUpperCase()))):null,Array.isArray(n)&&n.length>0?a.createElement("div",{className:E["links-container"]},n.map((function(e,t){var o=e.label,n=e.href;return a.createElement(s,{key:t,className:E["link-container"],title:o,href:n},_(o))}))):null)};_.propTypes={className:n.string,label:n.string,links:n.arrayOf(n.shape({label:n.string,href:n.string}))},e.exports=_},7818:(e,t,o)=>{var a=o(8049);e.exports=a},6314:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o0&&(e.has(o)||e.set(o,[]),e.get(o).push({label:a,href:"https://www.stremio.com/warning#".concat(encodeURIComponent(n))})),e}),new Map):new Map}),[P]),H=i.useMemo((function(){return y?"string"==typeof y.player?y.player:"string"==typeof y.metaDetailsStreams?y.metaDetailsStreams:"string"==typeof y.metaDetailsVideos?y.metaDetailsVideos:null:null}),[y]),V=i.useMemo((function(){return Array.isArray(B)&&0!==B.length?B[0].deepLinks.player:null}),[B]),Y=i.useCallback((function(){return i.createElement("div",{className:p["logo-placeholder"]},A?null:R)}),[A,R]);return i.createElement("div",{className:E(s,p["meta-preview-container"],(t={},o=p.compact,r=A,o in t?Object.defineProperty(t,o,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[o]=r,t))},"string"==typeof L&&L.length>0?i.createElement("div",{className:p["background-image-layer"]},i.createElement(u,{className:p["background-image"],src:L,alt:" "})):null,i.createElement("div",{className:p["meta-info-container"]},"string"==typeof f&&f.length>0?i.createElement(u,{className:p.logo,src:f,alt:" ",title:R,renderFallback:Y}):Y(),"string"==typeof D&&D.length>0||g instanceof Date&&!isNaN(g.getTime())||"string"==typeof C&&C.length>0||w.has(I.IMDB_LINK_CATEGORY)?i.createElement("div",{className:p["runtime-release-info-container"]},"string"==typeof C&&C.length>0?i.createElement("div",{className:p["runtime-label"]},C):null,"string"==typeof D&&D.length>0?i.createElement("div",{className:p["release-info-label"]},D):g instanceof Date&&!isNaN(g.getTime())?i.createElement("div",{className:p["release-info-label"]},g.getFullYear()):null,w.has(I.IMDB_LINK_CATEGORY)?i.createElement(S,a({className:p["imdb-button-container"],title:w.get(I.IMDB_LINK_CATEGORY).label,href:w.get(I.IMDB_LINK_CATEGORY).href,target:"_blank"},A?{tabIndex:-1}:null),i.createElement(l,{className:p.icon,icon:"ic_imdbnoframe"}),i.createElement("div",{className:p.label},w.get(I.IMDB_LINK_CATEGORY).label)):null):null,A&&"string"==typeof R&&R.length>0?i.createElement("div",{className:p["name-container"]},R):null,A&&"string"==typeof v&&v.length>0?i.createElement("div",{className:p["description-container"]},v):null,Array.from(w.keys()).filter((function(e){return e!==I.IMDB_LINK_CATEGORY&&e!==I.SHARE_LINK_CATEGORY&&e!==I.WRITERS_LINK_CATEGORY})).map((function(e,t){return i.createElement(m,{key:t,className:p["meta-links"],label:e,links:w.get(e)})}))),i.createElement("div",{className:p["action-buttons-container"]},"function"==typeof M?i.createElement(N,{className:p["action-button"],icon:b?"ic_removelib":"ic_addlib",label:U(b?"REMOVE_FROM_LIB":"ADD_TO_LIB"),tabIndex:A?-1:0,onClick:M}):null,"string"==typeof V?i.createElement(N,{className:p["action-button"],icon:"ic_movies",label:U("TRAILER"),tabIndex:A?-1:0,href:V}):null,"string"==typeof H&&A?i.createElement(N,{className:p["action-button"],icon:"ic_play",label:U("SHOW"),tabIndex:A?-1:0,href:H}):null,w.has(I.SHARE_LINK_CATEGORY)&&!A?i.createElement(i.Fragment,null,i.createElement(N,{className:p["action-button"],icon:"ic_share",label:U("CTX_SHARE"),tabIndex:A?-1:0,onClick:F}),G?i.createElement(d,{title:U("CTX_SHARE"),onCloseRequest:k},i.createElement(c,{className:p["share-prompt"],url:w.get(I.SHARE_LINK_CATEGORY).href})):null):null))};f.Placeholder=R,f.propTypes={className:s.string,compact:s.bool,name:s.string,logo:s.string,background:s.string,runtime:s.string,releaseInfo:s.string,released:s.instanceOf(Date),description:s.string,deepLinks:s.shape({metaDetailsVideos:s.string,metaDetailsStreams:s.string,player:s.string}),links:s.arrayOf(s.shape({category:s.string,name:s.string,url:s.string})),trailerStreams:s.array,inLibrary:s.bool,toggleInLibrary:s.func},e.exports=f},2641:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(6506),s=function(e){var t=e.className;return a.createElement("div",{className:r(t,i["meta-preview-placeholder-container"])},a.createElement("div",{className:i["meta-info-container"]},a.createElement("div",{className:i["logo-container"]}),a.createElement("div",{className:i["duration-release-info-container"]},a.createElement("div",{className:i["duration-container"]}),a.createElement("div",{className:i["release-info-container"]})),a.createElement("div",{className:i["description-container"]},a.createElement("div",{className:i["description-label-container"]}),a.createElement("div",{className:i["description-label-container"]})),a.createElement("div",{className:i["genres-container"]},a.createElement("div",{className:i["genres-header-container"]}),a.createElement("div",{className:i["genre-label-container"]})),a.createElement("div",{className:i["genres-container"]},a.createElement("div",{className:i["genres-header-container"]}),a.createElement("div",{className:i["genre-label-container"]}))),a.createElement("div",{className:i["action-buttons-container"]},a.createElement("div",{className:i["action-button-container"]},a.createElement("div",{className:i["action-button-icon"]}),a.createElement("div",{className:i["action-button-label"]})),a.createElement("div",{className:i["action-button-container"]},a.createElement("div",{className:i["action-button-icon"]}),a.createElement("div",{className:i["action-button-label"]})),a.createElement("div",{className:i["action-button-container"]},a.createElement("div",{className:i["action-button-icon"]}),a.createElement("div",{className:i["action-button-label"]}))))};s.propTypes={className:n.string},e.exports=s},4322:(e,t,o)=>{var a=o(2641);e.exports=a},3070:(e,t,o)=>{var a=o(6314);e.exports=a},8370:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t0||d&&("string"==typeof d.discover||"string"==typeof d.library)?i.createElement("div",{className:c["header-container"]},"string"==typeof o&&o.length>0?i.createElement("div",{className:c["title-container"],title:o},o):null,!d||"string"!=typeof d.discover&&"string"!=typeof d.library?null:i.createElement(S,{className:c["see-all-container"],title:I("BUTTON_SEE_ALL"),href:d.discover||d.library,tabIndex:-1},i.createElement("div",{className:c.label},I("BUTTON_SEE_ALL")),i.createElement(l,{className:c.icon,icon:"ic_arrow_thin_right"}))):null,"string"==typeof a&&a.length>0?i.createElement("div",{className:c["message-container"],title:a},a):i.createElement("div",{className:c["meta-items-container"]},s.isValidElementType(E)?r.slice(0,u.CATALOG_PREVIEW_SIZE).map((function(e,t){return i.createElement(E,n(n({},e),{},{key:t,className:_(c["meta-item"],c["poster-shape-poster"],c["poster-shape-".concat(e.posterShape)])}))})):null,Array(Math.max(0,u.CATALOG_PREVIEW_SIZE-r.length)).fill(null).map((function(e,t){return i.createElement("div",{key:t,className:_(c["meta-item"],c["poster-shape-poster"])})}))))};I.Placeholder=d,I.propTypes={className:E.string,title:E.string,message:E.string,items:E.arrayOf(E.shape({posterShape:E.string})),itemComponent:E.elementType,deepLinks:E.shape({discover:E.string,library:E.string})},e.exports=I},2268:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(2601),E=o(6851),_=o(2734),T=o(7841),l=function(e){var t=e.className,o=e.title,n=e.deepLinks,l=i().t;return a.createElement("div",{className:r(t,T["meta-row-placeholder-container"])},a.createElement("div",{className:T["header-container"]},a.createElement("div",{className:T["title-container"],title:"string"==typeof o&&o.length>0?o:null},"string"==typeof o&&o.length>0?o:null),n&&"string"==typeof n.discover?a.createElement(E,{className:T["see-all-container"],title:l("BUTTON_SEE_ALL"),href:n.discover,tabIndex:-1},a.createElement("div",{className:T.label},l("BUTTON_SEE_ALL")),a.createElement(s,{className:T.icon,icon:"ic_arrow_thin_right"})):null),a.createElement("div",{className:T["meta-items-container"]},Array(_.CATALOG_PREVIEW_SIZE).fill(null).map((function(e,t){return a.createElement("div",{key:t,className:T["meta-item"]},a.createElement("div",{className:T["poster-container"]}),a.createElement("div",{className:T["title-bar-container"]},a.createElement("div",{className:T["title-label"]})))}))))};l.propTypes={className:n.string,title:n.string,deepLinks:n.shape({discover:n.string})},e.exports=l},411:(e,t,o)=>{var a=o(2268);e.exports=a},9321:(e,t,o)=>{var a=o(8370);e.exports=a},8787:(e,t,o)=>{var a=["className","title","buttons","children","dataset","onCloseRequest"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(1665),T=_.useRouteFocused,l=_.useModalsContainer,S=o(6851),u=o(2601),d=o(1665).Modal,c=o(1621),I=function(e){var t=e.className,o=e.title,s=e.buttons,_=e.children,I=e.dataset,A=e.onCloseRequest,O=r(e,a),N=T(),m=l(),R=i.useRef(null),p=i.useCallback((function(e){"function"==typeof A&&A({type:"close",dataset:I,reactEvent:e,nativeEvent:e.nativeEvent})}),[I,A]),h=i.useCallback((function(e){e.nativeEvent.closeModalDialogPrevented||"function"!=typeof A||A({type:"close",dataset:I,reactEvent:e,nativeEvent:e.nativeEvent})}),[I,A]),f=i.useCallback((function(e){e.nativeEvent.closeModalDialogPrevented=!0}),[]);return i.useEffect((function(){var e=function(e){"Escape"===e.code&&m.childNodes[m.childElementCount-2]===R.current&&"function"==typeof A&&A({type:"close",dataset:I,nativeEvent:e})};return N&&window.addEventListener("keydown",e),function(){window.removeEventListener("keydown",e)}}),[N,I,A]),i.createElement(d,n({ref:R},O,{className:E(t,c["modal-container"]),onMouseDown:h}),i.createElement("div",{className:c["modal-dialog-container"],onMouseDown:f},i.createElement(S,{className:c["close-button-container"],title:"Close",onClick:p},i.createElement(u,{className:c.icon,icon:"ic_x"})),"string"==typeof o&&o.length>0?i.createElement("div",{className:c["title-container"],title:o},o):null,i.createElement("div",{className:c["modal-dialog-content"]},_),Array.isArray(s)&&s.length>0?i.createElement("div",{className:c["buttons-container"]},s.map((function(e,t){var o=e.className,a=e.label,r=e.icon,s=e.props;return i.createElement(S,n({title:a},s,{key:t,className:E(o,c["action-button"])}),"string"==typeof r&&r.length>0?i.createElement(u,{className:c.icon,icon:r}):null,"string"==typeof a&&a.length>0?i.createElement("div",{className:c.label},a):null)}))):null))};I.propTypes={className:s.string,title:s.string,buttons:s.arrayOf(s.shape({className:s.string,label:s.string,icon:s.string,props:s.object})),children:s.oneOfType([s.arrayOf(s.node),s.node]),dataset:s.object,onCloseRequest:s.func},e.exports=I},8253:(e,t,o)=>{var a=o(8787);e.exports=a},2035:(e,t,o)=>{var a=["className","mode","direction","title","disabled","dataset","renderLabelContent","renderLabelText","onOpen","onClose","onSelect"],n=["children","className"];function r(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function i(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var S=o(7294),u=o(5697),d=o(4184),c=o(2601),I=o(6851),A=o(9418),O=o(8253),N=o(4024),m=o(7409),R=function(e){var t=e.className,o=e.mode,r=e.direction,s=e.title,T=e.disabled,u=e.dataset,R=e.renderLabelContent,p=e.renderLabelText,h=e.onOpen,f=e.onClose,L=e.onSelect,C=l(e,a),D=_(N(!1),4),g=D[0],v=D[2],y=D[3],P=S.useMemo((function(){return Array.isArray(C.options)?C.options.filter((function(e){return e&&"string"==typeof e.value})):[]}),[C.options]),B=S.useMemo((function(){return Array.isArray(C.selected)?C.selected.filter((function(e){return"string"==typeof e})):[]}),[C.selected]),b=S.useCallback((function(e){"function"==typeof C.onClick&&C.onClick(e),e.nativeEvent.toggleMenuPrevented||y()}),[C.onClick,y]),M=S.useCallback((function(e){e.nativeEvent.toggleMenuPrevented=!0}),[]),U=S.useCallback((function(e){e.nativeEvent.buttonClickPrevented=!0}),[]),W=S.useCallback((function(e){"function"==typeof L&&L({type:"select",value:e.currentTarget.dataset.value,reactEvent:e,nativeEvent:e.nativeEvent,dataset:u}),e.nativeEvent.closeMenuPrevented||v()}),[u,L]),G=S.useRef(!1);S.useLayoutEffect((function(){G.current&&(g?"function"==typeof h&&h({type:"open",dataset:u}):"function"==typeof f&&f({type:"close",dataset:u})),G.current=!0}),[g]);var F=S.useCallback((function(e){var t=e.children,o=e.className,a=l(e,n);return S.createElement(I,E({},a,{className:d(o,m["label-container"],{active:g}),title:s,disabled:T,onClick:b}),"function"==typeof R?R():S.createElement(S.Fragment,null,S.createElement("div",{className:m.label},"function"==typeof p?p():B.length>0?B.map((function(e){var t=P.find((function(t){return t.value===e}));return t&&"string"==typeof t.label?t.label:e})).join(", "):s),S.createElement(c,{className:m.icon,icon:"ic_arrow_thin_down"})),t)}),[g,s,T,P,B,b,R,p]),k=S.useCallback((function(){return S.createElement("div",{className:m["menu-container"],onKeyDown:U,onClick:M},P.length>0?P.map((function(e){var t=e.label,o=e.title,a=e.value;return S.createElement(I,{key:a,className:d(m["option-container"],{selected:B.includes(a)}),title:"string"==typeof o?o:"string"==typeof t?t:a,"data-value":a,onClick:W},S.createElement("div",{className:m.label},"string"==typeof t?t:a),S.createElement("div",{className:m.icon}))})):S.createElement("div",{className:m["no-options-container"]},S.createElement("div",{className:m.label},"No options available")))}),[P,B,U,M,W]),w=S.useMemo((function(){return function(e){return F(i(i(i({},e),C),{},{className:d(t,e.className)}))}}),[C,t,F]);return"modal"===o?F(i(i({},C),{},{className:t,children:g?S.createElement(O,{className:m["modal-container"],title:s,onCloseRequest:v,onKeyDown:U,onClick:M},k()):null})):S.createElement(A,{open:g,direction:r,onCloseRequest:v,renderLabel:w,renderMenu:k})};R.propTypes={className:u.string,mode:u.oneOf(["popup","modal"]),direction:u.any,title:u.string,options:u.arrayOf(u.shape({value:u.string.isRequired,title:u.string,label:u.string})),selected:u.arrayOf(u.string),disabled:u.bool,dataset:u.object,renderLabelContent:u.func,renderLabelText:u.func,onOpen:u.func,onClose:u.func,onSelect:u.func,onClick:u.func},e.exports=R},3981:(e,t,o)=>{var a=o(2035);e.exports=a},6934:(e,t,o)=>{var a=["className","route","query","title","backButton","searchBar","addonsButton","fullscreenButton","navMenu"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(2601),S=o(6851),u=o(9872),d=o(8489),c=o(5430),I=o(923),A=o(4887),O=o(6073).t,N=E.memo((function(e){var t=e.className,i=e.route,_=e.query,N=e.title,m=e.backButton,R=e.searchBar,p=e.addonsButton,h=e.fullscreenButton,f=e.navMenu,L=s(e,a),C=E.useCallback((function(){window.history.back()}),[]),D=r(d(),3),g=D[0],v=D[1],y=D[2],P=E.useCallback((function(e){var t=e.ref,o=e.className,a=e.onClick,n=e.children;return E.createElement(S,{ref:t,className:T(o,A["button-container"],A["menu-button-container"]),tabIndex:-1,onClick:a},E.createElement(l,{className:A.icon,icon:"ic_more"}),n)}),[]);return E.createElement("nav",n({},L,{className:T(t,A["horizontal-nav-bar-container"])}),m?E.createElement(S,{className:T(A["button-container"],A["back-button-container"]),tabIndex:-1,onClick:C},E.createElement(l,{className:A.icon,icon:"ic_back_ios"})):E.createElement("div",{className:A["logo-container"]},E.createElement(u,{className:A.logo,src:o(5313),alt:" "})),"string"==typeof N&&N.length>0?E.createElement("h2",{className:A.title},N):null,E.createElement("div",{className:A.spacing}),R?E.createElement(c,{className:A["search-bar"],query:_,active:"search"===i}):null,E.createElement("div",{className:A.spacing}),p?E.createElement(S,{className:A["button-container"],href:"#/addons",title:O("ADDONS"),tabIndex:-1},E.createElement(l,{className:A.icon,icon:"ic_addons"})):null,h?E.createElement(S,{className:A["button-container"],title:O(g?"EXIT_FULLSCREEN":"ENTER_FULLSCREEN"),tabIndex:-1,onClick:g?y:v},E.createElement(l,{className:A.icon,icon:g?"ic_exit_fullscreen":"ic_fullscreen"})):null,f?E.createElement(I,{renderLabel:P}):null)}));N.displayName="HorizontalNavBar",N.propTypes={className:_.string,route:_.string,query:_.string,title:_.string,backButton:_.bool,searchBar:_.bool,addonsButton:_.bool,fullscreenButton:_.bool,navMenu:_.bool},e.exports=N},1229:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{function a(e,t,o,a,n,r,i){try{var s=e[r](i),E=s.value}catch(e){return void o(e)}s.done?t(E):Promise.resolve(E).then(a,n)}function n(e){return function(){var t=this,o=arguments;return new Promise((function(n,r){var i=e.apply(t,o);function s(e){a(i,n,r,s,E,"next",e)}function E(e){a(i,n,r,s,E,"throw",e)}s(void 0)}))}}function r(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return i(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return i(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(1229);e.exports=a},3833:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(2601),E=o(1665).useRouteFocused,_=o(6851),T=o(6230),l=o(1657),S=o(6672).withCoreSuspender,u=o(7551),d=function(e){var t=e.className,o=e.query,n=e.active,S=i().t,d=E(),c=l().createTorrentFromMagnet,I=a.useRef(null),A=a.useCallback((function(){n||(window.location="#/search")}),[n]),O=a.useCallback((function(){try{c(I.current.value)}catch(e){}}),[]),N=a.useCallback((function(){if(null!==I.current){var e=new URLSearchParams([["search",I.current.value]]);window.location="#/search?".concat(e.toString())}}),[]);return a.useEffect((function(){d&&n&&I.current.focus()}),[d,n,o]),a.createElement("label",{className:r(t,u["search-bar-container"],{active:n}),onClick:A},n?a.createElement(T,{key:o,ref:I,className:u["search-input"],type:"text",placeholder:S("SEARCH_OR_PASTE_LINK"),defaultValue:o,tabIndex:-1,onChange:O,onSubmit:N}):a.createElement("div",{className:u["search-input"]},a.createElement("div",{className:u["placeholder-label"]},S("SEARCH_OR_PASTE_LINK"))),a.createElement(_,{className:u["submit-button-container"],tabIndex:-1,onClick:N},a.createElement(s,{className:u.icon,icon:"ic_search_link"})))};d.propTypes={className:n.string,query:n.string,active:n.bool};var c=function(e){var t=e.className,o=i().t;return a.createElement("label",{className:r(t,u["search-bar-container"])},a.createElement("div",{className:u["search-input"]},a.createElement("div",{className:u["placeholder-label"]},o("SEARCH_OR_PASTE_LINK"))),a.createElement(_,{className:u["submit-button-container"],tabIndex:-1},a.createElement(s,{className:u.icon,icon:"ic_search_link"})))};c.propTypes=d.propTypes,e.exports=S(d,c)},5430:(e,t,o)=>{var a=o(3833);e.exports=a},1871:(e,t,o)=>{var a=o(6934);e.exports=a},2878:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(6851),E=o(9872),_=o(9842),T=function(e){var t=e.className,o=e.logo,n=e.icon,T=e.label,l=e.href,S=e.selected,u=e.onClick,d=a.useCallback((function(){return"string"==typeof n&&n.length>0?a.createElement(i,{className:_.icon,icon:n}):null}),[n]);return a.createElement(s,{className:r(t,_["nav-tab-button-container"],{selected:S}),title:T,tabIndex:-1,href:l,onClick:u},"string"==typeof o&&o.length>0?a.createElement(E,{className:_.logo,src:o,alt:" ",renderFallback:d}):"string"==typeof n&&n.length>0?a.createElement(i,{className:_.icon,icon:n}):null,"string"==typeof T&&T.length>0?a.createElement("div",{className:_.label},T):null)};T.propTypes={className:n.string,logo:n.string,icon:n.string,label:n.string,href:n.string,selected:n.bool,onClick:n.func},e.exports=T},3908:(e,t,o)=>{var a=o(2878);e.exports=a},6063:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(3908),E=o(7636),_=a.memo((function(e){var t=e.className,o=e.selected,n=e.tabs,_=i().t;return a.createElement("nav",{className:r(t,E["vertical-nav-bar-container"])},Array.isArray(n)?n.map((function(e,t){return a.createElement(s,{key:t,className:E["nav-tab-button"],selected:e.id===o,href:e.href,logo:e.logo,icon:e.icon,label:_(e.label),onClick:e.onClick})})):null)}));_.displayName="VerticalNavBar",_.propTypes={className:n.string,selected:n.string,tabs:n.arrayOf(n.shape({id:n.string,label:n.string,logo:n.string,icon:n.string,href:n.string,onClick:n.func}))},e.exports=_},9798:(e,t,o)=>{var a=o(6063);e.exports=a},2935:(e,t,o)=>{var a=o(1871),n=o(9798);e.exports={HorizontalNavBar:a,VerticalNavBar:n}},8417:(e,t,o)=>{var a=["className","label","dataset","onSelect"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(2601),T=o(6851),l=o(2168),S=function(e){var t=e.className,o=e.label,s=e.dataset,S=e.onSelect,u=r(e,a),d=i.useCallback((function(e){"function"==typeof S&&S({type:"change-page",value:e.currentTarget.dataset.value,dataset:s,reactEvent:e,nativeEvent:e.nativeEvent})}),[s,S]);return i.createElement("div",n({},u,{className:E(t,l["pagination-input-container"])}),i.createElement(T,{className:l["prev-button-container"],title:"Previous page","data-value":"prev",onClick:d},i.createElement(_,{className:l.icon,icon:"ic_arrow_left"})),i.createElement("div",{className:l["label-container"],title:o},i.createElement("div",{className:l.label},o)),i.createElement(T,{className:l["next-button-container"],title:"Next page","data-value":"next",onClick:d},i.createElement(_,{className:l.icon,icon:"ic_arrow_right"})))};S.propTypes={className:s.string,label:s.string,dataset:s.object,onSelect:s.func},e.exports=S},2391:(e,t,o)=>{var a=o(8417);e.exports=a},7206:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(9192),i=function(e){var t=e.className;return a.createElement("svg",{className:t,viewBox:"0 0 100 100"},a.createElement("circle",{className:r.background,cx:"50",cy:"50",r:"50"}),a.createElement("svg",{className:r.icon,x:"0",y:"25",width:"100",height:"50",viewBox:"0 0 37.14 32"},a.createElement("path",{d:"M 9.14,0 37.14,16 9.14,32 Z"})))};i.propTypes={className:n.string},e.exports=i},926:(e,t,o)=>{var a=o(7206);e.exports=a},1804:(e,t,o)=>{var a=["open","direction","renderLabel","renderMenu","dataset","onCloseRequest"];function n(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function r(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var T=o(7294),l=o(5697),S=o(4184),u=o(6413).ZP,d=o(1665).useRouteFocused,c=o(194),I=function e(t){if(t===document.documentElement)return t;var o=window.getComputedStyle(t);return-1!==o.overflowY.indexOf("auto")||-1!==o.overflowY.indexOf("scroll")?t:e(t.parentElement)},A=function(e){var t=e.open,o=e.direction,n=e.renderLabel,E=e.renderMenu,l=e.dataset,A=e.onCloseRequest,O=_(e,a),N=d(),m=T.useRef(null),R=T.useRef(null),p=s(T.useState(null),2),h=p[0],f=p[1],L=T.useCallback((function(e){e.nativeEvent.closePopupPrevented=!0}),[]);return T.useEffect((function(){var e=function(e){if(!e.closePopupPrevented&&"function"==typeof A){var t={type:"close",nativeEvent:e,dataset:l};switch(e.type){case"keydown":"Escape"===e.code&&A(t);break;case"mousedown":e.target===document.documentElement||m.current.contains(e.target)||A(t)}}};return N&&t&&(window.addEventListener("keydown",e),window.addEventListener("mousedown",e)),function(){window.removeEventListener("keydown",e),window.removeEventListener("mousedown",e)}}),[N,t,A,l]),T.useLayoutEffect((function(){if(t){var e=[],o=I(m.current).getBoundingClientRect(),a=m.current.getBoundingClientRect(),n=R.current.getBoundingClientRect(),r={left:a.left-o.left,top:a.top-o.top,right:o.width+o.left-(a.left+a.width),bottom:o.height+o.top-(a.top+a.height)};n.height<=r.bottom?e.push("bottom"):n.height<=r.top?e.push("top"):r.bottom>=r.top?e.push("bottom"):e.push("top"),n.width<=r.right+a.width?e.push("right"):n.width<=r.left+a.width?e.push("left"):r.right>r.left?e.push("right"):e.push("left"),f(e.join("-"))}else f(null)}),[t]),n(r(r({},O),{},{ref:m,className:S(c["label-container"],O.className,{active:t}),children:t?T.createElement(u,{ref:R,className:S(c["menu-container"],i({},c["menu-direction-".concat(h)],!o),i({},c["menu-direction-".concat(o)],o)),autoFocus:!1,lockProps:{onMouseDown:L}},E()):null}))};A.propTypes={open:l.bool,direction:l.oneOf(["top-left","bottom-left","top-right","bottom-right"]),renderLabel:l.func.isRequired,renderMenu:l.func.isRequired,dataset:l.object,onCloseRequest:l.func},e.exports=A},9418:(e,t,o)=>{var a=o(1804);e.exports=a},6182:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(6230),E=o(4830),_=o(330),T=function(e){var t=e.className,o=e.title,n=e.value,E=e.onChange;return a.createElement("label",{title:o,className:r(t,_["search-bar-container"])},a.createElement(s,{className:_["search-input"],type:"text",placeholder:o,value:n,onChange:E}),a.createElement(i,{className:_.icon,icon:"ic_search"}))};T.Placeholder=E,T.propTypes={className:n.string,title:n.string,value:n.string,onChange:n.func},e.exports=T},3994:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(3109),E=function(e){var t=e.className,o=e.title;return a.createElement("div",{className:r(t,s["search-bar-container"])},a.createElement("div",{className:s["search-input"]},o),a.createElement(i,{className:s.icon,icon:"ic_search"}))};E.propTypes={className:n.string,title:n.string},e.exports=E},4830:(e,t,o)=>{var a=o(3994);e.exports=a},6798:(e,t,o)=>{var a=o(6182);e.exports=a},5005:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(2601),E=o(1665).useRouteFocused,_=o(3662).useServices,T=o(6851),l=o(6230),S=o(4530),u=function(e){var t=e.className,o=e.url,n=i().t,u=_().core,d=a.useRef(null),c=E(),I=a.useCallback((function(){null!==d.current&&d.current.select()}),[]),A=a.useCallback((function(){null!==d.current&&(d.current.select(),document.execCommand("copy"))}),[]);return a.useEffect((function(){c&&null!==d.current&&d.current.select()}),[c]),a.useEffect((function(){u.transport.analytics({event:"Share",args:{url:o}})}),[o]),a.createElement("div",{className:r(t,S["share-prompt-container"])},a.createElement("div",{className:S["buttons-container"]},a.createElement(T,{className:r(S["button-container"],S["facebook-button"]),title:"Facebook",href:"https://www.facebook.com/sharer/sharer.php?u=".concat(o),target:"_blank"},a.createElement(s,{className:S.icon,icon:"ic_facebook"}),a.createElement("div",{className:S.label},"Facebook")),a.createElement(T,{className:r(S["button-container"],S["twitter-button"]),title:"Twitter",href:"https://twitter.com/home?status=".concat(o),target:"_blank"},a.createElement(s,{className:S.icon,icon:"ic_twitter"}),a.createElement("div",{className:S.label},"Twitter"))),a.createElement("div",{className:S["url-container"]},a.createElement(l,{ref:d,className:S["url-text-input"],type:"text",readOnly:!0,defaultValue:o,onClick:I,tabIndex:-1}),a.createElement(T,{className:S["copy-button"],title:"Copy to clipboard",onClick:A},a.createElement(s,{className:S.icon,icon:"ic_link"}),a.createElement("div",{className:S.label},n("COPY")))))};u.propTypes={className:n.string,url:n.string},e.exports=u},9393:(e,t,o)=>{var a=o(5005);e.exports=a},4068:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(4068);e.exports=a},9009:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;tDate.now()?null:i.createElement("div",{className:_(t,d["warning-container"])},i.createElement("div",{className:d["warning-statement"]},o("SETTINGS_SERVER_UNAVAILABLE")),i.createElement(l,{className:d["warning-button"],title:o("WARNING_STREAMING_SERVER_LATER"),onClick:E,tabIndex:-1},i.createElement("div",{className:d["warning-label"]},o("WARNING_STREAMING_SERVER_LATER"))),i.createElement(l,{className:d["warning-button"],title:o("WARNING_STREAMING_SERVER_DISMISS"),onClick:u,tabIndex:-1},i.createElement("div",{className:d["warning-label"]},o("WARNING_STREAMING_SERVER_DISMISS"))))};c.propTypes={className:E.string},e.exports=u(c)},861:(e,t,o)=>{var a=o(9009);e.exports=a},1007:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;t{var a=o(1007);e.exports=a},6049:(e,t,o)=>{var a=o(7294).createContext({show:function(){},clear:function(){}});a.displayName="ToastContext",e.exports=a},3345:(e,t,o)=>{var a=["title","message","dataset","onSelect","onClose"];function n(e,t){if(null==e)return{};var o,a,n=(function(e,t){if(null==e)return{};var o,a,n={},r=Object.keys(e);for(a=0;a=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var r=o(7294),i=o(5697),s=o(4184),E=o(2601),_=o(6851),T=o(9775),l=function(e){var t=e.title,o=e.message,i=e.dataset,l=e.onSelect,S=e.onClose,u=n(e,a),d=r.useMemo((function(){return["success","alert","error"].includes(u.type)?u.type:"success"}),[u.type]),c=r.useMemo((function(){return"string"==typeof u.icon?u.icon:"success"===d?"ic_check":"error"===d?"ic_warning":null}),[d,u.icon]),I=r.useCallback((function(e){e.nativeEvent.selectToastPrevented||"function"!=typeof l||l({type:"select",dataset:i,reactEvent:e,nativeEvent:e.nativeEvent}),e.nativeEvent.closeToastPrevented||"function"!=typeof S||S({type:"close",dataset:i,reactEvent:e,nativeEvent:e.nativeEvent})}),[i,l,S]),A=r.useCallback((function(e){e.nativeEvent.selectToastPrevented=!0,"function"==typeof S&&S({type:"close",dataset:i,reactEvent:e,nativeEvent:e.nativeEvent})}),[i,S]);return r.createElement(_,{className:s(T["toast-item-container"],T[d]),tabIndex:-1,onClick:I},"string"==typeof c&&c.length>0?r.createElement("div",{className:T["icon-container"]},r.createElement(E,{className:T.icon,icon:c})):null,r.createElement("div",{className:T["info-container"]},"string"==typeof t&&t.length>0?r.createElement("div",{className:T["title-container"]},t):null,"string"==typeof o&&o.length>0?r.createElement("div",{className:T["message-container"]},o):null),r.createElement(_,{className:T["close-button-container"],title:"Close",tabIndex:-1,onClick:A},r.createElement(E,{className:T.icon,icon:"ic_x"})))};l.propTypes={type:i.oneOf(["success","alert","error"]),title:i.string,message:i.string,icon:i.string,dataset:i.object,onSelect:i.func,onClose:i.func},e.exports=l},5008:(e,t,o)=>{var a=o(3345);e.exports=a},9076:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o-1&&e.splice(o,1)},show:function(t){if(!e.some((function(e){return e(t)}))){var o="number"!=typeof t.timeout||isNaN(t.timeout)?3e3:t.timeout,a=setTimeout((function(){c({type:"remove",id:a})}),o);c({type:"add",item:r(r({},t),{},{id:a,dataset:r(r({},t.dataset),{},{id:a}),onClose:I})})}},clear:function(){c({type:"clear"})}}}),[]);return _.createElement(S.Provider,{value:A},i instanceof HTMLElement?o:null,_.createElement("div",{ref:E,className:t},d.map((function(e,t){return _.createElement(l,a({key:t},e))}))))};u.propTypes={className:T.string,children:T.node},e.exports=u},18:(e,t,o)=>{var a=o(9076),n=o(7263);e.exports={ToastProvider:a,useToast:n}},7263:(e,t,o)=>{var a=o(7294),n=o(6049);e.exports=function(){return a.useContext(n)}},9309:e=>{e.exports=function(e){return function(t,o){return isNaN(e[t])&&isNaN(e[o])?t.localeCompare(o):isNaN(e[t])?e[o]===Number.NEGATIVE_INFINITY?-1:1:isNaN(e[o])?e[t]===Number.NEGATIVE_INFINITY?1:-1:e[o]-e[t]}}},9324:e=>{e.exports=function(e){return Array.from(e.children).reduce((function(t,o,a){return(function(e,t){var o=t.offsetTop,a=t.offsetTop+t.clientHeight,n=e.scrollTop,r=e.scrollTop+e.clientHeight;return o>=n&&a<=r||o{var a=o(8512),n=o(6851),r=o(9666),i=o(8809),s=o(8006),E=o(9872),_=o(5748),T=o(1297),l=o(8277),S=o(3070),u=o(9321),d=o(8253),c=o(3981),I=o(2935),A=I.HorizontalNavBar,O=I.VerticalNavBar,N=o(2391),m=o(926),R=o(9418),p=o(6798),h=o(861),f=o(9393),L=o(6e3),C=o(6230),D=o(18),g=D.ToastProvider,v=D.useToast,y=o(9309),P=o(2734),B=o(6672),b=B.withCoreSuspender,M=B.useCoreSuspender,U=o(9324),W=o(5232),G=o(8832),F=o(8803),k=o(6649),w=o(4),H=o(4024),V=o(8489),Y=o(1549),z=o(1535),x=o(3760),K=o(552),j=o(432),Q=o(1657);e.exports={AddonDetailsModal:a,Button:n,Checkbox:r,ColorInput:i,DelayedRenderer:s,Image:E,LibItem:_,MainNavBars:T,MetaItem:l,MetaPreview:S,MetaRow:u,ModalDialog:d,Multiselect:c,HorizontalNavBar:A,VerticalNavBar:O,PaginationInput:N,PlayIconCircleCentered:m,Popup:R,SearchBar:p,StreamingServerWarning:h,SharePrompt:f,Slider:L,TextInput:C,ToastProvider:g,useToast:v,comparatorWithPriorities:y,CONSTANTS:P,withCoreSuspender:b,useCoreSuspender:M,getVisibleChildrenRange:U,interfaceLanguages:W,languageNames:G,routesRegexp:F,translateOption:k,useAnimationFrame:w,useBinaryState:H,useFullscreen:V,useLiveRef:Y,useModelState:z,useOnScrollToBottom:x,useProfile:K,useStreamingServer:j,useTorrent:Q}},8803:e=>{e.exports={intro:{regexp:/^\/intro$/,urlParamsNames:[]},board:{regexp:/^\/?$/,urlParamsNames:[]},discover:{regexp:/^\/discover(?:\/([^/]*)\/([^/]*)\/([^/]*))?$/,urlParamsNames:["transportUrl","type","catalogId"]},library:{regexp:/^\/library(?:\/([^/]*))?$/,urlParamsNames:["type"]},continuewatching:{regexp:/^\/continuewatching(?:\/([^/]*))?$/,urlParamsNames:["type"]},search:{regexp:/^\/search$/,urlParamsNames:[]},metadetails:{regexp:/^\/(?:metadetails|detail)\/([^/]*)\/([^/]*)(?:\/([^/]*))?$/,urlParamsNames:["type","id","videoId"]},addons:{regexp:/^\/addons(?:\/([^/]*)(?:\/([^/]*)\/([^/]*))?)?$/,urlParamsNames:["type","transportUrl","catalogId"]},settings:{regexp:/^\/settings$/,urlParamsNames:[]},player:{regexp:/^\/player\/([^/]*)(?:\/([^/]*)\/([^/]*)\/([^/]*)\/([^/]*)\/([^/]*))?$/,urlParamsNames:["stream","streamTransportUrl","metaTransportUrl","type","id","videoId"]}}},6649:(e,t,o)=>{var a=o(6073).t;e.exports=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",o="".concat(t).concat(e),n=a(o,{defaultValue:a(o.toUpperCase(),{defaultValue:null})});return null!=n?n:e.charAt(0).toUpperCase()+e.slice(1)}},4:(e,t,o)=>{var a=o(7294);e.exports=function(){var e=a.useRef(null),t=a.useCallback((function(){cancelAnimationFrame(e.current),e.current=null}),[]);return[a.useCallback((function(o){t(),e.current=requestAnimationFrame((function(){o(),e.current=null}))}),[]),t]}},4024:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(7294);e.exports=function(e){var t=a.useRef();return t.current=e,t}},1535:(e,t,o)=>{var a=["action"];function n(e,t,o,a,n,r,i){try{var s=e[r](i),E=s.value}catch(e){return void o(e)}s.done?t(E):Promise.resolve(E).then(a,n)}function r(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return i(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return i(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function i(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(3096),T=o(2307),l=o(394),S=o(6672).useCoreSuspender,u=o(1665).useRouteFocused,d=o(3662).useServices;e.exports=function(e){var t=e.action,o=s(e,a),i=d().core,c=u(),I=E.useRef(!1),A=r(E.useMemo((function(){return[o.model,o.timeout,o.map,o.deps]}),[]),4),O=A[0],N=A[1],m=A[2],R=A[3],p=S().getState,h=r(E.useReducer((function(e,t){return Object.keys(e).reduce((function(o,a){return o[a]=T(e[a],t[a])?e[a]:t[a],o}),{})}),void 0,(function(){return"function"==typeof m?m(p(O)):p(O)})),2),f=h[0],L=h[1];return E.useInsertionEffect((function(){t&&i.transport.dispatch(t,O)}),[t]),E.useInsertionEffect((function(){return function(){i.transport.dispatch({action:"Unload"},O)}}),[]),E.useInsertionEffect((function(){var e=(function(){var e,t=(e=regeneratorRuntime.mark((function e(t){var o;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(-1!==t.indexOf(O)||Array.isArray(R)&&0!==l(R,t).length){e.next=2;break}return e.abrupt("return");case 2:return e.next=4,i.transport.getState(O);case 4:o=e.sent,L("function"==typeof m?m(o):o);case 6:case"end":return e.stop()}}),e)})),function(){var t=this,o=arguments;return new Promise((function(a,r){var i=e.apply(t,o);function s(e){n(i,a,r,s,E,"next",e)}function E(e){n(i,a,r,s,E,"throw",e)}s(void 0)}))});return function(e){return t.apply(this,arguments)}})(),t=_(e,N);return c&&(i.transport.on("NewState",t),I.current&&e([O])),function(){t.cancel(),i.transport.off("NewState",t)}}),[c]),E.useInsertionEffect((function(){I.current=!0}),[]),f}},3760:(e,t,o)=>{var a=o(7294);e.exports=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,o=a.useRef(!1),n=a.useCallback((function(a){a.target.scrollTop+a.target.clientHeight>=a.target.scrollHeight-t?o.current||(o.current=!0,"function"==typeof e&&e(a)):o.current=!1}),[e]);return n}},552:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{var a=o(1535);e.exports=function(){return a({model:"streaming_server"})}},1657:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=["className","autoFocus","disabled","children"];function n(e,t){if(null==e)return{};var o,a,n=(function(e,t){if(null==e)return{};var o,a,n={},r=Object.keys(e);for(a=0;a=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var r=o(7294),i=o(3935),s=o(5697),E=o(4184),_=o(6413).ZP,T=o(8795).useModalsContainer,l=r.forwardRef((function(e,t){var o=e.className,s=e.autoFocus,l=e.disabled,S=e.children,u=n(e,a),d=T();return i.createPortal(r.createElement(_,{ref:t,className:E(o,"modal-container"),autoFocus:!!s,disabled:!!l,lockProps:u},S),d)}));l.displayName="Modal",l.propTypes={className:s.string,autoFocus:s.bool,disabled:s.bool,children:s.node},e.exports=l},5717:(e,t,o)=>{var a=o(9900);e.exports=a},7033:(e,t,o)=>{var a=o(7294).createContext(null);a.displayName="ModalsContainerContext",e.exports=a},115:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(115),n=o(4163);e.exports={ModalsContainerProvider:a,useModalsContainer:n}},4163:(e,t,o)=>{var a=o(7294),n=o(7033);e.exports=function(){return a.useContext(n)}},9314:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(8795).ModalsContainerProvider,i=function(e){var t=e.children;return a.createElement("div",{className:"route-container"},a.createElement(r,null,a.createElement("div",{className:"route-content"},t)))};i.propTypes={children:n.node},e.exports=i},4777:(e,t,o)=>{var a=o(9314);e.exports=a},9010:(e,t,o)=>{var a=o(7294).createContext(!0);a.displayName="RouteFocusedContext",e.exports=a},6267:(e,t,o)=>{var a=o(9010),n=o(1517);e.exports={RouteFocusedProvider:a.Provider,useRouteFocused:n}},1517:(e,t,o)=>{var a=o(7294),n=o(9010);e.exports=function(){return a.useContext(n)}},8968:(e,t,o)=>{var a=["className","onPathNotMatch"];function n(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return r(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return r(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function r(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var s=o(7294),E=o(9864),_=o(5697),T=o(4184),l=o(8575),S=o(2307),u=o(6267).RouteFocusedProvider,d=o(4777),c=o(3295),I=o(598),A=function(e){var t=e.className,o=e.onPathNotMatch,r=i(e,a),_=s.useMemo((function(){return r.viewsConfig}),[]),A=n(s.useState((function(){return Array(_.length).fill(null)})),2),O=A[0],N=A[1];return s.useLayoutEffect((function(){var e=function(){var e=l.parse(window.location.hash.slice(1)),t=e.pathname,a=e.query,n=new URLSearchParams("string"==typeof a?a:""),r=c(_,"string"==typeof t?t:"");if(null!==r){var i=I(r,"string"==typeof t?t:""),s=_.findIndex((function(e){return e.includes(r)})),T=_[s].findIndex((function(e){return e===r}));N((function(e){return e.slice(0,_.length).map((function(e,t){return t{var a=o(8968);e.exports=a},3295:e=>{function t(e,t){var a="undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(!a){if(Array.isArray(e)||(a=(function(e,t){if(!e)return;if("string"==typeof e)return o(e,t);var a=Object.prototype.toString.call(e).slice(8,-1);"Object"===a&&e.constructor&&(a=e.constructor.name);if("Map"===a||"Set"===a)return Array.from(e);if("Arguments"===a||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a))return o(e,t)})(e))||t&&e&&"number"==typeof e.length){a&&(e=a);var n=0,r=function(){};return{s:r,n:function(){return n>=e.length?{done:!0}:{done:!1,value:e[n++]}},e:function(e){throw e},f:r}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,s=!0,E=!1;return{s:function(){a=a.call(e)},n:function(){var e=a.next();return s=e.done,e},e:function(e){E=!0,i=e},f:function(){try{s||null==a.return||a.return()}finally{if(E)throw i}}}}function o(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{e.exports=function(e,t){var o=t.match(e.regexp);return e.urlParamsNames.reduce((function(e,t,a){return Array.isArray(o)&&"string"==typeof o[a+1]?e[t]=decodeURIComponent(o[a+1]):e[t]=null,e}),{path:t})}},1665:(e,t,o)=>{var a=o(6267).useRouteFocused,n=o(8795).useModalsContainer,r=o(5717),i=o(6013);e.exports={useRouteFocused:a,useModalsContainer:n,Modal:r,Router:i}},2788:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(2601),E=o(6590),_=E.Button,T=E.Image,l=o(2638),S=function(e){var t=e.className,o=e.id,n=e.name,E=e.version,S=e.logo,u=e.description,d=e.types,c=e.behaviorHints,I=e.installed,A=e.onToggle,O=e.onConfigure,N=e.onShare,m=e.dataset,R=i().t,p=a.useCallback((function(e){"function"==typeof A&&A({type:"toggle",nativeEvent:e.nativeEvent,reactEvent:e,dataset:m})}),[A,m]),h=a.useCallback((function(e){"function"==typeof O&&O({type:"configure",nativeEvent:e.nativeEvent,reactEvent:e,dataset:m})}),[O,m]),f=a.useCallback((function(e){"function"==typeof N&&N({type:"share",nativeEvent:e.nativeEvent,reactEvent:e,dataset:m})}),[N,m]),L=a.useCallback((function(e){"Enter"===e.key&&"function"==typeof A&&A({type:"toggle",nativeEvent:e.nativeEvent,reactEvent:e,dataset:m})}),[A,m]),C=a.useCallback((function(){return a.createElement(s,{className:l.icon,icon:"ic_addons"})}),[]);return a.createElement(_,{className:r(t,l["addon-container"]),onKeyDown:L},a.createElement("div",{className:l["logo-container"]},a.createElement(T,{className:l.logo,src:S,alt:" ",renderFallback:C})),a.createElement("div",{className:l["info-container"]},a.createElement("div",{className:l["name-container"],title:"string"==typeof n&&n.length>0?n:o},"string"==typeof n&&n.length>0?n:o),"string"==typeof E&&E.length>0?a.createElement("div",{className:l["version-container"],title:"v.".concat(E)},"v.",E):null,Array.isArray(d)&&d.length>0?a.createElement("div",{className:l["types-container"]},1===d.length?d.join(""):d.slice(0,-1).join(", ")+" & "+d[d.length-1]):null,"string"==typeof u&&u.length>0?a.createElement("div",{className:l["description-container"],title:u},u):null),a.createElement("div",{className:l["buttons-container"]},a.createElement("div",{className:l["action-buttons-container"]},!c.configurationRequired&&c.configurable?a.createElement(_,{className:l["configure-button-container"],title:R("ADDON_CONFIGURE"),tabIndex:-1,onClick:h},a.createElement(s,{className:l.icon,icon:"ic_settings"})):null,a.createElement(_,{className:I?l["uninstall-button-container"]:l["install-button-container"],title:I?R("ADDON_UNINSTALL"):c.configurationRequired?R("ADDON_CONFIGURE"):R("ADDON_INSTALL"),tabIndex:-1,onClick:!I&&c.configurationRequired?h:p},a.createElement("div",{className:l.label},I?R("ADDON_UNINSTALL"):c.configurationRequired?R("ADDON_CONFIGURE"):R("ADDON_INSTALL")))),a.createElement(_,{className:l["share-button-container"],title:R("SHARE_ADDON"),tabIndex:-1,onClick:f},a.createElement(s,{className:l.icon,icon:"ic_share"}),a.createElement("div",{className:l.label},R("SHARE_ADDON")))))};S.propTypes={className:n.string,id:n.string,name:n.string,version:n.string,logo:n.string,description:n.string,types:n.arrayOf(n.string),behaviorHints:n.shape({adult:n.bool,configurable:n.bool,configurationRequired:n.bool,p2p:n.bool}),installed:n.bool,onToggle:n.func,onConfigure:n.func,onShare:n.func,dataset:n.object},e.exports=S},4845:(e,t,o)=>{var a=o(2788);e.exports=a},2994:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o0?Q.manifest.name:Q.manifest.id),"string"==typeof Q.manifest.version&&Q.manifest.version.length>0?i.createElement("span",{className:g.version},"v. ",Q.manifest.version):null)),i.createElement(N,{className:g["share-prompt-container"],url:Q.transportUrl})):null,"string"==typeof v?i.createElement(S,{transportUrl:v,onCloseRequest:ee}):null)};v.propTypes={urlParams:s.shape({path:s.string,transportUrl:s.string,catalogId:s.string,type:s.string}),queryParams:s.instanceOf(URLSearchParams)};e.exports=p(v,(function(){return i.createElement(I,{className:g["addons-container"],route:"addons"})}))},7165:(e,t,o)=>{var a=o(2994);e.exports=a},290:(e,t,o)=>{var a=o(7294);e.exports=function(e,t){var o=a.useMemo((function(){return t.get("addon")}),[t]),n=a.useCallback((function(o){var a=new URLSearchParams(t);"string"==typeof o?a.set("addon",o):a.delete("addon"),window.location.replace("#".concat(e.path,"?").concat(a))}),[e,t]);return[o,n]}},8061:(e,t,o)=>{var a=o(7294),n=o(6590).useModelState;e.exports=function(e){var t=a.useMemo((function(){return"string"!=typeof e.transportUrl&&"string"!=typeof e.catalogId?{action:"Load",args:{model:"InstalledAddonsWithFilters",args:{request:{type:"string"==typeof e.type?e.type:null}}}}:{action:"Unload"}}),[e]);return n({model:"installed_addons",action:t})}},8916:(e,t,o)=>{var a=o(7294),n=o(6590).useModelState;e.exports=function(e){var t=a.useMemo((function(){return"string"==typeof e.type&&"string"==typeof e.transportUrl&&"string"==typeof e.catalogId?{action:"Load",args:{model:"CatalogWithFilters",args:{request:{base:e.transportUrl,path:{resource:"addon_catalog",type:e.type,id:e.catalogId,extra:[]}}}}}:{action:"Unload"}}),[e]);return n({model:"remote_addons",action:t,deps:["ctx"]})}},146:(e,t,o)=>{var a=o(7294),n=o(6073).t,r=o(6590).translateOption;e.exports=function(e,t){var o=a.useMemo((function(){return(function(e,t){var o={title:n("SELECT_CATALOG"),options:t.selectable.catalogs.concat(e.selectable.catalogs).map((function(e){var t=e.name;return{value:e.deepLinks.addons,label:r(t,"ADDON_"),title:r(t,"ADDON_")}})),selected:t.selectable.catalogs.concat(e.selectable.catalogs).filter((function(e){return e.selected})).map((function(e){return e.deepLinks.addons})),renderLabelText:null!==t.selected?function(){var e=t.selectable.catalogs.find((function(e){return e.id===t.selected.request.path.id}));return e?r(e.name,"ADDON_"):t.selected.request.path.id}:null,onSelect:function(e){window.location=e.value}},a={title:n("SELECT_TYPE"),options:null!==e.selected?e.selectable.types.map((function(e){var t=e.type;return{value:e.deepLinks.addons,label:null!==t?r(t,"TYPE_"):n("TYPE_ALL")}})):t.selectable.types.map((function(e){var t=e.type;return{value:e.deepLinks.addons,label:r(t,"TYPE_")}})),selected:null!==e.selected?e.selectable.types.filter((function(e){return e.selected})).map((function(e){return e.deepLinks.addons})):t.selectable.types.filter((function(e){return e.selected})).map((function(e){return e.deepLinks.addons})),renderLabelText:function(){return null!==e.selected?null===e.selected.request.type?n("TYPE_ALL"):r(e.selected.request.type,"TYPE_"):null!==t.selected?r(t.selected.request.path.type,"TYPE_"):a.title},onSelect:function(e){window.location=e.value}};return[o,a]})(e,t)}),[e,t]);return o}},1180:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o0?1:0,p=r.useRef(),h=r.useCallback((function(){var e=A(p.current);if(null!==e){var t=Math.max(0,e.start-R-5),o=e.end-R+5;o0?r.createElement(l,{className:i(m["board-row"],m["continue-watching-row"],"animation-fade-in"),title:e("BOARD_CONTINUE_WATCHING"),items:o.libraryItems,itemComponent:S,deepLinks:o.deepLinks}):null,_.catalogs.map((function(e,t){var o;switch(null===(o=e.content)||void 0===o?void 0:o.type){case"Ready":return r.createElement(l,{key:t,className:i(m["board-row"],m["board-row-".concat(e.content.content[0].posterShape)],"animation-fade-in"),title:e.title,items:e.content.content,itemComponent:u,deepLinks:e.deepLinks});case"Err":return r.createElement(l,{key:t,className:i(m["board-row"],"animation-fade-in"),title:e.title,message:e.content.content,deepLinks:e.deepLinks});default:return r.createElement(l.Placeholder,{key:t,className:i(m["board-row"],m["board-row-poster"],"animation-fade-in"),title:e.title,deepLinks:e.deepLinks})}})))),null!==t.settings&&"Err"===t.settings.type?r.createElement(d,{className:m["board-warning-container"]}):null)}),(function(){return r.createElement("div",{className:m["board-container"]},r.createElement(T,{className:m["board-content-container"],route:"board"}))}))},8823:(e,t,o)=>{var a=o(1180);e.exports=a},6981:(e,t,o)=>{var a=o(7294),n=o(3662).useServices,r=o(6590).useModelState;e.exports=function(){var e=n().core,t=a.useMemo((function(){return{action:"Load",args:{model:"CatalogsWithExtra",args:{extra:[]}}}}),[]),o=a.useCallback((function(t){e.transport.dispatch({action:"CatalogsWithExtra",args:{action:"LoadRange",args:t}},"board")}),[]);return[r({model:"board",timeout:1500,action:t}),o]}},2916:(e,t,o)=>{var a=o(6590).useModelState;e.exports=function(){return a({model:"continue_watching_preview"})}},9694:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(9694);e.exports=a},83:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t0?{action:"Load",args:{model:"CatalogWithFilters",args:{request:{base:e.transportUrl,path:{resource:"catalog",type:e.type,id:e.catalogId,extra:Array.from(t.entries())}}}}}:{action:"Unload"}}),[e,t]);return[_({model:"discover",action:n,map:T,deps:["ctx"]}),a]}},8674:(e,t,o)=>{function a(e){return(function(e){if(Array.isArray(e))return n(e)})(e)||(function(e){if("undefined"!=typeof Symbol&&null!=e[Symbol.iterator]||null!=e["@@iterator"])return Array.from(e)})(e)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e)||(function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=["className","label","link","href","onToggle"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(6590),T=_.Button,l=_.Checkbox,S=o(6947),u=i.forwardRef((function(e,t){var o=e.className,s=e.label,_=e.link,u=e.href,d=e.onToggle,c=r(e,a),I=i.useCallback((function(e){"function"==typeof c.onClick&&c.onClick(e),e.nativeEvent.togglePrevented||"function"!=typeof d||d({type:"toggle",reactEvent:e,nativeEvent:e.nativeEvent})}),[d,c.onClick]),A=i.useCallback((function(e){e.nativeEvent.togglePrevented=!0}),[]);return i.createElement(l,n({},c,{ref:t,className:E(o,S["consent-checkbox-container"]),onClick:I}),i.createElement("div",{className:S.label},s," ","string"==typeof _&&_.length>0&&"string"==typeof u&&u.length>0?i.createElement(T,{className:S.link,href:u,target:"_blank",tabIndex:-1,onClick:A},_):null))}));u.displayName="ConsentCheckbox",u.propTypes={className:s.string,checked:s.bool,label:s.string,link:s.string,href:s.string,onToggle:s.func,onClick:s.func},e.exports=u},6050:(e,t,o)=>{var a=o(8465);e.exports=a},2130:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;t{var a=o(2130);e.exports=a},5398:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o0&&void 0!==arguments[0]?arguments[0]:{},t=e.user;if(!t||"string"!=typeof t.email||"string"!=typeof t.fbLoginToken)throw new Error("Login failed at getting token from Stremio");return{email:t.email,password:t.fbLoginToken}}))})).then((function(e){var t=e.email,o=e.password;a.transport.dispatch({action:"Ctx",args:{action:"Authenticate",args:{type:"Login",email:t,password:o,facebook:!0}}})})).catch((function(e){k(),Y({type:"error",error:e.message})}))}),[]),x=E.useCallback((function(){"string"==typeof V.email&&0!==V.email.length&&S.current.validity.valid?"string"==typeof V.password&&0!==V.password.length?(F(),a.transport.dispatch({action:"Ctx",args:{action:"Authenticate",args:{type:"Login",email:V.email,password:V.password}}})):Y({type:"error",error:"Invalid password"}):Y({type:"error",error:"Invalid email"})}),[V.email,V.password]),K=E.useCallback((function(){V.termsAccepted?(a.transport.dispatch({action:"Ctx",args:{action:"Logout"}}),window.location="#/"):Y({type:"error",error:"You must accept the Terms of Service"})}),[V.termsAccepted]),j=E.useCallback((function(){"string"==typeof V.email&&0!==V.email.length&&S.current.validity.valid?"string"==typeof V.password&&0!==V.password.length?V.password===V.confirmPassword?V.termsAccepted?V.privacyPolicyAccepted?(F(),a.transport.dispatch({action:"Ctx",args:{action:"Authenticate",args:{type:"Register",email:V.email,password:V.password,gdpr_consent:{tos:V.termsAccepted,privacy:V.privacyPolicyAccepted,marketing:V.marketingAccepted,from:"web"}}}})):Y({type:"error",error:"You must accept the Privacy Policy"}):Y({type:"error",error:"You must accept the Terms of Service"}):Y({type:"error",error:"Passwords do not match"}):Y({type:"error",error:"Invalid password"}):Y({type:"error",error:"Invalid email"})}),[V.email,V.password,V.confirmPassword,V.termsAccepted,V.privacyPolicyAccepted,V.marketingAccepted]),Q=E.useCallback((function(e){Y({type:"change-credentials",name:"email",value:e.currentTarget.value})}),[]),X=E.useCallback((function(){I.current.focus()}),[]),$=E.useCallback((function(e){Y({type:"change-credentials",name:"password",value:e.currentTarget.value})}),[]),q=E.useCallback((function(){V.form===L?D.current.focus():x()}),[V.form,x]),J=E.useCallback((function(e){Y({type:"change-credentials",name:"confirmPassword",value:e.currentTarget.value})}),[]),Z=E.useCallback((function(){g.current.focus()}),[]),ee=E.useCallback((function(){Y({type:"toggle-checkbox",name:"termsAccepted"})}),[]),te=E.useCallback((function(){Y({type:"toggle-checkbox",name:"privacyPolicyAccepted"})}),[]),oe=E.useCallback((function(){Y({type:"toggle-checkbox",name:"marketingAccepted"})}),[]),ae=E.useCallback((function(){var e=new URLSearchParams([["form",V.form===L?C:L]]);window.location="#/intro?".concat(e.toString())}),[V.form]);return E.useEffect((function(){[C,L].includes(t.get("form"))&&Y({type:"set-form",form:t.get("form")})}),[t]),E.useEffect((function(){s&&"string"==typeof V.error&&V.error.length>0&&P.current.scrollIntoView()}),[V.error]),E.useEffect((function(){s&&S.current.focus()}),[V.form,s]),E.useEffect((function(){var e=function(e){var t=e.event,o=e.args;switch(t){case"UserAuthenticated":k(),s&&(window.location="#/");break;case"Error":"UserAuthenticated"===o.source.event&&k()}};return a.transport.on("CoreEvent",e),function(){a.transport.off("CoreEvent",e)}}),[s]),E.createElement("div",{className:f["intro-container"]},E.createElement("div",{className:f["form-container"]},E.createElement("div",{className:f["logo-container"]},E.createElement(O,{className:f.logo,src:o(5313),alt:" "}),E.createElement(l,{className:f.name,icon:"ic_stremio"})),E.createElement(A,{className:T(f["form-button"],f["facebook-button"]),onClick:z},E.createElement(l,{className:f.icon,icon:"ic_facebook"}),E.createElement("div",{className:f.label},"Continue with Facebook")),V.form===L?E.createElement(A,{className:T(f["form-button"],f["login-form-button"]),onClick:ae},"Already have an account?"," ",E.createElement("span",{className:f["login-label"]},"LOG IN")):null,E.createElement(m,{ref:S,className:f["credentials-text-input"],type:"email",placeholder:"Email",value:V.email,onChange:Q,onSubmit:X}),E.createElement(m,{ref:I,className:f["credentials-text-input"],type:"password",placeholder:"Password",value:V.password,onChange:$,onSubmit:q}),V.form===L?E.createElement(E.Fragment,null,E.createElement(m,{ref:D,className:f["credentials-text-input"],type:"password",placeholder:"Confirm Password",value:V.confirmPassword,onChange:J,onSubmit:Z}),E.createElement(R,{ref:g,className:f["consent-checkbox"],label:"I have read and agree with the Stremio",link:"Terms and conditions",href:"https://www.stremio.com/tos",checked:V.termsAccepted,onToggle:ee}),E.createElement(R,{ref:v,className:f["consent-checkbox"],label:"I have read and agree with the Stremio",link:"Privacy Policy",href:"https://www.stremio.com/privacy",checked:V.privacyPolicyAccepted,onToggle:te}),E.createElement(R,{ref:y,className:f["consent-checkbox"],label:"I agree to receive marketing communications from Stremio",checked:V.marketingAccepted,onToggle:oe})):E.createElement("div",{className:f["forgot-password-link-container"]},E.createElement(A,{className:f["forgot-password-link"],onClick:M},"Forgot password?")),V.error.length>0?E.createElement("div",{ref:P,className:f["error-message"]},V.error):null,E.createElement(A,{className:T(f["form-button"],f["submit-button"]),onClick:V.form===L?j:x},E.createElement("div",{className:f.label},V.form===L?"Sign up":"Log in")),V.form===L?E.createElement(A,{className:T(f["form-button"],f["guest-login-button"]),onClick:K},E.createElement("div",{className:f.label},"GUEST LOGIN")):null,V.form===C?E.createElement(A,{className:T(f["form-button"],f["signup-form-button"]),onClick:ae},E.createElement("div",{className:f.label},"SIGN UP WITH EMAIL")):null),b?E.createElement(p,{email:V.email,onCloseRequest:U}):null,G?E.createElement(u,{className:f["loading-modal-container"]},E.createElement("div",{className:f["loader-container"]},E.createElement(l,{className:f.icon,icon:"ic_user"}),E.createElement("div",{className:f.label},"Authenticating..."))):null)};D.propTypes={queryParams:_.instanceOf(URLSearchParams)},e.exports=D},8142:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o0&&u.current.validity.valid?window.open("https://www.strem.io/reset-password/"+u.current.value,"_blank"):S("Invalid email")}),[]),c=r.useMemo((function(){return[{className:T["cancel-button"],label:"Cancel",props:{onClick:o}},{label:"Send",props:{onClick:d}}]}),[o]),I=r.useCallback((function(){S("")}),[]);return r.useEffect((function(){n&&u.current.focus()}),[n]),r.createElement(E,{className:T["password-reset-modal-container"],title:"Password reset",buttons:c,onCloseRequest:o},r.createElement(_,{ref:u,className:T["credentials-text-input"],type:"email",placeholder:"Email",defaultValue:"string"==typeof t?t:"",onChange:I,onSubmit:d}),l.length>0?r.createElement("div",{className:T["error-message"]},l):null)};l.propTypes={email:i.string,onCloseRequest:i.func},e.exports=l},2015:(e,t,o)=>{var a=o(8142);e.exports=a},6732:(e,t,o)=>{var a=o(5398);e.exports=a},4167:(e,t,o)=>{var a=o(7294);e.exports=function(){var e=a.useCallback((function(){return new Promise((function(e,t){"undefined"!=typeof FB?FB.getLoginStatus((function(o){o&&o.authResponse&&"string"==typeof o.authResponse.accessToken?e(o.authResponse.accessToken):FB.login((function(o){o&&o.authResponse&&"string"==typeof o.authResponse.accessToken?e(o.authResponse.accessToken):t(new Error("Failed to get token from Facebook"))}))})):t(new Error("Failed to connect to Facebook"))}))}),[]);return a.useEffect((function(){window.fbAsyncInit=function(){FB.init({appId:"1537119779906825",status:!0,xfbml:!1,version:"v2.7"})};var e=document.createElement("script");return e.src="https://connect.facebook.net/en_US/sdk.js",e.async=!0,e.defer=!0,document.body.appendChild(e),function(){document.body.removeChild(e)}}),[]),e}},8171:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(8171);e.exports=a},3242:(e,t,o)=>{var a=o(7294),n=o(6590).useModelState;e.exports=function(e,t,o){var r=a.useMemo((function(){return{action:"Load",args:{model:"LibraryWithFilters",args:{request:{type:"string"==typeof t.type?t.type:null,sort:o.has("sort")?o.get("sort"):void 0,page:o.has("page")?parseInt(o.get("page"),10):void 0}}}}}),[t,o]);return n({model:e,action:r})}},3780:(e,t,o)=>{var a=o(7294),n=o(1468).useTranslation,r=o(6590).translateOption;e.exports=function(e){var t=n().t,o=a.useMemo((function(){return(function(e,t){return[{title:t("SELECT_TYPE"),options:e.selectable.types.map((function(e){var o=e.type;return{value:e.deepLinks.library,label:null===o?t("TYPE_ALL"):r(o,"TYPE_")}})),selected:e.selectable.types.filter((function(e){return e.selected})).map((function(e){return e.deepLinks.library})),onSelect:function(e){window.location=e.value}},{title:t("SELECT_SORT"),options:e.selectable.sorts.map((function(e){var t=e.sort;return{value:e.deepLinks.library,label:r(t,"SORT_")}})),selected:e.selectable.sorts.filter((function(e){return e.selected})).map((function(e){return e.deepLinks.library})),onSelect:function(e){window.location=e.value}},e.selectable.prevPage||e.selectable.nextPage?{label:e.selected.request.page.toString(),onSelect:function(t){"prev"===t.value&&e.selectable.prevPage&&(window.location=e.selectable.prevPage.deepLinks.library),"next"===t.value&&e.selectable.nextPage&&(window.location=e.selectable.nextPage.deepLinks.library)}}:null]})(e,t)}),[e]);return o}},8493:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o0?r.createElement(T,{className:p["vertical-nav-bar"],tabs:C,selected:null!==D?D.url:null}):null,null===y?r.createElement(c,{delay:500},r.createElement("div",{className:p["meta-message-container"]},r.createElement(d,{className:p.image,src:o(7740),alt:" "}),r.createElement("div",{className:p["message-label"]},"No meta was selected!"))):null===_.metaItem?r.createElement("div",{className:p["meta-message-container"]},r.createElement(d,{className:p.image,src:o(7740),alt:" "}),r.createElement("div",{className:p["message-label"]},"No addons ware requested for this meta!")):"Err"===_.metaItem.content.type?r.createElement("div",{className:p["meta-message-container"]},r.createElement(d,{className:p.image,src:o(7740),alt:" "}),r.createElement("div",{className:p["message-label"]},"No metadata was found!")):"Loading"===_.metaItem.content.type?r.createElement(S.Placeholder,{className:p["meta-preview"]}):r.createElement(r.Fragment,null,"string"==typeof _.metaItem.content.content.background&&_.metaItem.content.content.background.length>0?r.createElement("div",{className:p["background-image-layer"]},r.createElement(d,{className:p["background-image"],src:_.metaItem.content.content.background,renderFallback:W,alt:" "})):null,r.createElement(S,{className:s(p["meta-preview"],"animation-fade-in"),name:_.metaItem.content.content.name,logo:_.metaItem.content.content.logo,runtime:_.metaItem.content.content.runtime,releaseInfo:_.metaItem.content.content.releaseInfo,released:_.metaItem.content.content.released,description:null!==B&&"string"==typeof B.overview&&B.overview.length>0?B.overview:_.metaItem.content.content.description,links:_.metaItem.content.content.links,trailerStreams:_.metaItem.content.content.trailerStreams,inLibrary:_.metaItem.content.content.inLibrary,toggleInLibrary:_.metaItem.content.content.inLibrary?M:b})),r.createElement("div",{className:p.spacing}),null!==P?r.createElement(A,{className:p["streams-list"],streams:_.streams}):null!==y?r.createElement(O,{className:p["videos-list"],metaItem:_.metaItem,season:h,seasonOnSelect:U}):null),null!==D?r.createElement(u,{className:p["meta-extension-modal-container"],title:D.name,onCloseRequest:g},r.createElement("iframe",{className:p["meta-extension-modal-iframe"],sandbox:"allow-forms allow-scripts allow-same-origin",src:D.url})):null)};h.propTypes={urlParams:i.shape({type:i.string,id:i.string,videoId:i.string}),queryParams:i.instanceOf(URLSearchParams)};e.exports=I(h,(function(){return r.createElement("div",{className:p["metadetails-container"]},r.createElement(l,{className:p["nav-bar"],backButton:!0,addonsButton:!0,fullscreenButton:!0,navMenu:!0}))}))},2742:(e,t,o)=>{var a=["className","addonName","name","description","thumbnail","progress","deepLinks"];function n(){return n=Object.assign||function(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var i=o(7294),s=o(5697),E=o(4184),_=o(2601),T=o(6590),l=T.Button,S=T.Image,u=T.PlayIconCircleCentered,d=o(4134),c=o(3458),I=function(e){var t=e.className,o=e.addonName,s=e.name,T=e.description,d=e.thumbnail,I=e.progress,A=e.deepLinks,O=r(e,a),N=i.useMemo((function(){return A&&"string"==typeof A.player?A.player:null}),[A]),m=i.useCallback((function(){return i.createElement(_,{className:c["placeholder-icon"],icon:"ic_broken_link"})}),[]);return i.createElement(l,n({href:N},O,{className:E(t,c["stream-container"]),title:o}),"string"==typeof d&&d.length>0?i.createElement("div",{className:c["thumbnail-container"],title:s||o},i.createElement(S,{className:c.thumbnail,src:d,alt:" ",renderFallback:m})):i.createElement("div",{className:c["addon-name-container"],title:s||o},i.createElement("div",{className:c["addon-name"]},s||o)),i.createElement("div",{className:c["info-container"],title:T},T),i.createElement(u,{className:c["play-icon"]}),null!==I&&!isNaN(I)&&I>0?i.createElement("div",{className:c["progress-bar-container"]},i.createElement("div",{className:c["progress-bar"],style:{width:"".concat(100*Math.min(I,1),"%")}})):null)};I.Placeholder=d,I.propTypes={className:s.string,addonName:s.string,name:s.string,description:s.string,thumbnail:s.string,progress:s.number,deepLinks:s.shape({player:s.string})},e.exports=I},3210:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(926),s=o(1384),E=function(e){var t=e.className;return a.createElement("div",{className:r(t,s["stream-placeholder-container"])},a.createElement("div",{className:s["addon-container"]},a.createElement("div",{className:s["addon-name"]})),a.createElement("div",{className:s["info-container"]},a.createElement("div",{className:s["description-container"]}),a.createElement("div",{className:s["description-container"]})),a.createElement(i,{className:s["play-icon"]}))};E.propTypes={className:n.string},e.exports=E},4134:(e,t,o)=>{var a=o(3210);e.exports=a},4674:(e,t,o)=>{var a=o(2742);e.exports=a},4176:(e,t,o)=>{var a=["className"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var u=o(7294),d=o(5697),c=o(4184),I=o(1468).useTranslation,A=o(2601),O=o(6590),N=O.Button,m=O.Image,R=O.Multiselect,p=o(3662).useServices,h=o(4674),f=o(6796),L="ALL",C=function(e){var t=e.className,i=S(e,a),E=I().t,T=p().core,l=_(u.useState(L),2),d=l[0],O=l[1],C=u.useCallback((function(e){O(e.value)}),[]),D=u.useMemo((function(){return i.streams.filter((function(e){return"Ready"===e.content.type})).reduce((function(e,t){return e[t.addon.transportUrl]={addon:t.addon,streams:t.content.content.map((function(e){return s(s({},e),{},{onClick:function(){T.transport.analytics({event:"StreamClicked",args:{stream:e}})},addonName:t.addon.manifest.name})}))},e}),{})}),[i.streams]),g=u.useMemo((function(){return d===L?Object.values(D).map((function(e){return e.streams})).flat(1):D[d]?D[d].streams:[]}),[D,d]),v=u.useMemo((function(){return{title:"Select Addon",options:[{value:L,label:E("ALL_ADDONS"),title:E("ALL_ADDONS")}].concat(r(Object.keys(D).map((function(e){return{value:e,label:D[e].addon.manifest.name,title:D[e].addon.manifest.name}})))),selected:[d],onSelect:C}}),[D,d]);return u.createElement("div",{className:c(t,f["streams-list-container"])},0===i.streams.length?u.createElement("div",{className:f["message-container"]},u.createElement(m,{className:f.image,src:o(7740),alt:" "}),u.createElement("div",{className:f.label},"No addons were requested for streams!")):i.streams.every((function(e){return"Err"===e.content.type}))?u.createElement("div",{className:f["message-container"]},u.createElement(m,{className:f.image,src:o(7740),alt:" "}),u.createElement("div",{className:f.label},E("NO_STREAM"))):0===g.length?u.createElement("div",{className:f["streams-container"]},u.createElement(h.Placeholder,null),u.createElement(h.Placeholder,null)):u.createElement(u.Fragment,null,Object.keys(D).length>1?u.createElement(R,n({},v,{className:f["select-input-container"]})):null,u.createElement("div",{className:f["streams-container"]},g.map((function(e,t){return u.createElement(h,{key:t,addonName:e.addonName,name:e.name,description:e.description,thumbnail:e.thumbnail,progress:e.progress,deepLinks:e.deepLinks,onClick:e.onClick})})))),u.createElement(N,{className:f["install-button-container"],title:E("ADDON_CATALOGUE_MORE"),href:"#/addons"},u.createElement(A,{className:f.icon,icon:"ic_addons"}),u.createElement("div",{className:f.label},E("ADDON_CATALOGUE_MORE"))))};C.propTypes={className:d.string,streams:d.arrayOf(d.object).isRequired},e.exports=C},2231:(e,t,o)=>{var a=o(4176);e.exports=a},2813:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(6073).t,s=o(2601),E=o(6590),_=E.Button,T=E.Multiselect,l=o(3570),S=o(6351),u=function(e){var t=e.className,o=e.seasons,n=e.season,E=e.onSelect,l=a.useMemo((function(){return o.map((function(e){return{value:String(e),label:e>0?"".concat(i("SEASON")," ").concat(e):i("SPECIAL")}}))}),[o]),u=a.useMemo((function(){return[String(n)]}),[n]),d=a.useCallback((function(e){if("function"==typeof E){var t=o.indexOf(n),a="next"===e.currentTarget.dataset.action?t+1=0?t-1:0,r=o[a];E({type:"select",value:r,reactEvent:e,nativeEvent:e.nativeEvent})}}),[n,o,E]),c=a.useCallback((function(e){var t=parseFloat(e.value);"function"==typeof E&&E({type:"select",value:t,reactEvent:e.reactEvent,nativeEvent:e.nativeEvent})}),[E]);return a.createElement("div",{className:r(t,S["seasons-bar-container"])},a.createElement(_,{className:S["prev-season-button"],title:"Previous season","data-action":"prev",onClick:d},a.createElement(s,{className:S.icon,icon:"ic_arrow_thin_left"}),a.createElement("div",{className:S.label},"Prev")),a.createElement(T,{className:S["seasons-popup-label-container"],title:n>0?"".concat(i("SEASON")," ").concat(n):i("SPECIAL"),direction:"bottom-left",options:l,selected:u,onSelect:c}),a.createElement(_,{className:S["next-season-button"],title:"Next season","data-action":"next",onClick:d},a.createElement("div",{className:S.label},"Next"),a.createElement(s,{className:S.icon,icon:"ic_arrow_thin_right"})))};u.Placeholder=l,u.propTypes={className:n.string,seasons:n.arrayOf(n.number).isRequired,season:n.number.isRequired,onSelect:n.func},e.exports=u},9319:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(2180),E=function(e){var t=e.className;return a.createElement("div",{className:r(t,s["seasons-bar-placeholder-container"])},a.createElement("div",{className:s["prev-season-button"]},a.createElement(i,{className:s.icon,icon:"ic_arrow_thin_left"}),a.createElement("div",{className:s.label},"Prev")),a.createElement("div",{className:s["seasons-popup-label-container"]},a.createElement("div",{className:s["seasons-popup-label"]},"Season 1"),a.createElement(i,{className:s["seasons-popup-icon"],icon:"ic_arrow_thin_down"})),a.createElement("div",{className:s["next-season-button"]},a.createElement("div",{className:s.label},"Next"),a.createElement(i,{className:s.icon,icon:"ic_arrow_thin_right"})))};E.propTypes={className:n.string},e.exports=E},3570:(e,t,o)=>{var a=o(9319);e.exports=a},3424:(e,t,o)=>{var a=o(2813);e.exports=a},2824:(e,t,o)=>{var a=["className","id","title","thumbnail","episode","released","upcoming","watched","progress","scheduled","deepLinks"],n=["className","id","title","thumbnail","episode","released","upcoming","watched","progress","scheduled","children"];function r(){return r=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var _=o(7294),T=o(5697),l=o(4184),S=o(3662).useServices,u=o(1665).useRouteFocused,d=o(2601),c=o(6590),I=c.Button,A=c.Image,O=c.Popup,N=c.useBinaryState,m=o(9922),R=o(4486),p=function(e){var t=e.className,o=e.id,s=e.title,T=e.thumbnail,c=e.episode,m=e.released,p=e.upcoming,h=e.watched,f=e.progress,L=e.scheduled,C=e.deepLinks,D=E(e,a),g=S().core,v=u(),y=i(N(!1),4),P=y[0],B=y[2],b=y[3],M=_.useCallback((function(e){!e.nativeEvent.togglePopupPrevented&&e.nativeEvent.ctrlKey&&(e.preventDefault(),b())}),[]),U=_.useCallback((function(e){e.nativeEvent.buttonClickPrevented=!0}),[]),W=_.useCallback((function(e){e.nativeEvent.togglePopupPrevented||e.nativeEvent.ctrlKey||(e.preventDefault(),b())}),[b]),G=_.useCallback((function(e){e.nativeEvent.togglePopupPrevented=!0}),[]),F=_.useCallback((function(e){e.nativeEvent.togglePopupPrevented=!0}),[]),k=_.useCallback((function(e){e.preventDefault(),B(),g.transport.dispatch({action:"MetaDetails",args:{action:"MarkVideoAsWatched",args:[o,!h]}})}),[o,h]),w=_.useMemo((function(){return C?"string"==typeof C.player?C.player:"string"==typeof C.metaDetailsStreams?C.metaDetailsStreams:null:null}),[C]),H=_.useMemo((function(){return function(e){var t=e.className,o=e.id,a=e.title,i=e.thumbnail,s=e.episode,T=e.released,S=e.upcoming,u=e.watched,c=e.progress,O=e.scheduled,N=e.children,m=E(e,n);return _.createElement(I,r({},m,{className:l(t,R["video-container"]),title:a}),"string"==typeof i&&i.length>0?_.createElement("div",{className:R["thumbnail-container"]},_.createElement(A,{className:R.thumbnail,src:i,alt:" ",renderFallback:function(){return _.createElement(d,{className:R["placeholder-icon"],icon:"ic_stremio_tray"})}})):null,_.createElement("div",{className:R["info-container"]},_.createElement("div",{className:R["title-container"]},null===s||isNaN(s)?null:"".concat(s,". "),"string"==typeof a&&a.length>0?a:o),_.createElement("div",{className:R["flex-row-container"]},T instanceof Date&&!isNaN(T.getTime())?_.createElement("div",{className:R["released-container"]},T.toLocaleString(void 0,{year:"numeric",month:"short",day:"numeric"})):O?_.createElement("div",{className:R["released-container"],title:"To be announced"},"TBA"):null,_.createElement("div",{className:R["upcoming-watched-container"]},S?_.createElement("div",{className:R["upcoming-container"]},_.createElement("div",{className:R["flag-label"]},"Upcoming")):null,u?_.createElement("div",{className:R["watched-container"]},_.createElement("div",{className:R["flag-label"]},"Watched")):null))),null!==c&&!isNaN(c)&&c>0?_.createElement("div",{className:R["progress-bar-container"]},_.createElement("div",{className:R["progress-bar"],style:{width:"".concat(100*Math.min(c,1),"%")}})):null,N)}}),[]),V=_.useMemo((function(){return function(){return _.createElement("div",{className:R["context-menu-content"],onContextMenu:G,onClick:F},_.createElement(I,{className:R["context-menu-option-container"],title:"Watch"},_.createElement("div",{className:R["context-menu-option-label"]},"Watch")),_.createElement(I,{className:R["context-menu-option-container"],title:h?"Mark as non-watched":"Mark as watched",onClick:k},_.createElement("div",{className:R["context-menu-option-label"]},h?"Mark as non-watched":"Mark as watched")))}}),[h,k]);return _.useEffect((function(){v||B()}),[v]),_.createElement(O,r({className:t,id:o,title:s,thumbnail:T,episode:c,released:m,upcoming:p,watched:h,progress:f,scheduled:L,href:w},D,{onClick:M,onKeyDown:U,onContextMenu:W,open:P,onCloseRequest:B,renderLabel:H,renderMenu:V}))};p.Placeholder=m,p.propTypes={className:T.string,id:T.string,title:T.string,thumbnail:T.string,episode:T.number,released:T.instanceOf(Date),upcoming:T.bool,watched:T.bool,progress:T.number,scheduled:T.bool,deepLinks:T.shape({metaDetailsStreams:T.string,player:T.string})},e.exports=p},8509:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(5507),s=function(e){var t=e.className;return a.createElement("div",{className:r(t,i["video-placeholder-container"])},a.createElement("div",{className:i["info-container"]},a.createElement("div",{className:i["name-container"]}),a.createElement("div",{className:i["released-container"]})))};s.propTypes={className:n.string},e.exports=s},9922:(e,t,o)=>{var a=o(8509);e.exports=a},123:(e,t,o)=>{var a=o(2824);e.exports=a},1702:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o0?e[e.length-1]:I.length>0?I[I.length-1]:null}),[I,i]),O=r.useMemo((function(){return c.filter((function(e){return null===A||e.season===A})).sort((function(e,t){return e.episode-t.episode}))}),[c,A]),N=a(r.useState(""),2),m=N[0],R=N[1],p=r.useCallback((function(e){R(e.currentTarget.value)}),[]);return r.createElement("div",{className:s(t,u["videos-list-container"])},n&&"Loading"!==n.content.type?"Err"===n.content.type||0===O.length?r.createElement("div",{className:u["message-container"]},r.createElement(_,{className:u.image,src:o(7740),alt:" "}),r.createElement("div",{className:u.label},"No videos found for this meta!")):r.createElement(r.Fragment,null,I.length>0?r.createElement(l,{className:u["seasons-bar"],season:A,seasons:I,onSelect:d}):null,r.createElement(T,{className:u["search-bar"],title:E("SEARCH_VIDEOS"),value:m,onChange:p}),r.createElement("div",{className:u["videos-container"]},O.filter((function(e){return 0===m.length||"string"==typeof e.title&&e.title.toLowerCase().includes(m.toLowerCase())||!isNaN(e.released.getTime())&&e.released.toLocaleString(void 0,{year:"2-digit",month:"short",day:"numeric"}).toLowerCase().includes(m.toLowerCase())})).map((function(e,t){return r.createElement(S,{key:t,id:e.id,title:e.title,thumbnail:e.thumbnail,episode:e.episode,released:e.released,upcoming:e.upcoming,watched:e.watched,progress:e.progress,deepLinks:e.deepLinks,scheduled:e.scheduled})})))):r.createElement(r.Fragment,null,r.createElement(l.Placeholder,{className:u["seasons-bar"]}),r.createElement(T.Placeholder,{className:u["search-bar"],title:E("SEARCH_VIDEOS")}),r.createElement("div",{className:u["videos-scroll-container"]},r.createElement(S.Placeholder,null),r.createElement(S.Placeholder,null),r.createElement(S.Placeholder,null),r.createElement(S.Placeholder,null),r.createElement(S.Placeholder,null))))};d.propTypes={className:i.string,metaItem:i.object,season:i.number,seasonOnSelect:i.func},e.exports=d},8437:(e,t,o)=>{var a=o(1702);e.exports=a},9005:(e,t,o)=>{var a=o(8493);e.exports=a},8450:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(7294);e.exports=function(e,t){var o=a.useMemo((function(){return t.has("season")&&!isNaN(t.get("season"))?parseInt(t.get("season"),10):null}),[t]),n=a.useCallback((function(o){var a=new URLSearchParams(t);a.set("season",o),window.location.replace("#".concat(e.path,"?").concat(a))}),[e,t]);return[o,n]}},9096:(e,t,o)=>{var a=o(7294),n=o(6590),r=n.Image,i=n.HorizontalNavBar,s=o(5142);e.exports=function(){return a.createElement("div",{className:s["not-found-container"]},a.createElement(i,{className:s["nav-bar"],title:"Page not found",backButton:!0,fullscreenButton:!0,navMenu:!0}),a.createElement("div",{className:s["not-found-content"]},a.createElement(r,{className:s["not-found-image"],src:o(7740),alt:" "}),a.createElement("div",{className:s["not-found-label"]},"Page not found!")))}},353:(e,t,o)=>{var a=o(9096);e.exports=a},9579:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(6590).Image,s=o(1391),E=function(e){var t=e.className,n=e.logo;return a.createElement("div",{className:r(t,s["buffering-loader-container"])},a.createElement(i,{className:s["buffering-loader"],src:n,alt:" ",fallbackSrc:o(5313)}))};E.propTypes={className:n.string,logo:n.string},e.exports=E},3475:(e,t,o)=>{var a=o(9579);e.exports=a},2479:(e,t,o)=>{var a=["className","paused","time","duration","volume","muted","playbackSpeed","subtitlesTracks","audioTracks","metaItem","nextVideo","onPlayRequested","onPauseRequested","onMuteRequested","onUnmuteRequested","onVolumeChangeRequested","onSeekRequested","onToggleSubtitlesMenu","onToggleInfoMenu","onToggleSpeedMenu","onToggleVideosMenu","onToggleOptionsMenu"];function n(){return n=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var _=o(7294),T=o(5697),l=o(4184),S=o(2601),u=o(6590).Button,d=o(3662).useServices,c=o(5280),I=o(7429),A=o(578),O=o(6590).useBinaryState,N=o(6073).t,m=function(e){var t,o,s=e.className,T=e.paused,m=e.time,R=e.duration,p=e.volume,h=e.muted,f=e.playbackSpeed,L=e.subtitlesTracks,C=e.audioTracks,D=e.metaItem,g=e.nextVideo,v=e.onPlayRequested,y=e.onPauseRequested,P=e.onMuteRequested,B=e.onUnmuteRequested,b=e.onVolumeChangeRequested,M=e.onSeekRequested,U=e.onToggleSubtitlesMenu,W=e.onToggleInfoMenu,G=e.onToggleSpeedMenu,F=e.onToggleVideosMenu,k=e.onToggleOptionsMenu,w=E(e,a),H=d().chromecast,V=i(_.useState((function(){return H.active})),2),Y=V[0],z=V[1],x=i(O(!1),4),K=x[0],j=x[3],Q=_.useCallback((function(e){e.nativeEvent.subtitlesMenuClosePrevented=!0}),[]),X=_.useCallback((function(e){e.nativeEvent.infoMenuClosePrevented=!0}),[]),$=_.useCallback((function(e){e.nativeEvent.speedMenuClosePrevented=!0}),[]),q=_.useCallback((function(e){e.nativeEvent.videosMenuClosePrevented=!0}),[]),J=_.useCallback((function(e){e.nativeEvent.optionsMenuClosePrevented=!0}),[]),Z=_.useCallback((function(){T?"function"==typeof v&&v():"function"==typeof y&&y()}),[T,v,y]),ee=_.useCallback((function(){null!==g&&"object"===r(g.deepLinks)&&(null!==g.deepLinks.player?window.location.replace(g.deepLinks.player):null!==g.deepLinks.metaDetailsStreams&&window.location.replace(g.deepLinks.metaDetailsStreams))}),[g]),te=_.useCallback((function(){h?"function"==typeof B&&B():"function"==typeof P&&P()}),[h,P,B]),oe=_.useCallback((function(){"function"==typeof U&&U()}),[U]),ae=_.useCallback((function(){"function"==typeof W&&W()}),[W]),ne=_.useCallback((function(){"function"==typeof G&&G()}),[G]),re=_.useCallback((function(){"function"==typeof F&&F()}),[F]),ie=_.useCallback((function(){"function"==typeof k&&k()}),[k]),se=_.useCallback((function(){H.transport.requestSession()}),[]);return _.useEffect((function(){var e=function(){z(H.active)};return H.on("stateChanged",e),function(){H.off("stateChanged",e)}}),[]),_.createElement("div",n({},w,{className:l(s,A["control-bar-container"])}),_.createElement(c,{className:A["seek-bar"],time:m,duration:R,onSeekRequested:M}),_.createElement("div",{className:A["control-bar-buttons-container"]},_.createElement(u,{className:l(A["control-bar-button"],{disabled:"boolean"!=typeof T}),title:N(T?"PLAYER_PLAY":"PLAYER_PAUSE"),tabIndex:-1,onClick:Z},_.createElement(S,{className:A.icon,icon:"boolean"!=typeof T||T?"ic_play":"ic_pause"})),null!==g?_.createElement(u,{className:l(A["control-bar-button"]),title:N("PLAYER_NEXT_VIDEO"),tabIndex:-1,onClick:ee},_.createElement(S,{className:A.icon,icon:"ic_play_next"})):null,_.createElement(u,{className:l(A["control-bar-button"],{disabled:"boolean"!=typeof h}),title:N(h?"PLAYER_UNMUTE":"PLAYER_MUTE"),tabIndex:-1,onClick:te},_.createElement(S,{className:A.icon,icon:"boolean"==typeof h&&h?"ic_volume0":null===p||isNaN(p)?"ic_volume3":p<30?"ic_volume1":p<70?"ic_volume2":"ic_volume3"})),_.createElement(I,{className:A["volume-slider"],volume:p,onVolumeChangeRequested:b}),_.createElement("div",{className:A.spacing}),_.createElement(u,{className:A["control-bar-buttons-menu-button"],onClick:j},_.createElement(S,{className:A.icon,icon:"ic_more"})),_.createElement("div",{className:l(A["control-bar-buttons-menu-container"],{open:K})},_.createElement(u,{className:l(A["control-bar-button"],{disabled:null===f}),tabIndex:-1,onMouseDown:$,onClick:ne},_.createElement(S,{className:A.icon,icon:"ic_speedometer"})),_.createElement(u,{className:l(A["control-bar-button"],"disabled"),tabIndex:-1},_.createElement(S,{className:A.icon,icon:"ic_network"})),_.createElement(u,{className:l(A["control-bar-button"],{disabled:null===D||"Ready"!==D.type}),tabIndex:-1,onMouseDown:X,onClick:ae},_.createElement(S,{className:A.icon,icon:"ic_info"})),_.createElement(u,{className:l(A["control-bar-button"],{disabled:!Y}),tabIndex:-1,onClick:se},_.createElement(S,{className:A.icon,icon:"ic_cast"})),_.createElement(u,{className:l(A["control-bar-button"],{disabled:!(Array.isArray(L)&&0!==L.length||Array.isArray(C)&&0!==C.length)}),tabIndex:-1,onMouseDown:Q,onClick:oe},_.createElement(S,{className:A.icon,icon:"ic_sub"})),(null==D||null===(t=D.content)||void 0===t||null===(o=t.videos)||void 0===o?void 0:o.length)>0?_.createElement(u,{className:A["control-bar-button"],tabIndex:-1,onMouseDown:q,onClick:re},_.createElement(S,{className:A.icon,icon:"ic_videos"})):null,_.createElement(u,{className:A["control-bar-button"],tabIndex:-1,onMouseDown:J,onClick:ie},_.createElement(S,{className:A.icon,icon:"ic_more"})))))};m.propTypes={className:T.string,paused:T.bool,time:T.number,duration:T.number,volume:T.number,muted:T.bool,playbackSpeed:T.number,subtitlesTracks:T.array,audioTracks:T.array,metaItem:T.object,nextVideo:T.object,onPlayRequested:T.func,onPauseRequested:T.func,onMuteRequested:T.func,onUnmuteRequested:T.func,onVolumeChangeRequested:T.func,onSeekRequested:T.func,onToggleSubtitlesMenu:T.func,onToggleInfoMenu:T.func,onToggleSpeedMenu:T.func,onToggleVideosMenu:T.func,onToggleOptionsMenu:T.func},e.exports=m},6181:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var t=function(e){return("0"+e).slice(-1*Math.max(e.toString().length,2))};e.exports=function(e){if(null===e||isNaN(e))return"--:--:--";var o=Math.floor(e/36e5),a=Math.floor(e/6e4%60),n=Math.floor(e/1e3%60);return"".concat(t(o),":").concat(t(a),":").concat(t(n))}},5280:(e,t,o)=>{var a=o(6181);e.exports=a},4932:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(4932);e.exports=a},9292:(e,t,o)=>{var a=o(2479);e.exports=a},8928:(e,t,o)=>{var a=["className"];function n(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function r(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(6590),S=l.MetaPreview,u=l.CONSTANTS,d=o(3800),c=function(e){var t=e.className,o=s(e,a),n=E.useMemo((function(){return null!==o.metaItem?r(r({},o.metaItem),{},{links:o.metaItem.links.filter((function(e){return e.category===u.SHARE_LINK_CATEGORY}))}):null}),[o.metaItem]),i=E.useCallback((function(e){e.nativeEvent.infoMenuClosePrevented=!0}),[]);return E.createElement("div",{className:T(t,d["info-menu-container"]),onMouseDown:i},null!==n?E.createElement(S,{className:d["meta-preview"],compact:!0,name:n.name,logo:n.logo,runtime:n.runtime,releaseInfo:n.releaseInfo,released:n.released,description:n.description,links:n.links}):null)};c.propTypes={className:_.string,metaItem:_.object,addon:_.object,stream:_.object},e.exports=c},5458:(e,t,o)=>{var a=o(8928);e.exports=a},2690:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(2690);e.exports=a},9252:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(6590).Button,E=o(1530),_=function(e){var t=e.icon,o=e.label,n=e.deviceId,_=e.disabled,T=e.onClick,l=a.useCallback((function(){"function"==typeof T&&T(n)}),[T,n]);return a.createElement(s,{className:r(E["option-container"],{disabled:_}),disabled:_,onClick:l},a.createElement(i,{className:E.icon,icon:t}),a.createElement("div",{className:E.label},o))};_.propTypes={icon:n.string,label:n.string,deviceId:n.string,disabled:n.bool,onClick:n.func},e.exports=_},9944:(e,t,o)=>{var a=o(9252);e.exports=a},1366:(e,t,o)=>{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(1366);e.exports=a},2230:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o0||Array.isArray(w.extraSubtitlesTracks)&&w.extraSubtitlesTracks.length>0||Array.isArray(w.audioTracks)&&w.audioTracks.length>0)&&ce();break;case"KeyI":Te(),de(),pe(),Ce(),null!==Y.metaItem&&"Ready"===Y.metaItem.type&&Ne();break;case"KeyR":Te(),Oe(),de(),Ce(),null!==w.playbackSpeed&&he();break;case"KeyV":Te(),Oe(),de(),pe(),null!==Y.metaItem&&"Ready"===Y.metaItem.type&&De();break;case"Escape":Te(),de(),Oe(),pe(),Ce(),st()}};return J&&window.addEventListener("keydown",e),function(){window.removeEventListener("keydown",e)}}),[Y.metaItem,X.seekTimeDuration,J,ue,Ae,Le,Re,_e,w.paused,w.time,w.volume,w.audioTracks,w.subtitlesTracks,w.extraSubtitlesTracks,w.playbackSpeed,ce,Ne,De]),E.useLayoutEffect((function(){return function(){se.cancel(),je.cancel(),Xe.cancel()}}),[]),E.createElement("div",{className:T(U["player-container"],r({},U.immersed,re&&!oe&&null!==w.paused&&!w.paused&&!ue&&!Ae&&!Re&&!Le&&!ve&&!_e)),onMouseDown:lt,onMouseMove:St,onMouseOver:St,onMouseLeave:ut},E.createElement(B,{ref:Fe,className:U.layer,onEnded:Ve,onError:Ye,onPropValue:He,onPropChanged:He,onSubtitlesTrackLoaded:ze,onExtraSubtitlesTrackLoaded:xe,onImplementationChanged:we}),w.buffering?E.createElement(f,{className:U.layer}):null,E.createElement("div",{className:U.layer,onClick:_t,onDoubleClick:Tt}),null!==We?E.createElement("div",{className:T(U.layer,U["error-layer"])},E.createElement("div",{className:U["error-label"],title:We.message},We.message),null!==Y.selected?E.createElement(A,{className:U["playlist-button"],title:"Open in external player",href:Y.selected.stream.deepLinks.externalPlayer.href,download:Y.selected.stream.deepLinks.externalPlayer.fileName,target:"_blank"},E.createElement(h,{className:U.icon,icon:"ic_downloads"}),E.createElement("div",{className:U.label},"Open in external player")):null):null,ue||Ae||Le||Re||_e?E.createElement("div",{className:U.layer}):null,E.createElement(I,{className:T(U.layer,U["nav-bar-layer"]),title:null!==Y.title?Y.title:"",backButton:!0,fullscreenButton:!0,onMouseMove:dt,onMouseOver:dt}),E.createElement(L,{className:T(U.layer,U["control-bar-layer"]),paused:w.paused,time:w.time,duration:w.duration,volume:w.volume,muted:w.muted,playbackSpeed:w.playbackSpeed,subtitlesTracks:w.subtitlesTracks.concat(w.extraSubtitlesTracks),audioTracks:w.audioTracks,metaItem:Y.metaItem,nextVideo:Y.nextVideo,onPlayRequested:Ke,onPauseRequested:Qe,onMuteRequested:$e,onUnmuteRequested:qe,onVolumeChangeRequested:Je,onSeekRequested:Ze,onToggleOptionsMenu:le,onToggleSubtitlesMenu:ce,onToggleInfoMenu:Ne,onToggleSpeedMenu:he,onToggleVideosMenu:De,onMouseMove:dt,onMouseOver:dt}),ve?E.createElement(C,{className:T(U.layer,U["menu-layer"]),metaItem:null!==Y.metaItem&&"Ready"===Y.metaItem.type?Y.metaItem.content:null,nextVideo:Y.nextVideo,onDismiss:st,onPlayNextVideoRequested:Et}):null,ue?E.createElement(y,{className:T(U.layer,U["menu-layer"]),audioTracks:w.audioTracks,selectedAudioTrackId:w.selectedAudioTrackId,subtitlesTracks:w.subtitlesTracks,selectedSubtitlesTrackId:w.selectedSubtitlesTrackId,subtitlesOffset:w.subtitlesOffset,subtitlesSize:w.subtitlesSize,extraSubtitlesTracks:w.extraSubtitlesTracks,selectedExtraSubtitlesTrackId:w.selectedExtraSubtitlesTrackId,extraSubtitlesOffset:w.extraSubtitlesOffset,extraSubtitlesDelay:w.extraSubtitlesDelay,extraSubtitlesSize:w.extraSubtitlesSize,onSubtitlesTrackSelected:tt,onExtraSubtitlesTrackSelected:ot,onAudioTrackSelected:at,onSubtitlesOffsetChanged:it,onSubtitlesSizeChanged:rt,onExtraSubtitlesOffsetChanged:it,onExtraSubtitlesDelayChanged:nt,onExtraSubtitlesSizeChanged:rt}):null,Ae?E.createElement(D,{className:T(U.layer,U["menu-layer"]),stream:null!==Y.selected?Y.selected.stream:null,addon:Y.addon,metaItem:null!==Y.metaItem&&"Ready"===Y.metaItem.type?Y.metaItem.content:null}):null,Re?E.createElement(P,{className:T(U.layer,U["menu-layer"]),playbackSpeed:w.playbackSpeed,onPlaybackSpeedChanged:et}):null,Le?E.createElement(v,{className:T(U.layer,U["menu-layer"]),metaItem:null!==Y.metaItem&&"Ready"===Y.metaItem.type?Y.metaItem.content:null,seriesInfo:Y.seriesInfo}):null,_e?E.createElement(g,{className:T(U.layer,U["menu-layer"]),stream:Y.selected.stream,playbackDevices:null!==q.playbackDevices&&"Ready"===q.playbackDevices.type?q.playbackDevices.content:[]}):null)};W.propTypes={urlParams:_.shape({stream:_.string,streamTransportUrl:_.string,metaTransportUrl:_.string,type:_.string,id:_.string,videoId:_.string}),queryParams:_.instanceOf(URLSearchParams)};e.exports=p(W,(function(){return E.createElement("div",{className:T(U["player-container"])})}))},7764:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(6590).Button,s=o(4805),E=function(e){var t=e.className,o=e.value,n=e.selected,E=e.onSelect,_=a.useCallback((function(){"function"==typeof E&&E(o)}),[E,o]);return a.createElement(i,{className:r(t,s.option,{selected:n}),onClick:_},a.createElement("div",{className:s.label},o,"x"),a.createElement("div",{className:s.icon}))};E.propTypes={className:n.string,value:n.number,selected:n.bool,onSelect:n.func},e.exports=E},9396:(e,t,o)=>{var a=o(7764);e.exports=a},5296:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(1468).useTranslation,s=o(9396),E=o(9715),_=Array.from(Array(8).keys(),(function(e){return.25*e+.25})).reverse(),T=function(e){var t=e.className,o=e.playbackSpeed,n=e.onPlaybackSpeedChanged,T=i().t,l=a.useCallback((function(e){e.nativeEvent.speedMenuClosePrevented=!0}),[]),S=a.useCallback((function(e){"function"==typeof n&&n(e)}),[n]);return a.createElement("div",{className:r(t,E["speed-menu-container"]),onMouseDown:l},a.createElement("div",{className:E.title},T("PLAYBACK_SPEED")),a.createElement("div",{className:E["options-container"]},_.map((function(e){return a.createElement(s,{className:E.option,key:e,value:e,selected:e===o,onSelect:S})}))))};T.propTypes={className:n.string,playbackSpeed:n.number,onPlaybackSpeedChanged:n.func},e.exports=T},1998:(e,t,o)=>{var a=o(5296);e.exports=a},569:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(2601),s=o(6590).Button,E=o(3283),_=function(e){var t=e.className,o=e.value,n=e.label,_=e.disabled,T=e.dataset,l=e.onChange,S=a.useCallback((function(e){"function"==typeof l&&l({type:"change",value:e.currentTarget.dataset.type,dataset:T,reactEvent:e,nativeEvent:e.nativeEvent})}),[T,l]);return a.createElement("div",{className:r(t,E["discrete-input-container"],{disabled:_})},a.createElement("div",{className:E.header},n),a.createElement("div",{className:E["input-container"],title:_?"".concat(n," is not configurable"):null},a.createElement(s,{className:r(E["button-container"],{disabled:_}),"data-type":"decrement",onClick:S},a.createElement(i,{className:E.icon,icon:"ic_minus"})),a.createElement("div",{className:E["option-label"],title:o},o),a.createElement(s,{className:r(E["button-container"],{disabled:_}),"data-type":"increment",onClick:S},a.createElement(i,{className:E.icon,icon:"ic_plus"}))))};_.propTypes={className:n.string,value:n.string,label:n.string,disabled:n.bool,dataset:n.object,onChange:n.func},e.exports=_},3132:(e,t,o)=>{var a=o(569);e.exports=a},1346:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(6590),s=i.Button,E=i.CONSTANTS,_=i.comparatorWithPriorities,T=i.languageNames,l=o(3132),S=o(3889),u=o(6073).t,d={EMBEDDED:2,EXCLUSIVE:1},c={eng:1},I=a.memo((function(e){var t=a.useMemo((function(){return(Array.isArray(e.subtitlesTracks)?e.subtitlesTracks:[]).concat(Array.isArray(e.extraSubtitlesTracks)?e.extraSubtitlesTracks:[]).reduce((function(e,t){var o=t.lang;return e.includes(o)||e.push(o),e}),[]).sort(_(c))}),[e.subtitlesTracks,e.extraSubtitlesTracks]),o=a.useMemo((function(){return"string"==typeof e.selectedSubtitlesTrackId?(Array.isArray(e.subtitlesTracks)?e.subtitlesTracks:[]).reduce((function(t,o){var a=o.id,n=o.lang;return a===e.selectedSubtitlesTrackId?n:t}),null):"string"==typeof e.selectedExtraSubtitlesTrackId?(Array.isArray(e.extraSubtitlesTracks)?e.extraSubtitlesTracks:[]).reduce((function(t,o){var a=o.id,n=o.lang;return a===e.selectedExtraSubtitlesTrackId?n:t}),null):null}),[e.subtitlesTracks,e.extraSubtitlesTracks,e.selectedSubtitlesTrackId,e.selectedExtraSubtitlesTrackId]),n=a.useMemo((function(){return(Array.isArray(e.subtitlesTracks)?e.subtitlesTracks:[]).concat(Array.isArray(e.extraSubtitlesTracks)?e.extraSubtitlesTracks:[]).filter((function(e){return e.lang===o})).sort((function(e,t){return _(d)(e.origin,t.origin)}))}),[e.subtitlesTracks,e.extraSubtitlesTracks,o]),i=a.useCallback((function(e){e.nativeEvent.subtitlesMenuClosePrevented=!0}),[]),I=a.useCallback((function(t){var o=(Array.isArray(e.subtitlesTracks)?e.subtitlesTracks:[]).concat(Array.isArray(e.extraSubtitlesTracks)?e.extraSubtitlesTracks:[]).filter((function(e){return e.lang===t.currentTarget.dataset.lang})).sort((function(e,t){return _(d)(e.origin,t.origin)})).shift();o?o.embedded?"function"==typeof e.onSubtitlesTrackSelected&&e.onSubtitlesTrackSelected(o.id):"function"==typeof e.onExtraSubtitlesTrackSelected&&e.onExtraSubtitlesTrackSelected(o.id):("function"==typeof e.onSubtitlesTrackSelected&&e.onSubtitlesTrackSelected(null),"function"==typeof e.onExtraSubtitlesTrackSelected&&e.onExtraSubtitlesTrackSelected(null))}),[e.subtitlesTracks,e.extraSubtitlesTracks,e.onSubtitlesTrackSelected,e.onExtraSubtitlesTrackSelected]),A=a.useCallback((function(t){"true"===t.currentTarget.dataset.embedded?"function"==typeof e.onSubtitlesTrackSelected&&e.onSubtitlesTrackSelected(t.currentTarget.dataset.id):"function"==typeof e.onExtraSubtitlesTrackSelected&&e.onExtraSubtitlesTrackSelected(t.currentTarget.dataset.id)}),[e.onSubtitlesTrackSelected,e.onExtraSubtitlesTrackSelected]),O=a.useCallback((function(t){var o="increment"===t.value?250:-250;if("string"==typeof e.selectedExtraSubtitlesTrackId&&null!==e.extraSubtitlesDelay&&!isNaN(e.extraSubtitlesDelay)){var a=e.extraSubtitlesDelay+o;"function"==typeof e.onExtraSubtitlesDelayChanged&&e.onExtraSubtitlesDelayChanged(a)}}),[e.selectedExtraSubtitlesTrackId,e.extraSubtitlesDelay,e.onExtraSubtitlesDelayChanged]),N=a.useCallback((function(t){var o="increment"===t.value?1:-1;if("string"==typeof e.selectedSubtitlesTrackId){if(null!==e.subtitlesSize&&!isNaN(e.subtitlesSize)){var a=E.SUBTITLES_SIZES.indexOf(e.subtitlesSize),n=E.SUBTITLES_SIZES[Math.max(0,Math.min(E.SUBTITLES_SIZES.length-1,a+o))];"function"==typeof e.onSubtitlesSizeChanged&&e.onSubtitlesSizeChanged(n)}}else if("string"==typeof e.selectedExtraSubtitlesTrackId&&null!==e.extraSubtitlesSize&&!isNaN(e.extraSubtitlesSize)){var r=E.SUBTITLES_SIZES.indexOf(e.extraSubtitlesSize),i=E.SUBTITLES_SIZES[Math.max(0,Math.min(E.SUBTITLES_SIZES.length-1,r+o))];"function"==typeof e.onExtraSubtitlesSizeChanged&&e.onExtraSubtitlesSizeChanged(i)}}),[e.selectedSubtitlesTrackId,e.selectedExtraSubtitlesTrackId,e.subtitlesSize,e.extraSubtitlesSize,e.onSubtitlesSizeChanged,e.onExtraSubtitlesSizeChanged]),m=a.useCallback((function(t){var o="increment"===t.value?1:-1;if("string"==typeof e.selectedSubtitlesTrackId){if(null!==e.extraSubtitlesOffset&&!isNaN(e.extraSubtitlesOffset)){var a=Math.max(0,Math.min(100,Math.floor(e.extraSubtitlesOffset+o)));"function"==typeof e.onExtraSubtitlesOffsetChanged&&e.onExtraSubtitlesOffsetChanged(a)}}else if("string"==typeof e.selectedExtraSubtitlesTrackId&&null!==e.subtitlesOffset&&!isNaN(e.subtitlesOffset)){var n=Math.max(0,Math.min(100,Math.floor(e.subtitlesOffset+o)));"function"==typeof e.onSubtitlesOffsetChanged&&e.onSubtitlesOffsetChanged(n)}}),[e.selectedSubtitlesTrackId,e.selectedExtraSubtitlesTrackId,e.subtitlesOffset,e.extraSubtitlesOffset,e.onSubtitlesOffsetChanged,e.onExtraSubtitlesOffsetChanged]),R=a.useCallback((function(t){"function"==typeof e.onAudioTrackSelected&&e.onAudioTrackSelected(t.currentTarget.dataset.id)}),[e.onAudioTrackSelected]);return a.createElement("div",{className:r(e.className,S["subtitles-menu-container"]),onMouseDown:i},Array.isArray(e.audioTracks)&&e.audioTracks.length>1?a.createElement("div",{className:S["languages-container"]},a.createElement("div",{className:S["languages-header"]},"Audio Languages"),a.createElement("div",{className:S["languages-list"]},e.audioTracks.map((function(t,o){var n=t.id,i=t.label,E=t.lang;return a.createElement(s,{key:o,title:i,className:r(S["language-option"],{selected:e.selectedAudioTrackId===n}),"data-id":n,onClick:R},a.createElement("div",{className:S["language-label"]},"string"==typeof T[E]?T[E]:E),e.selectedAudioTrackId===n?a.createElement("div",{className:S.icon}):null)})))):null,a.createElement("div",{className:S["languages-container"]},a.createElement("div",{className:S["languages-header"]},u("PLAYER_SUBTITLES_LANGUAGES")),a.createElement("div",{className:S["languages-list"]},a.createElement(s,{title:u("OFF"),className:r(S["language-option"],{selected:null===o}),onClick:I},a.createElement("div",{className:S["language-label"]},u("OFF")),null===o?a.createElement("div",{className:S.icon}):null),t.map((function(e,t){return a.createElement(s,{key:t,title:"string"==typeof T[e]?T[e]:e,className:r(S["language-option"],{selected:o===e}),"data-lang":e,onClick:I},a.createElement("div",{className:S["language-label"]},"string"==typeof T[e]?T[e]:e),o===e?a.createElement("div",{className:S.icon}):null)})))),a.createElement("div",{className:S["variants-container"]},a.createElement("div",{className:S["variants-header"]},u("PLAYER_SUBTITLES_VARIANTS")),n.length>0?a.createElement("div",{className:S["variants-list"]},n.map((function(t,o){return a.createElement(s,{key:o,title:t.label,className:r(S["variant-option"],{selected:e.selectedSubtitlesTrackId===t.id||e.selectedExtraSubtitlesTrackId===t.id}),"data-id":t.id,"data-origin":t.origin,"data-embedded":t.embedded,onClick:A},a.createElement("div",{className:S["variant-label"]},t.origin),e.selectedSubtitlesTrackId===t.id||e.selectedExtraSubtitlesTrackId===t.id?a.createElement("div",{className:S.icon}):null)}))):a.createElement("div",{className:S["no-variants-container"]},a.createElement("div",{className:S["no-variants-label"]},u("PLAYER_SUBTITLES_DISABLED")))),a.createElement("div",{className:S["subtitles-settings-container"]},a.createElement("div",{className:S["settings-header"]},"Subtitles Settings"),a.createElement(l,{className:S["discrete-input"],label:u("DELAY"),value:"string"!=typeof e.selectedExtraSubtitlesTrackId||null===e.extraSubtitlesDelay||isNaN(e.extraSubtitlesDelay)?"--":"".concat((e.extraSubtitlesDelay/1e3).toFixed(2),"s"),disabled:"string"!=typeof e.selectedExtraSubtitlesTrackId||null===e.extraSubtitlesDelay||isNaN(e.extraSubtitlesDelay),onChange:O}),a.createElement(l,{className:S["discrete-input"],label:u("SIZE"),value:"string"==typeof e.selectedSubtitlesTrackId?null===e.subtitlesSize||isNaN(e.subtitlesSize)?"--":"".concat(e.subtitlesSize,"%"):"string"==typeof e.selectedExtraSubtitlesTrackId?null===e.extraSubtitlesSize||isNaN(e.extraSubtitlesSize)?"--":"".concat(e.extraSubtitlesSize,"%"):"--",disabled:"string"==typeof e.selectedSubtitlesTrackId?null===e.subtitlesSize||isNaN(e.subtitlesSize):"string"!=typeof e.selectedExtraSubtitlesTrackId||(null===e.extraSubtitlesSize||isNaN(e.extraSubtitlesSize)),onChange:N}),a.createElement(l,{className:S["discrete-input"],label:u("PLAYER_SUBTITLES_VERTICAL_POSIITON"),value:"string"==typeof e.selectedSubtitlesTrackId?null===e.subtitlesOffset||isNaN(e.subtitlesOffset)?"--":"".concat(e.subtitlesOffset,"%"):"string"==typeof e.selectedExtraSubtitlesTrackId?null===e.extraSubtitlesOffset||isNaN(e.extraSubtitlesOffset)?"--":"".concat(e.extraSubtitlesOffset,"%"):"--",disabled:"string"==typeof e.selectedSubtitlesTrackId?null===e.subtitlesOffset||isNaN(e.subtitlesOffset):"string"!=typeof e.selectedExtraSubtitlesTrackId||(null===e.extraSubtitlesOffset||isNaN(e.extraSubtitlesOffset)),onChange:m}),a.createElement("div",{className:S.spacing}),a.createElement(s,{className:r(S["advanced-button"],"disabled"),title:"Advanced"},"Advanced")))}));I.displayName="MainNavBars",I.propTypes={className:n.string,subtitlesTracks:n.arrayOf(n.shape({id:n.string.isRequired,lang:n.string.isRequired,origin:n.string.isRequired})),selectedSubtitlesTrackId:n.string,subtitlesOffset:n.number,subtitlesSize:n.number,extraSubtitlesTracks:n.arrayOf(n.shape({id:n.string.isRequired,lang:n.string.isRequired,origin:n.string.isRequired,label:n.string.isRequired})),selectedExtraSubtitlesTrackId:n.string,extraSubtitlesOffset:n.number,extraSubtitlesDelay:n.number,extraSubtitlesSize:n.number,audioTracks:n.arrayOf(n.shape({id:n.string.isRequired,lang:n.string.isRequired,origin:n.string.isRequired,label:n.string.isRequired})),selectedAudioTrackId:n.string,onSubtitlesTrackSelected:n.func,onExtraSubtitlesTrackSelected:n.func,onAudioTrackSelected:n.func,onSubtitlesOffsetChanged:n.func,onSubtitlesSizeChanged:n.func,onExtraSubtitlesOffsetChanged:n.func,onExtraSubtitlesDelayChanged:n.func,onExtraSubtitlesSizeChanged:n.func},e.exports=I},9646:(e,t,o)=>{var a=o(1346);e.exports=a},5245:(e,t,o)=>{var a=["className"];function n(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function r(e){for(var t=1;t=0||(n[o]=e[o]);return n})(e,t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(n[o]=e[o])}return n}var E=o(7294),_=o(5697),T=o(4184),l=o(1654),S=o(6590).useLiveRef,u=o(4236),d=E.forwardRef((function(e,t){var o=e.className,n=s(e,a),i=S(n.onEnded),_=S(n.onError),d=S(n.onPropValue),c=S(n.onPropChanged),I=S(n.onSubtitlesTrackLoaded),A=S(n.onExtraSubtitlesTrackLoaded),O=S(n.onImplementationChanged),N=E.useRef(null),m=E.useRef(null),R=E.useCallback((function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(null!==m.current)try{m.current.dispatch(e,r(r({},t),{},{containerElement:N.current}))}catch(e){console.error("Video",e)}}),[]);return E.useImperativeHandle(t,(function(){return{dispatch:R}}),[]),E.useEffect((function(){return null!==N.current&&(m.current=new l,m.current.on("ended",(function(){"function"==typeof i.current&&i.current()})),m.current.on("error",(function(e){"function"==typeof _.current&&_.current(e)})),m.current.on("propValue",(function(e,t){"function"==typeof d.current&&d.current(e,t)})),m.current.on("propChanged",(function(e,t){"function"==typeof c.current&&c.current(e,t)})),m.current.on("subtitlesTrackLoaded",(function(e){"function"==typeof I.current&&I.current(e)})),m.current.on("extraSubtitlesTrackLoaded",(function(e){"function"==typeof A.current&&A.current(e)})),m.current.on("implementationChanged",(function(e){"function"==typeof O.current&&O.current(e)}))),function(){m.current.destroy()}}),[]),E.createElement("div",{className:T(o,u["video-container"])},E.createElement("div",{ref:N,className:u.video}))}));d.displayName="Video",d.propTypes={className:_.string,onEnded:_.func,onError:_.func,onPropValue:_.func,onPropChanged:_.func,onSubtitlesTrackLoaded:_.func,onExtraSubtitlesTrackLoaded:_.func,onImplementationChanged:_.func},e.exports=d},5711:(e,t,o)=>{var a=o(5245);e.exports=a},4027:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(4184),i=o(123),s=o(674),E=function(e){var t=e.className,o=e.metaItem,n=e.seriesInfo,E=a.useCallback((function(e){e.nativeEvent.videosMenuClosePrevented=!0}),[]),_=a.useMemo((function(){return n&&"number"==typeof n.season&&Array.isArray(o.videos)?o.videos.filter((function(e){return e.season===n.season})):o.videos}),[o,n]);return a.createElement("div",{className:r(t,s["videos-menu-container"]),onMouseDown:E},_.map((function(e,t){return a.createElement(i,{key:t,id:e.id,title:e.title,thumbnail:e.thumbnail,episode:e.episode,released:e.released,upcoming:e.upcoming,watched:e.watched,progress:e.progress,deepLinks:e.deepLinks,scheduled:e.scheduled})})))};E.propTypes={className:n.string,metaItem:n.object,seriesInfo:n.shape({season:n.number,episode:n.number})},e.exports=E},6429:(e,t,o)=>{var a=o(4027);e.exports=a},7793:(e,t,o)=>{var a=o(2230);e.exports=a},5852:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o{var a=o(4853);e.exports=a},4182:(e,t,o)=>{var a=o(7294),n=o(6590).useModelState,r=o(3662).useServices;e.exports=function(e){var t=r().core,o=a.useMemo((function(){return e.has("search")&&e.get("search").length>0?{action:"Load",args:{model:"CatalogsWithExtra",args:{extra:[["search",e.get("search")]]}}}:{action:"Unload"}}),[e]),i=a.useCallback((function(e){t.transport.dispatch({action:"CatalogsWithExtra",args:{action:"LoadRange",args:e}},"search")}),[]);return[n({model:"search",action:o}),i]}},5674:(e,t,o)=>{function a(){return a=Object.assign||function(e){for(var t=1;te.length)&&(t=e.length);for(var o=0,a=new Array(t);o=Ne.current.scrollHeight-50)De(fe[fe.length-1].id);else for(var e=fe.length-1;e>=0;e--)if(fe[e].ref.current.offsetTop-Ne.current.offsetTop<=Ne.current.scrollTop){De(fe[e].id);break}}),[]),ve=s.useCallback((function(e){var t=fe.find((function(t){return t.id===e.currentTarget.dataset.section}));Ne.current.scrollTo({top:t.ref.current.offsetTop-Ne.current.offsetTop,behavior:"smooth"})}),[]),ye=s.useCallback(_((function(){ge()}),50),[]);return s.useEffect((function(){Se&&Te&&(t.transport.dispatch({action:"Ctx",args:{action:"InstallTraktAddon"}}),le(!1))}),[Se,Te]),s.useEffect((function(){null!==U.exportUrl&&"string"==typeof U.exportUrl&&window.open(U.exportUrl)}),[U.exportUrl]),s.useLayoutEffect((function(){i&&ge(),ie()}),[i]),s.createElement(A,{className:y["settings-container"],route:"settings"},s.createElement("div",{className:E(y["settings-content"],"animation-fade-in")},s.createElement("div",{className:y["side-menu-container"]},s.createElement(c,{className:E(y["side-menu-button"],n({},y.selected,Ce===P)),title:e("SETTINGS_NAV_GENERAL"),"data-section":P,onClick:ve},e("SETTINGS_NAV_GENERAL")),s.createElement(c,{className:E(y["side-menu-button"],n({},y.selected,Ce===B)),title:e("SETTINGS_NAV_PLAYER"),"data-section":B,onClick:ve},e("SETTINGS_NAV_PLAYER")),s.createElement(c,{className:E(y["side-menu-button"],n({},y.selected,Ce===b)),title:e("SETTINGS_NAV_STREAMING"),"data-section":b,onClick:ve},e("SETTINGS_NAV_STREAMING")),s.createElement(c,{className:E(y["side-menu-button"],n({},y.selected,Ce===M)),title:e("SETTINGS_NAV_SHORTCUTS"),"data-section":M,onClick:ve},e("SETTINGS_NAV_SHORTCUTS")),s.createElement("div",{className:y.spacing}),s.createElement("div",{className:y["version-info-label"],title:"5.0.0"},"App Version: ","5.0.0"),null!==G.settings&&"Ready"===G.settings.type?s.createElement("div",{className:y["version-info-label"],title:G.settings.content.serverVersion},"Server Version: ",G.settings.content.serverVersion):null),s.createElement("div",{ref:Ne,className:y["sections-container"],onScroll:ye},s.createElement("div",{ref:me,className:y["section-container"]},s.createElement("div",{className:y["section-title"]},e("SETTINGS_NAV_GENERAL")),s.createElement("div",{className:E(y["option-container"],y["user-info-option-container"])},s.createElement("div",{className:y["avatar-container"],style:{backgroundImage:null===d.auth?"url('".concat(o(3028),"')"):d.auth.user.avatar?"url('".concat(d.auth.user.avatar,"')"):"url('".concat(o(1251),"')")}}),s.createElement("div",{className:y["email-logout-container"]},s.createElement("div",{className:y["email-label-container"],title:null===d.auth?"Anonymous user":d.auth.user.email},s.createElement("div",{className:y["email-label"]},null===d.auth?"Anonymous user":d.auth.user.email)),null!==d.auth?s.createElement(c,{className:y["logout-button-container"],title:e("LOG_OUT"),href:"#/intro",onClick:de},s.createElement("div",{className:y["logout-label"]},e("LOG_OUT"))):null),s.createElement(c,{className:y["user-panel-container"],title:"User panel",target:"_blank",href:"https://www.stremio.com/acc-settings"},s.createElement("div",{className:y["user-panel-label"]},e("USER_PANEL")))),null===d.auth?s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["button-container"]),title:"".concat(e("LOG_IN")," / ").concat(e("SIGN_UP")),href:"#/intro",onClick:de},s.createElement("div",{className:y.label},e("LOG_IN")," / ",e("SIGN_UP")))):null,s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_INTERFACE_LANGUAGE"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"]),tabIndex:-1},w))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},"Trakt Scrobbling")),s.createElement(c,{className:E(y["option-input-container"],y["button-container"]),title:"Authenticate",disabled:null===d.auth,tabIndex:-1,onClick:ce},s.createElement(l,{className:y.icon,icon:"ic_trakt"}),s.createElement("div",{className:y.label},null!==d.auth&&null!==d.auth.user&&null!==d.auth.user.trakt?e("LOG_OUT"):e("SETTINGS_TRAKT_AUTHENTICATE")))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("Calendar"))),s.createElement(c,{className:E(y["option-input-container"],y["button-container"]),title:"Subscribe",disabled:!(d.auth&&d.auth.user&&d.auth.user._id),tabIndex:-1,onClick:Ie},s.createElement(l,{className:y.icon,icon:"ic_calendar"}),s.createElement("div",{className:y.label},e("SETTINGS_CALENDAR_SUBSCRIBE")))),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["link-container"]),title:e("SETTINGS_DATA_EXPORT"),tabIndex:-1,onClick:Ae},s.createElement("div",{className:y.label},e("SETTINGS_DATA_EXPORT")))),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["link-container"]),title:e("SETTINGS_SUPPORT"),target:"_blank",href:"https://stremio.zendesk.com/hc/en-us"},s.createElement("div",{className:y.label},e("SETTINGS_SUPPORT")))),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["link-container"]),title:"Source code",target:"_blank",href:"https://github.com/stremio/stremio-web/tree/".concat("4ffa1a051cd42350e1948a517da3018721508d5d")},s.createElement("div",{className:y.label},"Source code"))),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["link-container"]),title:e("TERMS_OF_SERVICE"),target:"_blank",href:"https://www.stremio.com/tos"},s.createElement("div",{className:y.label},e("TERMS_OF_SERVICE")))),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["link-container"]),title:e("PRIVACY_POLICY"),target:"_blank",href:"https://www.stremio.com/privacy"},s.createElement("div",{className:y.label},e("PRIVACY_POLICY"))))),s.createElement("div",{ref:Re,className:y["section-container"]},s.createElement("div",{className:y["section-title"]},e("SETTINGS_NAV_PLAYER")),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SUBTITLES_LANGUAGE"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},H))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SUBTITLES_SIZE"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},V))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SUBTITLES_COLOR"))),s.createElement(N,a({className:E(y["option-input-container"],y["color-input-container"])},Y))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SUBTITLES_COLOR_BACKGROUND"))),s.createElement(N,a({className:E(y["option-input-container"],y["color-input-container"])},z))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SUBTITLES_COLOR_OUTLINE"))),s.createElement(N,a({className:E(y["option-input-container"],y["color-input-container"])},x))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_DEFAULT_AUDIO_TRACK"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},K))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_REWIND_FAST_FORWARD_DURATION"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},j))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("AUTO_PLAY"))),s.createElement(I,a({className:E(y["option-input-container"],y["checkbox-container"])},X))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_NEXT_VIDEO_POPUP_DURATION"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"]),disabled:!d.settings.bingeWatching},Q))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_PLAY_IN_BACKGROUND"))),s.createElement(I,a({className:E(y["option-input-container"],y["checkbox-container"]),disabled:!0,tabIndex:-1},$))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_PLAY_IN_EXTERNAL_PLAYER"))),s.createElement(I,a({className:E(y["option-input-container"],y["checkbox-container"]),disabled:!0,tabIndex:-1},q))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_HWDEC"))),s.createElement(I,a({className:E(y["option-input-container"],y["checkbox-container"]),disabled:!0,tabIndex:-1},J)))),s.createElement("div",{ref:pe,className:y["section-container"]},s.createElement("div",{className:y["section-title"]},e("SETTINGS_NAV_STREAMING")),s.createElement("div",{className:y["option-container"]},s.createElement(c,{className:E(y["option-input-container"],y["button-container"]),title:"Reload",onClick:Oe},s.createElement("div",{className:y.label},e("RELOAD")))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("STATUS"))),s.createElement("div",{className:E(y["option-input-container"],y["info-container"])},s.createElement("div",{className:y.label},null===G.settings?"NotLoaded":"Ready"===G.settings.type?e("SETTINGS_SERVER_STATUS_ONLINE"):"Error"===G.settings.type?"".concat(e("SETTINGS_SERVER_STATUS_ERROR"),": (").concat(G.settings.content,")"):G.settings.type))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},"Url")),s.createElement("div",{className:E(y["option-input-container"],y["configure-input-container"])},s.createElement("div",{className:y.label,title:Z.value},Z.value),s.createElement(c,{className:y["configure-button-container"],title:"Configure server url",onClick:re},s.createElement(l,{className:y.icon,icon:"ic_settings"})))),null!==te?s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SERVER_CACHE_SIZE"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},te))):null,null!==oe?s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SERVER_TORRENT_PROFILE"))),s.createElement(O,a({className:E(y["option-input-container"],y["multiselect-container"])},oe))):null),s.createElement("div",{ref:he,className:y["section-container"]},s.createElement("div",{className:y["section-title"]},e("SETTINGS_NAV_SHORTCUTS")),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_PLAY_PAUSE"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,e("SETTINGS_SHORTCUT_SPACE")))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_SEEK_FORWARD"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"→"),s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_OR")),s.createElement("kbd",null,"⇧ ",e("SETTINGS_SHORTCUT_SHIFT")),s.createElement("div",{className:y.label},"+"),s.createElement("kbd",null,"→"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_SEEK_BACKWARD"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"←"),s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_OR")),s.createElement("kbd",null,"⇧ ",e("SETTINGS_SHORTCUT_SHIFT")),s.createElement("div",{className:y.label},"+"),s.createElement("kbd",null,"←"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_VOLUME_UP"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"↑"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_VOLUME_DOWN"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"↓"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_MENU_SUBTITLES"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"S"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_MENU_INFO"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"I"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_FULLSCREEN"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"F"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_NAVIGATE_MENUS"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"1"),s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_TO")),s.createElement("kbd",null,"5"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_GO_TO_SEARCH"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,"0"))),s.createElement("div",{className:y["option-container"]},s.createElement("div",{className:y["option-name-container"]},s.createElement("div",{className:y.label},e("SETTINGS_SHORTCUT_EXIT_BACK"))),s.createElement("div",{className:E(y["option-input-container"],y["shortcut-container"])},s.createElement("kbd",null,e("SETTINGS_SHORTCUT_ESC"))))))),ne?s.createElement(R,{className:y["configure-server-url-modal-container"],title:e("SETTINGS_SERVER_CONFIGURE_TITLE"),buttons:ue,onCloseRequest:ie},s.createElement(m,{ref:se,autoFocus:!0,className:y["server-url-input"],type:"text",defaultValue:Z.value,placeholder:e("SETTINGS_SERVER_CONFIGURE_INPUT"),onSubmit:Ee})):null)}),(function(){return s.createElement(A,{className:y["settings-container"],route:"settings"})}))},2465:(e,t,o)=>{var a=o(5674);e.exports=a},4137:(e,t,o)=>{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{function a(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function n(e){for(var t=1;t{var a=o(7165),n=o(8823),r=o(1901),i=o(7965),s=o(9005),E=o(353),_=o(6375),T=o(2465),l=o(7793),S=o(6732);e.exports={Addons:a,Board:n,Discover:r,Library:i,MetaDetails:s,NotFound:E,Search:_,Settings:T,Player:l,Intro:S}},1099:(e,t,o)=>{var a=o(6729),n=o(5482);e.exports=function(){var e=!1,t=null,o=!1,r=null,i=new a;function s(){e=!0,t=null,o=!1,_()}function E(a){console.error(a),e=!1,t=new Error("Google Cast API not available",{cause:a}),o=!1,_(),r=null}function _(){i.emit("stateChanged")}Object.defineProperties(this,{active:{configurable:!1,enumerable:!0,get:function(){return e}},error:{configurable:!1,enumerable:!0,get:function(){return t}},starting:{configurable:!1,enumerable:!0,get:function(){return o}},transport:{configurable:!1,enumerable:!0,get:function(){return r}}}),this.start=function(){e||t instanceof Error||o||(o=!0,(r=new n).on("init",s),r.on("init-error",E),_())},this.stop=function(){e=!1,t=null,o=!1,_(),null!==r&&(r.removeAllListeners(),r=null)},this.on=function(e,t){i.on(e,t)},this.off=function(e,t){i.off(e,t)}}},5482:(e,t,o)=>{var a=o(6729),n=o(542),r="urn:x-cast:com.stremio",i=2e4,s=null,E=new a;window.__onGCastApiAvailable=function(e){delete window.__onGCastApiAvailable,s=!!e,E.emit("availabilityChanged")};e.exports=function(){var e=new a,t={};function o(o,a){try{var n=JSON.parse(a),r=n.id,i=n.chunk,s=n.index,E=n.length;if(t[r]=t[r]||[],t[r][s]=i,Object.keys(t[r]).length===E){var _=JSON.parse(t[r].join(""));delete t[r],e.emit("message",_)}}catch(t){e.emit("message-error",t)}}function _(t){e.emit(cast.framework.CastSession.APPLICATION_STATUS_CHANGED,t)}function T(t){e.emit(cast.framework.CastSession.APPLICATION_METADATA_CHANGED,t)}function l(t){e.emit(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED,t)}function S(t){e.emit(cast.framework.CastSession.VOLUME_CHANGED,t)}function u(t){e.emit(cast.framework.CastSession.MEDIA_SESSION,t)}function d(t){e.emit(cast.framework.CastContextEventType.CAST_STATE_CHANGED,t)}function c(t){switch(e.emit(cast.framework.CastContextEventType.SESSION_STATE_CHANGED,t),t.sessionState){case cast.framework.SessionState.SESSION_STARTED:t.session.addMessageListener(r,o),t.session.addEventListener(cast.framework.CastSession.APPLICATION_STATUS_CHANGED,_),t.session.addEventListener(cast.framework.CastSession.APPLICATION_METADATA_CHANGED,T),t.session.addEventListener(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED,l),t.session.addEventListener(cast.framework.CastSession.VOLUME_CHANGED,S),t.session.addEventListener(cast.framework.CastSession.MEDIA_SESSION,u);break;case cast.framework.SessionState.SESSION_ENDED:t.session.removeMessageListener(r,o),t.session.removeEventListener(cast.framework.CastSession.APPLICATION_STATUS_CHANGED,_),t.session.removeEventListener(cast.framework.CastSession.APPLICATION_METADATA_CHANGED,T),t.session.removeEventListener(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED,l),t.session.removeEventListener(cast.framework.CastSession.VOLUME_CHANGED,S),t.session.removeEventListener(cast.framework.CastSession.MEDIA_SESSION,u)}}new Promise((function(e,t){function o(){E.off("availabilityChanged",o),s?e():t(new Error("window.cast api not available"))}null!==s?o():E.on("availabilityChanged",o)})).then((function(){cast.framework.CastContext.getInstance().addEventListener(cast.framework.CastContextEventType.CAST_STATE_CHANGED,d),cast.framework.CastContext.getInstance().addEventListener(cast.framework.CastContextEventType.SESSION_STATE_CHANGED,c)})).then((function(){try{e.emit("init")}catch(e){console.error("ChromecastTransport",e)}})).catch((function(t){e.emit("init-error",t)})),this.on=function(t,o){e.on(t,o)},this.off=function(t,o){e.off(t,o)},this.removeAllListeners=function(){e.removeAllListeners()},this.getCastState=function(){return cast.framework.CastContext.getInstance().getCastState()},this.getSessionState=function(){return cast.framework.CastContext.getInstance().getSessionState()},this.getCastDevice=function(){var e=cast.framework.CastContext.getInstance().getCurrentSession();return null!==e?e.getCastDevice():null},this.setOptions=function(e){cast.framework.CastContext.getInstance().setOptions(e)},this.requestSession=function(){return cast.framework.CastContext.getInstance().requestSession()},this.endCurrentSession=function(e){cast.framework.CastContext.getInstance().endCurrentSession(e)},this.sendMessage=function(e){var t=cast.framework.CastContext.getInstance().getCurrentSession();if(null!==t){for(var o=JSON.stringify(e),a=Math.ceil(o.length/i),s=[],E=0;E{var a=o(1099);e.exports=a},6194:(e,t,o)=>{var a=o(6729),n=o(6806);e.exports=function(e){var t=!1,o=null,r=!1,i=null,s=new a;function E(){t=!0,o=null,r=!1,T()}function _(e){console.error(e),t=!1,o=new Error("Stremio Core Transport initialization failed",{cause:e}),r=!1,T(),i=null}function T(){s.emit("stateChanged")}Object.defineProperties(this,{active:{configurable:!1,enumerable:!0,get:function(){return t}},error:{configurable:!1,enumerable:!0,get:function(){return o}},starting:{configurable:!1,enumerable:!0,get:function(){return r}},transport:{configurable:!1,enumerable:!0,get:function(){return i}}}),this.start=function(){t||o instanceof Error||r||(r=!0,(i=new n(e)).on("init",E),i.on("error",_),T())},this.stop=function(){t=!1,o=null,r=!1,T(),null!==i&&(i.removeAllListeners(),i=null)},this.on=function(e,t){s.on(e,t)},this.off=function(e,t){s.off(e,t)}}},6806:(e,t,o)=>{function a(e,t,o,a,n,r,i){try{var s=e[r](i),E=s.value}catch(e){return void o(e)}s.done?t(E):Promise.resolve(E).then(a,n)}function n(e){return function(){var t=this,o=arguments;return new Promise((function(n,r){var i=e.apply(t,o);function s(e){a(i,n,r,s,E,"next",e)}function E(e){a(i,n,r,s,E,"throw",e)}s(void 0)}))}}var r=o(6729),i=o(6553);e.exports=function(e){var t=new r,o=new Worker("".concat("4ffa1a051cd42350e1948a517da3018721508d5d","/scripts/worker.js")),a=new i(window,o);window.onCoreEvent=function(e){var o=e.name,a=e.args;try{t.emit(o,a)}catch(e){console.error("CoreTransport",e)}},a.call(["init"],[e]).then((function(){try{t.emit("init")}catch(e){console.error("CoreTransport",e)}})).catch((function(e){t.emit("error",e)})),this.on=function(e,o){t.on(e,o)},this.off=function(e,o){t.off(e,o)},this.removeAllListeners=function(){t.removeAllListeners()},this.getState=(function(){var e=n(regeneratorRuntime.mark((function e(t){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.abrupt("return",a.call(["getState"],[t]));case 1:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}})(),this.getDebugState=n(regeneratorRuntime.mark((function e(){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.abrupt("return",a.call(["getDebugState"],[]));case 1:case"end":return e.stop()}}),e)}))),this.dispatch=(function(){var e=n(regeneratorRuntime.mark((function e(t,o){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.abrupt("return",a.call(["dispatch"],[t,o,location.hash]));case 1:case"end":return e.stop()}}),e)})));return function(t,o){return e.apply(this,arguments)}})(),this.analytics=(function(){var e=n(regeneratorRuntime.mark((function e(t){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.abrupt("return",a.call(["analytics"],[t,location.hash]));case 1:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}})(),this.decodeStream=(function(){var e=n(regeneratorRuntime.mark((function e(t){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.abrupt("return",a.call(["decodeStream"],[t]));case 1:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}})()}},4937:(e,t,o)=>{var a=o(6194);e.exports=a},8634:(e,t,o)=>{function a(e,t,o,a,n,r,i){try{var s=e[r](i),E=s.value}catch(e){return void o(e)}s.done?t(E):Promise.resolve(E).then(a,n)}function n(e){return function(){var t=this,o=arguments;return new Promise((function(n,r){var i=e.apply(t,o);function s(e){a(i,n,r,s,E,"next",e)}function E(e){a(i,n,r,s,E,"throw",e)}s(void 0)}))}}var r=o(6729);e.exports=function(e){var t=e.core,o=!1,a=new r;function i(e){e.preventDefault()}function s(e){return E.apply(this,arguments)}function E(){return(E=n(regeneratorRuntime.mark((function e(o){var n,r;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(o.preventDefault(),!(o.dataTransfer.files instanceof FileList&&o.dataTransfer.files.length>0)){e.next=18;break}n=o.dataTransfer.files[0],e.t0=n.type,e.next="application/x-bittorrent"===e.t0?6:17;break;case 6:return e.prev=6,e.next=9,n.arrayBuffer();case 9:r=e.sent,t.transport.dispatch({action:"StreamingServer",args:{action:"CreateTorrent",args:Array.from(new Uint8Array(r))}}),e.next=16;break;case 13:e.prev=13,e.t1=e.catch(6),a.emit("error",{message:"Failed to process file",file:{name:n.name,type:n.type}});case 16:return e.abrupt("break",18);case 17:a.emit("error",{message:"Unsupported file",file:{name:n.name,type:n.type}});case 18:case"end":return e.stop()}}),e,null,[[6,13]])})))).apply(this,arguments)}function _(){a.emit("stateChanged")}Object.defineProperties(this,{active:{configurable:!1,enumerable:!0,get:function(){return o}}}),this.start=function(){o||(window.addEventListener("dragover",i),window.addEventListener("drop",s),o=!0,_())},this.stop=function(){window.removeEventListener("dragover",i),window.removeEventListener("drop",s),o=!1,_()},this.on=function(e,t){a.on(e,t)},this.off=function(e,t){a.off(e,t)}}},8500:(e,t,o)=>{var a=o(8634);e.exports=a},9093:(e,t,o)=>{var a=o(6729);e.exports=function(){var e=!1,t=new a;function o(e){if(!(e.keyboardShortcutPrevented||"INPUT"===e.target.tagName||e.ctrlKey||e.altKey||e.shiftKey||e.metaKey))switch(e.code){case"Digit0":e.preventDefault(),window.location="#/search";break;case"Digit1":e.preventDefault(),window.location="#/";break;case"Digit2":e.preventDefault(),window.location="#/discover";break;case"Digit3":e.preventDefault(),window.location="#/library";break;case"Digit4":e.preventDefault(),window.location="#/settings";break;case"Digit5":e.preventDefault(),window.location="#/addons";break;case"Backspace":e.preventDefault(),e.ctrlKey?window.history.forward():window.history.back();break;case"KeyF":e.preventDefault(),document.fullscreenElement===document.documentElement?document.exitFullscreen():document.documentElement.requestFullscreen()}}function n(){t.emit("stateChanged")}Object.defineProperties(this,{active:{configurable:!1,enumerable:!0,get:function(){return e}}}),this.start=function(){e||(window.addEventListener("keydown",o),e=!0,n())},this.stop=function(){window.removeEventListener("keydown",o),e=!1,n()}}},7369:(e,t,o)=>{var a=o(9093);e.exports=a},2207:(e,t,o)=>{var a=o(7294).createContext({});a.displayName="ServicesContext",e.exports=a},8261:(e,t,o)=>{var a=o(7294),n=o(5697),r=o(2207),i=function(e){var t=e.services,o=void 0===t?{}:t,n=e.children;return a.createElement(r.Provider,{value:o},n)};i.propTypes={services:n.object,children:n.oneOfType([n.arrayOf(n.node),n.node])},e.exports=i},3487:(e,t,o)=>{var a=o(8261),n=o(1806);e.exports={ServicesProvider:a,useServices:n}},1806:(e,t,o)=>{var a=o(7294),n=o(2207);e.exports=function(){return a.useContext(n)}},3015:(e,t,o)=>{var a=o(6729),n=o(755);e.exports=function(){var e=!1,t=null,o=!1,r=null,i=new a;function s(){e=!0,t=null,o=!1,_()}function E(a){console.error(a),e=!1,t=new Error(a),o=!1,_(),r=null}function _(){i.emit("stateChanged")}Object.defineProperties(this,{active:{configurable:!1,enumerable:!0,get:function(){return e}},error:{configurable:!1,enumerable:!0,get:function(){return t}},starting:{configurable:!1,enumerable:!0,get:function(){return o}},transport:{configurable:!1,enumerable:!0,get:function(){return r}}}),this.start=function(){e||t instanceof Error||o||(e=!1,o=!0,(r=new n).on("init",s),r.on("init-error",E),_())},this.stop=function(){e=!1,t=null,o=!1,_()},this.on=function(e,t){i.on(e,t)},this.off=function(e,t){i.off(e,t)}}},755:(e,t,o)=>{var a=o(6729),n=!1,r=new a,i=1,s=3,E=6,_=7,T="transport";window.initShellComm=function(){delete window.initShellComm,r.emit("availabilityChanged")};e.exports=function(){var e=new a;this.props={};var t=this;(window.qt?new Promise((function(e){function t(){r.off("availabilityChanged",t),n=!0,e()}n?t():r.on("availabilityChanged",t)})):Promise.reject("Qt API not found")).then((function(){var o=window.qt&&window.qt.webChannelTransport;if(!o)throw"no viable transport found (qt.webChannelTransport)";var a=0;function n(e){e.id=a++,o.send(JSON.stringify(e))}o.onmessage=function(o){var a=JSON.parse(o.data);if(0===a.id){var r=a.data[T];r.properties.slice(1).forEach((function(e){t.props[e[1]]=e[3]})),"string"==typeof t.props.shellVersion&&(t.shellVersionArr=(t.props.shellVersion.match(/(\d+)\.(\d+)\.(\d+)/)||[]).slice(1,4).map(Number)),e.emit("received-props",t.props),r.signals.forEach((function(e){n({type:_,object:T,signal:e[1]})}));var s=r.methods.filter((function(e){return"onEvent"===e[0]}))[0];t.send=function(e,t){n({type:E,object:T,method:s[1],args:[e,t||{}]})},t.send("app-ready",{})}a.object===T&&a.type===i&&e.emit(a.args[0],a.args[1]),e.emit("init")},n({type:s})})).catch((function(t){e.emit("init-error",t)})),this.on=function(t,o){e.on(t,o)},this.off=function(t,o){e.off(t,o)},this.removeAllListeners=function(){e.removeAllListeners()}}},1921:(e,t,o)=>{var a=o(3015);e.exports=a},3662:(e,t,o)=>{var a=o(6623),n=o(4937),r=o(8500),i=o(7369),s=o(3487),E=s.ServicesProvider,_=s.useServices,T=o(1921);e.exports={Chromecast:a,Core:n,DragAndDrop:r,KeyboardShortcuts:i,ServicesProvider:E,useServices:_,Shell:T}},9742:(e,t)=>{"use strict";t.byteLength=function(e){var t=E(e),o=t[0],a=t[1];return 3*(o+a)/4-a},t.toByteArray=function(e){var t,o,r=E(e),i=r[0],s=r[1],_=new n((function(e,t,o){return 3*(t+o)/4-o})(0,i,s)),T=0,l=s>0?i-4:i;for(o=0;o>16&255,_[T++]=t>>8&255,_[T++]=255&t;2===s&&(t=a[e.charCodeAt(o)]<<2|a[e.charCodeAt(o+1)]>>4,_[T++]=255&t);1===s&&(t=a[e.charCodeAt(o)]<<10|a[e.charCodeAt(o+1)]<<4|a[e.charCodeAt(o+2)]>>2,_[T++]=t>>8&255,_[T++]=255&t);return _},t.fromByteArray=function(e){for(var t,a=e.length,n=a%3,r=[],i=16383,s=0,E=a-n;sE?E:s+i));1===n?(t=e[a-1],r.push(o[t>>2]+o[t<<4&63]+"==")):2===n&&(t=(e[a-2]<<8)+e[a-1],r.push(o[t>>10]+o[t>>4&63]+o[t<<2&63]+"="));return r.join("")};for(var o=[],a=[],n="undefined"!=typeof Uint8Array?Uint8Array:Array,r="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",i=0,s=r.length;i0)throw new Error("Invalid string. Length must be a multiple of 4");var o=e.indexOf("=");return-1===o&&(o=t),[o,o===t?0:4-o%4]}function _(e,t,a){for(var n,r,i=[],s=t;s>18&63]+o[r>>12&63]+o[r>>6&63]+o[63&r]);return i.join("")}a["-".charCodeAt(0)]=62,a["_".charCodeAt(0)]=63},7500:e=>{function t(e){return e.reduce(((e,t,o,a)=>{const n=t.split("-").map((e=>parseInt(e)));return e.concat(((e,t=e)=>Array.from({length:t-e+1},((t,o)=>o+e)))(...n))}),[])}e.exports=t,e.exports.parse=t,e.exports.compose=function(e){return e.reduce(((e,t,o,a)=>(0!==o&&t===a[o-1]+1||e.push([]),e[e.length-1].push(t),e)),[]).map((e=>e.length>1?`${e[0]}-${e[e.length-1]}`:`${e[0]}`))}},1206:function(e){e.exports=(function(e){var t={};function o(a){if(t[a])return t[a].exports;var n=t[a]={i:a,l:!1,exports:{}};return e[a].call(n.exports,n,n.exports,o),n.l=!0,n.exports}return o.m=e,o.c=t,o.d=function(e,t,a){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:a})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var a=Object.create(null);if(o.r(a),Object.defineProperty(a,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)o.d(a,n,function(t){return e[t]}.bind(null,n));return a},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=90)})({17:function(e,t,o){"use strict";t.__esModule=!0,t.default=void 0;var a=o(18),n=(function(){function e(){}return e.getFirstMatch=function(e,t){var o=t.match(e);return o&&o.length>0&&o[1]||""},e.getSecondMatch=function(e,t){var o=t.match(e);return o&&o.length>1&&o[2]||""},e.matchAndReturnConst=function(e,t,o){if(e.test(t))return o},e.getWindowsVersionName=function(e){switch(e){case"NT":return"NT";case"XP":case"NT 5.1":return"XP";case"NT 5.0":return"2000";case"NT 5.2":return"2003";case"NT 6.0":return"Vista";case"NT 6.1":return"7";case"NT 6.2":return"8";case"NT 6.3":return"8.1";case"NT 10.0":return"10";default:return}},e.getMacOSVersionName=function(e){var t=e.split(".").splice(0,2).map((function(e){return parseInt(e,10)||0}));if(t.push(0),10===t[0])switch(t[1]){case 5:return"Leopard";case 6:return"Snow Leopard";case 7:return"Lion";case 8:return"Mountain Lion";case 9:return"Mavericks";case 10:return"Yosemite";case 11:return"El Capitan";case 12:return"Sierra";case 13:return"High Sierra";case 14:return"Mojave";case 15:return"Catalina";default:return}},e.getAndroidVersionName=function(e){var t=e.split(".").splice(0,2).map((function(e){return parseInt(e,10)||0}));if(t.push(0),!(1===t[0]&&t[1]<5))return 1===t[0]&&t[1]<6?"Cupcake":1===t[0]&&t[1]>=6?"Donut":2===t[0]&&t[1]<2?"Eclair":2===t[0]&&2===t[1]?"Froyo":2===t[0]&&t[1]>2?"Gingerbread":3===t[0]?"Honeycomb":4===t[0]&&t[1]<1?"Ice Cream Sandwich":4===t[0]&&t[1]<4?"Jelly Bean":4===t[0]&&t[1]>=4?"KitKat":5===t[0]?"Lollipop":6===t[0]?"Marshmallow":7===t[0]?"Nougat":8===t[0]?"Oreo":9===t[0]?"Pie":void 0},e.getVersionPrecision=function(e){return e.split(".").length},e.compareVersions=function(t,o,a){void 0===a&&(a=!1);var n=e.getVersionPrecision(t),r=e.getVersionPrecision(o),i=Math.max(n,r),s=0,E=e.map([t,o],(function(t){var o=i-e.getVersionPrecision(t),a=t+new Array(o+1).join(".0");return e.map(a.split("."),(function(e){return new Array(20-e.length).join("0")+e})).reverse()}));for(a&&(s=i-Math.min(n,r)),i-=1;i>=s;){if(E[0][i]>E[1][i])return 1;if(E[0][i]===E[1][i]){if(i===s)return 0;i-=1}else if(E[0][i]1?n-1:0),i=1;i0){var i=Object.keys(o),E=s.default.find(i,(function(e){return t.isOS(e)}));if(E){var _=this.satisfies(o[E]);if(void 0!==_)return _}var T=s.default.find(i,(function(e){return t.isPlatform(e)}));if(T){var l=this.satisfies(o[T]);if(void 0!==l)return l}}if(r>0){var S=Object.keys(n),u=s.default.find(S,(function(e){return t.isBrowser(e,!0)}));if(void 0!==u)return this.compareVersion(n[u])}},t.isBrowser=function(e,t){void 0===t&&(t=!1);var o=this.getBrowserName().toLowerCase(),a=e.toLowerCase(),n=s.default.getBrowserTypeByAlias(a);return t&&n&&(a=n.toLowerCase()),a===o},t.compareVersion=function(e){var t=[0],o=e,a=!1,n=this.getBrowserVersion();if("string"==typeof n)return">"===e[0]||"<"===e[0]?(o=e.substr(1),"="===e[1]?(a=!0,o=e.substr(2)):t=[],">"===e[0]?t.push(1):t.push(-1)):"="===e[0]?o=e.substr(1):"~"===e[0]&&(a=!0,o=e.substr(1)),t.indexOf(s.default.compareVersions(n,o,a))>-1},t.isOS=function(e){return this.getOSName(!0)===String(e).toLowerCase()},t.isPlatform=function(e){return this.getPlatformType(!0)===String(e).toLowerCase()},t.isEngine=function(e){return this.getEngineName(!0)===String(e).toLowerCase()},t.is=function(e,t){return void 0===t&&(t=!1),this.isBrowser(e,t)||this.isOS(e)||this.isPlatform(e)},t.some=function(e){var t=this;return void 0===e&&(e=[]),e.some((function(e){return t.is(e)}))},e})();t.default=_,e.exports=t.default},92:function(e,t,o){"use strict";t.__esModule=!0,t.default=void 0;var a,n=(a=o(17))&&a.__esModule?a:{default:a},r=/version\/(\d+(\.?_?\d+)+)/i,i=[{test:[/googlebot/i],describe:function(e){var t={name:"Googlebot"},o=n.default.getFirstMatch(/googlebot\/(\d+(\.\d+))/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/opera/i],describe:function(e){var t={name:"Opera"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:opera)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/opr\/|opios/i],describe:function(e){var t={name:"Opera"},o=n.default.getFirstMatch(/(?:opr|opios)[\s/](\S+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/SamsungBrowser/i],describe:function(e){var t={name:"Samsung Internet for Android"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:SamsungBrowser)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/Whale/i],describe:function(e){var t={name:"NAVER Whale Browser"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:whale)[\s/](\d+(?:\.\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/MZBrowser/i],describe:function(e){var t={name:"MZ Browser"},o=n.default.getFirstMatch(/(?:MZBrowser)[\s/](\d+(?:\.\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/focus/i],describe:function(e){var t={name:"Focus"},o=n.default.getFirstMatch(/(?:focus)[\s/](\d+(?:\.\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/swing/i],describe:function(e){var t={name:"Swing"},o=n.default.getFirstMatch(/(?:swing)[\s/](\d+(?:\.\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/coast/i],describe:function(e){var t={name:"Opera Coast"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:coast)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/opt\/\d+(?:.?_?\d+)+/i],describe:function(e){var t={name:"Opera Touch"},o=n.default.getFirstMatch(/(?:opt)[\s/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/yabrowser/i],describe:function(e){var t={name:"Yandex Browser"},o=n.default.getFirstMatch(/(?:yabrowser)[\s/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/ucbrowser/i],describe:function(e){var t={name:"UC Browser"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:ucbrowser)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/Maxthon|mxios/i],describe:function(e){var t={name:"Maxthon"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:Maxthon|mxios)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/epiphany/i],describe:function(e){var t={name:"Epiphany"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:epiphany)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/puffin/i],describe:function(e){var t={name:"Puffin"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:puffin)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/sleipnir/i],describe:function(e){var t={name:"Sleipnir"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:sleipnir)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/k-meleon/i],describe:function(e){var t={name:"K-Meleon"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/(?:k-meleon)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/micromessenger/i],describe:function(e){var t={name:"WeChat"},o=n.default.getFirstMatch(/(?:micromessenger)[\s/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/qqbrowser/i],describe:function(e){var t={name:/qqbrowserlite/i.test(e)?"QQ Browser Lite":"QQ Browser"},o=n.default.getFirstMatch(/(?:qqbrowserlite|qqbrowser)[/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/msie|trident/i],describe:function(e){var t={name:"Internet Explorer"},o=n.default.getFirstMatch(/(?:msie |rv:)(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/\sedg\//i],describe:function(e){var t={name:"Microsoft Edge"},o=n.default.getFirstMatch(/\sedg\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/edg([ea]|ios)/i],describe:function(e){var t={name:"Microsoft Edge"},o=n.default.getSecondMatch(/edg([ea]|ios)\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/vivaldi/i],describe:function(e){var t={name:"Vivaldi"},o=n.default.getFirstMatch(/vivaldi\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/seamonkey/i],describe:function(e){var t={name:"SeaMonkey"},o=n.default.getFirstMatch(/seamonkey\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/sailfish/i],describe:function(e){var t={name:"Sailfish"},o=n.default.getFirstMatch(/sailfish\s?browser\/(\d+(\.\d+)?)/i,e);return o&&(t.version=o),t}},{test:[/silk/i],describe:function(e){var t={name:"Amazon Silk"},o=n.default.getFirstMatch(/silk\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/phantom/i],describe:function(e){var t={name:"PhantomJS"},o=n.default.getFirstMatch(/phantomjs\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/slimerjs/i],describe:function(e){var t={name:"SlimerJS"},o=n.default.getFirstMatch(/slimerjs\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/blackberry|\bbb\d+/i,/rim\stablet/i],describe:function(e){var t={name:"BlackBerry"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/blackberry[\d]+\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/(web|hpw)[o0]s/i],describe:function(e){var t={name:"WebOS Browser"},o=n.default.getFirstMatch(r,e)||n.default.getFirstMatch(/w(?:eb)?[o0]sbrowser\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/bada/i],describe:function(e){var t={name:"Bada"},o=n.default.getFirstMatch(/dolfin\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/tizen/i],describe:function(e){var t={name:"Tizen"},o=n.default.getFirstMatch(/(?:tizen\s?)?browser\/(\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/qupzilla/i],describe:function(e){var t={name:"QupZilla"},o=n.default.getFirstMatch(/(?:qupzilla)[\s/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/firefox|iceweasel|fxios/i],describe:function(e){var t={name:"Firefox"},o=n.default.getFirstMatch(/(?:firefox|iceweasel|fxios)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/electron/i],describe:function(e){var t={name:"Electron"},o=n.default.getFirstMatch(/(?:electron)\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/MiuiBrowser/i],describe:function(e){var t={name:"Miui"},o=n.default.getFirstMatch(/(?:MiuiBrowser)[\s/](\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/chromium/i],describe:function(e){var t={name:"Chromium"},o=n.default.getFirstMatch(/(?:chromium)[\s/](\d+(\.?_?\d+)+)/i,e)||n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/chrome|crios|crmo/i],describe:function(e){var t={name:"Chrome"},o=n.default.getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/GSA/i],describe:function(e){var t={name:"Google Search"},o=n.default.getFirstMatch(/(?:GSA)\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:function(e){var t=!e.test(/like android/i),o=e.test(/android/i);return t&&o},describe:function(e){var t={name:"Android Browser"},o=n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/playstation 4/i],describe:function(e){var t={name:"PlayStation 4"},o=n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/safari|applewebkit/i],describe:function(e){var t={name:"Safari"},o=n.default.getFirstMatch(r,e);return o&&(t.version=o),t}},{test:[/.*/i],describe:function(e){var t=-1!==e.search("\\(")?/^(.*)\/(.*)[ \t]\((.*)/:/^(.*)\/(.*) /;return{name:n.default.getFirstMatch(t,e),version:n.default.getSecondMatch(t,e)}}}];t.default=i,e.exports=t.default},93:function(e,t,o){"use strict";t.__esModule=!0,t.default=void 0;var a,n=(a=o(17))&&a.__esModule?a:{default:a},r=o(18),i=[{test:[/Roku\/DVP/],describe:function(e){var t=n.default.getFirstMatch(/Roku\/DVP-(\d+\.\d+)/i,e);return{name:r.OS_MAP.Roku,version:t}}},{test:[/windows phone/i],describe:function(e){var t=n.default.getFirstMatch(/windows phone (?:os)?\s?(\d+(\.\d+)*)/i,e);return{name:r.OS_MAP.WindowsPhone,version:t}}},{test:[/windows /i],describe:function(e){var t=n.default.getFirstMatch(/Windows ((NT|XP)( \d\d?.\d)?)/i,e),o=n.default.getWindowsVersionName(t);return{name:r.OS_MAP.Windows,version:t,versionName:o}}},{test:[/Macintosh(.*?) FxiOS(.*?)\//],describe:function(e){var t={name:r.OS_MAP.iOS},o=n.default.getSecondMatch(/(Version\/)(\d[\d.]+)/,e);return o&&(t.version=o),t}},{test:[/macintosh/i],describe:function(e){var t=n.default.getFirstMatch(/mac os x (\d+(\.?_?\d+)+)/i,e).replace(/[_\s]/g,"."),o=n.default.getMacOSVersionName(t),a={name:r.OS_MAP.MacOS,version:t};return o&&(a.versionName=o),a}},{test:[/(ipod|iphone|ipad)/i],describe:function(e){var t=n.default.getFirstMatch(/os (\d+([_\s]\d+)*) like mac os x/i,e).replace(/[_\s]/g,".");return{name:r.OS_MAP.iOS,version:t}}},{test:function(e){var t=!e.test(/like android/i),o=e.test(/android/i);return t&&o},describe:function(e){var t=n.default.getFirstMatch(/android[\s/-](\d+(\.\d+)*)/i,e),o=n.default.getAndroidVersionName(t),a={name:r.OS_MAP.Android,version:t};return o&&(a.versionName=o),a}},{test:[/(web|hpw)[o0]s/i],describe:function(e){var t=n.default.getFirstMatch(/(?:web|hpw)[o0]s\/(\d+(\.\d+)*)/i,e),o={name:r.OS_MAP.WebOS};return t&&t.length&&(o.version=t),o}},{test:[/blackberry|\bbb\d+/i,/rim\stablet/i],describe:function(e){var t=n.default.getFirstMatch(/rim\stablet\sos\s(\d+(\.\d+)*)/i,e)||n.default.getFirstMatch(/blackberry\d+\/(\d+([_\s]\d+)*)/i,e)||n.default.getFirstMatch(/\bbb(\d+)/i,e);return{name:r.OS_MAP.BlackBerry,version:t}}},{test:[/bada/i],describe:function(e){var t=n.default.getFirstMatch(/bada\/(\d+(\.\d+)*)/i,e);return{name:r.OS_MAP.Bada,version:t}}},{test:[/tizen/i],describe:function(e){var t=n.default.getFirstMatch(/tizen[/\s](\d+(\.\d+)*)/i,e);return{name:r.OS_MAP.Tizen,version:t}}},{test:[/linux/i],describe:function(){return{name:r.OS_MAP.Linux}}},{test:[/CrOS/],describe:function(){return{name:r.OS_MAP.ChromeOS}}},{test:[/PlayStation 4/],describe:function(e){var t=n.default.getFirstMatch(/PlayStation 4[/\s](\d+(\.\d+)*)/i,e);return{name:r.OS_MAP.PlayStation4,version:t}}}];t.default=i,e.exports=t.default},94:function(e,t,o){"use strict";t.__esModule=!0,t.default=void 0;var a,n=(a=o(17))&&a.__esModule?a:{default:a},r=o(18),i=[{test:[/googlebot/i],describe:function(){return{type:"bot",vendor:"Google"}}},{test:[/huawei/i],describe:function(e){var t=n.default.getFirstMatch(/(can-l01)/i,e)&&"Nova",o={type:r.PLATFORMS_MAP.mobile,vendor:"Huawei"};return t&&(o.model=t),o}},{test:[/nexus\s*(?:7|8|9|10).*/i],describe:function(){return{type:r.PLATFORMS_MAP.tablet,vendor:"Nexus"}}},{test:[/ipad/i],describe:function(){return{type:r.PLATFORMS_MAP.tablet,vendor:"Apple",model:"iPad"}}},{test:[/Macintosh(.*?) FxiOS(.*?)\//],describe:function(){return{type:r.PLATFORMS_MAP.tablet,vendor:"Apple",model:"iPad"}}},{test:[/kftt build/i],describe:function(){return{type:r.PLATFORMS_MAP.tablet,vendor:"Amazon",model:"Kindle Fire HD 7"}}},{test:[/silk/i],describe:function(){return{type:r.PLATFORMS_MAP.tablet,vendor:"Amazon"}}},{test:[/tablet(?! pc)/i],describe:function(){return{type:r.PLATFORMS_MAP.tablet}}},{test:function(e){var t=e.test(/ipod|iphone/i),o=e.test(/like (ipod|iphone)/i);return t&&!o},describe:function(e){var t=n.default.getFirstMatch(/(ipod|iphone)/i,e);return{type:r.PLATFORMS_MAP.mobile,vendor:"Apple",model:t}}},{test:[/nexus\s*[0-6].*/i,/galaxy nexus/i],describe:function(){return{type:r.PLATFORMS_MAP.mobile,vendor:"Nexus"}}},{test:[/[^-]mobi/i],describe:function(){return{type:r.PLATFORMS_MAP.mobile}}},{test:function(e){return"blackberry"===e.getBrowserName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.mobile,vendor:"BlackBerry"}}},{test:function(e){return"bada"===e.getBrowserName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.mobile}}},{test:function(e){return"windows phone"===e.getBrowserName()},describe:function(){return{type:r.PLATFORMS_MAP.mobile,vendor:"Microsoft"}}},{test:function(e){var t=Number(String(e.getOSVersion()).split(".")[0]);return"android"===e.getOSName(!0)&&t>=3},describe:function(){return{type:r.PLATFORMS_MAP.tablet}}},{test:function(e){return"android"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.mobile}}},{test:function(e){return"macos"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.desktop,vendor:"Apple"}}},{test:function(e){return"windows"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.desktop}}},{test:function(e){return"linux"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.desktop}}},{test:function(e){return"playstation 4"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.tv}}},{test:function(e){return"roku"===e.getOSName(!0)},describe:function(){return{type:r.PLATFORMS_MAP.tv}}}];t.default=i,e.exports=t.default},95:function(e,t,o){"use strict";t.__esModule=!0,t.default=void 0;var a,n=(a=o(17))&&a.__esModule?a:{default:a},r=o(18),i=[{test:function(e){return"microsoft edge"===e.getBrowserName(!0)},describe:function(e){if(/\sedg\//i.test(e))return{name:r.ENGINE_MAP.Blink};var t=n.default.getFirstMatch(/edge\/(\d+(\.?_?\d+)+)/i,e);return{name:r.ENGINE_MAP.EdgeHTML,version:t}}},{test:[/trident/i],describe:function(e){var t={name:r.ENGINE_MAP.Trident},o=n.default.getFirstMatch(/trident\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:function(e){return e.test(/presto/i)},describe:function(e){var t={name:r.ENGINE_MAP.Presto},o=n.default.getFirstMatch(/presto\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:function(e){var t=e.test(/gecko/i),o=e.test(/like gecko/i);return t&&!o},describe:function(e){var t={name:r.ENGINE_MAP.Gecko},o=n.default.getFirstMatch(/gecko\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}},{test:[/(apple)?webkit\/537\.36/i],describe:function(){return{name:r.ENGINE_MAP.Blink}}},{test:[/(apple)?webkit/i],describe:function(e){var t={name:r.ENGINE_MAP.WebKit},o=n.default.getFirstMatch(/webkit\/(\d+(\.?_?\d+)+)/i,e);return o&&(t.version=o),t}}];t.default=i,e.exports=t.default}})},8764:(e,t,o)=>{"use strict";const a=o(9742),n=o(645),r="function"==typeof Symbol&&"function"==typeof Symbol.for?Symbol.for("nodejs.util.inspect.custom"):null;t.Buffer=E,t.SlowBuffer=function(e){+e!=e&&(e=0);return E.alloc(+e)},t.INSPECT_MAX_BYTES=50;const i=2147483647;function s(e){if(e>i)throw new RangeError('The value "'+e+'" is invalid for option "size"');const t=new Uint8Array(e);return Object.setPrototypeOf(t,E.prototype),t}function E(e,t,o){if("number"==typeof e){if("string"==typeof t)throw new TypeError('The "string" argument must be of type string. Received type number');return l(e)}return _(e,t,o)}function _(e,t,o){if("string"==typeof e)return(function(e,t){"string"==typeof t&&""!==t||(t="utf8");if(!E.isEncoding(t))throw new TypeError("Unknown encoding: "+t);const o=0|c(e,t);let a=s(o);const n=a.write(e,t);n!==o&&(a=a.slice(0,n));return a})(e,t);if(ArrayBuffer.isView(e))return(function(e){if(X(e,Uint8Array)){const t=new Uint8Array(e);return u(t.buffer,t.byteOffset,t.byteLength)}return S(e)})(e);if(null==e)throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof e);if(X(e,ArrayBuffer)||e&&X(e.buffer,ArrayBuffer))return u(e,t,o);if("undefined"!=typeof SharedArrayBuffer&&(X(e,SharedArrayBuffer)||e&&X(e.buffer,SharedArrayBuffer)))return u(e,t,o);if("number"==typeof e)throw new TypeError('The "value" argument must not be of type number. Received type number');const a=e.valueOf&&e.valueOf();if(null!=a&&a!==e)return E.from(a,t,o);const n=(function(e){if(E.isBuffer(e)){const t=0|d(e.length),o=s(t);return 0===o.length||e.copy(o,0,0,t),o}if(void 0!==e.length)return"number"!=typeof e.length||$(e.length)?s(0):S(e);if("Buffer"===e.type&&Array.isArray(e.data))return S(e.data)})(e);if(n)return n;if("undefined"!=typeof Symbol&&null!=Symbol.toPrimitive&&"function"==typeof e[Symbol.toPrimitive])return E.from(e[Symbol.toPrimitive]("string"),t,o);throw new TypeError("The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type "+typeof e)}function T(e){if("number"!=typeof e)throw new TypeError('"size" argument must be of type number');if(e<0)throw new RangeError('The value "'+e+'" is invalid for option "size"')}function l(e){return T(e),s(e<0?0:0|d(e))}function S(e){const t=e.length<0?0:0|d(e.length),o=s(t);for(let a=0;a=i)throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x"+i.toString(16)+" bytes");return 0|e}function c(e,t){if(E.isBuffer(e))return e.length;if(ArrayBuffer.isView(e)||X(e,ArrayBuffer))return e.byteLength;if("string"!=typeof e)throw new TypeError('The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type '+typeof e);const o=e.length,a=arguments.length>2&&!0===arguments[2];if(!a&&0===o)return 0;let n=!1;for(;;)switch(t){case"ascii":case"latin1":case"binary":return o;case"utf8":case"utf-8":return K(e).length;case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return 2*o;case"hex":return o>>>1;case"base64":return j(e).length;default:if(n)return a?-1:K(e).length;t=(""+t).toLowerCase(),n=!0}}function I(e,t,o){let a=!1;if((void 0===t||t<0)&&(t=0),t>this.length)return"";if((void 0===o||o>this.length)&&(o=this.length),o<=0)return"";if((o>>>=0)<=(t>>>=0))return"";for(e||(e="utf8");;)switch(e){case"hex":return y(this,t,o);case"utf8":case"utf-8":return C(this,t,o);case"ascii":return g(this,t,o);case"latin1":case"binary":return v(this,t,o);case"base64":return L(this,t,o);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return P(this,t,o);default:if(a)throw new TypeError("Unknown encoding: "+e);e=(e+"").toLowerCase(),a=!0}}function A(e,t,o){const a=e[t];e[t]=e[o],e[o]=a}function O(e,t,o,a,n){if(0===e.length)return-1;if("string"==typeof o?(a=o,o=0):o>2147483647?o=2147483647:o<-2147483648&&(o=-2147483648),$(o=+o)&&(o=n?0:e.length-1),o<0&&(o=e.length+o),o>=e.length){if(n)return-1;o=e.length-1}else if(o<0){if(!n)return-1;o=0}if("string"==typeof t&&(t=E.from(t,a)),E.isBuffer(t))return 0===t.length?-1:N(e,t,o,a,n);if("number"==typeof t)return t&=255,"function"==typeof Uint8Array.prototype.indexOf?n?Uint8Array.prototype.indexOf.call(e,t,o):Uint8Array.prototype.lastIndexOf.call(e,t,o):N(e,[t],o,a,n);throw new TypeError("val must be string, number or Buffer")}function N(e,t,o,a,n){let r,i=1,s=e.length,E=t.length;if(void 0!==a&&("ucs2"===(a=String(a).toLowerCase())||"ucs-2"===a||"utf16le"===a||"utf-16le"===a)){if(e.length<2||t.length<2)return-1;i=2,s/=2,E/=2,o/=2}function _(e,t){return 1===i?e[t]:e.readUInt16BE(t*i)}if(n){let a=-1;for(r=o;rs&&(o=s-E),r=o;r>=0;r--){let o=!0;for(let a=0;an&&(a=n):a=n;const r=t.length;let i;for(a>r/2&&(a=r/2),i=0;i>8,n=o%256,r.push(n),r.push(a);return r})(t,e.length-o),e,o,a)}function L(e,t,o){return 0===t&&o===e.length?a.fromByteArray(e):a.fromByteArray(e.slice(t,o))}function C(e,t,o){o=Math.min(e.length,o);const a=[];let n=t;for(;n239?4:t>223?3:t>191?2:1;if(n+i<=o){let o,a,s,E;switch(i){case 1:t<128&&(r=t);break;case 2:o=e[n+1],128==(192&o)&&(E=(31&t)<<6|63&o,E>127&&(r=E));break;case 3:o=e[n+1],a=e[n+2],128==(192&o)&&128==(192&a)&&(E=(15&t)<<12|(63&o)<<6|63&a,E>2047&&(E<55296||E>57343)&&(r=E));break;case 4:o=e[n+1],a=e[n+2],s=e[n+3],128==(192&o)&&128==(192&a)&&128==(192&s)&&(E=(15&t)<<18|(63&o)<<12|(63&a)<<6|63&s,E>65535&&E<1114112&&(r=E))}}null===r?(r=65533,i=1):r>65535&&(r-=65536,a.push(r>>>10&1023|55296),r=56320|1023&r),a.push(r),n+=i}return(function(e){const t=e.length;if(t<=D)return String.fromCharCode.apply(String,e);let o="",a=0;for(;aa.length?(E.isBuffer(t)||(t=E.from(t)),t.copy(a,n)):Uint8Array.prototype.set.call(a,t,n);else{if(!E.isBuffer(t))throw new TypeError('"list" argument must be an Array of Buffers');t.copy(a,n)}n+=t.length}return a},E.byteLength=c,E.prototype._isBuffer=!0,E.prototype.swap16=function(){const e=this.length;if(e%2!=0)throw new RangeError("Buffer size must be a multiple of 16-bits");for(let t=0;to&&(e+=" ... "),""},r&&(E.prototype[r]=E.prototype.inspect),E.prototype.compare=function(e,t,o,a,n){if(X(e,Uint8Array)&&(e=E.from(e,e.offset,e.byteLength)),!E.isBuffer(e))throw new TypeError('The "target" argument must be one of type Buffer or Uint8Array. Received type '+typeof e);if(void 0===t&&(t=0),void 0===o&&(o=e?e.length:0),void 0===a&&(a=0),void 0===n&&(n=this.length),t<0||o>e.length||a<0||n>this.length)throw new RangeError("out of range index");if(a>=n&&t>=o)return 0;if(a>=n)return-1;if(t>=o)return 1;if(this===e)return 0;let r=(n>>>=0)-(a>>>=0),i=(o>>>=0)-(t>>>=0);const s=Math.min(r,i),_=this.slice(a,n),T=e.slice(t,o);for(let e=0;e>>=0,isFinite(o)?(o>>>=0,void 0===a&&(a="utf8")):(a=o,o=void 0)}const n=this.length-t;if((void 0===o||o>n)&&(o=n),e.length>0&&(o<0||t<0)||t>this.length)throw new RangeError("Attempt to write outside buffer bounds");a||(a="utf8");let r=!1;for(;;)switch(a){case"hex":return m(this,e,t,o);case"utf8":case"utf-8":return R(this,e,t,o);case"ascii":case"latin1":case"binary":return p(this,e,t,o);case"base64":return h(this,e,t,o);case"ucs2":case"ucs-2":case"utf16le":case"utf-16le":return f(this,e,t,o);default:if(r)throw new TypeError("Unknown encoding: "+a);a=(""+a).toLowerCase(),r=!0}},E.prototype.toJSON=function(){return{type:"Buffer",data:Array.prototype.slice.call(this._arr||this,0)}};const D=4096;function g(e,t,o){let a="";o=Math.min(e.length,o);for(let n=t;na)&&(o=a);let n="";for(let a=t;ao)throw new RangeError("Trying to access beyond buffer length")}function b(e,t,o,a,n,r){if(!E.isBuffer(e))throw new TypeError('"buffer" argument must be a Buffer instance');if(t>n||te.length)throw new RangeError("Index out of range")}function M(e,t,o,a,n){V(t,a,n,e,o,7);let r=Number(t&BigInt(4294967295));e[o++]=r,r>>=8,e[o++]=r,r>>=8,e[o++]=r,r>>=8,e[o++]=r;let i=Number(t>>BigInt(32)&BigInt(4294967295));return e[o++]=i,i>>=8,e[o++]=i,i>>=8,e[o++]=i,i>>=8,e[o++]=i,o}function U(e,t,o,a,n){V(t,a,n,e,o,7);let r=Number(t&BigInt(4294967295));e[o+7]=r,r>>=8,e[o+6]=r,r>>=8,e[o+5]=r,r>>=8,e[o+4]=r;let i=Number(t>>BigInt(32)&BigInt(4294967295));return e[o+3]=i,i>>=8,e[o+2]=i,i>>=8,e[o+1]=i,i>>=8,e[o]=i,o+8}function W(e,t,o,a,n,r){if(o+a>e.length)throw new RangeError("Index out of range");if(o<0)throw new RangeError("Index out of range")}function G(e,t,o,a,r){return t=+t,o>>>=0,r||W(e,0,o,4),n.write(e,t,o,a,23,4),o+4}function F(e,t,o,a,r){return t=+t,o>>>=0,r||W(e,0,o,8),n.write(e,t,o,a,52,8),o+8}E.prototype.slice=function(e,t){const o=this.length;(e=~~e)<0?(e+=o)<0&&(e=0):e>o&&(e=o),(t=void 0===t?o:~~t)<0?(t+=o)<0&&(t=0):t>o&&(t=o),t>>=0,t>>>=0,o||B(e,t,this.length);let a=this[e],n=1,r=0;for(;++r>>=0,t>>>=0,o||B(e,t,this.length);let a=this[e+--t],n=1;for(;t>0&&(n*=256);)a+=this[e+--t]*n;return a},E.prototype.readUint8=E.prototype.readUInt8=function(e,t){return e>>>=0,t||B(e,1,this.length),this[e]},E.prototype.readUint16LE=E.prototype.readUInt16LE=function(e,t){return e>>>=0,t||B(e,2,this.length),this[e]|this[e+1]<<8},E.prototype.readUint16BE=E.prototype.readUInt16BE=function(e,t){return e>>>=0,t||B(e,2,this.length),this[e]<<8|this[e+1]},E.prototype.readUint32LE=E.prototype.readUInt32LE=function(e,t){return e>>>=0,t||B(e,4,this.length),(this[e]|this[e+1]<<8|this[e+2]<<16)+16777216*this[e+3]},E.prototype.readUint32BE=E.prototype.readUInt32BE=function(e,t){return e>>>=0,t||B(e,4,this.length),16777216*this[e]+(this[e+1]<<16|this[e+2]<<8|this[e+3])},E.prototype.readBigUInt64LE=J((function(e){Y(e>>>=0,"offset");const t=this[e],o=this[e+7];void 0!==t&&void 0!==o||z(e,this.length-8);const a=t+256*this[++e]+65536*this[++e]+this[++e]*2**24,n=this[++e]+256*this[++e]+65536*this[++e]+o*2**24;return BigInt(a)+(BigInt(n)<>>=0,"offset");const t=this[e],o=this[e+7];void 0!==t&&void 0!==o||z(e,this.length-8);const a=t*2**24+65536*this[++e]+256*this[++e]+this[++e],n=this[++e]*2**24+65536*this[++e]+256*this[++e]+o;return(BigInt(a)<>>=0,t>>>=0,o||B(e,t,this.length);let a=this[e],n=1,r=0;for(;++r=n&&(a-=Math.pow(2,8*t)),a},E.prototype.readIntBE=function(e,t,o){e>>>=0,t>>>=0,o||B(e,t,this.length);let a=t,n=1,r=this[e+--a];for(;a>0&&(n*=256);)r+=this[e+--a]*n;return n*=128,r>=n&&(r-=Math.pow(2,8*t)),r},E.prototype.readInt8=function(e,t){return e>>>=0,t||B(e,1,this.length),128&this[e]?-1*(255-this[e]+1):this[e]},E.prototype.readInt16LE=function(e,t){e>>>=0,t||B(e,2,this.length);const o=this[e]|this[e+1]<<8;return 32768&o?4294901760|o:o},E.prototype.readInt16BE=function(e,t){e>>>=0,t||B(e,2,this.length);const o=this[e+1]|this[e]<<8;return 32768&o?4294901760|o:o},E.prototype.readInt32LE=function(e,t){return e>>>=0,t||B(e,4,this.length),this[e]|this[e+1]<<8|this[e+2]<<16|this[e+3]<<24},E.prototype.readInt32BE=function(e,t){return e>>>=0,t||B(e,4,this.length),this[e]<<24|this[e+1]<<16|this[e+2]<<8|this[e+3]},E.prototype.readBigInt64LE=J((function(e){Y(e>>>=0,"offset");const t=this[e],o=this[e+7];void 0!==t&&void 0!==o||z(e,this.length-8);const a=this[e+4]+256*this[e+5]+65536*this[e+6]+(o<<24);return(BigInt(a)<>>=0,"offset");const t=this[e],o=this[e+7];void 0!==t&&void 0!==o||z(e,this.length-8);const a=(t<<24)+65536*this[++e]+256*this[++e]+this[++e];return(BigInt(a)<>>=0,t||B(e,4,this.length),n.read(this,e,!0,23,4)},E.prototype.readFloatBE=function(e,t){return e>>>=0,t||B(e,4,this.length),n.read(this,e,!1,23,4)},E.prototype.readDoubleLE=function(e,t){return e>>>=0,t||B(e,8,this.length),n.read(this,e,!0,52,8)},E.prototype.readDoubleBE=function(e,t){return e>>>=0,t||B(e,8,this.length),n.read(this,e,!1,52,8)},E.prototype.writeUintLE=E.prototype.writeUIntLE=function(e,t,o,a){if(e=+e,t>>>=0,o>>>=0,!a){b(this,e,t,o,Math.pow(2,8*o)-1,0)}let n=1,r=0;for(this[t]=255&e;++r>>=0,o>>>=0,!a){b(this,e,t,o,Math.pow(2,8*o)-1,0)}let n=o-1,r=1;for(this[t+n]=255&e;--n>=0&&(r*=256);)this[t+n]=e/r&255;return t+o},E.prototype.writeUint8=E.prototype.writeUInt8=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,1,255,0),this[t]=255&e,t+1},E.prototype.writeUint16LE=E.prototype.writeUInt16LE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,2,65535,0),this[t]=255&e,this[t+1]=e>>>8,t+2},E.prototype.writeUint16BE=E.prototype.writeUInt16BE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,2,65535,0),this[t]=e>>>8,this[t+1]=255&e,t+2},E.prototype.writeUint32LE=E.prototype.writeUInt32LE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,4,4294967295,0),this[t+3]=e>>>24,this[t+2]=e>>>16,this[t+1]=e>>>8,this[t]=255&e,t+4},E.prototype.writeUint32BE=E.prototype.writeUInt32BE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,4,4294967295,0),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},E.prototype.writeBigUInt64LE=J((function(e,t=0){return M(this,e,t,BigInt(0),BigInt("0xffffffffffffffff"))})),E.prototype.writeBigUInt64BE=J((function(e,t=0){return U(this,e,t,BigInt(0),BigInt("0xffffffffffffffff"))})),E.prototype.writeIntLE=function(e,t,o,a){if(e=+e,t>>>=0,!a){const a=Math.pow(2,8*o-1);b(this,e,t,o,a-1,-a)}let n=0,r=1,i=0;for(this[t]=255&e;++n>0)-i&255;return t+o},E.prototype.writeIntBE=function(e,t,o,a){if(e=+e,t>>>=0,!a){const a=Math.pow(2,8*o-1);b(this,e,t,o,a-1,-a)}let n=o-1,r=1,i=0;for(this[t+n]=255&e;--n>=0&&(r*=256);)e<0&&0===i&&0!==this[t+n+1]&&(i=1),this[t+n]=(e/r>>0)-i&255;return t+o},E.prototype.writeInt8=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,1,127,-128),e<0&&(e=255+e+1),this[t]=255&e,t+1},E.prototype.writeInt16LE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,2,32767,-32768),this[t]=255&e,this[t+1]=e>>>8,t+2},E.prototype.writeInt16BE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,2,32767,-32768),this[t]=e>>>8,this[t+1]=255&e,t+2},E.prototype.writeInt32LE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,4,2147483647,-2147483648),this[t]=255&e,this[t+1]=e>>>8,this[t+2]=e>>>16,this[t+3]=e>>>24,t+4},E.prototype.writeInt32BE=function(e,t,o){return e=+e,t>>>=0,o||b(this,e,t,4,2147483647,-2147483648),e<0&&(e=4294967295+e+1),this[t]=e>>>24,this[t+1]=e>>>16,this[t+2]=e>>>8,this[t+3]=255&e,t+4},E.prototype.writeBigInt64LE=J((function(e,t=0){return M(this,e,t,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),E.prototype.writeBigInt64BE=J((function(e,t=0){return U(this,e,t,-BigInt("0x8000000000000000"),BigInt("0x7fffffffffffffff"))})),E.prototype.writeFloatLE=function(e,t,o){return G(this,e,t,!0,o)},E.prototype.writeFloatBE=function(e,t,o){return G(this,e,t,!1,o)},E.prototype.writeDoubleLE=function(e,t,o){return F(this,e,t,!0,o)},E.prototype.writeDoubleBE=function(e,t,o){return F(this,e,t,!1,o)},E.prototype.copy=function(e,t,o,a){if(!E.isBuffer(e))throw new TypeError("argument should be a Buffer");if(o||(o=0),a||0===a||(a=this.length),t>=e.length&&(t=e.length),t||(t=0),a>0&&a=this.length)throw new RangeError("Index out of range");if(a<0)throw new RangeError("sourceEnd out of bounds");a>this.length&&(a=this.length),e.length-t>>=0,o=void 0===o?this.length:o>>>0,e||(e=0),"number"==typeof e)for(n=t;n=a+4;o-=3)t=`_${e.slice(o-3,o)}${t}`;return`${e.slice(0,o)}${t}`}function V(e,t,o,a,n,r){if(e>o||e3?0===t||t===BigInt(0)?`>= 0${a} and < 2${a} ** ${8*(r+1)}${a}`:`>= -(2${a} ** ${8*(r+1)-1}${a}) and < 2 ** ${8*(r+1)-1}${a}`:`>= ${t}${a} and <= ${o}${a}`,new k.ERR_OUT_OF_RANGE("value",n,e)}!(function(e,t,o){Y(t,"offset"),void 0!==e[t]&&void 0!==e[t+o]||z(t,e.length-(o+1))})(a,n,r)}function Y(e,t){if("number"!=typeof e)throw new k.ERR_INVALID_ARG_TYPE(t,"number",e)}function z(e,t,o){if(Math.floor(e)!==e)throw Y(e,o),new k.ERR_OUT_OF_RANGE(o||"offset","an integer",e);if(t<0)throw new k.ERR_BUFFER_OUT_OF_BOUNDS;throw new k.ERR_OUT_OF_RANGE(o||"offset",`>= ${o?1:0} and <= ${t}`,e)}w("ERR_BUFFER_OUT_OF_BOUNDS",(function(e){return e?`${e} is outside of buffer bounds`:"Attempt to access memory outside buffer bounds"}),RangeError),w("ERR_INVALID_ARG_TYPE",(function(e,t){return`The "${e}" argument must be of type number. Received type ${typeof t}`}),TypeError),w("ERR_OUT_OF_RANGE",(function(e,t,o){let a=`The value of "${e}" is out of range.`,n=o;return Number.isInteger(o)&&Math.abs(o)>2**32?n=H(String(o)):"bigint"==typeof o&&(n=String(o),(o>BigInt(2)**BigInt(32)||o<-(BigInt(2)**BigInt(32)))&&(n=H(n)),n+="n"),a+=` It must be ${t}. Received ${n}`,a}),RangeError);const x=/[^+/0-9A-Za-z-_]/g;function K(e,t){let o;t=t||1/0;const a=e.length;let n=null;const r=[];for(let i=0;i55295&&o<57344){if(!n){if(o>56319){(t-=3)>-1&&r.push(239,191,189);continue}if(i+1===a){(t-=3)>-1&&r.push(239,191,189);continue}n=o;continue}if(o<56320){(t-=3)>-1&&r.push(239,191,189),n=o;continue}o=65536+(n-55296<<10|o-56320)}else n&&(t-=3)>-1&&r.push(239,191,189);if(n=null,o<128){if((t-=1)<0)break;r.push(o)}else if(o<2048){if((t-=2)<0)break;r.push(o>>6|192,63&o|128)}else if(o<65536){if((t-=3)<0)break;r.push(o>>12|224,o>>6&63|128,63&o|128)}else{if(!(o<1114112))throw new Error("Invalid code point");if((t-=4)<0)break;r.push(o>>18|240,o>>12&63|128,o>>6&63|128,63&o|128)}}return r}function j(e){return a.toByteArray((function(e){if((e=(e=e.split("=")[0]).trim().replace(x,"")).length<2)return"";for(;e.length%4!=0;)e+="=";return e})(e))}function Q(e,t,o,a){let n;for(n=0;n=t.length||n>=e.length);++n)t[n+o]=e[n];return n}function X(e,t){return e instanceof t||null!=e&&null!=e.constructor&&null!=e.constructor.name&&e.constructor.name===t.name}function $(e){return e!=e}const q=(function(){const e="0123456789abcdef",t=new Array(256);for(let o=0;o<16;++o){const a=16*o;for(let n=0;n<16;++n)t[a+n]=e[o]+e[n]}return t})();function J(e){return"undefined"==typeof BigInt?Z:e}function Z(){throw new Error("BigInt not supported")}},4184:(e,t)=>{var o;!(function(){"use strict";var a={}.hasOwnProperty;function n(){for(var e=[],t=0;t{"use strict";e.exports={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]}},9818:(e,t,o)=>{var a=o(8874),n=o(1110),r=Object.hasOwnProperty,i=Object.create(null);for(var s in a)r.call(a,s)&&(i[a[s]]=s);var E=e.exports={to:{},get:{}};function _(e,t,o){return Math.min(Math.max(t,e),o)}function T(e){var t=Math.round(e).toString(16).toUpperCase();return t.length<2?"0"+t:t}E.get=function(e){var t,o;switch(e.substring(0,3).toLowerCase()){case"hsl":t=E.get.hsl(e),o="hsl";break;case"hwb":t=E.get.hwb(e),o="hwb";break;default:t=E.get.rgb(e),o="rgb"}return t?{model:o,value:t}:null},E.get.rgb=function(e){if(!e)return null;var t,o,n,i=[0,0,0,1];if(t=e.match(/^#([a-f0-9]{6})([a-f0-9]{2})?$/i)){for(n=t[2],t=t[1],o=0;o<3;o++){var s=2*o;i[o]=parseInt(t.slice(s,s+2),16)}n&&(i[3]=parseInt(n,16)/255)}else if(t=e.match(/^#([a-f0-9]{3,4})$/i)){for(n=(t=t[1])[3],o=0;o<3;o++)i[o]=parseInt(t[o]+t[o],16);n&&(i[3]=parseInt(n+n,16)/255)}else if(t=e.match(/^rgba?\(\s*([+-]?\d+)(?=[\s,])\s*(?:,\s*)?([+-]?\d+)(?=[\s,])\s*(?:,\s*)?([+-]?\d+)\s*(?:[,|\/]\s*([+-]?[\d\.]+)(%?)\s*)?\)$/)){for(o=0;o<3;o++)i[o]=parseInt(t[o+1],0);t[4]&&(t[5]?i[3]=.01*parseFloat(t[4]):i[3]=parseFloat(t[4]))}else{if(!(t=e.match(/^rgba?\(\s*([+-]?[\d\.]+)\%\s*,?\s*([+-]?[\d\.]+)\%\s*,?\s*([+-]?[\d\.]+)\%\s*(?:[,|\/]\s*([+-]?[\d\.]+)(%?)\s*)?\)$/)))return(t=e.match(/^(\w+)$/))?"transparent"===t[1]?[0,0,0,0]:r.call(a,t[1])?((i=a[t[1]])[3]=1,i):null:null;for(o=0;o<3;o++)i[o]=Math.round(2.55*parseFloat(t[o+1]));t[4]&&(t[5]?i[3]=.01*parseFloat(t[4]):i[3]=parseFloat(t[4]))}for(o=0;o<3;o++)i[o]=_(i[o],0,255);return i[3]=_(i[3],0,1),i},E.get.hsl=function(e){if(!e)return null;var t=e.match(/^hsla?\(\s*([+-]?(?:\d{0,3}\.)?\d+)(?:deg)?\s*,?\s*([+-]?[\d\.]+)%\s*,?\s*([+-]?[\d\.]+)%\s*(?:[,|\/]\s*([+-]?(?=\.\d|\d)(?:0|[1-9]\d*)?(?:\.\d*)?(?:[eE][+-]?\d+)?)\s*)?\)$/);if(t){var o=parseFloat(t[4]);return[(parseFloat(t[1])%360+360)%360,_(parseFloat(t[2]),0,100),_(parseFloat(t[3]),0,100),_(isNaN(o)?1:o,0,1)]}return null},E.get.hwb=function(e){if(!e)return null;var t=e.match(/^hwb\(\s*([+-]?\d{0,3}(?:\.\d+)?)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?(?=\.\d|\d)(?:0|[1-9]\d*)?(?:\.\d*)?(?:[eE][+-]?\d+)?)\s*)?\)$/);if(t){var o=parseFloat(t[4]);return[(parseFloat(t[1])%360+360)%360,_(parseFloat(t[2]),0,100),_(parseFloat(t[3]),0,100),_(isNaN(o)?1:o,0,1)]}return null},E.to.hex=function(){var e=n(arguments);return"#"+T(e[0])+T(e[1])+T(e[2])+(e[3]<1?T(Math.round(255*e[3])):"")},E.to.rgb=function(){var e=n(arguments);return e.length<4||1===e[3]?"rgb("+Math.round(e[0])+", "+Math.round(e[1])+", "+Math.round(e[2])+")":"rgba("+Math.round(e[0])+", "+Math.round(e[1])+", "+Math.round(e[2])+", "+e[3]+")"},E.to.rgb.percent=function(){var e=n(arguments),t=Math.round(e[0]/255*100),o=Math.round(e[1]/255*100),a=Math.round(e[2]/255*100);return e.length<4||1===e[3]?"rgb("+t+"%, "+o+"%, "+a+"%)":"rgba("+t+"%, "+o+"%, "+a+"%, "+e[3]+")"},E.to.hsl=function(){var e=n(arguments);return e.length<4||1===e[3]?"hsl("+e[0]+", "+e[1]+"%, "+e[2]+"%)":"hsla("+e[0]+", "+e[1]+"%, "+e[2]+"%, "+e[3]+")"},E.to.hwb=function(){var e=n(arguments),t="";return e.length>=4&&1!==e[3]&&(t=", "+e[3]),"hwb("+e[0]+", "+e[1]+"%, "+e[2]+"%"+t+")"},E.to.keyword=function(e){return i[e.slice(0,3)]}},6767:(e,t,o)=>{const a=o(9818),n=o(978),r=["keyword","gray","hex"],i={};for(const e of Object.keys(n))i[[...n[e].labels].sort().join("")]=e;const s={};function E(e,t){if(!(this instanceof E))return new E(e,t);if(t&&t in r&&(t=null),t&&!(t in n))throw new Error("Unknown model: "+t);let o,_;if(null==e)this.model="rgb",this.color=[0,0,0],this.valpha=1;else if(e instanceof E)this.model=e.model,this.color=[...e.color],this.valpha=e.valpha;else if("string"==typeof e){const t=a.get(e);if(null===t)throw new Error("Unable to parse color from string: "+e);this.model=t.model,_=n[this.model].channels,this.color=t.value.slice(0,_),this.valpha="number"==typeof t.value[_]?t.value[_]:1}else if(e.length>0){this.model=t||"rgb",_=n[this.model].channels;const o=Array.prototype.slice.call(e,0,_);this.color=S(o,_),this.valpha="number"==typeof e[_]?e[_]:1}else if("number"==typeof e)this.model="rgb",this.color=[e>>16&255,e>>8&255,255&e],this.valpha=1;else{this.valpha=1;const t=Object.keys(e);"alpha"in e&&(t.splice(t.indexOf("alpha"),1),this.valpha="number"==typeof e.alpha?e.alpha:0);const a=t.sort().join("");if(!(a in i))throw new Error("Unable to parse color from object: "+JSON.stringify(e));this.model=i[a];const{labels:r}=n[this.model],s=[];for(o=0;o(e%360+360)%360)),saturationl:T("hsl",1,l(100)),lightness:T("hsl",2,l(100)),saturationv:T("hsv",1,l(100)),value:T("hsv",2,l(100)),chroma:T("hcg",1,l(100)),gray:T("hcg",2,l(100)),white:T("hwb",1,l(100)),wblack:T("hwb",2,l(100)),cyan:T("cmyk",0,l(100)),magenta:T("cmyk",1,l(100)),yellow:T("cmyk",2,l(100)),black:T("cmyk",3,l(100)),x:T("xyz",0,l(95.047)),y:T("xyz",1,l(100)),z:T("xyz",2,l(108.833)),l:T("lab",0,l(100)),a:T("lab",1),b:T("lab",2),keyword(e){return void 0!==e?new E(e):n[this.model].keyword(this.color)},hex(e){return void 0!==e?new E(e):a.to.hex(this.rgb().round().color)},hexa(e){if(void 0!==e)return new E(e);const t=this.rgb().round().color;let o=Math.round(255*this.valpha).toString(16).toUpperCase();return 1===o.length&&(o="0"+o),a.to.hex(t)+o},rgbNumber(){const e=this.rgb().color;return(255&e[0])<<16|(255&e[1])<<8|255&e[2]},luminosity(){const e=this.rgb().color,t=[];for(const[o,a]of e.entries()){const e=a/255;t[o]=e<=.04045?e/12.92:((e+.055)/1.055)**2.4}return.2126*t[0]+.7152*t[1]+.0722*t[2]},contrast(e){const t=this.luminosity(),o=e.luminosity();return t>o?(t+.05)/(o+.05):(o+.05)/(t+.05)},level(e){const t=this.contrast(e);return t>=7?"AAA":t>=4.5?"AA":""},isDark(){const e=this.rgb().color;return(2126*e[0]+7152*e[1]+722*e[2])/1e4<128},isLight(){return!this.isDark()},negate(){const e=this.rgb();for(let t=0;t<3;t++)e.color[t]=255-e.color[t];return e},lighten(e){const t=this.hsl();return t.color[2]+=t.color[2]*e,t},darken(e){const t=this.hsl();return t.color[2]-=t.color[2]*e,t},saturate(e){const t=this.hsl();return t.color[1]+=t.color[1]*e,t},desaturate(e){const t=this.hsl();return t.color[1]-=t.color[1]*e,t},whiten(e){const t=this.hwb();return t.color[1]+=t.color[1]*e,t},blacken(e){const t=this.hwb();return t.color[2]+=t.color[2]*e,t},grayscale(){const e=this.rgb().color,t=.3*e[0]+.59*e[1]+.11*e[2];return E.rgb(t,t,t)},fade(e){return this.alpha(this.valpha-this.valpha*e)},opaquer(e){return this.alpha(this.valpha+this.valpha*e)},rotate(e){const t=this.hsl();let o=t.color[0];return o=(o+e)%360,o=o<0?360+o:o,t.color[0]=o,t},mix(e,t){if(!e||!e.rgb)throw new Error('Argument to "mix" was not a Color instance, but rather an instance of '+typeof e);const o=e.rgb(),a=this.rgb(),n=void 0===t?.5:t,r=2*n-1,i=o.alpha()-a.alpha(),s=((r*i==-1?r:(r+i)/(1+r*i))+1)/2,_=1-s;return E.rgb(s*o.red()+_*a.red(),s*o.green()+_*a.green(),s*o.blue()+_*a.blue(),o.alpha()*n+a.alpha()*(1-n))}};for(const e of Object.keys(n)){if(r.includes(e))continue;const{channels:t}=n[e];E.prototype[e]=function(...t){return this.model===e?new E(this):t.length>0?new E(t,e):new E([...(o=n[this.model][e].raw(this.color),Array.isArray(o)?o:[o]),this.valpha],e);var o},E[e]=function(...o){let a=o[0];return"number"==typeof a&&(a=S(o,t)),new E(a,e)}}function _(e){return function(t){return(function(e,t){return Number(e.toFixed(t))})(t,e)}}function T(e,t,o){e=Array.isArray(e)?e:[e];for(const a of e)(s[a]||(s[a]=[]))[t]=o;return e=e[0],function(a){let n;return void 0!==a?(o&&(a=o(a)),n=this[e](),n.color[t]=a,n):(n=this[e]().color[t],o&&(n=o(n)),n)}}function l(e){return function(t){return Math.max(0,Math.min(e,t))}}function S(e,t){for(let o=0;o{const a=o(8900),n={};for(const e of Object.keys(a))n[a[e]]=e;const r={rgb:{channels:3,labels:"rgb"},hsl:{channels:3,labels:"hsl"},hsv:{channels:3,labels:"hsv"},hwb:{channels:3,labels:"hwb"},cmyk:{channels:4,labels:"cmyk"},xyz:{channels:3,labels:"xyz"},lab:{channels:3,labels:"lab"},lch:{channels:3,labels:"lch"},hex:{channels:1,labels:["hex"]},keyword:{channels:1,labels:["keyword"]},ansi16:{channels:1,labels:["ansi16"]},ansi256:{channels:1,labels:["ansi256"]},hcg:{channels:3,labels:["h","c","g"]},apple:{channels:3,labels:["r16","g16","b16"]},gray:{channels:1,labels:["gray"]}};e.exports=r;for(const e of Object.keys(r)){if(!("channels"in r[e]))throw new Error("missing channels property: "+e);if(!("labels"in r[e]))throw new Error("missing channel labels property: "+e);if(r[e].labels.length!==r[e].channels)throw new Error("channel and label counts mismatch: "+e);const{channels:t,labels:o}=r[e];delete r[e].channels,delete r[e].labels,Object.defineProperty(r[e],"channels",{value:t}),Object.defineProperty(r[e],"labels",{value:o})}r.rgb.hsl=function(e){const t=e[0]/255,o=e[1]/255,a=e[2]/255,n=Math.min(t,o,a),r=Math.max(t,o,a),i=r-n;let s,E;r===n?s=0:t===r?s=(o-a)/i:o===r?s=2+(a-t)/i:a===r&&(s=4+(t-o)/i),s=Math.min(60*s,360),s<0&&(s+=360);const _=(n+r)/2;return E=r===n?0:_<=.5?i/(r+n):i/(2-r-n),[s,100*E,100*_]},r.rgb.hsv=function(e){let t,o,a,n,r;const i=e[0]/255,s=e[1]/255,E=e[2]/255,_=Math.max(i,s,E),T=_-Math.min(i,s,E),l=function(e){return(_-e)/6/T+.5};return 0===T?(n=0,r=0):(r=T/_,t=l(i),o=l(s),a=l(E),i===_?n=a-o:s===_?n=1/3+t-a:E===_&&(n=2/3+o-t),n<0?n+=1:n>1&&(n-=1)),[360*n,100*r,100*_]},r.rgb.hwb=function(e){const t=e[0],o=e[1];let a=e[2];const n=r.rgb.hsl(e)[0],i=1/255*Math.min(t,Math.min(o,a));return a=1-1/255*Math.max(t,Math.max(o,a)),[n,100*i,100*a]},r.rgb.cmyk=function(e){const t=e[0]/255,o=e[1]/255,a=e[2]/255,n=Math.min(1-t,1-o,1-a);return[100*((1-t-n)/(1-n)||0),100*((1-o-n)/(1-n)||0),100*((1-a-n)/(1-n)||0),100*n]},r.rgb.keyword=function(e){const t=n[e];if(t)return t;let o,r=1/0;for(const t of Object.keys(a)){const n=a[t],E=(s=n,((i=e)[0]-s[0])**2+(i[1]-s[1])**2+(i[2]-s[2])**2);E.04045?((t+.055)/1.055)**2.4:t/12.92,o=o>.04045?((o+.055)/1.055)**2.4:o/12.92,a=a>.04045?((a+.055)/1.055)**2.4:a/12.92;return[100*(.4124*t+.3576*o+.1805*a),100*(.2126*t+.7152*o+.0722*a),100*(.0193*t+.1192*o+.9505*a)]},r.rgb.lab=function(e){const t=r.rgb.xyz(e);let o=t[0],a=t[1],n=t[2];o/=95.047,a/=100,n/=108.883,o=o>.008856?o**(1/3):7.787*o+16/116,a=a>.008856?a**(1/3):7.787*a+16/116,n=n>.008856?n**(1/3):7.787*n+16/116;return[116*a-16,500*(o-a),200*(a-n)]},r.hsl.rgb=function(e){const t=e[0]/360,o=e[1]/100,a=e[2]/100;let n,r,i;if(0===o)return i=255*a,[i,i,i];n=a<.5?a*(1+o):a+o-a*o;const s=2*a-n,E=[0,0,0];for(let e=0;e<3;e++)r=t+1/3*-(e-1),r<0&&r++,r>1&&r--,i=6*r<1?s+6*(n-s)*r:2*r<1?n:3*r<2?s+(n-s)*(2/3-r)*6:s,E[e]=255*i;return E},r.hsl.hsv=function(e){const t=e[0];let o=e[1]/100,a=e[2]/100,n=o;const r=Math.max(a,.01);a*=2,o*=a<=1?a:2-a,n*=r<=1?r:2-r;return[t,100*(0===a?2*n/(r+n):2*o/(a+o)),100*((a+o)/2)]},r.hsv.rgb=function(e){const t=e[0]/60,o=e[1]/100;let a=e[2]/100;const n=Math.floor(t)%6,r=t-Math.floor(t),i=255*a*(1-o),s=255*a*(1-o*r),E=255*a*(1-o*(1-r));switch(a*=255,n){case 0:return[a,E,i];case 1:return[s,a,i];case 2:return[i,a,E];case 3:return[i,s,a];case 4:return[E,i,a];case 5:return[a,i,s]}},r.hsv.hsl=function(e){const t=e[0],o=e[1]/100,a=e[2]/100,n=Math.max(a,.01);let r,i;i=(2-o)*a;const s=(2-o)*n;return r=o*n,r/=s<=1?s:2-s,r=r||0,i/=2,[t,100*r,100*i]},r.hwb.rgb=function(e){const t=e[0]/360;let o=e[1]/100,a=e[2]/100;const n=o+a;let r;n>1&&(o/=n,a/=n);const i=Math.floor(6*t),s=1-a;r=6*t-i,0!=(1&i)&&(r=1-r);const E=o+r*(s-o);let _,T,l;switch(i){default:_=s,T=E,l=o;break;case 1:_=E,T=s,l=o;break;case 2:_=o,T=s,l=E;break;case 3:_=o,T=E,l=s;break;case 4:_=E,T=o,l=s;break;case 5:_=s,T=o,l=E}return[255*_,255*T,255*l]},r.cmyk.rgb=function(e){const t=e[0]/100,o=e[1]/100,a=e[2]/100,n=e[3]/100;return[255*(1-Math.min(1,t*(1-n)+n)),255*(1-Math.min(1,o*(1-n)+n)),255*(1-Math.min(1,a*(1-n)+n))]},r.xyz.rgb=function(e){const t=e[0]/100,o=e[1]/100,a=e[2]/100;let n,r,i;return n=3.2406*t+-1.5372*o+-.4986*a,r=-.9689*t+1.8758*o+.0415*a,i=.0557*t+-.204*o+1.057*a,n=n>.0031308?1.055*n**(1/2.4)-.055:12.92*n,r=r>.0031308?1.055*r**(1/2.4)-.055:12.92*r,i=i>.0031308?1.055*i**(1/2.4)-.055:12.92*i,n=Math.min(Math.max(0,n),1),r=Math.min(Math.max(0,r),1),i=Math.min(Math.max(0,i),1),[255*n,255*r,255*i]},r.xyz.lab=function(e){let t=e[0],o=e[1],a=e[2];t/=95.047,o/=100,a/=108.883,t=t>.008856?t**(1/3):7.787*t+16/116,o=o>.008856?o**(1/3):7.787*o+16/116,a=a>.008856?a**(1/3):7.787*a+16/116;return[116*o-16,500*(t-o),200*(o-a)]},r.lab.xyz=function(e){let t,o,a;o=(e[0]+16)/116,t=e[1]/500+o,a=o-e[2]/200;const n=o**3,r=t**3,i=a**3;return o=n>.008856?n:(o-16/116)/7.787,t=r>.008856?r:(t-16/116)/7.787,a=i>.008856?i:(a-16/116)/7.787,t*=95.047,o*=100,a*=108.883,[t,o,a]},r.lab.lch=function(e){const t=e[0],o=e[1],a=e[2];let n;n=360*Math.atan2(a,o)/2/Math.PI,n<0&&(n+=360);return[t,Math.sqrt(o*o+a*a),n]},r.lch.lab=function(e){const t=e[0],o=e[1],a=e[2]/360*2*Math.PI;return[t,o*Math.cos(a),o*Math.sin(a)]},r.rgb.ansi16=function(e,t=null){const[o,a,n]=e;let i=null===t?r.rgb.hsv(e)[2]:t;if(i=Math.round(i/50),0===i)return 30;let s=30+(Math.round(n/255)<<2|Math.round(a/255)<<1|Math.round(o/255));return 2===i&&(s+=60),s},r.hsv.ansi16=function(e){return r.rgb.ansi16(r.hsv.rgb(e),e[2])},r.rgb.ansi256=function(e){const t=e[0],o=e[1],a=e[2];if(t===o&&o===a)return t<8?16:t>248?231:Math.round((t-8)/247*24)+232;return 16+36*Math.round(t/255*5)+6*Math.round(o/255*5)+Math.round(a/255*5)},r.ansi16.rgb=function(e){let t=e%10;if(0===t||7===t)return e>50&&(t+=3.5),t=t/10.5*255,[t,t,t];const o=.5*(1+~~(e>50));return[(1&t)*o*255,(t>>1&1)*o*255,(t>>2&1)*o*255]},r.ansi256.rgb=function(e){if(e>=232){const t=10*(e-232)+8;return[t,t,t]}let t;e-=16;return[Math.floor(e/36)/5*255,Math.floor((t=e%36)/6)/5*255,t%6/5*255]},r.rgb.hex=function(e){const t=(((255&Math.round(e[0]))<<16)+((255&Math.round(e[1]))<<8)+(255&Math.round(e[2]))).toString(16).toUpperCase();return"000000".substring(t.length)+t},r.hex.rgb=function(e){const t=e.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);if(!t)return[0,0,0];let o=t[0];3===t[0].length&&(o=o.split("").map((e=>e+e)).join(""));const a=parseInt(o,16);return[a>>16&255,a>>8&255,255&a]},r.rgb.hcg=function(e){const t=e[0]/255,o=e[1]/255,a=e[2]/255,n=Math.max(Math.max(t,o),a),r=Math.min(Math.min(t,o),a),i=n-r;let s,E;return s=i<1?r/(1-i):0,E=i<=0?0:n===t?(o-a)/i%6:n===o?2+(a-t)/i:4+(t-o)/i,E/=6,E%=1,[360*E,100*i,100*s]},r.hsl.hcg=function(e){const t=e[1]/100,o=e[2]/100,a=o<.5?2*t*o:2*t*(1-o);let n=0;return a<1&&(n=(o-.5*a)/(1-a)),[e[0],100*a,100*n]},r.hsv.hcg=function(e){const t=e[1]/100,o=e[2]/100,a=t*o;let n=0;return a<1&&(n=(o-a)/(1-a)),[e[0],100*a,100*n]},r.hcg.rgb=function(e){const t=e[0]/360,o=e[1]/100,a=e[2]/100;if(0===o)return[255*a,255*a,255*a];const n=[0,0,0],r=t%1*6,i=r%1,s=1-i;let E=0;switch(Math.floor(r)){case 0:n[0]=1,n[1]=i,n[2]=0;break;case 1:n[0]=s,n[1]=1,n[2]=0;break;case 2:n[0]=0,n[1]=1,n[2]=i;break;case 3:n[0]=0,n[1]=s,n[2]=1;break;case 4:n[0]=i,n[1]=0,n[2]=1;break;default:n[0]=1,n[1]=0,n[2]=s}return E=(1-o)*a,[255*(o*n[0]+E),255*(o*n[1]+E),255*(o*n[2]+E)]},r.hcg.hsv=function(e){const t=e[1]/100,o=t+e[2]/100*(1-t);let a=0;return o>0&&(a=t/o),[e[0],100*a,100*o]},r.hcg.hsl=function(e){const t=e[1]/100,o=e[2]/100*(1-t)+.5*t;let a=0;return o>0&&o<.5?a=t/(2*o):o>=.5&&o<1&&(a=t/(2*(1-o))),[e[0],100*a,100*o]},r.hcg.hwb=function(e){const t=e[1]/100,o=t+e[2]/100*(1-t);return[e[0],100*(o-t),100*(1-o)]},r.hwb.hcg=function(e){const t=e[1]/100,o=1-e[2]/100,a=o-t;let n=0;return a<1&&(n=(o-a)/(1-a)),[e[0],100*a,100*n]},r.apple.rgb=function(e){return[e[0]/65535*255,e[1]/65535*255,e[2]/65535*255]},r.rgb.apple=function(e){return[e[0]/255*65535,e[1]/255*65535,e[2]/255*65535]},r.gray.rgb=function(e){return[e[0]/100*255,e[0]/100*255,e[0]/100*255]},r.gray.hsl=function(e){return[0,0,e[0]]},r.gray.hsv=r.gray.hsl,r.gray.hwb=function(e){return[0,100,e[0]]},r.gray.cmyk=function(e){return[0,0,0,e[0]]},r.gray.lab=function(e){return[e[0],0,0]},r.gray.hex=function(e){const t=255&Math.round(e[0]/100*255),o=((t<<16)+(t<<8)+t).toString(16).toUpperCase();return"000000".substring(o.length)+o},r.rgb.gray=function(e){return[(e[0]+e[1]+e[2])/3/255*100]}},978:(e,t,o)=>{const a=o(2956),n=o(7774),r={};Object.keys(a).forEach((e=>{r[e]={},Object.defineProperty(r[e],"channels",{value:a[e].channels}),Object.defineProperty(r[e],"labels",{value:a[e].labels});const t=n(e);Object.keys(t).forEach((o=>{const a=t[o];r[e][o]=(function(e){const t=function(...t){const o=t[0];if(null==o)return o;o.length>1&&(t=o);const a=e(t);if("object"==typeof a)for(let e=a.length,t=0;t1&&(t=o),e(t))};return"conversion"in e&&(t.conversion=e.conversion),t})(a)}))})),e.exports=r},7774:(e,t,o)=>{const a=o(2956);function n(e){const t=(function(){const e={},t=Object.keys(a);for(let o=t.length,a=0;a{"use strict";e.exports={aliceblue:[240,248,255],antiquewhite:[250,235,215],aqua:[0,255,255],aquamarine:[127,255,212],azure:[240,255,255],beige:[245,245,220],bisque:[255,228,196],black:[0,0,0],blanchedalmond:[255,235,205],blue:[0,0,255],blueviolet:[138,43,226],brown:[165,42,42],burlywood:[222,184,135],cadetblue:[95,158,160],chartreuse:[127,255,0],chocolate:[210,105,30],coral:[255,127,80],cornflowerblue:[100,149,237],cornsilk:[255,248,220],crimson:[220,20,60],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgoldenrod:[184,134,11],darkgray:[169,169,169],darkgreen:[0,100,0],darkgrey:[169,169,169],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkseagreen:[143,188,143],darkslateblue:[72,61,139],darkslategray:[47,79,79],darkslategrey:[47,79,79],darkturquoise:[0,206,209],darkviolet:[148,0,211],deeppink:[255,20,147],deepskyblue:[0,191,255],dimgray:[105,105,105],dimgrey:[105,105,105],dodgerblue:[30,144,255],firebrick:[178,34,34],floralwhite:[255,250,240],forestgreen:[34,139,34],fuchsia:[255,0,255],gainsboro:[220,220,220],ghostwhite:[248,248,255],gold:[255,215,0],goldenrod:[218,165,32],gray:[128,128,128],green:[0,128,0],greenyellow:[173,255,47],grey:[128,128,128],honeydew:[240,255,240],hotpink:[255,105,180],indianred:[205,92,92],indigo:[75,0,130],ivory:[255,255,240],khaki:[240,230,140],lavender:[230,230,250],lavenderblush:[255,240,245],lawngreen:[124,252,0],lemonchiffon:[255,250,205],lightblue:[173,216,230],lightcoral:[240,128,128],lightcyan:[224,255,255],lightgoldenrodyellow:[250,250,210],lightgray:[211,211,211],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightsalmon:[255,160,122],lightseagreen:[32,178,170],lightskyblue:[135,206,250],lightslategray:[119,136,153],lightslategrey:[119,136,153],lightsteelblue:[176,196,222],lightyellow:[255,255,224],lime:[0,255,0],limegreen:[50,205,50],linen:[250,240,230],magenta:[255,0,255],maroon:[128,0,0],mediumaquamarine:[102,205,170],mediumblue:[0,0,205],mediumorchid:[186,85,211],mediumpurple:[147,112,219],mediumseagreen:[60,179,113],mediumslateblue:[123,104,238],mediumspringgreen:[0,250,154],mediumturquoise:[72,209,204],mediumvioletred:[199,21,133],midnightblue:[25,25,112],mintcream:[245,255,250],mistyrose:[255,228,225],moccasin:[255,228,181],navajowhite:[255,222,173],navy:[0,0,128],oldlace:[253,245,230],olive:[128,128,0],olivedrab:[107,142,35],orange:[255,165,0],orangered:[255,69,0],orchid:[218,112,214],palegoldenrod:[238,232,170],palegreen:[152,251,152],paleturquoise:[175,238,238],palevioletred:[219,112,147],papayawhip:[255,239,213],peachpuff:[255,218,185],peru:[205,133,63],pink:[255,192,203],plum:[221,160,221],powderblue:[176,224,230],purple:[128,0,128],rebeccapurple:[102,51,153],red:[255,0,0],rosybrown:[188,143,143],royalblue:[65,105,225],saddlebrown:[139,69,19],salmon:[250,128,114],sandybrown:[244,164,96],seagreen:[46,139,87],seashell:[255,245,238],sienna:[160,82,45],silver:[192,192,192],skyblue:[135,206,235],slateblue:[106,90,205],slategray:[112,128,144],slategrey:[112,128,144],snow:[255,250,250],springgreen:[0,255,127],steelblue:[70,130,180],tan:[210,180,140],teal:[0,128,128],thistle:[216,191,216],tomato:[255,99,71],turquoise:[64,224,208],violet:[238,130,238],wheat:[245,222,179],white:[255,255,255],whitesmoke:[245,245,245],yellow:[255,255,0],yellowgreen:[154,205,50]}},2682:e=>{e.exports=function e(t){return Object.freeze(t),Object.getOwnPropertyNames(t).forEach((function(o){!t.hasOwnProperty(o)||null===t[o]||"object"!=typeof t[o]&&"function"!=typeof t[o]||Object.isFrozen(t[o])||e(t[o])})),t}},6729:e=>{"use strict";var t=Object.prototype.hasOwnProperty,o="~";function a(){}function n(e,t,o){this.fn=e,this.context=t,this.once=o||!1}function r(e,t,a,r,i){if("function"!=typeof a)throw new TypeError("The listener must be a function");var s=new n(a,r||e,i),E=o?o+t:t;return e._events[E]?e._events[E].fn?e._events[E]=[e._events[E],s]:e._events[E].push(s):(e._events[E]=s,e._eventsCount++),e}function i(e,t){0==--e._eventsCount?e._events=new a:delete e._events[t]}function s(){this._events=new a,this._eventsCount=0}Object.create&&(a.prototype=Object.create(null),(new a).__proto__||(o=!1)),s.prototype.eventNames=function(){var e,a,n=[];if(0===this._eventsCount)return n;for(a in e=this._events)t.call(e,a)&&n.push(o?a.slice(1):a);return Object.getOwnPropertySymbols?n.concat(Object.getOwnPropertySymbols(e)):n},s.prototype.listeners=function(e){var t=o?o+e:e,a=this._events[t];if(!a)return[];if(a.fn)return[a.fn];for(var n=0,r=a.length,i=new Array(r);n{"use strict";t.Z=function(e){var t={};for(var o in e)e.hasOwnProperty(o)&&s(o)&&(t[o]=e[o]);return t};var a,n=o(2047),r=(a=n)&&a.__esModule?a:{default:a};var i={onCopy:!0,onCut:!0,onPaste:!0,onLoad:!0,onError:!0,onWheel:!0,onScroll:!0,onCompositionEnd:!0,onCompositionStart:!0,onCompositionUpdate:!0,onKeyDown:!0,onKeyPress:!0,onKeyUp:!0,onFocus:!0,onBlur:!0,onChange:!0,onInput:!0,onSubmit:!0,onClick:!0,onContextMenu:!0,onDoubleClick:!0,onDrag:!0,onDragEnd:!0,onDragEnter:!0,onDragExit:!0,onDragLeave:!0,onDragOver:!0,onDragStart:!0,onDrop:!0,onMouseDown:!0,onMouseEnter:!0,onMouseLeave:!0,onMouseMove:!0,onMouseOut:!0,onMouseOver:!0,onMouseUp:!0,onSelect:!0,onTouchCancel:!0,onTouchEnd:!0,onTouchMove:!0,onTouchStart:!0,onAnimationStart:!0,onAnimationEnd:!0,onAnimationIteration:!0,onTransitionEnd:!0};function s(e){return i[e]||r.default[e]||/^(data|aria)-/.test(e)}},542:e=>{var t=e.exports=function(e,o){if(o||(o=16),void 0===e&&(e=128),e<=0)return"0";for(var a=Math.log(Math.pow(2,e))/Math.log(o),n=2;a===1/0;n*=2)a=Math.log(Math.pow(2,e/n))/Math.log(o)*n;var r=a-Math.floor(a),i="";for(n=0;n=Math.pow(2,e)?t(e,o):i};t.rack=function(e,o,a){var n=function(n){var i=0;do{if(i++>10){if(!a)throw new Error("too many ID collisions, use more bits");e+=a}var s=t(e,o)}while(Object.hasOwnProperty.call(r,s));return r[s]=n,s},r=n.hats={};return n.get=function(e){return n.hats[e]},n.set=function(e,t){return n.hats[e]=t,n},n.bits=e||128,n.base=o||16,n}},7631:function(e){var t;"undefined"!=typeof window&&(t=function(){return(function(e){var t={};function o(a){if(t[a])return t[a].exports;var n=t[a]={i:a,l:!1,exports:{}};return e[a].call(n.exports,n,n.exports,o),n.l=!0,n.exports}return o.m=e,o.c=t,o.d=function(e,t,a){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:a})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var a=Object.create(null);if(o.r(a),Object.defineProperty(a,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)o.d(a,n,function(t){return e[t]}.bind(null,n));return a},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="/dist/",o(o.s="./src/hls.ts")})({"./node_modules/eventemitter3/index.js":function(e,t,o){"use strict";var a=Object.prototype.hasOwnProperty,n="~";function r(){}function i(e,t,o){this.fn=e,this.context=t,this.once=o||!1}function s(e,t,o,a,r){if("function"!=typeof o)throw new TypeError("The listener must be a function");var s=new i(o,a||e,r),E=n?n+t:t;return e._events[E]?e._events[E].fn?e._events[E]=[e._events[E],s]:e._events[E].push(s):(e._events[E]=s,e._eventsCount++),e}function E(e,t){0==--e._eventsCount?e._events=new r:delete e._events[t]}function _(){this._events=new r,this._eventsCount=0}Object.create&&(r.prototype=Object.create(null),(new r).__proto__||(n=!1)),_.prototype.eventNames=function(){var e,t,o=[];if(0===this._eventsCount)return o;for(t in e=this._events)a.call(e,t)&&o.push(n?t.slice(1):t);return Object.getOwnPropertySymbols?o.concat(Object.getOwnPropertySymbols(e)):o},_.prototype.listeners=function(e){var t=n?n+e:e,o=this._events[t];if(!o)return[];if(o.fn)return[o.fn];for(var a=0,r=o.length,i=new Array(r);a0}),!1)}e.exports=function(e,t){t=t||{};var n={main:o.m},r=t.all?{main:Object.keys(n.main)}:(function(e,t){for(var o={main:[t]},a={main:[]},n={main:{}};E(o);)for(var r=Object.keys(o),i=0;i=2*l/u||N<=R)){var p,h=Number.POSITIVE_INFINITY;for(p=e.level-1;p>c&&!((h=l*d[p].maxBitrate/(6.4*O))=N)){var f=this.bwEstimator.getEstimate();_.logger.warn("Fragment "+e.sn+(t?" part "+t.index:"")+" of level "+e.level+" is loading too slowly and will cause an underbuffer; aborting and switching to level "+p+"\n Current BW estimate: "+(Object(a.isFiniteNumber)(f)?(f/1024).toFixed(3):"Unknown")+" Kb/s\n Estimated load time for current fragment: "+N.toFixed(3)+" s\n Estimated load time for the next fragment: "+h.toFixed(3)+" s\n Time to underbuffer: "+R.toFixed(3)+" s"),o.nextLoadLevel=p,this.bwEstimator.sample(S,T.loaded),this.clearTimer(),e.loader&&(this.fragCurrent=this.partCurrent=null,e.loader.abort()),o.trigger(r.Events.FRAG_LOAD_EMERGENCY_ABORTED,{frag:e,part:t,stats:T})}}}}}},S.onFragLoaded=function(e,t){var o=t.frag,n=t.part;if(o.type===E.PlaylistLevelType.MAIN&&Object(a.isFiniteNumber)(o.sn)){var i=n?n.stats:o.stats,s=n?n.duration:o.duration;if(this.clearTimer(),this.lastLoadedFragLevel=o.level,this._nextAutoLevel=-1,this.hls.config.abrMaxWithRealBitrate){var _=this.hls.levels[o.level],T=(_.loaded?_.loaded.bytes:0)+i.loaded,l=(_.loaded?_.loaded.duration:0)+s;_.loaded={bytes:T,duration:l},_.realBitrate=Math.round(8*T/l)}if(o.bitrateTest){var S={stats:i,frag:o,part:n,id:o.type};this.onFragBuffered(r.Events.FRAG_BUFFERED,S)}}},S.onFragBuffered=function(e,t){var o=t.frag,a=t.part,n=a?a.stats:o.stats;if(!n.aborted&&o.type===E.PlaylistLevelType.MAIN&&"initSegment"!==o.sn){var r=n.parsing.end-n.loading.start;this.bwEstimator.sample(r,n.loaded),n.bwEstimate=this.bwEstimator.getEstimate(),o.bitrateTest?this.bitrateTestDelay=r/1e3:this.bitrateTestDelay=0}},S.onError=function(e,t){switch(t.details){case s.ErrorDetails.FRAG_LOAD_ERROR:case s.ErrorDetails.FRAG_LOAD_TIMEOUT:this.clearTimer()}},S.clearTimer=function(){self.clearInterval(this.timer),this.timer=void 0},S.getNextABRAutoLevel=function(){var e=this.fragCurrent,t=this.partCurrent,o=this.hls,a=o.maxAutoLevel,n=o.config,r=o.minAutoLevel,s=o.media,E=t?t.duration:e?e.duration:0,T=s?s.currentTime:0,l=s&&0!==s.playbackRate?Math.abs(s.playbackRate):1,S=this.bwEstimator?this.bwEstimator.getEstimate():n.abrEwmaDefaultEstimate,u=(i.BufferHelper.bufferInfo(s,T,n.maxBufferHole).end-T)/l,d=this.findBestLevel(S,r,a,u,n.abrBandWidthFactor,n.abrBandWidthUpFactor);if(d>=0)return d;_.logger.trace((u?"rebuffering expected":"buffer is empty")+", finding optimal quality level");var c=E?Math.min(E,n.maxStarvationDelay):n.maxStarvationDelay,I=n.abrBandWidthFactor,A=n.abrBandWidthUpFactor;if(!u){var O=this.bitrateTestDelay;O&&(c=(E?Math.min(E,n.maxLoadingDelay):n.maxLoadingDelay)-O,_.logger.trace("bitrate test took "+Math.round(1e3*O)+"ms, set first fragment max fetchDuration to "+Math.round(1e3*c)+" ms"),I=A=1)}return d=this.findBestLevel(S,r,a,u+c,I,A),Math.max(d,0)},S.findBestLevel=function(e,t,o,a,n,r){for(var i,s=this.fragCurrent,E=this.partCurrent,T=this.lastLoadedFragLevel,l=this.hls.levels,S=l[T],u=!(null==S||null===(i=S.details)||void 0===i||!i.live),d=null==S?void 0:S.codecSet,c=E?E.duration:s?s.duration:0,I=o;I>=t;I--){var A=l[I];if(A&&(!d||A.codecSet===d)){var O=A.details,N=(E?null==O?void 0:O.partTarget:null==O?void 0:O.averagetargetduration)||c,m=void 0;m=I<=T?n*e:r*e;var R=l[I].maxBitrate,p=R*N/m;if(_.logger.trace("level/adjustedbw/bitrate/avgDuration/maxFetchDuration/fetchDuration: "+I+"/"+Math.round(m)+"/"+R+"/"+N+"/"+a+"/"+p),m>R&&(!p||u&&!this.bitrateTestDelay||p0&&-1===e?(this.log("Override startPosition with lastCurrentTime @"+t.toFixed(3)),e=t,this.state=n.State.IDLE):(this.loadedmetadata=!1,this.state=n.State.WAITING_TRACK),this.nextLoadPosition=this.startPosition=this.lastCurrentTime=e,this.tick()},m.doTick=function(){switch(this.state){case n.State.IDLE:this.doTickIdle();break;case n.State.WAITING_TRACK:var t,o=this.levels,a=this.trackId,r=null==o||null===(t=o[a])||void 0===t?void 0:t.details;if(r){if(this.waitForCdnTuneIn(r))break;this.state=n.State.WAITING_INIT_PTS}break;case n.State.FRAG_LOADING_WAITING_RETRY:var s,E=performance.now(),_=this.retryDate;(!_||E>=_||null!==(s=this.media)&&void 0!==s&&s.seeking)&&(this.log("RetryDate reached, switch back to IDLE state"),this.resetStartWhenNotLoaded(this.trackId),this.state=n.State.IDLE);break;case n.State.WAITING_INIT_PTS:var T=this.waitingData;if(T){var l=T.frag,S=T.part,u=T.cache,c=T.complete;if(void 0!==this.initPTS[l.cc]){this.waitingData=null,this.waitingVideoCC=-1,this.state=n.State.FRAG_LOADING;var I={frag:l,part:S,payload:u.flush(),networkDetails:null};this._handleFragmentLoadProgress(I),c&&e.prototype._handleFragmentLoadComplete.call(this,I)}else if(this.videoTrackCC!==this.waitingVideoCC)this.log("Waiting fragment cc ("+l.cc+") cancelled because video is at cc "+this.videoTrackCC),this.clearWaitingFragment();else{var A=this.getLoadPosition(),O=i.BufferHelper.bufferInfo(this.mediaBuffer,A,this.config.maxBufferHole);Object(d.fragmentWithinToleranceTest)(O.end,this.config.maxFragLookUpTolerance,l)<0&&(this.log("Waiting fragment cc ("+l.cc+") @ "+l.start+" cancelled because another fragment at "+O.end+" is needed"),this.clearWaitingFragment())}}else this.state=n.State.IDLE}this.onTickEnd()},m.clearWaitingFragment=function(){var e=this.waitingData;e&&(this.fragmentTracker.removeFragment(e.frag),this.waitingData=null,this.waitingVideoCC=-1,this.state=n.State.IDLE)},m.resetLoadingState=function(){this.clearWaitingFragment(),e.prototype.resetLoadingState.call(this)},m.onTickEnd=function(){var e=this.media;if(e&&e.readyState){var t=(this.mediaBuffer?this.mediaBuffer:e).buffered;!this.loadedmetadata&&t.length&&(this.loadedmetadata=!0),this.lastCurrentTime=e.currentTime}},m.doTickIdle=function(){var e,t,o=this.hls,a=this.levels,i=this.media,s=this.trackId,E=o.config;if(a&&a[s]&&(i||!this.startFragRequested&&E.startFragPrefetch)){var l=a[s].details;if(!l||l.live&&this.levelLastLoaded!==s||this.waitForCdnTuneIn(l))this.state=n.State.WAITING_TRACK;else{var S=this.mediaBuffer?this.mediaBuffer:this.media;this.bufferFlushed&&S&&(this.bufferFlushed=!1,this.afterBufferFlushed(S,T.ElementaryStreamTypes.AUDIO,_.PlaylistLevelType.AUDIO));var u=this.getFwdBufferInfo(S,_.PlaylistLevelType.AUDIO);if(null!==u){var d=this.getFwdBufferInfo(this.videoBuffer?this.videoBuffer:this.media,_.PlaylistLevelType.MAIN),c=u.len,I=this.getMaxBufferLength(null==d?void 0:d.len),A=this.audioSwitch;if(!(c>=I)||A){if(!A&&this._streamEnded(u,l))return o.trigger(r.Events.BUFFER_EOS,{type:"audio"}),void(this.state=n.State.ENDED);var O=l.fragments[0].start,N=u.end;if(A&&i){var m=this.getLoadPosition();N=m,l.PTSKnown&&mO||u.nextStart)&&(this.log("Alt audio track ahead of main track, seek to start of alt audio track"),i.currentTime=O+.05)}if(!(d&&N>d.end+l.targetduration)&&(d&&d.len||!u.len)){var R=this.getNextFragment(N,l);R?"identity"!==(null===(e=R.decryptdata)||void 0===e?void 0:e.keyFormat)||null!==(t=R.decryptdata)&&void 0!==t&&t.key?this.loadFragment(R,l,N):this.loadKey(R,l):this.bufferFlushed=!0}}}}}},m.getMaxBufferLength=function(t){var o=e.prototype.getMaxBufferLength.call(this);return t?Math.max(o,t):o},m.onMediaDetaching=function(){this.videoBuffer=null,e.prototype.onMediaDetaching.call(this)},m.onAudioTracksUpdated=function(e,t){var o=t.audioTracks;this.resetTransmuxer(),this.levels=o.map((function(e){return new E.Level(e)}))},m.onAudioTrackSwitching=function(e,t){var o=!!t.url;this.trackId=t.id;var a=this.fragCurrent;null!=a&&a.loader&&a.loader.abort(),this.fragCurrent=null,this.clearWaitingFragment(),o?this.setInterval(100):this.resetTransmuxer(),o?(this.audioSwitch=!0,this.state=n.State.IDLE):this.state=n.State.STOPPED,this.tick()},m.onManifestLoading=function(){this.mainDetails=null,this.fragmentTracker.removeAllFragments(),this.startPosition=this.lastCurrentTime=0,this.bufferFlushed=!1},m.onLevelLoaded=function(e,t){this.mainDetails=t.details,null!==this.cachedTrackLoadedData&&(this.hls.trigger(r.Events.AUDIO_TRACK_LOADED,this.cachedTrackLoadedData),this.cachedTrackLoadedData=null)},m.onAudioTrackLoaded=function(e,t){var o;if(null!=this.mainDetails){var a=this.levels,r=t.details,i=t.id;if(a){this.log("Track "+i+" loaded ["+r.startSN+","+r.endSN+"],duration:"+r.totalduration);var s=a[i],E=0;if(r.live||null!==(o=s.details)&&void 0!==o&&o.live){var _=this.mainDetails;if(r.fragments[0]||(r.deltaUpdateFailed=!0),r.deltaUpdateFailed||!_)return;!s.details&&r.hasProgramDateTime&&_.hasProgramDateTime?(Object(c.alignMediaPlaylistByPDT)(r,_),E=r.fragments[0].start):E=this.alignPlaylists(r,s.details)}s.details=r,this.levelLastLoaded=i,this.startFragRequested||!this.mainDetails&&r.live||this.setStartPosition(s.details,E),this.state!==n.State.WAITING_TRACK||this.waitForCdnTuneIn(r)||(this.state=n.State.IDLE),this.tick()}else this.warn("Audio tracks were reset while loading level "+i)}else this.cachedTrackLoadedData=t},m._handleFragmentLoadProgress=function(e){var t,o=e.frag,a=e.part,r=e.payload,i=this.config,s=this.trackId,E=this.levels;if(E){var T=E[s];console.assert(T,"Audio track is defined on fragment load progress");var d=T.details;console.assert(d,"Audio track details are defined on fragment load progress");var c=i.defaultAudioCodec||T.audioCodec||"mp4a.40.2",I=this.transmuxer;I||(I=this.transmuxer=new S.default(this.hls,_.PlaylistLevelType.AUDIO,this._handleTransmuxComplete.bind(this),this._handleTransmuxerFlush.bind(this)));var A=this.initPTS[o.cc],O=null===(t=o.initSegment)||void 0===t?void 0:t.data;if(void 0!==A){var N=a?a.index:-1,m=-1!==N,R=new u.ChunkMetadata(o.level,o.sn,o.stats.chunkCount,r.byteLength,N,m);I.push(r,O,c,"",o,a,d.totalduration,!1,R,A)}else this.log("Unknown video PTS for cc "+o.cc+", waiting for video PTS before demuxing audio frag "+o.sn+" of ["+d.startSN+" ,"+d.endSN+"],track "+s),(this.waitingData=this.waitingData||{frag:o,part:a,cache:new l.default,complete:!1}).cache.push(new Uint8Array(r)),this.waitingVideoCC=this.videoTrackCC,this.state=n.State.WAITING_INIT_PTS}else this.warn("Audio tracks were reset while fragment load was in progress. Fragment "+o.sn+" of level "+o.level+" will not be buffered")},m._handleFragmentLoadComplete=function(t){this.waitingData?this.waitingData.complete=!0:e.prototype._handleFragmentLoadComplete.call(this,t)},m.onBufferReset=function(){this.mediaBuffer=this.videoBuffer=null,this.loadedmetadata=!1},m.onBufferCreated=function(e,t){var o=t.tracks.audio;o&&(this.mediaBuffer=o.buffer||null),t.tracks.video&&(this.videoBuffer=t.tracks.video.buffer||null)},m.onFragBuffered=function(e,t){var o=t.frag,a=t.part;o.type===_.PlaylistLevelType.AUDIO&&(this.fragContextChanged(o)?this.warn("Fragment "+o.sn+(a?" p: "+a.index:"")+" of level "+o.level+" finished buffering, but was aborted. state: "+this.state+", audioSwitch: "+this.audioSwitch):("initSegment"!==o.sn&&(this.fragPrevious=o,this.audioSwitch&&(this.audioSwitch=!1,this.hls.trigger(r.Events.AUDIO_TRACK_SWITCHED,{id:this.trackId}))),this.fragBufferedComplete(o,a)))},m.onError=function(t,o){switch(o.details){case I.ErrorDetails.FRAG_LOAD_ERROR:case I.ErrorDetails.FRAG_LOAD_TIMEOUT:case I.ErrorDetails.KEY_LOAD_ERROR:case I.ErrorDetails.KEY_LOAD_TIMEOUT:this.onFragmentOrKeyLoadError(_.PlaylistLevelType.AUDIO,o);break;case I.ErrorDetails.AUDIO_TRACK_LOAD_ERROR:case I.ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:this.state!==n.State.ERROR&&this.state!==n.State.STOPPED&&(this.state=o.fatal?n.State.ERROR:n.State.IDLE,this.warn(o.details+" while loading frag, switching to "+this.state+" state"));break;case I.ErrorDetails.BUFFER_FULL_ERROR:if("audio"===o.parent&&(this.state===n.State.PARSING||this.state===n.State.PARSED)){var a=!0,r=this.getFwdBufferInfo(this.mediaBuffer,_.PlaylistLevelType.AUDIO);r&&r.len>.5&&(a=!this.reduceMaxBufferLength(r.len)),a&&(this.warn("Buffer full error also media.currentTime is not buffered, flush audio buffer"),this.fragCurrent=null,e.prototype.flushMainBuffer.call(this,0,Number.POSITIVE_INFINITY,"audio")),this.resetLoadingState()}}},m.onBufferFlushed=function(e,t){t.type===T.ElementaryStreamTypes.AUDIO&&(this.bufferFlushed=!0)},m._handleTransmuxComplete=function(e){var t,o="audio",a=this.hls,i=e.remuxResult,s=e.chunkMeta,E=this.getCurrentContext(s);if(!E)return this.warn("The loading context changed while buffering fragment "+s.sn+" of level "+s.level+". This chunk will not be buffered."),void this.resetStartWhenNotLoaded(s.level);var _=E.frag,l=E.part,S=E.level.details,u=i.audio,d=i.text,c=i.id3,I=i.initSegment;if(!this.fragContextChanged(_)&&S){if(this.state=n.State.PARSING,this.audioSwitch&&u&&this.completeAudioSwitch(),null!=I&&I.tracks&&(this._bufferInitSegment(I.tracks,_,s),a.trigger(r.Events.FRAG_PARSING_INIT_SEGMENT,{frag:_,id:o,tracks:I.tracks})),u){var O=u.startPTS,N=u.endPTS,m=u.startDTS,R=u.endDTS;l&&(l.elementaryStreams[T.ElementaryStreamTypes.AUDIO]={startPTS:O,endPTS:N,startDTS:m,endDTS:R}),_.setElementaryStreamInfo(T.ElementaryStreamTypes.AUDIO,O,N,m,R),this.bufferFragmentData(u,_,l,s)}if(null!=c&&null!==(t=c.samples)&&void 0!==t&&t.length){var p=A({id:o,frag:_,details:S},c);a.trigger(r.Events.FRAG_PARSING_METADATA,p)}if(d){var h=A({id:o,frag:_,details:S},d);a.trigger(r.Events.FRAG_PARSING_USERDATA,h)}}},m._bufferInitSegment=function(e,t,o){if(this.state===n.State.PARSING){e.video&&delete e.video;var a=e.audio;if(a){a.levelCodec=a.codec,a.id="audio",this.log("Init audio buffer, container:"+a.container+", codecs[parsed]=["+a.codec+"]"),this.hls.trigger(r.Events.BUFFER_CODECS,e);var i=a.initSegment;if(null!=i&&i.byteLength){var s={type:"audio",frag:t,part:null,chunkMeta:o,parent:t.type,data:i};this.hls.trigger(r.Events.BUFFER_APPENDING,s)}this.tick()}}},m.loadFragment=function(t,o,r){var i=this.fragmentTracker.getState(t);this.fragCurrent=t,(this.audioSwitch||i===s.FragmentState.NOT_LOADED||i===s.FragmentState.PARTIAL)&&("initSegment"===t.sn?this._loadInitSegment(t):o.live&&!Object(a.isFiniteNumber)(this.initPTS[t.cc])?(this.log("Waiting for video PTS in continuity counter "+t.cc+" of live stream before loading audio fragment "+t.sn+" of level "+this.trackId),this.state=n.State.WAITING_INIT_PTS):(this.startFragRequested=!0,e.prototype.loadFragment.call(this,t,o,r)))},m.completeAudioSwitch=function(){var t=this.hls,o=this.media,a=this.trackId;o&&(this.log("Switching audio track : flushing all audio"),e.prototype.flushMainBuffer.call(this,0,Number.POSITIVE_INFINITY,"audio")),this.audioSwitch=!1,t.trigger(r.Events.AUDIO_TRACK_SWITCHED,{id:a})},N})(n.default);t.default=N},"./src/controller/audio-track-controller.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/events.ts"),n=o("./src/errors.ts"),r=o("./src/controller/base-playlist-controller.ts"),i=o("./src/types/loader.ts");function s(e,t){for(var o=0;o=t.length)this.warn("Invalid id passed to audio-track controller");else{this.clearTimer();var o=t[this.trackId];this.log("Now switching to audio-track index "+e);var n=t[e],r=n.id,i=n.groupId,s=void 0===i?"":i,E=n.name,_=n.type,T=n.url;if(this.trackId=e,this.trackName=E,this.selectDefaultTrack=!1,this.hls.trigger(a.Events.AUDIO_TRACK_SWITCHING,{id:r,groupId:s,name:E,type:_,url:T}),!n.details||n.details.live){var l=this.switchParams(n.url,null==o?void 0:o.details);this.loadPlaylist(l)}}},S.selectInitialTrack=function(){var e=this.tracksInGroup;console.assert(e.length,"Initial audio track should be selected when tracks are known");var t=this.trackName,o=this.findTrackId(t)||this.findTrackId();-1!==o?this.setAudioTrack(o):(this.warn("No track found for running audio group-ID: "+this.groupId),this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.AUDIO_TRACK_LOAD_ERROR,fatal:!0}))},S.findTrackId=function(e){for(var t=this.tracksInGroup,o=0;ot.partTarget&&(_+=1)}if(Object(a.isFiniteNumber)(E))return new n.HlsUrlParameters(E,Object(a.isFiniteNumber)(_)?_:void 0,n.HlsSkip.No)}}},t.loadPlaylist=function(e){},t.shouldLoadTrack=function(e){return this.canLoad&&e&&!!e.url&&(!e.details||e.details.live)},t.playlistLoaded=function(e,t,o){var a=this,n=t.details,i=t.stats,s=i.loading.end?Math.max(0,self.performance.now()-i.loading.end):0;if(n.advancedDateTime=Date.now()-s,n.live||null!=o&&o.live){if(n.reloaded(o),o&&this.log("live playlist "+e+" "+(n.advanced?"REFRESHED "+n.lastPartSn+"-"+n.lastPartIndex:"MISSED")),o&&n.fragments.length>0&&Object(r.mergeDetails)(o,n),!this.canLoad||!n.live)return;var E,_=void 0,T=void 0;if(n.canBlockReload&&n.endSN&&n.advanced){var l=this.hls.config.lowLatencyMode,S=n.lastPartSn,u=n.endSN,d=n.lastPartIndex,c=S===u;-1!==d?(_=c?u+1:S,T=c?l?0:d:d+1):_=u+1;var I=n.age,A=I+n.ageHeader,O=Math.min(A-n.partTarget,1.5*n.targetduration);if(O>0){if(o&&O>o.tuneInGoal)this.warn("CDN Tune-in goal increased from: "+o.tuneInGoal+" to: "+O+" with playlist age: "+n.age),O=0;else{var N=Math.floor(O/n.targetduration);_+=N,void 0!==T&&(T+=Math.round(O%n.targetduration/n.partTarget)),this.log("CDN Tune-in age: "+n.ageHeader+"s last advanced "+I.toFixed(2)+"s goal: "+O+" skip sn "+N+" to part "+T)}n.tuneInGoal=O}if(E=this.getDeliveryDirectives(n,t.deliveryDirectives,_,T),l||!c)return void this.loadPlaylist(E)}else E=this.getDeliveryDirectives(n,t.deliveryDirectives,_,T);var m=Object(r.computeReloadInterval)(n,i);void 0!==_&&n.canBlockReload&&(m-=n.partTarget||1),this.log("reload live playlist "+e+" in "+Math.round(m)+" ms"),this.timer=self.setTimeout((function(){return a.loadPlaylist(E)}),m)}else this.clearTimer()},t.getDeliveryDirectives=function(e,t,o,a){var r=Object(n.getSkipValue)(e,o);return null!=t&&t.skip&&e.deltaUpdateFailed&&(o=t.msn,a=t.part,r=n.HlsSkip.No),new n.HlsUrlParameters(o,a,r)},t.retryLoadingOrFail=function(e){var t,o=this,a=this.hls.config,n=this.retryCount-1&&null!==(t=e.context)&&void 0!==t&&t.deliveryDirectives)this.warn("retry playlist loading #"+this.retryCount+' after "'+e.details+'"'),this.loadPlaylist();else{var r=Math.min(Math.pow(2,this.retryCount)*a.levelLoadingRetryDelay,a.levelLoadingMaxRetryTimeout);this.timer=self.setTimeout((function(){return o.loadPlaylist()}),r),this.warn("retry playlist loading #"+this.retryCount+" in "+r+' ms after "'+e.details+'"')}else this.warn('cannot recover from error "'+e.details+'"'),this.clearTimer(),e.fatal=!0;return n},e})()},"./src/controller/base-stream-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"State",(function(){return p})),o.d(t,"default",(function(){return h}));var a=o("./src/polyfills/number.ts"),n=o("./src/task-loop.ts"),r=o("./src/controller/fragment-tracker.ts"),i=o("./src/utils/buffer-helper.ts"),s=o("./src/utils/logger.ts"),E=o("./src/events.ts"),_=o("./src/errors.ts"),T=o("./src/types/transmuxer.ts"),l=o("./src/utils/mp4-tools.ts"),S=o("./src/utils/discontinuities.ts"),u=o("./src/controller/fragment-finders.ts"),d=o("./src/controller/level-helper.ts"),c=o("./src/loader/fragment-loader.ts"),I=o("./src/crypt/decrypter.ts"),A=o("./src/utils/time-ranges.ts"),O=o("./src/types/loader.ts");function N(e,t){for(var o=0;o=t.endSN&&!e.nextStart){var n=t.partList;if(null!=n&&n.length){var s=n[n.length-1];return i.BufferHelper.isBuffered(this.media,s.start+s.duration/2)}var E=a.getState(o);return E===r.FragmentState.PARTIAL||E===r.FragmentState.OK}return!1},C.onMediaAttached=function(e,t){var o=this.media=this.mediaBuffer=t.media;this.onvseeking=this.onMediaSeeking.bind(this),this.onvended=this.onMediaEnded.bind(this),o.addEventListener("seeking",this.onvseeking),o.addEventListener("ended",this.onvended);var a=this.config;this.levels&&a.autoStartLoad&&this.state===p.STOPPED&&this.startLoad(a.startPosition)},C.onMediaDetaching=function(){var e=this.media;null!=e&&e.ended&&(this.log("MSE detaching and video ended, reset startPosition"),this.startPosition=this.lastCurrentTime=0),e&&this.onvseeking&&this.onvended&&(e.removeEventListener("seeking",this.onvseeking),e.removeEventListener("ended",this.onvended),this.onvseeking=this.onvended=null),this.media=this.mediaBuffer=null,this.loadedmetadata=!1,this.fragmentTracker.removeAllFragments(),this.stopLoad()},C.onMediaSeeking=function(){var e=this.config,t=this.fragCurrent,o=this.media,n=this.mediaBuffer,r=this.state,s=o?o.currentTime:0,E=i.BufferHelper.bufferInfo(n||o,s,e.maxBufferHole);if(this.log("media seeking to "+(Object(a.isFiniteNumber)(s)?s.toFixed(3):s)+", state: "+r),r===p.ENDED)this.resetLoadingState();else if(t&&!E.len){var _=e.maxFragLookUpTolerance,T=t.start-_,l=s>t.start+t.duration+_;(s0&&r&&r.key&&r.iv&&"AES-128"===r.method){var i=self.performance.now();return t.decrypter.webCryptoDecrypt(new Uint8Array(n),r.key.buffer,r.iv.buffer).then((function(t){var n=self.performance.now();return a.trigger(E.Events.FRAG_DECRYPTED,{frag:e,payload:t,stats:{tstart:i,tdecrypt:n}}),o.payload=t,o}))}return o})).then((function(o){var a=t.fragCurrent,n=t.hls,r=t.levels;if(!r)throw new Error("init load aborted, missing levels");var i=r[e.level].details;console.assert(i,"Level details are defined when init segment is loaded");var s=e.stats;t.state=p.IDLE,t.fragLoadError=0,e.data=new Uint8Array(o.payload),s.parsing.start=s.buffering.start=self.performance.now(),s.parsing.end=s.buffering.end=self.performance.now(),o.frag===a&&n.trigger(E.Events.FRAG_BUFFERED,{stats:s,frag:a,part:null,id:e.type}),t.tick()})).catch((function(o){t.state!==p.STOPPED&&t.state!==p.ERROR&&(t.warn(o),t.resetFragmentLoading(e))}))},C.fragContextChanged=function(e){var t=this.fragCurrent;return!e||!t||e.level!==t.level||e.sn!==t.sn||e.urlId!==t.urlId},C.fragBufferedComplete=function(e,t){var o=this.mediaBuffer?this.mediaBuffer:this.media;this.log("Buffered "+e.type+" sn: "+e.sn+(t?" part: "+t.index:"")+" of "+("[stream-controller]"===this.logPrefix?"level":"track")+" "+e.level+" "+(o?A.default.toString(i.BufferHelper.getBuffered(o)):"(detached)")),this.state=p.IDLE,o&&(!this.loadedmetadata&&o.buffered.length&&this.fragCurrent===this.fragPrevious&&(this.loadedmetadata=!0,this.seekToStartPos()),this.tick())},C.seekToStartPos=function(){},C._handleFragmentLoadComplete=function(e){var t=this.transmuxer;if(t){var o=e.frag,a=e.part,n=e.partsLoaded,r=!n||0===n.length||n.some((function(e){return!e})),i=new T.ChunkMetadata(o.level,o.sn,o.stats.chunkCount+1,0,a?a.index:-1,!r);t.flush(i)}},C._handleFragmentLoadProgress=function(e){},C._doFragLoad=function(e,t,o,n){var r=this;if(void 0===o&&(o=null),!this.levels)throw new Error("frag load aborted, missing levels");if(o=Math.max(e.start,o||0),this.config.lowLatencyMode&&t){var i=t.partList;if(i&&n){o>e.end&&t.fragmentHint&&(e=t.fragmentHint);var s=this.getNextPart(i,e,o);if(s>-1){var _=i[s];return this.log("Loading part sn: "+e.sn+" p: "+_.index+" cc: "+e.cc+" of playlist ["+t.startSN+"-"+t.endSN+"] parts [0-"+s+"-"+(i.length-1)+"] "+("[stream-controller]"===this.logPrefix?"level":"track")+": "+e.level+", target: "+parseFloat(o.toFixed(3))),this.nextLoadPosition=_.start+_.duration,this.state=p.FRAG_LOADING,this.hls.trigger(E.Events.FRAG_LOADING,{frag:e,part:i[s],targetBufferTime:o}),this.doFragPartsLoad(e,i,s,n).catch((function(e){return r.handleFragLoadError(e)}))}if(!e.url||this.loadedEndOfParts(i,o))return Promise.resolve(null)}}return this.log("Loading fragment "+e.sn+" cc: "+e.cc+" "+(t?"of ["+t.startSN+"-"+t.endSN+"] ":"")+("[stream-controller]"===this.logPrefix?"level":"track")+": "+e.level+", target: "+parseFloat(o.toFixed(3))),Object(a.isFiniteNumber)(e.sn)&&!this.bitrateTest&&(this.nextLoadPosition=e.start+e.duration),this.state=p.FRAG_LOADING,this.hls.trigger(E.Events.FRAG_LOADING,{frag:e,targetBufferTime:o}),this.fragmentLoader.load(e,n).catch((function(e){return r.handleFragLoadError(e)}))},C.doFragPartsLoad=function(e,t,o,a){var n=this;return new Promise((function(r,i){var s=[];!(function o(_){var T=t[_];n.fragmentLoader.loadPart(e,T,a).then((function(a){s[T.index]=a;var i=a.part;n.hls.trigger(E.Events.FRAG_LOADED,a);var l=t[_+1];if(!l||l.fragment!==e)return r({frag:e,part:i,partsLoaded:s});o(_+1)})).catch(i)})(o)}))},C.handleFragLoadError=function(e){var t=e.data;return t&&t.details===_.ErrorDetails.INTERNAL_ABORTED?this.handleFragLoadAborted(t.frag,t.part):this.hls.trigger(E.Events.ERROR,t),null},C._handleTransmuxerFlush=function(e){var t=this.getCurrentContext(e);if(t&&this.state===p.PARSING){var o=t.frag,a=t.part,n=t.level,r=self.performance.now();o.stats.parsing.end=r,a&&(a.stats.parsing.end=r),this.updateLevelTiming(o,a,n,e.partial)}else this.fragCurrent||(this.state=p.IDLE)},C.getCurrentContext=function(e){var t=this.levels,o=e.level,a=e.sn,n=e.part;if(!t||!t[o])return this.warn("Levels object was unset while buffering fragment "+a+" of level "+o+". The current chunk will not be buffered."),null;var r=t[o],i=n>-1?Object(d.getPartWith)(r,a,n):null,s=i?i.fragment:Object(d.getFragmentWithSN)(r,a,this.fragCurrent);return s?{frag:s,part:i,level:r}:null},C.bufferFragmentData=function(e,t,o,a){if(e&&this.state===p.PARSING){var n=e.data1,r=e.data2,i=n;if(n&&r&&(i=Object(l.appendUint8Array)(n,r)),i&&i.length){var s={type:e.type,frag:t,part:o,chunkMeta:a,parent:t.type,data:i};this.hls.trigger(E.Events.BUFFER_APPENDING,s),e.dropped&&e.independent&&!o&&this.flushBufferGap(t)}}},C.flushBufferGap=function(e){var t=this.media;if(t)if(i.BufferHelper.isBuffered(t,t.currentTime)){var o=t.currentTime,a=i.BufferHelper.bufferInfo(t,o,0),n=e.duration,r=Math.min(2*this.config.maxFragLookUpTolerance,.25*n),s=Math.max(Math.min(e.start-r,a.end-r),o+r);e.start-s>r&&this.flushMainBuffer(s,e.start)}else this.flushMainBuffer(0,e.start)},C.getFwdBufferInfo=function(e,t){var o=this.config,n=this.getLoadPosition();if(!Object(a.isFiniteNumber)(n))return null;var r=i.BufferHelper.bufferInfo(e,n,o.maxBufferHole);if(0===r.len&&void 0!==r.nextStart){var s=this.fragmentTracker.getBufferedFrag(n,t);if(s&&r.nextStart=o&&(t.maxMaxBufferLength/=2,this.warn("Reduce max buffer length to "+t.maxMaxBufferLength+"s"),!0)},C.getNextFragment=function(e,t){var o=t.fragments,a=o.length;if(!a)return null;var n,r=this.config,i=o[0].start;if(t.live){var s=r.initialLiveManifestSize;if(a-1&&oo.start&&o.loaded},C.getInitialLiveFragment=function(e,t){var o=this.fragPrevious,a=null;if(o){if(e.hasProgramDateTime&&(this.log("Live playlist, switching playlist, load frag with same PDT: "+o.programDateTime),a=Object(u.findFragmentByPDT)(t,o.endProgramDateTime,this.config.maxFragLookUpTolerance)),!a){var n=o.sn+1;if(n>=e.startSN&&n<=e.endSN){var r=t[n-e.startSN];o.cc===r.cc&&(a=r,this.log("Live playlist, switching playlist, load frag with next SN: "+a.sn))}a||(a=Object(u.findFragWithCC)(t,o.cc))&&this.log("Live playlist, switching playlist, load frag with same CC: "+a.sn)}}else{var i=this.hls.liveSyncPosition;null!==i&&(a=this.getFragmentAtPosition(i,this.bitrateTest?e.fragmentEnd:e.edge,e))}return a},C.getFragmentAtPosition=function(e,t,o){var a,n=this.config,i=this.fragPrevious,s=o.fragments,E=o.endSN,_=o.fragmentHint,T=n.maxFragLookUpTolerance,l=!!(n.lowLatencyMode&&o.partList&&_);if(l&&_&&!this.bitrateTest&&(s=s.concat(_),E=_.sn),et-T?0:T;a=Object(u.findFragmentByPTS)(i,s,e,S)}else a=s[s.length-1];if(a){var d=a.sn-o.startSN;if(i&&a.sn===i.sn&&!l&&i&&a.level===i.level){var c=s[d+1];a.sn=r-t.maxFragLookUpTolerance&&n<=i;if(null!==a&&o.duration>a&&(n"+e.startSN+" prev-sn: "+(r?r.sn:"na")+" fragments: "+s),l}return E},C.waitForCdnTuneIn=function(e){return e.live&&e.canBlockReload&&e.partTarget&&e.tuneInGoal>Math.max(e.partHoldBack,3*e.partTarget)},C.setStartPosition=function(e,t){var o=this.startPosition;if(o"+e))}}])&&N(h.prototype,f),L&&N(h,L),Object.defineProperty(h,"prototype",{writable:!1}),n})(n.default)},"./src/controller/buffer-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return u}));var a=o("./src/polyfills/number.ts"),n=o("./src/events.ts"),r=o("./src/utils/logger.ts"),i=o("./src/errors.ts"),s=o("./src/utils/buffer-helper.ts"),E=o("./src/utils/mediasource-helper.ts"),_=o("./src/loader/fragment.ts"),T=o("./src/controller/buffer-operation-queue.ts"),l=Object(E.getMediaSource)(),S=/([ha]vc.)(?:\.[^.,]+)+/,u=(function(){function e(e){var t=this;this.details=null,this._objectUrl=null,this.operationQueue=void 0,this.listeners=void 0,this.hls=void 0,this.bufferCodecEventsExpected=0,this._bufferCodecEventsTotal=0,this.media=null,this.mediaSource=null,this.appendError=0,this.tracks={},this.pendingTracks={},this.sourceBuffer=void 0,this._onMediaSourceOpen=function(){var e=t.hls,o=t.media,a=t.mediaSource;r.logger.log("[buffer-controller]: Media source opened"),o&&(t.updateMediaElementDuration(),e.trigger(n.Events.MEDIA_ATTACHED,{media:o})),a&&a.removeEventListener("sourceopen",t._onMediaSourceOpen),t.checkPendingTracks()},this._onMediaSourceClose=function(){r.logger.log("[buffer-controller]: Media source closed")},this._onMediaSourceEnded=function(){r.logger.log("[buffer-controller]: Media source ended")},this.hls=e,this._initSourceBuffer(),this.registerListeners()}var t=e.prototype;return t.hasSourceTypes=function(){return this.getSourceBufferTypes().length>0||Object.keys(this.pendingTracks).length>0},t.destroy=function(){this.unregisterListeners(),this.details=null},t.registerListeners=function(){var e=this.hls;e.on(n.Events.MEDIA_ATTACHING,this.onMediaAttaching,this),e.on(n.Events.MEDIA_DETACHING,this.onMediaDetaching,this),e.on(n.Events.MANIFEST_PARSED,this.onManifestParsed,this),e.on(n.Events.BUFFER_RESET,this.onBufferReset,this),e.on(n.Events.BUFFER_APPENDING,this.onBufferAppending,this),e.on(n.Events.BUFFER_CODECS,this.onBufferCodecs,this),e.on(n.Events.BUFFER_EOS,this.onBufferEos,this),e.on(n.Events.BUFFER_FLUSHING,this.onBufferFlushing,this),e.on(n.Events.LEVEL_UPDATED,this.onLevelUpdated,this),e.on(n.Events.FRAG_PARSED,this.onFragParsed,this),e.on(n.Events.FRAG_CHANGED,this.onFragChanged,this)},t.unregisterListeners=function(){var e=this.hls;e.off(n.Events.MEDIA_ATTACHING,this.onMediaAttaching,this),e.off(n.Events.MEDIA_DETACHING,this.onMediaDetaching,this),e.off(n.Events.MANIFEST_PARSED,this.onManifestParsed,this),e.off(n.Events.BUFFER_RESET,this.onBufferReset,this),e.off(n.Events.BUFFER_APPENDING,this.onBufferAppending,this),e.off(n.Events.BUFFER_CODECS,this.onBufferCodecs,this),e.off(n.Events.BUFFER_EOS,this.onBufferEos,this),e.off(n.Events.BUFFER_FLUSHING,this.onBufferFlushing,this),e.off(n.Events.LEVEL_UPDATED,this.onLevelUpdated,this),e.off(n.Events.FRAG_PARSED,this.onFragParsed,this),e.off(n.Events.FRAG_CHANGED,this.onFragChanged,this)},t._initSourceBuffer=function(){this.sourceBuffer={},this.operationQueue=new T.default(this.sourceBuffer),this.listeners={audio:[],video:[],audiovideo:[]}},t.onManifestParsed=function(e,t){var o=2;(t.audio&&!t.video||!t.altAudio)&&(o=1),this.bufferCodecEventsExpected=this._bufferCodecEventsTotal=o,this.details=null,r.logger.log(this.bufferCodecEventsExpected+" bufferCodec event(s) expected")},t.onMediaAttaching=function(e,t){var o=this.media=t.media;if(o&&l){var a=this.mediaSource=new l;a.addEventListener("sourceopen",this._onMediaSourceOpen),a.addEventListener("sourceended",this._onMediaSourceEnded),a.addEventListener("sourceclose",this._onMediaSourceClose),o.src=self.URL.createObjectURL(a),this._objectUrl=o.src}},t.onMediaDetaching=function(){var e=this.media,t=this.mediaSource,o=this._objectUrl;if(t){if(r.logger.log("[buffer-controller]: media source detaching"),"open"===t.readyState)try{t.endOfStream()}catch(e){r.logger.warn("[buffer-controller]: onMediaDetaching: "+e.message+" while calling endOfStream")}this.onBufferReset(),t.removeEventListener("sourceopen",this._onMediaSourceOpen),t.removeEventListener("sourceended",this._onMediaSourceEnded),t.removeEventListener("sourceclose",this._onMediaSourceClose),e&&(o&&self.URL.revokeObjectURL(o),e.src===o?(e.removeAttribute("src"),e.load()):r.logger.warn("[buffer-controller]: media.src was changed by a third party - skip cleanup")),this.mediaSource=null,this.media=null,this._objectUrl=null,this.bufferCodecEventsExpected=this._bufferCodecEventsTotal,this.pendingTracks={},this.tracks={}}this.hls.trigger(n.Events.MEDIA_DETACHED,void 0)},t.onBufferReset=function(){var e=this;this.getSourceBufferTypes().forEach((function(t){var o=e.sourceBuffer[t];try{o&&(e.removeBufferListeners(t),e.mediaSource&&e.mediaSource.removeSourceBuffer(o),e.sourceBuffer[t]=void 0)}catch(e){r.logger.warn("[buffer-controller]: Failed to reset the "+t+" buffer",e)}})),this._initSourceBuffer()},t.onBufferCodecs=function(e,t){var o=this,a=this.getSourceBufferTypes().length;Object.keys(t).forEach((function(e){if(a){var n=o.tracks[e];if(n&&"function"==typeof n.buffer.changeType){var i=t[e],s=i.id,E=i.codec,_=i.levelCodec,T=i.container,l=i.metadata,u=(n.levelCodec||n.codec).replace(S,"$1"),d=(_||E).replace(S,"$1");if(u!==d){var c=T+";codecs="+(_||E);o.appendChangeType(e,c),r.logger.log("[buffer-controller]: switching codec "+u+" to "+d),o.tracks[e]={buffer:n.buffer,codec:E,container:T,levelCodec:_,metadata:l,id:s}}}}else o.pendingTracks[e]=t[e]})),a||(this.bufferCodecEventsExpected=Math.max(this.bufferCodecEventsExpected-1,0),this.mediaSource&&"open"===this.mediaSource.readyState&&this.checkPendingTracks())},t.appendChangeType=function(e,t){var o=this,a=this.operationQueue,n={execute:function(){var n=o.sourceBuffer[e];n&&(r.logger.log("[buffer-controller]: changing "+e+" sourceBuffer type to "+t),n.changeType(t)),a.shiftAndExecuteNext(e)},onStart:function(){},onComplete:function(){},onError:function(t){r.logger.warn("[buffer-controller]: Failed to change "+e+" SourceBuffer type",t)}};a.append(n,e)},t.onBufferAppending=function(e,t){var o=this,a=this.hls,E=this.operationQueue,_=this.tracks,T=t.data,l=t.type,S=t.frag,u=t.part,d=t.chunkMeta,c=d.buffering[l],I=self.performance.now();c.start=I;var A=S.stats.buffering,O=u?u.stats.buffering:null;0===A.start&&(A.start=I),O&&0===O.start&&(O.start=I);var N=_.audio,m="audio"===l&&1===d.id&&"audio/mpeg"===(null==N?void 0:N.container),R={execute:function(){if(c.executeStart=self.performance.now(),m){var e=o.sourceBuffer[l];if(e){var t=S.start-e.timestampOffset;Math.abs(t)>=.1&&(r.logger.log("[buffer-controller]: Updating audio SourceBuffer timestampOffset to "+S.start+" (delta: "+t+") sn: "+S.sn+")"),e.timestampOffset=S.start)}}o.appendExecutor(T,l)},onStart:function(){},onComplete:function(){var e=self.performance.now();c.executeEnd=c.end=e,0===A.first&&(A.first=e),O&&0===O.first&&(O.first=e);var t=o.sourceBuffer,a={};for(var r in t)a[r]=s.BufferHelper.getBuffered(t[r]);o.appendError=0,o.hls.trigger(n.Events.BUFFER_APPENDED,{type:l,frag:S,part:u,chunkMeta:d,parent:S.type,timeRanges:a})},onError:function(e){r.logger.error("[buffer-controller]: Error encountered while trying to append to the "+l+" SourceBuffer",e);var t={type:i.ErrorTypes.MEDIA_ERROR,parent:S.type,details:i.ErrorDetails.BUFFER_APPEND_ERROR,err:e,fatal:!1};e.code===DOMException.QUOTA_EXCEEDED_ERR?t.details=i.ErrorDetails.BUFFER_FULL_ERROR:(o.appendError++,t.details=i.ErrorDetails.BUFFER_APPEND_ERROR,o.appendError>a.config.appendErrorMaxRetry&&(r.logger.error("[buffer-controller]: Failed "+a.config.appendErrorMaxRetry+" times to append segment in sourceBuffer"),t.fatal=!0,a.stopLoad())),a.trigger(n.Events.ERROR,t)}};E.append(R,l)},t.onBufferFlushing=function(e,t){var o=this,a=this.operationQueue,i=function(e){return{execute:o.removeExecutor.bind(o,e,t.startOffset,t.endOffset),onStart:function(){},onComplete:function(){o.hls.trigger(n.Events.BUFFER_FLUSHED,{type:e})},onError:function(t){r.logger.warn("[buffer-controller]: Failed to remove from "+e+" SourceBuffer",t)}}};t.type?a.append(i(t.type),t.type):this.getSourceBufferTypes().forEach((function(e){a.append(i(e),e)}))},t.onFragParsed=function(e,t){var o=this,a=t.frag,i=t.part,s=[],E=i?i.elementaryStreams:a.elementaryStreams;E[_.ElementaryStreamTypes.AUDIOVIDEO]?s.push("audiovideo"):(E[_.ElementaryStreamTypes.AUDIO]&&s.push("audio"),E[_.ElementaryStreamTypes.VIDEO]&&s.push("video")),0===s.length&&r.logger.warn("Fragments must have at least one ElementaryStreamType set. type: "+a.type+" level: "+a.level+" sn: "+a.sn),this.blockBuffers((function(){var e=self.performance.now();a.stats.buffering.end=e,i&&(i.stats.buffering.end=e);var t=i?i.stats:a.stats;o.hls.trigger(n.Events.FRAG_BUFFERED,{frag:a,part:i,stats:t,id:a.type})}),s)},t.onFragChanged=function(e,t){this.flushBackBuffer()},t.onBufferEos=function(e,t){var o=this;this.getSourceBufferTypes().reduce((function(e,a){var n=o.sourceBuffer[a];return t.type&&t.type!==a||n&&!n.ended&&(n.ended=!0,r.logger.log("[buffer-controller]: "+a+" sourceBuffer now EOS")),e&&!(n&&!n.ended)}),!0)&&this.blockBuffers((function(){var e=o.mediaSource;e&&"open"===e.readyState&&e.endOfStream()}))},t.onLevelUpdated=function(e,t){var o=t.details;o.fragments.length&&(this.details=o,this.getSourceBufferTypes().length?this.blockBuffers(this.updateMediaElementDuration.bind(this)):this.updateMediaElementDuration())},t.flushBackBuffer=function(){var e=this.hls,t=this.details,o=this.media,r=this.sourceBuffer;if(o&&null!==t){var i=this.getSourceBufferTypes();if(i.length){var E=t.live&&null!==e.config.liveBackBufferLength?e.config.liveBackBufferLength:e.config.backBufferLength;if(Object(a.isFiniteNumber)(E)&&!(E<0)){var _=o.currentTime,T=t.levelTargetDuration,l=Math.max(E,T),S=Math.floor(_/T)*T-l;i.forEach((function(o){var a=r[o];if(a){var i=s.BufferHelper.getBuffered(a);i.length>0&&S>i.start(0)&&(e.trigger(n.Events.BACK_BUFFER_REACHED,{bufferEnd:S}),t.live&&e.trigger(n.Events.LIVE_BACK_BUFFER_REACHED,{bufferEnd:S}),e.trigger(n.Events.BUFFER_FLUSHING,{startOffset:0,endOffset:S,type:o}))}}))}}}},t.updateMediaElementDuration=function(){if(this.details&&this.media&&this.mediaSource&&"open"===this.mediaSource.readyState){var e=this.details,t=this.hls,o=this.media,n=this.mediaSource,i=e.fragments[0].start+e.totalduration,s=o.duration,E=Object(a.isFiniteNumber)(n.duration)?n.duration:0;e.live&&t.config.liveDurationInfinity?(r.logger.log("[buffer-controller]: Media Source duration is set to Infinity"),n.duration=1/0,this.updateSeekableRange(e)):(i>E&&i>s||!Object(a.isFiniteNumber)(s))&&(r.logger.log("[buffer-controller]: Updating Media Source duration to "+i.toFixed(3)),n.duration=i)}},t.updateSeekableRange=function(e){var t=this.mediaSource,o=e.fragments;if(o.length&&e.live&&null!=t&&t.setLiveSeekableRange){var a=Math.max(0,o[0].start),n=Math.max(a,a+e.totalduration);t.setLiveSeekableRange(a,n)}},t.checkPendingTracks=function(){var e=this.bufferCodecEventsExpected,t=this.operationQueue,o=this.pendingTracks,a=Object.keys(o).length;if(a&&!e||2===a){this.createSourceBuffers(o),this.pendingTracks={};var r=this.getSourceBufferTypes();if(0===r.length)return void this.hls.trigger(n.Events.ERROR,{type:i.ErrorTypes.MEDIA_ERROR,details:i.ErrorDetails.BUFFER_INCOMPATIBLE_CODECS_ERROR,fatal:!0,reason:"could not create source buffer for media codec(s)"});r.forEach((function(e){t.executeNext(e)}))}},t.createSourceBuffers=function(e){var t=this.sourceBuffer,o=this.mediaSource;if(!o)throw Error("createSourceBuffers called when mediaSource was null");var a=0;for(var s in e)if(!t[s]){var E=e[s];if(!E)throw Error("source buffer exists for track "+s+", however track does not");var _=E.levelCodec||E.codec,T=E.container+";codecs="+_;r.logger.log("[buffer-controller]: creating sourceBuffer("+T+")");try{var l=t[s]=o.addSourceBuffer(T),S=s;this.addBufferListener(S,"updatestart",this._onSBUpdateStart),this.addBufferListener(S,"updateend",this._onSBUpdateEnd),this.addBufferListener(S,"error",this._onSBUpdateError),this.tracks[s]={buffer:l,codec:_,container:E.container,levelCodec:E.levelCodec,metadata:E.metadata,id:E.id},a++}catch(e){r.logger.error("[buffer-controller]: error while trying to add sourceBuffer: "+e.message),this.hls.trigger(n.Events.ERROR,{type:i.ErrorTypes.MEDIA_ERROR,details:i.ErrorDetails.BUFFER_ADD_CODEC_ERROR,fatal:!1,error:e,mimeType:T})}}a&&this.hls.trigger(n.Events.BUFFER_CREATED,{tracks:this.tracks})},t._onSBUpdateStart=function(e){this.operationQueue.current(e).onStart()},t._onSBUpdateEnd=function(e){var t=this.operationQueue;t.current(e).onComplete(),t.shiftAndExecuteNext(e)},t._onSBUpdateError=function(e,t){r.logger.error("[buffer-controller]: "+e+" SourceBuffer error",t),this.hls.trigger(n.Events.ERROR,{type:i.ErrorTypes.MEDIA_ERROR,details:i.ErrorDetails.BUFFER_APPENDING_ERROR,fatal:!1});var o=this.operationQueue.current(e);o&&o.onError(t)},t.removeExecutor=function(e,t,o){var n=this.media,i=this.mediaSource,s=this.operationQueue,E=this.sourceBuffer[e];if(!n||!i||!E)return r.logger.warn("[buffer-controller]: Attempting to remove from the "+e+" SourceBuffer, but it does not exist"),void s.shiftAndExecuteNext(e);var _=Object(a.isFiniteNumber)(n.duration)?n.duration:1/0,T=Object(a.isFiniteNumber)(i.duration)?i.duration:1/0,l=Math.max(0,t),S=Math.min(o,_,T);S>l?(r.logger.log("[buffer-controller]: Removing ["+l+","+S+"] from the "+e+" SourceBuffer"),console.assert(!E.updating,e+" sourceBuffer must not be updating"),E.remove(l,S)):s.shiftAndExecuteNext(e)},t.appendExecutor=function(e,t){var o=this.operationQueue,a=this.sourceBuffer[t];if(!a)return r.logger.warn("[buffer-controller]: Attempting to append to the "+t+" SourceBuffer, but it does not exist"),void o.shiftAndExecuteNext(t);a.ended=!1,console.assert(!a.updating,t+" sourceBuffer must not be updating"),a.appendBuffer(e)},t.blockBuffers=function(e,t){var o=this;if(void 0===t&&(t=this.getSourceBufferTypes()),!t.length)return r.logger.log("[buffer-controller]: Blocking operation requested, but no SourceBuffers exist"),void Promise.resolve().then(e);var a=this.operationQueue,n=t.map((function(e){return a.appendBlocker(e)}));Promise.all(n).then((function(){e(),t.forEach((function(e){var t=o.sourceBuffer[e];t&&t.updating||a.shiftAndExecuteNext(e)}))}))},t.getSourceBufferTypes=function(){return Object.keys(this.sourceBuffer)},t.addBufferListener=function(e,t,o){var a=this.sourceBuffer[e];if(a){var n=o.bind(this,e);this.listeners[e].push({event:t,listener:n}),a.addEventListener(t,n)}},t.removeBufferListeners=function(e){var t=this.sourceBuffer[e];t&&this.listeners[e].forEach((function(e){t.removeEventListener(e.event,e.listener)}))},e})()},"./src/controller/buffer-operation-queue.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return n}));var a=o("./src/utils/logger.ts"),n=(function(){function e(e){this.buffers=void 0,this.queues={video:[],audio:[],audiovideo:[]},this.buffers=e}var t=e.prototype;return t.append=function(e,t){var o=this.queues[t];o.push(e),1===o.length&&this.buffers[t]&&this.executeNext(t)},t.insertAbort=function(e,t){this.queues[t].unshift(e),this.executeNext(t)},t.appendBlocker=function(e){var t,o=new Promise((function(e){t=e})),a={execute:t,onStart:function(){},onComplete:function(){},onError:function(){}};return this.append(a,e),o},t.executeNext=function(e){var t=this.buffers,o=this.queues,n=t[e],r=o[e];if(r.length){var i=r[0];try{i.execute()}catch(t){a.logger.warn("[buffer-operation-queue]: Unhandled exception executing the current operation"),i.onError(t),n&&n.updating||(r.shift(),this.executeNext(e))}}},t.shiftAndExecuteNext=function(e){this.queues[e].shift(),this.executeNext(e)},t.current=function(e){return this.queues[e][0]},e})()},"./src/controller/cap-level-controller.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/events.ts");function n(e,t){for(var o=0;o0&&this.mediaWidth>0){var e=this.hls.levels;if(e.length){var t=this.hls;t.autoLevelCapping=this.getMaxLevel(e.length-1),t.autoLevelCapping>this.autoLevelCapping&&this.streamController&&this.streamController.nextLevelSwitch(),this.autoLevelCapping=t.autoLevelCapping}}},i.getMaxLevel=function(t){var o=this,a=this.hls.levels;if(!a.length)return-1;var n=a.filter((function(a,n){return e.isLevelAllowed(n,o.restrictedLevels)&&n<=t}));return this.clientRect=null,e.getMaxLevelByMediaSize(n,this.mediaWidth,this.mediaHeight)},i.startCapping=function(){this.timer||(this.autoLevelCapping=Number.POSITIVE_INFINITY,this.hls.firstLevel=this.getMaxLevel(this.firstLevel),self.clearInterval(this.timer),this.timer=self.setInterval(this.detectPlayerSize.bind(this),1e3),this.detectPlayerSize())},i.stopCapping=function(){this.restrictedLevels=[],this.firstLevel=-1,this.autoLevelCapping=Number.POSITIVE_INFINITY,this.timer&&(self.clearInterval(this.timer),this.timer=void 0)},i.getDimensions=function(){if(this.clientRect)return this.clientRect;var e=this.media,t={width:0,height:0};if(e){var o=e.getBoundingClientRect();t.width=o.width,t.height=o.height,t.width||t.height||(t.width=o.right-o.left||e.width||0,t.height=o.bottom-o.top||e.height||0)}return this.clientRect=t,t},e.isLevelAllowed=function(e,t){return void 0===t&&(t=[]),-1===t.indexOf(e)},e.getMaxLevelByMediaSize=function(e,t,o){if(!e||!e.length)return-1;for(var a,n,r=e.length-1,i=0;i=t||s.height>=o)&&(a=s,!(n=e[i+1])||a.width!==n.width||a.height!==n.height)){r=i;break}}return r},t=e,(o=[{key:"mediaWidth",get:function(){return this.getDimensions().width*this.contentScaleFactor}},{key:"mediaHeight",get:function(){return this.getDimensions().height*this.contentScaleFactor}},{key:"contentScaleFactor",get:function(){var e=1;if(!this.hls.config.ignoreDevicePixelRatio)try{e=self.devicePixelRatio}catch(e){}return e}}])&&n(t.prototype,o),r&&n(t,r),Object.defineProperty(t,"prototype",{writable:!1}),e})();t.default=r},"./src/controller/cmcd-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return S}));var a=o("./src/events.ts"),n=o("./src/types/cmcd.ts"),r=o("./src/utils/buffer-helper.ts"),i=o("./src/utils/logger.ts");function s(e,t){for(var o=0;o=e.length?{done:!0}:{done:!1,value:e[a++]}}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function T(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o-1?r+1:a.levels.length;t=a.levels.slice(0,i)}for(var s,E=_(t);!(s=E()).done;){var T=s.value;T.bitrate>o&&(o=T.bitrate)}return o>0?o:NaN},t.getBufferLength=function(e){var t=this.hls.media,o=e===n.CMCDObjectType.AUDIO?this.audioBuffer:this.videoBuffer;return o&&t?1e3*r.BufferHelper.bufferInfo(o,t.currentTime,this.config.maxBufferHole).len:NaN},t.createPlaylistLoader=function(){var e=this.config.pLoader,t=this.applyPlaylistData,o=e||this.config.loader;return(function(){function e(e){this.loader=void 0,this.loader=new o(e)}var a=e.prototype;return a.destroy=function(){this.loader.destroy()},a.abort=function(){this.loader.abort()},a.load=function(e,o,a){t(e),this.loader.load(e,o,a)},E(e,[{key:"stats",get:function(){return this.loader.stats}},{key:"context",get:function(){return this.loader.context}}]),e})()},t.createFragmentLoader=function(){var e=this.config.fLoader,t=this.applyFragmentData,o=e||this.config.loader;return(function(){function e(e){this.loader=void 0,this.loader=new o(e)}var a=e.prototype;return a.destroy=function(){this.loader.destroy()},a.abort=function(){this.loader.abort()},a.load=function(e,o,a){t(e),this.loader.load(e,o,a)},E(e,[{key:"stats",get:function(){return this.loader.stats}},{key:"context",get:function(){return this.loader.context}}]),e})()},e.uuid=function(){var e=URL.createObjectURL(new Blob),t=e.toString();return URL.revokeObjectURL(e),t.slice(t.lastIndexOf("/")+1)},e.serialize=function(e){for(var t,o=[],a=function(e){return!Number.isNaN(e)&&null!=e&&""!==e&&!1!==e},n=function(e){return Math.round(e)},r=function(e){return 100*n(e/100)},i={br:n,d:n,bl:r,dl:r,mtp:r,nor:function(e){return encodeURIComponent(e)},rtp:r,tb:n},s=_(Object.keys(e||{}).sort());!(t=s()).done;){var E=t.value,T=e[E];if(a(T)&&!("v"===E&&1===T||"pr"==E&&1===T)){var l=i[E];l&&(T=l(T));var S=typeof T,u=void 0;u="ot"===E||"sf"===E||"st"===E?E+"="+T:"boolean"===S?E:"number"===S?E+"="+T:E+"="+JSON.stringify(T),o.push(u)}}return o.join(",")},e.toHeaders=function(t){for(var o={},a=["Object","Request","Session","Status"],n=[{},{},{},{}],r={br:0,d:0,ot:0,tb:0,bl:1,dl:1,mtp:1,nor:1,nrr:1,su:1,cid:2,pr:2,sf:2,sid:2,st:2,v:2,bs:3,rtp:3},i=0,s=Object.keys(t);i3)return void this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.KEY_SYSTEM_ERROR,details:n.ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,fatal:!0});var _=3-this._requestLicenseFailureCount+1;r.logger.warn("Retrying license request, "+_+" attempts left"),this._requestLicense(o,i)}},_._generateLicenseRequestChallenge=function(e,t){if(e.mediaKeySystemDomain===i.KeySystems.WIDEVINE)return t;throw new Error("unsupported key-system: "+e.mediaKeySystemDomain)},_._requestLicense=function(e,t){r.logger.log("Requesting content license for key-system");var o=this._mediaKeysList[0];if(!o)return r.logger.error("Fatal error: Media is encrypted but no key-system access has been obtained yet"),void this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.KEY_SYSTEM_ERROR,details:n.ErrorDetails.KEY_SYSTEM_NO_ACCESS,fatal:!0});try{var i=this.getLicenseServerUrl(o.mediaKeySystemDomain),s=this._createLicenseXhr(i,e,t);r.logger.log("Sending license request to URL: "+i);var E=this._generateLicenseRequestChallenge(o,e);s.send(E)}catch(e){r.logger.error("Failure requesting DRM license: "+e),this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.KEY_SYSTEM_ERROR,details:n.ErrorDetails.KEY_SYSTEM_LICENSE_REQUEST_FAILED,fatal:!0})}},_.onMediaAttached=function(e,t){if(this._emeEnabled){var o=t.media;this._media=o,o.addEventListener("encrypted",this._onMediaEncrypted)}},_.onMediaDetached=function(){var e=this._media,t=this._mediaKeysList;e&&(e.removeEventListener("encrypted",this._onMediaEncrypted),this._media=null,this._mediaKeysList=[],Promise.all(t.map((function(e){if(e.mediaKeysSession)return e.mediaKeysSession.close().catch((function(){}))}))).then((function(){return e.setMediaKeys(null)})).catch((function(){})))},_.onManifestParsed=function(e,t){if(this._emeEnabled){var o=t.levels.map((function(e){return e.audioCodec})).filter((function(e){return!!e})),a=t.levels.map((function(e){return e.videoCodec})).filter((function(e){return!!e}));this._attemptKeySystemAccess(i.KeySystems.WIDEVINE,o,a)}},t=e,(o=[{key:"requestMediaKeySystemAccess",get:function(){if(!this._requestMediaKeySystemAccess)throw new Error("No requestMediaKeySystemAccess function configured");return this._requestMediaKeySystemAccess}}])&&s(t.prototype,o),E&&s(t,E),Object.defineProperty(t,"prototype",{writable:!1}),e})();t.default=E},"./src/controller/fps-controller.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/events.ts"),n=o("./src/utils/logger.ts"),r=(function(){function e(e){this.hls=void 0,this.isVideoPlaybackQualityAvailable=!1,this.timer=void 0,this.media=null,this.lastTime=void 0,this.lastDroppedFrames=0,this.lastDecodedFrames=0,this.streamController=void 0,this.hls=e,this.registerListeners()}var t=e.prototype;return t.setStreamController=function(e){this.streamController=e},t.registerListeners=function(){this.hls.on(a.Events.MEDIA_ATTACHING,this.onMediaAttaching,this)},t.unregisterListeners=function(){this.hls.off(a.Events.MEDIA_ATTACHING,this.onMediaAttaching)},t.destroy=function(){this.timer&&clearInterval(this.timer),this.unregisterListeners(),this.isVideoPlaybackQualityAvailable=!1,this.media=null},t.onMediaAttaching=function(e,t){var o=this.hls.config;if(o.capLevelOnFPSDrop){var a=t.media instanceof self.HTMLVideoElement?t.media:null;this.media=a,a&&"function"==typeof a.getVideoPlaybackQuality&&(this.isVideoPlaybackQualityAvailable=!0),self.clearInterval(this.timer),this.timer=self.setInterval(this.checkFPSInterval.bind(this),o.fpsDroppedMonitoringPeriod)}},t.checkFPS=function(e,t,o){var r=performance.now();if(t){if(this.lastTime){var i=r-this.lastTime,s=o-this.lastDroppedFrames,E=t-this.lastDecodedFrames,_=1e3*s/i,T=this.hls;if(T.trigger(a.Events.FPS_DROP,{currentDropped:s,currentDecoded:E,totalDroppedFrames:o}),_>0&&s>T.config.fpsDroppedMonitoringThreshold*E){var l=T.currentLevel;n.logger.warn("drop FPS ratio greater than max allowed value for currentLevel: "+l),l>0&&(-1===T.autoLevelCapping||T.autoLevelCapping>=l)&&(l-=1,T.trigger(a.Events.FPS_DROP_LEVEL_CAPPING,{level:l,droppedLevel:T.currentLevel}),T.autoLevelCapping=l,this.streamController.nextLevelSwitch())}}this.lastTime=r,this.lastDroppedFrames=o,this.lastDecodedFrames=t}},t.checkFPSInterval=function(){var e=this.media;if(e)if(this.isVideoPlaybackQualityAvailable){var t=e.getVideoPlaybackQuality();this.checkFPS(e,t.totalVideoFrames,t.droppedVideoFrames)}else this.checkFPS(e,e.webkitDecodedFrameCount,e.webkitDroppedFrameCount)},e})();t.default=r},"./src/controller/fragment-finders.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"findFragmentByPDT",(function(){return r})),o.d(t,"findFragmentByPTS",(function(){return i})),o.d(t,"fragmentWithinToleranceTest",(function(){return s})),o.d(t,"pdtWithinToleranceTest",(function(){return E})),o.d(t,"findFragWithCC",(function(){return _}));var a=o("./src/polyfills/number.ts"),n=o("./src/utils/binary-search.ts");function r(e,t,o){if(null===t||!Array.isArray(e)||!e.length||!Object(a.isFiniteNumber)(t))return null;if(t<(e[0].programDateTime||0))return null;if(t>=(e[e.length-1].endProgramDateTime||0))return null;o=o||0;for(var n=0;ne&&o.start?-1:0}function E(e,t,o){var a=1e3*Math.min(t,o.duration+(o.deltaPTS?o.deltaPTS:0));return(o.endProgramDateTime||0)-a>e}function _(e,t){return n.default.search(e,(function(e){return e.cct?-1:0}))}},"./src/controller/fragment-tracker.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"FragmentState",(function(){return a})),o.d(t,"FragmentTracker",(function(){return i}));var a,n=o("./src/events.ts"),r=o("./src/types/loader.ts");!(function(e){e.NOT_LOADED="NOT_LOADED",e.APPENDING="APPENDING",e.PARTIAL="PARTIAL",e.OK="OK"})(a||(a={}));var i=(function(){function e(e){this.activeFragment=null,this.activeParts=null,this.fragments=Object.create(null),this.timeRanges=Object.create(null),this.bufferPadding=.2,this.hls=void 0,this.hls=e,this._registerListeners()}var t=e.prototype;return t._registerListeners=function(){var e=this.hls;e.on(n.Events.BUFFER_APPENDED,this.onBufferAppended,this),e.on(n.Events.FRAG_BUFFERED,this.onFragBuffered,this),e.on(n.Events.FRAG_LOADED,this.onFragLoaded,this)},t._unregisterListeners=function(){var e=this.hls;e.off(n.Events.BUFFER_APPENDED,this.onBufferAppended,this),e.off(n.Events.FRAG_BUFFERED,this.onFragBuffered,this),e.off(n.Events.FRAG_LOADED,this.onFragLoaded,this)},t.destroy=function(){this._unregisterListeners(),this.fragments=this.timeRanges=null},t.getAppendedFrag=function(e,t){if(t===r.PlaylistLevelType.MAIN){var o=this.activeFragment,a=this.activeParts;if(!o)return null;if(a)for(var n=a.length;n--;){var i=a[n],s=i?i.end:o.appendedPTS;if(i.start<=e&&void 0!==s&&e<=s)return n>9&&(this.activeParts=a.slice(n-9)),i}else if(o.start<=e&&void 0!==o.appendedPTS&&e<=o.appendedPTS)return o}return this.getBufferedFrag(e,t)},t.getBufferedFrag=function(e,t){for(var o=this.fragments,a=Object.keys(o),n=a.length;n--;){var r=o[a[n]];if((null==r?void 0:r.body.type)===t&&r.buffered){var i=r.body;if(i.start<=e&&e<=i.end)return i}}return null},t.detectEvictedFragments=function(e,t,o){var a=this;Object.keys(this.fragments).forEach((function(n){var r=a.fragments[n];if(r)if(r.buffered){var i=r.range[e];i&&i.time.some((function(e){var o=!a.isTimeBuffered(e.startPTS,e.endPTS,t);return o&&a.removeFragment(r.body),o}))}else r.body.type===o&&a.removeFragment(r.body)}))},t.detectPartialFragments=function(e){var t=this,o=this.timeRanges,a=e.frag,n=e.part;if(o&&"initSegment"!==a.sn){var r=E(a),i=this.fragments[r];i&&(Object.keys(o).forEach((function(e){var r=a.elementaryStreams[e];if(r){var s=o[e],E=null!==n||!0===r.partial;i.range[e]=t.getBufferedTimes(a,n,E,s)}})),i.loaded=null,Object.keys(i.range).length?i.buffered=!0:this.removeFragment(i.body))}},t.fragBuffered=function(e){var t=E(e),o=this.fragments[t];o&&(o.loaded=null,o.buffered=!0)},t.getBufferedTimes=function(e,t,o,a){for(var n={time:[],partial:o},r=t?t.start:e.start,i=t?t.end:e.end,s=e.minEndPTS||i,E=e.maxStartPTS||r,_=0;_=T&&s<=l){n.time.push({startPTS:Math.max(r,a.start(_)),endPTS:Math.min(i,a.end(_))});break}if(rT)n.partial=!0,n.time.push({startPTS:Math.max(r,a.start(_)),endPTS:Math.min(i,a.end(_))});else if(i<=T)break}return n},t.getPartialFragment=function(e){var t,o,a,n=null,r=0,i=this.bufferPadding,E=this.fragments;return Object.keys(E).forEach((function(_){var T=E[_];T&&s(T)&&(o=T.body.start-i,a=T.body.end+i,e>=o&&e<=a&&(t=Math.min(e-o,a-e),r<=t&&(n=T.body,r=t)))})),n},t.getState=function(e){var t=E(e),o=this.fragments[t];return o?o.buffered?s(o)?a.PARTIAL:a.OK:a.APPENDING:a.NOT_LOADED},t.isTimeBuffered=function(e,t,o){for(var a,n,r=0;r=a&&t<=n)return!0;if(t<=a)return!1}return!1},t.onFragLoaded=function(e,t){var o=t.frag,a=t.part;if("initSegment"!==o.sn&&!o.bitrateTest&&!a){var n=E(o);this.fragments[n]={body:o,loaded:t,buffered:!1,range:Object.create(null)}}},t.onBufferAppended=function(e,t){var o=this,a=t.frag,n=t.part,i=t.timeRanges;if(a.type===r.PlaylistLevelType.MAIN)if(this.activeFragment=a,n){var s=this.activeParts;s||(this.activeParts=s=[]),s.push(n)}else this.activeParts=null;this.timeRanges=i,Object.keys(i).forEach((function(e){var t=i[e];if(o.detectEvictedFragments(e,t),!n)for(var r=0;re&&a.removeFragment(i)}}))},t.removeFragment=function(e){var t=E(e);e.stats.loaded=0,e.clearElementaryStreamInfo(),delete this.fragments[t]},t.removeAllFragments=function(){this.fragments=Object.create(null),this.activeFragment=null,this.activeParts=null},e})();function s(e){var t,o;return e.buffered&&((null===(t=e.range.video)||void 0===t?void 0:t.partial)||(null===(o=e.range.audio)||void 0===o?void 0:o.partial))}function E(e){return e.type+"_"+e.level+"_"+e.urlId+"_"+e.sn}},"./src/controller/gap-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"STALL_MINIMUM_DURATION_MS",(function(){return s})),o.d(t,"MAX_START_GAP_JUMP",(function(){return E})),o.d(t,"SKIP_BUFFER_HOLE_STEP_SECONDS",(function(){return _})),o.d(t,"SKIP_BUFFER_RANGE_START",(function(){return T})),o.d(t,"default",(function(){return l}));var a=o("./src/utils/buffer-helper.ts"),n=o("./src/errors.ts"),r=o("./src/events.ts"),i=o("./src/utils/logger.ts"),s=250,E=2,_=.1,T=.05,l=(function(){function e(e,t,o,a){this.config=void 0,this.media=null,this.fragmentTracker=void 0,this.hls=void 0,this.nudgeRetry=0,this.stallReported=!1,this.stalled=null,this.moved=!1,this.seeking=!1,this.config=e,this.media=t,this.fragmentTracker=o,this.hls=a}var t=e.prototype;return t.destroy=function(){this.media=null,this.hls=this.fragmentTracker=null},t.poll=function(e,t){var o=this.config,n=this.media,r=this.stalled;if(null!==n){var _=n.currentTime,T=n.seeking,l=this.seeking&&!T,S=!this.seeking&&T;if(this.seeking=T,_===e){if((S||l)&&(this.stalled=null),!(n.paused&&!T||n.ended||0===n.playbackRate)&&a.BufferHelper.getBuffered(n).length){var u=a.BufferHelper.bufferInfo(n,_,0),d=u.len>0,c=u.nextStart||0;if(d||c){if(T){var I=u.len>E,A=!c||t&&t.start<=_||c-_>E&&!this.fragmentTracker.getPartialFragment(_);if(I||A)return;this.moved=!1}if(!this.moved&&null!==this.stalled){var O,N=Math.max(c,u.start||0)-_,m=this.hls.levels?this.hls.levels[this.hls.currentLevel]:null,R=(null==m||null===(O=m.details)||void 0===O?void 0:O.live)?2*m.details.targetduration:E;if(N>0&&N<=R)return void this._trySkipBufferHole(null)}var p=self.performance.now();if(null!==r){var h=p-r;if(T||!(h>=s)||(this._reportStall(u),this.media)){var f=a.BufferHelper.bufferInfo(n,_,o.maxBufferHole);this._tryFixBufferStall(f,h)}}else this.stalled=p}}}else if(this.moved=!0,null!==r){if(this.stallReported){var L=self.performance.now()-r;i.logger.warn("playback not stuck anymore @"+_+", after "+Math.round(L)+"ms"),this.stallReported=!1}this.stalled=null,this.nudgeRetry=0}}},t._tryFixBufferStall=function(e,t){var o=this.config,a=this.fragmentTracker,n=this.media;if(null!==n){var r=n.currentTime,s=a.getPartialFragment(r);if(s&&(this._trySkipBufferHole(s)||!this.media))return;e.len>o.maxBufferHole&&t>1e3*o.highBufferWatchdogPeriod&&(i.logger.warn("Trying to nudge playhead over buffer-hole"),this.stalled=null,this._tryNudgeBuffer())}},t._reportStall=function(e){var t=this.hls,o=this.media;!this.stallReported&&o&&(this.stallReported=!0,i.logger.warn("Playback stalling at @"+o.currentTime+" due to low buffer ("+JSON.stringify(e)+")"),t.trigger(r.Events.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.BUFFER_STALLED_ERROR,fatal:!1,buffer:e.len}))},t._trySkipBufferHole=function(e){var t=this.config,o=this.hls,s=this.media;if(null===s)return 0;for(var E=s.currentTime,l=0,S=a.BufferHelper.getBuffered(s),u=0;u=l&&Ea.startDate&&e.push(o),e}),[]).sort((function(e,t){return e.startDate.getTime()-t.startDate.getTime()}))[0];I&&(d=T(I.startDate,A),_=!0)}for(var m,R=Object.keys(a.attr),p=0;p.05&&this.forwardBufferLength>1){var _=Math.min(2,Math.max(1,r)),T=Math.round(2/(1+Math.exp(-.75*s-this.edgeStalled))*20)/20;e.playbackRate=Math.min(_,Math.max(1,T))}else 1!==e.playbackRate&&0!==e.playbackRate&&(e.playbackRate=1)}}}}},E.estimateLiveEdge=function(){var e=this.levelDetails;return null===e?null:e.edge+e.age},E.computeLatency=function(){var e=this.estimateLiveEdge();return null===e?null:e-this.currentTime},t=e,(o=[{key:"latency",get:function(){return this._latency||0}},{key:"maxLatency",get:function(){var e=this.config,t=this.levelDetails;return void 0!==e.liveMaxLatencyDuration?e.liveMaxLatencyDuration:t?e.liveMaxLatencyDurationCount*t.targetduration:0}},{key:"targetLatency",get:function(){var e=this.levelDetails;if(null===e)return null;var t=e.holdBack,o=e.partHoldBack,a=e.targetduration,n=this.config,r=n.liveSyncDuration,i=n.liveSyncDurationCount,s=n.lowLatencyMode,E=this.hls.userConfig,_=s&&o||t;(E.liveSyncDuration||E.liveSyncDurationCount||0===_)&&(_=void 0!==r?r:i*a);var T=a;return _+Math.min(1*this.stallCount,T)}},{key:"liveSyncPosition",get:function(){var e=this.estimateLiveEdge(),t=this.targetLatency,o=this.levelDetails;if(null===e||null===t||null===o)return null;var a=o.edge,n=e-t-this.edgeStalled,r=a-o.totalduration,i=a-(this.config.lowLatencyMode&&o.partTarget||o.targetduration);return Math.min(Math.max(r,n),i)}},{key:"drift",get:function(){var e=this.levelDetails;return null===e?1:e.drift}},{key:"edgeStalled",get:function(){var e=this.levelDetails;if(null===e)return 0;var t=3*(this.config.lowLatencyMode&&e.partTarget||e.targetduration);return Math.max(e.age-t,0)}},{key:"forwardBufferLength",get:function(){var e=this.media,t=this.levelDetails;if(!e||!t)return 0;var o=e.buffered.length;return(o?e.buffered.end(o-1):t.edge)-this.currentTime}}])&&i(t.prototype,o),s&&i(t,s),Object.defineProperty(t,"prototype",{writable:!1}),e})()},"./src/controller/level-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return d}));var a=o("./src/types/level.ts"),n=o("./src/events.ts"),r=o("./src/errors.ts"),i=o("./src/utils/codecs.ts"),s=o("./src/controller/level-helper.ts"),E=o("./src/controller/base-playlist-controller.ts"),_=o("./src/types/loader.ts");function T(){return T=Object.assign?Object.assign.bind():function(e){for(var t=1;t0){o=_[0].bitrate,_.sort((function(e,t){return e.bitrate-t.bitrate})),this._levels=_;for(var A=0;A<_.length;A++)if(_[A].bitrate===o){this._firstLevel=A,this.log("manifest loaded, "+_.length+" level(s) found, first bitrate: "+o);break}var O=I&&!c,N={levels:_,audioTracks:T,subtitleTracks:l,firstLevel:this._firstLevel,stats:t.stats,audio:I,video:c,altAudio:!O&&T.some((function(e){return!!e.url}))};this.hls.trigger(n.Events.MANIFEST_PARSED,N),(this.hls.config.autoStartLoad||this.hls.forceStartLoad)&&this.hls.startLoad(this.hls.config.startPosition)}else this.hls.trigger(n.Events.ERROR,{type:r.ErrorTypes.MEDIA_ERROR,details:r.ErrorDetails.MANIFEST_INCOMPATIBLE_CODECS_ERROR,fatal:!0,url:t.url,reason:"no level with compatible codecs found in manifest"})},A.onError=function(t,o){var a;if(e.prototype.onError.call(this,t,o),!o.fatal){var n=o.context,i=this._levels[this.currentLevelIndex];if(n&&(n.type===_.PlaylistContextType.AUDIO_TRACK&&i.audioGroupIds&&n.groupId===i.audioGroupIds[i.urlId]||n.type===_.PlaylistContextType.SUBTITLE_TRACK&&i.textGroupIds&&n.groupId===i.textGroupIds[i.urlId]))this.redundantFailover(this.currentLevelIndex);else{var s,E=!1,T=!0;switch(o.details){case r.ErrorDetails.FRAG_LOAD_ERROR:case r.ErrorDetails.FRAG_LOAD_TIMEOUT:case r.ErrorDetails.KEY_LOAD_ERROR:case r.ErrorDetails.KEY_LOAD_TIMEOUT:if(o.frag){var l=o.frag.type===_.PlaylistLevelType.MAIN?o.frag.level:this.currentLevelIndex,S=this._levels[l];S?(S.fragmentError++,S.fragmentError>this.hls.config.fragLoadingMaxRetry&&(s=l)):s=l}break;case r.ErrorDetails.LEVEL_LOAD_ERROR:case r.ErrorDetails.LEVEL_LOAD_TIMEOUT:n&&(n.deliveryDirectives&&(T=!1),s=n.level),E=!0;break;case r.ErrorDetails.REMUX_ALLOC_ERROR:s=null!=(a=o.level)?a:this.currentLevelIndex,E=!0}void 0!==s&&this.recoverLevel(o,s,E,T)}}},A.recoverLevel=function(e,t,o,a){var n=e.details,r=this._levels[t];if(r.loadError++,o){if(!this.retryLoadingOrFail(e))return void(this.currentLevelIndex=-1);e.levelRetry=!0}if(a){var i=r.url.length;if(i>1&&r.loadError-1&&this.currentLevelIndex!==s&&(this.warn(n+": switch to "+s),e.levelRetry=!0,this.hls.nextAutoLevel=s)}}},A.redundantFailover=function(e){var t=this._levels[e],o=t.url.length;if(o>1){var a=(t.urlId+1)%o;this.warn("Switching to redundant URL-id "+a),this._levels.forEach((function(e){e.urlId=a})),this.level=e}},A.onFragLoaded=function(e,t){var o=t.frag;if(void 0!==o&&o.type===_.PlaylistLevelType.MAIN){var a=this._levels[o.level];void 0!==a&&(a.fragmentError=0,a.loadError=0)}},A.onLevelLoaded=function(e,t){var o,a,n=t.level,r=t.details,i=this._levels[n];if(!i)return this.warn("Invalid level index "+n),void(null!==(a=t.deliveryDirectives)&&void 0!==a&&a.skip&&(r.deltaUpdateFailed=!0));n===this.currentLevelIndex?(0===i.fragmentError&&(i.loadError=0,this.retryCount=0),this.playlistLoaded(n,t,i.details)):null!==(o=t.deliveryDirectives)&&void 0!==o&&o.skip&&(r.deltaUpdateFailed=!0)},A.onAudioTrackSwitched=function(e,t){var o=this.hls.levels[this.currentLevelIndex];if(o&&o.audioGroupIds){for(var a=-1,n=this.hls.audioTracks[t.id].groupId,r=0;r0){var a=o.urlId,r=o.url[a];if(e)try{r=e.addDirectives(r)}catch(e){this.warn("Could not construct new URL with HLS Delivery Directives: "+e)}this.log("Attempt loading level index "+t+(e?" at sn "+e.msn+" part "+e.part:"")+" with URL-id "+a+" "+r),this.clearTimer(),this.hls.trigger(n.Events.LEVEL_LOADING,{url:r,level:t,id:a,deliveryDirectives:e||null})}},A.removeLevel=function(e,t){var o=function(e,o){return o!==t},a=this._levels.filter((function(a,n){return n!==e||a.url.length>1&&void 0!==t&&(a.url=a.url.filter(o),a.audioGroupIds&&(a.audioGroupIds=a.audioGroupIds.filter(o)),a.textGroupIds&&(a.textGroupIds=a.textGroupIds.filter(o)),a.urlId=0,!0)})).map((function(e,t){var o=e.details;return null!=o&&o.fragments&&o.fragments.forEach((function(e){e.level=t})),e}));this._levels=a,this.hls.trigger(n.Events.LEVELS_UPDATED,{levels:a})},d=E,(c=[{key:"levels",get:function(){return 0===this._levels.length?null:this._levels}},{key:"level",get:function(){return this.currentLevelIndex},set:function(e){var t,o=this._levels;if(0!==o.length&&(this.currentLevelIndex!==e||null===(t=o[e])||void 0===t||!t.details)){if(e<0||e>=o.length){var a=e<0;if(this.hls.trigger(n.Events.ERROR,{type:r.ErrorTypes.OTHER_ERROR,details:r.ErrorDetails.LEVEL_SWITCH_ERROR,level:e,fatal:a,reason:"invalid level idx"}),a)return;e=Math.min(e,o.length-1)}this.clearTimer();var i=this.currentLevelIndex,s=o[i],E=o[e];this.log("switching to level "+e+" from "+i),this.currentLevelIndex=e;var _=T({},E,{level:e,maxBitrate:E.maxBitrate,uri:E.uri,urlId:E.urlId});delete _._urlId,this.hls.trigger(n.Events.LEVEL_SWITCHING,_);var l=E.details;if(!l||l.live){var S=this.switchParams(E.uri,null==s?void 0:s.details);this.loadPlaylist(S)}}}},{key:"manualLevel",get:function(){return this.manualLevelIndex},set:function(e){this.manualLevelIndex=e,void 0===this._startLevel&&(this._startLevel=e),-1!==e&&(this.level=e)}},{key:"firstLevel",get:function(){return this._firstLevel},set:function(e){this._firstLevel=e}},{key:"startLevel",get:function(){if(void 0===this._startLevel){var e=this.hls.config.startLevel;return void 0!==e?e:this._firstLevel}return this._startLevel},set:function(e){this._startLevel=e}},{key:"nextLoadLevel",get:function(){return-1!==this.manualLevelIndex?this.manualLevelIndex:this.hls.nextAutoLevel},set:function(e){this.level=e,-1===this.manualLevelIndex&&(this.hls.nextAutoLevel=e)}}])&&l(d.prototype,c),I&&l(d,I),Object.defineProperty(d,"prototype",{writable:!1}),E})(E.default)},"./src/controller/level-helper.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"addGroupId",(function(){return s})),o.d(t,"assignTrackIdsByGroup",(function(){return E})),o.d(t,"updatePTS",(function(){return _})),o.d(t,"updateFragPTSDTS",(function(){return l})),o.d(t,"mergeDetails",(function(){return S})),o.d(t,"mapPartIntersection",(function(){return u})),o.d(t,"mapFragmentIntersection",(function(){return d})),o.d(t,"adjustSliding",(function(){return c})),o.d(t,"addSliding",(function(){return I})),o.d(t,"computeReloadInterval",(function(){return A})),o.d(t,"getFragmentWithSN",(function(){return O})),o.d(t,"getPartWith",(function(){return N}));var a=o("./src/polyfills/number.ts"),n=o("./src/utils/logger.ts"),r=o("./src/loader/date-range.ts");function i(){return i=Object.assign?Object.assign.bind():function(e){for(var t=1;te.sn?(r=o-e.start,n=e):(r=e.start-o,n=t),n.duration!==r&&(n.duration=r)}else t.sn>e.sn?e.cc===t.cc&&e.minEndPTS?t.start=e.start+(e.minEndPTS-e.start):t.start=e.start+e.duration:t.start=Math.max(e.start-t.duration,0)}function l(e,t,o,r,i,s){r-o<=0&&(n.logger.warn("Fragment should have a positive duration",t),r=o+t.duration,s=i+t.duration);var E=o,_=r,l=t.startPTS,S=t.endPTS;if(Object(a.isFiniteNumber)(l)){var u=Math.abs(l-o);Object(a.isFiniteNumber)(t.deltaPTS)?t.deltaPTS=Math.max(u,t.deltaPTS):t.deltaPTS=u,E=Math.max(o,l),o=Math.min(o,l),i=Math.min(i,t.startDTS),_=Math.min(r,S),r=Math.max(r,S),s=Math.max(s,t.endDTS)}t.duration=r-o;var d=o-t.start;t.appendedPTS=r,t.start=t.startPTS=o,t.maxStartPTS=E,t.startDTS=i,t.endPTS=r,t.minEndPTS=_,t.endDTS=s;var c,I=t.sn;if(!e||Ie.endSN)return 0;var A=I-e.startSN,O=e.fragments;for(O[A]=t,c=A;c>0;c--)T(O[c],O[c-1]);for(c=A;c=0;E--){var _=s[E].initSegment;if(_){o=_;break}}e.fragmentHint&&delete e.fragmentHint.endPTS;var T,S,I,A,O,N=0;if(d(e,t,(function(e,n){e.relurl&&(N=e.cc-n.cc),Object(a.isFiniteNumber)(e.startPTS)&&Object(a.isFiniteNumber)(e.endPTS)&&(n.start=n.startPTS=e.startPTS,n.startDTS=e.startDTS,n.appendedPTS=e.appendedPTS,n.maxStartPTS=e.maxStartPTS,n.endPTS=e.endPTS,n.endDTS=e.endDTS,n.minEndPTS=e.minEndPTS,n.duration=e.endPTS-e.startPTS,n.duration&&(T=n),t.PTSKnown=t.alignedSliding=!0),n.elementaryStreams=e.elementaryStreams,n.loader=e.loader,n.stats=e.stats,n.urlId=e.urlId,e.initSegment&&(n.initSegment=e.initSegment,o=e.initSegment)})),o&&(t.fragmentHint?t.fragments.concat(t.fragmentHint):t.fragments).forEach((function(e){var t;e.initSegment&&e.initSegment.relurl!==(null===(t=o)||void 0===t?void 0:t.relurl)||(e.initSegment=o)})),t.skippedSegments)if(t.deltaUpdateFailed=t.fragments.some((function(e){return!e})),t.deltaUpdateFailed){n.logger.warn("[level-helper] Previous playlist missing segments skipped in delta playlist");for(var m=t.skippedSegments;m--;)t.fragments.shift();t.startSN=t.fragments[0].sn,t.startCC=t.fragments[0].cc}else t.canSkipDateRanges&&(t.dateRanges=(S=e.dateRanges,I=t.dateRanges,A=t.recentlyRemovedDateranges,O=i({},S),A&&A.forEach((function(e){delete O[e]})),Object.keys(I).forEach((function(e){var t=new r.DateRange(I[e].attr,O[e]);t.isValid?O[e]=t:n.logger.warn('Ignoring invalid Playlist Delta Update DATERANGE tag: "'+JSON.stringify(I[e].attr)+'"')})),O));var R=t.fragments;if(N){n.logger.warn("discontinuity sliding from playlist, take drift into account");for(var p=0;p=a.length||I(t,a[o].start)}function I(e,t){if(t){for(var o=e.fragments,a=e.skippedSegments;a0&&r<3*a,s=t.loading.end-t.loading.start,E=e.availabilityDelay;if(!1===e.updated)if(i){var _=333*e.misses;o=Math.max(Math.min(n,2*s),_),e.availabilityDelay=(e.availabilityDelay||0)+o}else o=n;else i?(E=Math.min(E||a/2,r),e.availabilityDelay=E,o=E+a-r):o=a-s;return Math.round(o)}function O(e,t,o){if(!e||!e.details)return null;var a=e.details,n=a.fragments[t-a.startSN];return n||((n=a.fragmentHint)&&n.sn===t?n:t1?(a=0,this.bitrateTest=!0):a=o.nextAutoLevel),this.level=o.nextLoadLevel=a,this.loadedmetadata=!1}t>0&&-1===e&&(this.log("Override startPosition with lastCurrentTime @"+t.toFixed(3)),e=t),this.state=n.State.IDLE,this.nextLoadPosition=this.startPosition=this.lastCurrentTime=e,this.tick()}else this._forceStartLoad=!0,this.state=n.State.STOPPED},R.stopLoad=function(){this._forceStartLoad=!1,e.prototype.stopLoad.call(this)},R.doTick=function(){switch(this.state){case n.State.IDLE:this.doTickIdle();break;case n.State.WAITING_LEVEL:var e,t=this.levels,o=this.level,a=null==t||null===(e=t[o])||void 0===e?void 0:e.details;if(a&&(!a.live||this.levelLastLoaded===this.level)){if(this.waitForCdnTuneIn(a))break;this.state=n.State.IDLE;break}break;case n.State.FRAG_LOADING_WAITING_RETRY:var r,i=self.performance.now(),s=this.retryDate;(!s||i>=s||null!==(r=this.media)&&void 0!==r&&r.seeking)&&(this.log("retryDate reached, switch back to IDLE state"),this.resetStartWhenNotLoaded(this.level),this.state=n.State.IDLE)}this.onTickEnd()},R.onTickEnd=function(){e.prototype.onTickEnd.call(this),this.checkBuffer(),this.checkFragmentChanged()},R.doTickIdle=function(){var e,t,o=this.hls,a=this.levelLastLoaded,r=this.levels,s=this.media,l=o.config,S=o.nextLoadLevel;if(null!==a&&(s||!this.startFragRequested&&l.startFragPrefetch)&&(!this.altAudio||!this.audioOnly)&&r&&r[S]){var u=r[S];this.level=o.nextLoadLevel=S;var d=u.details;if(!d||this.state===n.State.WAITING_LEVEL||d.live&&this.levelLastLoaded!==S)this.state=n.State.WAITING_LEVEL;else{var c=this.getMainFwdBufferInfo();if(null!==c&&!(c.len>=this.getMaxBufferLength(u.maxBitrate))){if(this._streamEnded(c,d)){var I={};return this.altAudio&&(I.type="video"),this.hls.trigger(i.Events.BUFFER_EOS,I),void(this.state=n.State.ENDED)}this.backtrackFragment&&this.backtrackFragment.start>c.end&&(this.backtrackFragment=null);var A=this.backtrackFragment?this.backtrackFragment.start:c.end,O=this.getNextFragment(A,d);if(this.couldBacktrack&&!this.fragPrevious&&O&&"initSegment"!==O.sn&&this.fragmentTracker.getState(O)!==E.FragmentState.OK){var N,m=(null!=(N=this.backtrackFragment)?N:O).sn-d.startSN,R=d.fragments[m-1];R&&O.cc===R.cc&&(O=R,this.fragmentTracker.removeFragment(R))}else this.backtrackFragment&&c.len&&(this.backtrackFragment=null);if(O&&this.fragmentTracker.getState(O)===E.FragmentState.OK&&this.nextLoadPosition>A){var p=this.audioOnly&&!this.altAudio?T.ElementaryStreamTypes.AUDIO:T.ElementaryStreamTypes.VIDEO;s&&this.afterBufferFlushed(s,p,_.PlaylistLevelType.MAIN),O=this.getNextFragment(this.nextLoadPosition,d)}O&&(!O.initSegment||O.initSegment.data||this.bitrateTest||(O=O.initSegment),"identity"!==(null===(e=O.decryptdata)||void 0===e?void 0:e.keyFormat)||null!==(t=O.decryptdata)&&void 0!==t&&t.key?this.loadFragment(O,d,A):this.loadKey(O,d))}}}},R.loadFragment=function(t,o,a){var n,r=this.fragmentTracker.getState(t);this.fragCurrent=t,r===E.FragmentState.NOT_LOADED?"initSegment"===t.sn?this._loadInitSegment(t):this.bitrateTest?(this.log("Fragment "+t.sn+" of level "+t.level+" is being downloaded to test bitrate and will not be buffered"),this._loadBitrateTestFrag(t)):(this.startFragRequested=!0,e.prototype.loadFragment.call(this,t,o,a)):r===E.FragmentState.APPENDING?this.reduceMaxBufferLength(t.duration)&&this.fragmentTracker.removeFragment(t):0===(null===(n=this.media)||void 0===n?void 0:n.buffered.length)&&this.fragmentTracker.removeAllFragments()},R.getAppendedFrag=function(e){var t=this.fragmentTracker.getAppendedFrag(e,_.PlaylistLevelType.MAIN);return t&&"fragment"in t?t.fragment:t},R.getBufferedFrag=function(e){return this.fragmentTracker.getBufferedFrag(e,_.PlaylistLevelType.MAIN)},R.followingBufferedFrag=function(e){return e?this.getBufferedFrag(e.end+.5):null},R.immediateLevelSwitch=function(){this.abortCurrentFrag(),this.flushMainBuffer(0,Number.POSITIVE_INFINITY)},R.nextLevelSwitch=function(){var e=this.levels,t=this.media;if(null!=t&&t.readyState){var o,a=this.getAppendedFrag(t.currentTime);if(a&&a.start>1&&this.flushMainBuffer(0,a.start-1),!t.paused&&e){var n=e[this.hls.nextLoadLevel],r=this.fragLastKbps;o=r&&this.fragCurrent?this.fragCurrent.duration*n.maxBitrate/(1e3*r)+1:0}else o=0;var i=this.getBufferedFrag(t.currentTime+o);if(i){var s=this.followingBufferedFrag(i);if(s){this.abortCurrentFrag();var E=s.maxStartPTS?s.maxStartPTS:s.start,_=s.duration,T=Math.max(i.end,E+Math.min(Math.max(_-this.config.maxFragLookUpTolerance,.5*_),.75*_));this.flushMainBuffer(T,Number.POSITIVE_INFINITY)}}}},R.abortCurrentFrag=function(){var e=this.fragCurrent;switch(this.fragCurrent=null,this.backtrackFragment=null,null!=e&&e.loader&&e.loader.abort(),this.state){case n.State.KEY_LOADING:case n.State.FRAG_LOADING:case n.State.FRAG_LOADING_WAITING_RETRY:case n.State.PARSING:case n.State.PARSED:this.state=n.State.IDLE}this.nextLoadPosition=this.getLoadPosition()},R.flushMainBuffer=function(t,o){e.prototype.flushMainBuffer.call(this,t,o,this.altAudio?"video":null)},R.onMediaAttached=function(t,o){e.prototype.onMediaAttached.call(this,t,o);var a=o.media;this.onvplaying=this.onMediaPlaying.bind(this),this.onvseeked=this.onMediaSeeked.bind(this),a.addEventListener("playing",this.onvplaying),a.addEventListener("seeked",this.onvseeked),this.gapController=new u.default(this.config,a,this.fragmentTracker,this.hls)},R.onMediaDetaching=function(){var t=this.media;t&&this.onvplaying&&this.onvseeked&&(t.removeEventListener("playing",this.onvplaying),t.removeEventListener("seeked",this.onvseeked),this.onvplaying=this.onvseeked=null,this.videoBuffer=null),this.fragPlaying=null,this.gapController&&(this.gapController.destroy(),this.gapController=null),e.prototype.onMediaDetaching.call(this)},R.onMediaPlaying=function(){this.tick()},R.onMediaSeeked=function(){var e=this.media,t=e?e.currentTime:null;Object(a.isFiniteNumber)(t)&&this.log("Media seeked to "+t.toFixed(3)),this.tick()},R.onManifestLoading=function(){this.log("Trigger BUFFER_RESET"),this.hls.trigger(i.Events.BUFFER_RESET,void 0),this.fragmentTracker.removeAllFragments(),this.couldBacktrack=!1,this.startPosition=this.lastCurrentTime=0,this.fragPlaying=null,this.backtrackFragment=null},R.onManifestParsed=function(e,t){var o,a=!1,n=!1;t.levels.forEach((function(e){(o=e.audioCodec)&&(-1!==o.indexOf("mp4a.40.2")&&(a=!0),-1!==o.indexOf("mp4a.40.5")&&(n=!0))})),this.audioCodecSwitch=a&&n&&!Object(r.changeTypeSupported)(),this.audioCodecSwitch&&this.log("Both AAC/HE-AAC audio found in levels; declaring level codec as HE-AAC"),this.levels=t.levels,this.startFragRequested=!1},R.onLevelLoading=function(e,t){var o=this.levels;if(o&&this.state===n.State.IDLE){var a=o[t.level];(!a.details||a.details.live&&this.levelLastLoaded!==t.level||this.waitForCdnTuneIn(a.details))&&(this.state=n.State.WAITING_LEVEL)}},R.onLevelLoaded=function(e,t){var o,a=this.levels,r=t.level,s=t.details,E=s.totalduration;if(a){this.log("Level "+r+" loaded ["+s.startSN+","+s.endSN+"], cc ["+s.startCC+", "+s.endCC+"] duration:"+E);var _=this.fragCurrent;!_||this.state!==n.State.FRAG_LOADING&&this.state!==n.State.FRAG_LOADING_WAITING_RETRY||_.level!==t.level&&_.loader&&(this.state=n.State.IDLE,this.backtrackFragment=null,_.loader.abort());var T=a[r],l=0;if(s.live||null!==(o=T.details)&&void 0!==o&&o.live){if(s.fragments[0]||(s.deltaUpdateFailed=!0),s.deltaUpdateFailed)return;l=this.alignPlaylists(s,T.details)}if(T.details=s,this.levelLastLoaded=r,this.hls.trigger(i.Events.LEVEL_UPDATED,{details:s,level:r}),this.state===n.State.WAITING_LEVEL){if(this.waitForCdnTuneIn(s))return;this.state=n.State.IDLE}this.startFragRequested?s.live&&this.synchronizeToLiveEdge(s):this.setStartPosition(s,l),this.tick()}else this.warn("Levels were reset while loading level "+r)},R._handleFragmentLoadProgress=function(e){var t,o=e.frag,a=e.part,n=e.payload,r=this.levels;if(r){var i=r[o.level],s=i.details;if(s){var E=i.videoCodec,T=s.PTSKnown||!s.live,u=null===(t=o.initSegment)||void 0===t?void 0:t.data,d=this._getAudioCodec(i),c=this.transmuxer=this.transmuxer||new l.default(this.hls,_.PlaylistLevelType.MAIN,this._handleTransmuxComplete.bind(this),this._handleTransmuxerFlush.bind(this)),I=a?a.index:-1,A=-1!==I,O=new S.ChunkMetadata(o.level,o.sn,o.stats.chunkCount,n.byteLength,I,A),N=this.initPTS[o.cc];c.push(n,u,d,E,o,a,s.totalduration,T,O,N)}else this.warn("Dropping fragment "+o.sn+" of level "+o.level+" after level details were reset")}else this.warn("Levels were reset while fragment load was in progress. Fragment "+o.sn+" of level "+o.level+" will not be buffered")},R.onAudioTrackSwitching=function(e,t){var o=this.altAudio,a=!!t.url,n=t.id;if(!a){if(this.mediaBuffer!==this.media){this.log("Switching on main audio, use media.buffered to schedule main fragment loading"),this.mediaBuffer=this.media;var r=this.fragCurrent;null!=r&&r.loader&&(this.log("Switching to main audio track, cancel main fragment load"),r.loader.abort()),this.resetTransmuxer(),this.resetLoadingState()}else this.audioOnly&&this.resetTransmuxer();var s=this.hls;o&&s.trigger(i.Events.BUFFER_FLUSHING,{startOffset:0,endOffset:Number.POSITIVE_INFINITY,type:"audio"}),s.trigger(i.Events.AUDIO_TRACK_SWITCHED,{id:n})}},R.onAudioTrackSwitched=function(e,t){var o=t.id,a=!!this.hls.audioTracks[o].url;if(a){var n=this.videoBuffer;n&&this.mediaBuffer!==n&&(this.log("Switching on alternate audio, use video.buffered to schedule main fragment loading"),this.mediaBuffer=n)}this.altAudio=a,this.tick()},R.onBufferCreated=function(e,t){var o,a,n=t.tracks,r=!1;for(var i in n){var s=n[i];if("main"===s.id){if(a=i,o=s,"video"===i){var E=n[i];E&&(this.videoBuffer=E.buffer)}}else r=!0}r&&o?(this.log("Alternate track found, use "+a+".buffered to schedule main fragment loading"),this.mediaBuffer=o.buffer):this.mediaBuffer=this.media},R.onFragBuffered=function(e,t){var o=t.frag,a=t.part;if(!o||o.type===_.PlaylistLevelType.MAIN){if(this.fragContextChanged(o))return this.warn("Fragment "+o.sn+(a?" p: "+a.index:"")+" of level "+o.level+" finished buffering, but was aborted. state: "+this.state),void(this.state===n.State.PARSED&&(this.state=n.State.IDLE));var r=a?a.stats:o.stats;this.fragLastKbps=Math.round(8*r.total/(r.buffering.end-r.loading.first)),"initSegment"!==o.sn&&(this.fragPrevious=o),this.fragBufferedComplete(o,a)}},R.onError=function(e,t){switch(t.details){case d.ErrorDetails.FRAG_LOAD_ERROR:case d.ErrorDetails.FRAG_LOAD_TIMEOUT:case d.ErrorDetails.KEY_LOAD_ERROR:case d.ErrorDetails.KEY_LOAD_TIMEOUT:this.onFragmentOrKeyLoadError(_.PlaylistLevelType.MAIN,t);break;case d.ErrorDetails.LEVEL_LOAD_ERROR:case d.ErrorDetails.LEVEL_LOAD_TIMEOUT:this.state!==n.State.ERROR&&(t.fatal?(this.warn(""+t.details),this.state=n.State.ERROR):t.levelRetry||this.state!==n.State.WAITING_LEVEL||(this.state=n.State.IDLE));break;case d.ErrorDetails.BUFFER_FULL_ERROR:if("main"===t.parent&&(this.state===n.State.PARSING||this.state===n.State.PARSED)){var o=!0,a=this.getFwdBufferInfo(this.media,_.PlaylistLevelType.MAIN);if(a&&a.len>.5&&(o=!this.reduceMaxBufferLength(a.len)),o)this.warn("buffer full error also media.currentTime is not buffered, flush main"),this.immediateLevelSwitch();else{var r=this.fragCurrent;this.abortCurrentFrag(),r&&(this.flushMainBuffer(r.start,Number.POSITIVE_INFINITY),this.nextLoadPosition=r.start)}this.resetTransmuxer(),this.resetLoadingState()}}},R.checkBuffer=function(){var e=this.media,t=this.gapController;if(e&&t&&e.readyState){if(this.loadedmetadata||!s.BufferHelper.getBuffered(e).length){var o=this.state!==n.State.IDLE?this.fragCurrent:null;t.poll(this.lastCurrentTime,o)}this.lastCurrentTime=e.currentTime}},R.onFragLoadEmergencyAborted=function(){this.state=n.State.IDLE,this.loadedmetadata||(this.startFragRequested=!1,this.nextLoadPosition=this.startPosition),this.tickImmediate()},R.onBufferFlushed=function(e,t){var o=t.type;if(o!==T.ElementaryStreamTypes.AUDIO||this.audioOnly&&!this.altAudio){var a=(o===T.ElementaryStreamTypes.VIDEO?this.videoBuffer:this.mediaBuffer)||this.media;this.afterBufferFlushed(a,o,_.PlaylistLevelType.MAIN)}},R.onLevelsUpdated=function(e,t){this.levels=t.levels},R.swapAudioCodec=function(){this.audioCodecSwap=!this.audioCodecSwap},R.seekToStartPos=function(){var e=this.media;if(e){var t=e.currentTime,o=this.startPosition;if(o>=0&&t0&&(n1&&!1===e.seeking){var o=e.currentTime;if(s.BufferHelper.isBuffered(e,o)?t=this.getAppendedFrag(o):s.BufferHelper.isBuffered(e,o+.1)&&(t=this.getAppendedFrag(o+.1)),t){this.backtrackFragment=null;var a=this.fragPlaying,n=t.level;a&&t.sn===a.sn&&a.level===n&&t.urlId===a.urlId||(this.hls.trigger(i.Events.FRAG_CHANGED,{frag:t}),a&&a.level===n||this.hls.trigger(i.Events.LEVEL_SWITCHED,{level:n}),this.fragPlaying=t)}}},O=A,(N=[{key:"nextLevel",get:function(){var e=this.nextBufferedFrag;return e?e.level:-1}},{key:"currentFrag",get:function(){var e=this.media;return e?this.fragPlaying||this.getAppendedFrag(e.currentTime):null}},{key:"currentProgramDateTime",get:function(){var e=this.media;if(e){var t=e.currentTime,o=this.currentFrag;if(o&&Object(a.isFiniteNumber)(t)&&Object(a.isFiniteNumber)(o.programDateTime)){var n=o.programDateTime+1e3*(t-o.start);return new Date(n)}}return null}},{key:"currentLevel",get:function(){var e=this.currentFrag;return e?e.level:-1}},{key:"nextBufferedFrag",get:function(){var e=this.currentFrag;return e?this.followingBufferedFrag(e):null}},{key:"forceStartLoad",get:function(){return this._forceStartLoad}}])&&c(O.prototype,N),m&&c(O,m),Object.defineProperty(O,"prototype",{writable:!1}),A})(n.default)},"./src/controller/subtitle-stream-controller.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"SubtitleStreamController",(function(){return d}));var a=o("./src/events.ts"),n=o("./src/utils/buffer-helper.ts"),r=o("./src/controller/fragment-finders.ts"),i=o("./src/utils/discontinuities.ts"),s=o("./src/controller/level-helper.ts"),E=o("./src/controller/fragment-tracker.ts"),_=o("./src/controller/base-stream-controller.ts"),T=o("./src/types/loader.ts"),l=o("./src/types/level.ts");function S(e,t){for(var o=0;o=n[s].start&&i<=n[s].end){r=n[s];break}var E=o.start+o.duration;r?r.end=E:(r={start:i,end:E},n.push(r)),this.fragmentTracker.fragBuffered(o)}}},N.onBufferFlushing=function(e,t){var o=t.startOffset,a=t.endOffset;if(0===o&&a!==Number.POSITIVE_INFINITY){var n=this.currentTrackId,r=this.levels;if(!r.length||!r[n]||!r[n].details)return;var i=a-r[n].details.targetduration;if(i<=0)return;t.endOffsetSubtitles=Math.max(0,i),this.tracksBuffered.forEach((function(e){for(var t=0;t=T.length||n!==E)&&l){if(this.mediaBuffer=this.mediaBufferTimeRanges,a.live||null!==(o=l.details)&&void 0!==o&&o.live){var S=this.mainDetails;if(a.deltaUpdateFailed||!S)return;var u=S.fragments[0];l.details?0===this.alignPlaylists(a,l.details)&&u&&Object(s.addSliding)(a,u.start):a.hasProgramDateTime&&S.hasProgramDateTime?Object(i.alignMediaPlaylistByPDT)(a,S):u&&Object(s.addSliding)(a,u.start)}l.details=a,this.levelLastLoaded=n,this.tick(),a.live&&!this.fragCurrent&&this.media&&this.state===_.State.IDLE&&(Object(r.findFragmentByPTS)(null,a.fragments,this.media.currentTime,0)||(this.warn("Subtitle playlist not aligned with playback"),l.details=void 0))}}},N._handleFragmentLoadComplete=function(e){var t=e.frag,o=e.payload,n=t.decryptdata,r=this.hls;if(!this.fragContextChanged(t)&&o&&o.byteLength>0&&n&&n.key&&n.iv&&"AES-128"===n.method){var i=performance.now();this.decrypter.webCryptoDecrypt(new Uint8Array(o),n.key.buffer,n.iv.buffer).then((function(e){var o=performance.now();r.trigger(a.Events.FRAG_DECRYPTED,{frag:t,payload:e,stats:{tstart:i,tdecrypt:o}})}))}},N.doTick=function(){if(this.media){if(this.state===_.State.IDLE){var e=this.currentTrackId,t=this.levels;if(!t.length||!t[e]||!t[e].details)return;var o=t[e].details,a=o.targetduration,i=this.config,s=this.media,T=n.BufferHelper.bufferedInfo(this.tracksBuffered[this.currentTrackId]||[],s.currentTime-a,i.maxBufferHole),l=T.end;if(T.len>this.getMaxBufferLength()+a)return;console.assert(o,"Subtitle track details are defined on idle subtitle stream controller tick");var S,u=o.fragments,d=u.length,c=o.edge,I=this.fragPrevious;if(l>>=0)>a-1)throw new DOMException("Failed to execute '"+t+"' on 'TimeRanges': The index provided ("+o+") is greater than the maximum bound ("+a+")");return e[o][t]};this.buffered={get length(){return e.length},end:function(o){return t("end",o,e.length)},start:function(o){return t("start",o,e.length)}}}},"./src/controller/subtitle-track-controller.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/events.ts"),n=o("./src/utils/texttrack-utils.ts"),r=o("./src/controller/base-playlist-controller.ts"),i=o("./src/types/loader.ts");function s(e,t){for(var o=0;o-1&&(this.subtitleTrack=this.queuedDefaultTrack,this.queuedDefaultTrack=-1),this.useTextTrackPolling=!(this.media.textTracks&&"onchange"in this.media.textTracks),this.useTextTrackPolling?this.pollTrackChange(500):this.media.textTracks.addEventListener("change",this.asyncPollTrackChange))},u.pollTrackChange=function(e){self.clearInterval(this.subtitlePollingInterval),this.subtitlePollingInterval=self.setInterval(this.trackChangeListener,e)},u.onMediaDetaching=function(){this.media&&(self.clearInterval(this.subtitlePollingInterval),this.useTextTrackPolling||this.media.textTracks.removeEventListener("change",this.asyncPollTrackChange),this.trackId>-1&&(this.queuedDefaultTrack=this.trackId),T(this.media.textTracks).forEach((function(e){Object(n.clearCurrentCues)(e)})),this.subtitleTrack=-1,this.media=null)},u.onManifestLoading=function(){this.tracks=[],this.groupId=null,this.tracksInGroup=[],this.trackId=-1,this.selectDefaultTrack=!0},u.onManifestParsed=function(e,t){this.tracks=t.subtitleTracks},u.onSubtitleTrackLoaded=function(e,t){var o=t.id,a=t.details,n=this.trackId,r=this.tracksInGroup[n];if(r){var i=r.details;r.details=t.details,this.log("subtitle track "+o+" loaded ["+a.startSN+"-"+a.endSN+"]"),o===this.trackId&&(this.retryCount=0,this.playlistLoaded(o,t,i))}else this.warn("Invalid subtitle track id "+o)},u.onLevelLoading=function(e,t){this.switchLevel(t.level)},u.onLevelSwitching=function(e,t){this.switchLevel(t.level)},u.switchLevel=function(e){var t=this.hls.levels[e];if(null!=t&&t.textGroupIds){var o=t.textGroupIds[t.urlId];if(this.groupId!==o){var n=this.tracksInGroup?this.tracksInGroup[this.trackId]:void 0,r=this.tracks.filter((function(e){return!o||e.groupId===o}));this.tracksInGroup=r;var i=this.findTrackId(null==n?void 0:n.name)||this.findTrackId();this.groupId=o;var s={subtitleTracks:r};this.log("Updating subtitle tracks, "+r.length+' track(s) found in "'+o+'" group-id'),this.hls.trigger(a.Events.SUBTITLE_TRACKS_UPDATED,s),-1!==i&&this.setSubtitleTrack(i,n)}}},u.findTrackId=function(e){for(var t=this.tracksInGroup,o=0;o=n.length)){this.clearTimer();var r=n[e];if(this.log("Switching to subtitle track "+e),this.trackId=e,r){var i=r.id,s=r.groupId,E=void 0===s?"":s,_=r.name,T=r.type,l=r.url;this.hls.trigger(a.Events.SUBTITLE_TRACK_SWITCH,{id:i,groupId:E,name:_,type:T,url:l});var S=this.switchParams(r.url,null==t?void 0:t.details);this.loadPlaylist(S)}else this.hls.trigger(a.Events.SUBTITLE_TRACK_SWITCH,{id:e})}}else this.queuedDefaultTrack=e},u.onTextTracksChanged=function(){if(this.useTextTrackPolling||self.clearInterval(this.subtitlePollingInterval),this.media&&this.hls.config.renderTextTracksNatively){for(var e=-1,t=T(this.media.textTracks),o=0;o-1&&this.toggleTrackModes(this.trackId)}},{key:"subtitleTracks",get:function(){return this.tracksInGroup}},{key:"subtitleTrack",get:function(){return this.trackId},set:function(e){this.selectDefaultTrack=!1;var t=this.tracksInGroup?this.tracksInGroup[this.trackId]:void 0;this.setSubtitleTrack(e,t)}}])&&s(_.prototype,l),S&&s(_,S),Object.defineProperty(_,"prototype",{writable:!1}),r})(r.default);function T(e){for(var t=[],o=0;o=0&&(S[0]=Math.min(S[0],t),S[1]=Math.max(S[1],o),T=!0,u/(o-t)>.5))return}if(T||r.push([t,o]),this.config.renderTextTracksNatively){var d=this.captionsTracks[e];this.Cues.newCue(d,t,o,a)}else{var c=this.Cues.newCue(null,t,o,a);this.hls.trigger(n.Events.CUES_PARSED,{type:"captions",cues:c,track:e})}},t.onInitPtsFound=function(e,t){var o=this,a=t.frag,r=t.id,i=t.initPTS,s=t.timescale,E=this.unparsedVttFrags;"main"===r&&(this.initPTS[a.cc]=i,this.timescale[a.cc]=s),E.length&&(this.unparsedVttFrags=[],E.forEach((function(e){o.onFragLoaded(n.Events.FRAG_LOADED,e)})))},t.getExistingTrack=function(e){var t=this.media;if(t)for(var o=0;o>>8^255&I^99,e[u]=I,t[I]=u;var A=S[u],O=S[A],N=S[O],m=257*S[I]^16843008*I;a[u]=m<<24|m>>>8,n[u]=m<<16|m>>>16,r[u]=m<<8|m>>>24,i[u]=m,m=16843009*N^65537*O^257*A^16843008*u,E[I]=m<<24|m>>>8,_[I]=m<<16|m>>>16,T[I]=m<<8|m>>>24,l[I]=m,u?(u=A^S[S[S[N^A]]],d^=S[S[d]]):u=d=1}},t.expandKey=function(e){for(var t=this.uint8ArrayToUint32Array_(e),o=!0,a=0;a>>6);var d=(60&t[o+2])>>>2;if(!(d>u.length-1))return _=(1&t[o+2])<<2,_|=(192&t[o+3])>>>6,a.logger.log("manifest codec:"+i+", ADTS type:"+s+", samplingIndex:"+d),/firefox/i.test(l)?d>=6?(s=5,T=new Array(4),E=d-3):(s=2,T=new Array(2),E=d):-1!==l.indexOf("android")?(s=2,T=new Array(2),E=d):(s=5,T=new Array(4),i&&(-1!==i.indexOf("mp4a.40.29")||-1!==i.indexOf("mp4a.40.5"))||!i&&d>=6?E=d-3:((i&&-1!==i.indexOf("mp4a.40.2")&&(d>=6&&1===_||/vivaldi/i.test(l))||!i&&1===_)&&(s=2,T=new Array(2)),E=d)),T[0]=s<<3,T[0]|=(14&d)>>1,T[1]|=(1&d)<<7,T[1]|=_<<3,5===s&&(T[1]|=(14&E)>>1,T[2]=(1&E)<<7,T[2]|=8,T[3]=0),{config:T,samplerate:u[d],channelCount:_,codec:"mp4a.40."+s,manifestCodec:S};e.trigger(r.Events.ERROR,{type:n.ErrorTypes.MEDIA_ERROR,details:n.ErrorDetails.FRAG_PARSING_ERROR,fatal:!0,reason:"invalid ADTS sampling index:"+d})}function s(e,t){return 255===e[t]&&240==(246&e[t+1])}function E(e,t){return 1&e[t+1]?7:9}function _(e,t){return(3&e[t+3])<<11|e[t+4]<<3|(224&e[t+5])>>>5}function T(e,t){return t+5=e.length)return!1;var a=_(e,t);if(a<=o)return!1;var n=t+a;return n===e.length||l(e,n)}return!1}function d(e,t,o,n,r){if(!e.samplerate){var s=i(t,o,n,r);if(!s)return;e.config=s.config,e.samplerate=s.samplerate,e.channelCount=s.channelCount,e.codec=s.codec,e.manifestCodec=s.manifestCodec,a.logger.log("parsed codec:"+e.codec+", rate:"+s.samplerate+", channels:"+s.channelCount)}}function c(e){return 9216e4/e}function I(e,t){var o=E(e,t);if(t+o<=e.length){var a=_(e,t)-o;if(a>0)return{headerLength:o,frameLength:a}}}function A(e,t,o,a,n){var r,i=a+n*c(e.samplerate),s=I(t,o);if(s){var E=s.frameLength,_=s.headerLength,T=_+E,l=Math.max(0,o+T-t.length);l?(r=new Uint8Array(T-_)).set(t.subarray(o+_,t.length),0):r=t.subarray(o+_,o+T);var S={unit:r,pts:i};return l||e.samples.push(S),{sample:S,length:T,missing:l}}var u=t.length-o;return(r=new Uint8Array(u)).set(t.subarray(o,t.length),0),{sample:{unit:r,pts:i},length:u,missing:-1}}},"./src/demux/base-audio-demuxer.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"initPTSFn",(function(){return T}));var a=o("./src/polyfills/number.ts"),n=o("./src/demux/id3.ts"),r=o("./src/types/demuxer.ts"),i=o("./src/demux/dummy-demuxed-track.ts"),s=o("./src/utils/mp4-tools.ts"),E=o("./src/utils/typed-array.ts"),_=(function(){function e(){this._audioTrack=void 0,this._id3Track=void 0,this.frameIndex=0,this.cachedData=null,this.basePTS=null,this.initPTS=null}var t=e.prototype;return t.resetInitSegment=function(e,t,o,a){this._id3Track={type:"id3",id:3,pid:-1,inputTimeScale:9e4,sequenceNumber:0,samples:[],dropped:0}},t.resetTimeStamp=function(e){this.initPTS=e,this.resetContiguity()},t.resetContiguity=function(){this.basePTS=null,this.frameIndex=0},t.canParse=function(e,t){return!1},t.appendFrame=function(e,t,o){},t.demux=function(e,t){this.cachedData&&(e=Object(s.appendUint8Array)(this.cachedData,e),this.cachedData=null);var o,_,l=n.getID3Data(e,0),S=l?l.length:0,u=this._audioTrack,d=this._id3Track,c=l?n.getTimeStamp(l):void 0,I=e.length;for((null===this.basePTS||0===this.frameIndex&&Object(a.isFiniteNumber)(c))&&(this.basePTS=T(c,t,this.initPTS)),l&&l.length>0&&d.samples.push({pts:this.basePTS,dts:this.basePTS,data:l,type:r.MetadataSchema.audioId3}),_=this.basePTS;Se?(this.word<<=e,this.bitsAvailable-=e):(e-=this.bitsAvailable,e-=(t=e>>3)>>3,this.bytesAvailable-=t,this.loadWord(),this.word<<=e,this.bitsAvailable-=e)},t.readBits=function(e){var t=Math.min(this.bitsAvailable,e),o=this.word>>>32-t;return e>32&&a.logger.error("Cannot read more than 32 bits at a time"),this.bitsAvailable-=t,this.bitsAvailable>0?this.word<<=t:this.bytesAvailable>0&&this.loadWord(),(t=e-t)>0&&this.bitsAvailable?o<>>e))return this.word<<=e,this.bitsAvailable-=e,e;return this.loadWord(),e+this.skipLZ()},t.skipUEG=function(){this.skipBits(1+this.skipLZ())},t.skipEG=function(){this.skipBits(1+this.skipLZ())},t.readUEG=function(){var e=this.skipLZ();return this.readBits(e+1)-1},t.readEG=function(){var e=this.readUEG();return 1&e?1+e>>>1:-1*(e>>>1)},t.readBoolean=function(){return 1===this.readBits(1)},t.readUByte=function(){return this.readBits(8)},t.readUShort=function(){return this.readBits(16)},t.readUInt=function(){return this.readBits(32)},t.skipScalingList=function(e){for(var t=8,o=8,a=0;a0)return e.subarray(o,o+a)},s=function(e,t){var o=0;return o=(127&e[t])<<21,o|=(127&e[t+1])<<14,o|=(127&e[t+2])<<7,o|=127&e[t+3]},E=function(e,t){return n(e,t)&&s(e,t+6)+10<=e.length-t},_=function(e){for(var t=S(e),o=0;o>4){case 0:case 1:case 2:case 3:case 4:case 5:case 6:case 7:_+=String.fromCharCode(r);break;case 12:case 13:i=e[T++],_+=String.fromCharCode((31&r)<<6|63&i);break;case 14:i=e[T++],s=e[T++],_+=String.fromCharCode((15&r)<<12|(63&i)<<6|(63&s)<<0)}}return _},N={decodeTextFrame:c};function m(){return a||void 0===self.TextDecoder||(a=new self.TextDecoder("utf-8")),a}},"./src/demux/mp3demuxer.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/demux/base-audio-demuxer.ts"),n=o("./src/demux/id3.ts"),r=o("./src/utils/logger.ts"),i=o("./src/demux/mpegaudio.ts");function s(e,t){return s=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,t){return e.__proto__=t,e},s(e,t)}var E=(function(e){var t,o;function a(){return e.apply(this,arguments)||this}o=e,(t=a).prototype=Object.create(o.prototype),t.prototype.constructor=t,s(t,o);var E=a.prototype;return E.resetInitSegment=function(t,o,a,n){e.prototype.resetInitSegment.call(this,t,o,a,n),this._audioTrack={container:"audio/mpeg",type:"audio",id:2,pid:-1,sequenceNumber:0,segmentCodec:"mp3",samples:[],manifestCodec:o,duration:n,inputTimeScale:9e4,dropped:0}},a.probe=function(e){if(!e)return!1;for(var t=(n.getID3Data(e,0)||[]).length,o=e.length;t16384?e.subarray(0,16384):e,Object(r.findBox)(e,["moof"]).length>0},t.demux=function(e,t){this.timeOffset=t;var o=e,a=this.videoTrack,n=this.txtTrack;if(this.config.progressive){this.remainderData&&(o=Object(r.appendUint8Array)(this.remainderData,e));var i=Object(r.segmentValidRange)(o);this.remainderData=i.remainder,a.samples=i.valid||new Uint8Array}else a.samples=o;var s=this.extractID3Track(a,t);return n.samples=Object(r.parseSamples)(t,a),{videoTrack:a,audioTrack:this.audioTrack,id3Track:s,textTrack:this.txtTrack}},t.flush=function(){var e=this.timeOffset,t=this.videoTrack,o=this.txtTrack;t.samples=this.remainderData||new Uint8Array,this.remainderData=null;var a=this.extractID3Track(t,this.timeOffset);return o.samples=Object(r.parseSamples)(e,t),{videoTrack:t,audioTrack:Object(i.dummyTrack)(),id3Track:a,textTrack:Object(i.dummyTrack)()}},t.extractID3Track=function(e,t){var o=this.id3Track;if(e.samples.length){var i=Object(r.findBox)(e.samples,["emsg"]);i&&i.forEach((function(e){var i=Object(r.parseEmsg)(e);if(s.test(i.schemeIdUri)){var E=Object(a.isFiniteNumber)(i.presentationTime)?i.presentationTime/i.timeScale:t+i.presentationTimeDelta/i.timeScale,_=i.payload;o.samples.push({data:_,len:_.byteLength,dts:E,pts:E,type:n.MetadataSchema.emsg})}}))}return o},t.demuxSampleAes=function(e,t,o){return Promise.reject(new Error("The MP4 demuxer does not support SAMPLE-AES decryption"))},t.destroy=function(){},e})();t.default=E},"./src/demux/mpegaudio.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"appendFrame",(function(){return E})),o.d(t,"parseHeader",(function(){return _})),o.d(t,"isHeaderPattern",(function(){return T})),o.d(t,"isHeader",(function(){return l})),o.d(t,"canParse",(function(){return S})),o.d(t,"probe",(function(){return u}));var a=null,n=[32,64,96,128,160,192,224,256,288,320,352,384,416,448,32,48,56,64,80,96,112,128,160,192,224,256,320,384,32,40,48,56,64,80,96,112,128,160,192,224,256,320,32,48,56,64,80,96,112,128,144,160,176,192,224,256,8,16,24,32,40,48,56,64,80,96,112,128,144,160],r=[44100,48e3,32e3,22050,24e3,16e3,11025,12e3,8e3],i=[[0,72,144,12],[0,0,0,0],[0,72,144,12],[0,144,144,12]],s=[0,1,1,4];function E(e,t,o,a,n){if(!(o+24>t.length)){var r=_(t,o);if(r&&o+r.frameLength<=t.length){var i=a+n*(9e4*r.samplesPerFrame/r.sampleRate),s={unit:t.subarray(o,o+r.frameLength),pts:i,dts:i};return e.config=[],e.channelCount=r.channelCount,e.samplerate=r.sampleRate,e.samples.push(s),{sample:s,length:r.frameLength,missing:0}}}}function _(e,t){var o=e[t+1]>>3&3,E=e[t+1]>>1&3,_=e[t+2]>>4&15,T=e[t+2]>>2&3;if(1!==o&&0!==_&&15!==_&&3!==T){var l=e[t+2]>>1&1,S=e[t+3]>>6,u=1e3*n[14*(3===o?3-E:3===E?3:4)+_-1],d=r[3*(3===o?0:2===o?1:2)+T],c=3===S?1:2,I=i[o][E],A=s[E],O=8*I*A,N=Math.floor(I*u/d+l)*A;if(null===a){var m=(navigator.userAgent||"").match(/Chrome\/(\d+)/i);a=m?parseInt(m[1]):0}return!!a&&a<=87&&2===E&&u>=224e3&&0===S&&(e[t+3]=128|e[t+3]),{sampleRate:d,channelCount:c,frameLength:N,samplesPerFrame:O}}}function T(e,t){return 255===e[t]&&224==(224&e[t+1])&&0!=(6&e[t+1])}function l(e,t){return t+1=e.length)return void o();if(!(e[t].unit.length<32)){var a=this.decrypter.isSync();if(this.decryptAacSample(e,t,o,a),!a)return}}},t.getAvcEncryptedData=function(e){for(var t=16*Math.floor((e.length-48)/160)+16,o=new Int8Array(t),a=0,n=32;n=e.length)return void a();for(var n=e[t].units;!(o>=n.length);o++){var r=n[o];if(!(r.data.length<=48||1!==r.type&&5!==r.type)){var i=this.decrypter.isSync();if(this.decryptAvcSample(e,t,o,a,r,i),!i)return}}}},e})();t.default=r},"./src/demux/transmuxer-interface.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return l}));var a=o("./node_modules/webworkify-webpack/index.js"),n=o("./src/events.ts"),r=o("./src/demux/transmuxer.ts"),i=o("./src/utils/logger.ts"),s=o("./src/errors.ts"),E=o("./src/utils/mediasource-helper.ts"),_=o("./node_modules/eventemitter3/index.js"),T=Object(E.getMediaSource)()||{isTypeSupported:function(){return!1}},l=(function(){function e(e,t,o,E){var l=this;this.hls=void 0,this.id=void 0,this.observer=void 0,this.frag=null,this.part=null,this.worker=void 0,this.onwmsg=void 0,this.transmuxer=null,this.onTransmuxComplete=void 0,this.onFlush=void 0,this.hls=e,this.id=t,this.onTransmuxComplete=o,this.onFlush=E;var S=e.config,u=function(t,o){(o=o||{}).frag=l.frag,o.id=l.id,e.trigger(t,o)};this.observer=new _.EventEmitter,this.observer.on(n.Events.FRAG_DECRYPTED,u),this.observer.on(n.Events.ERROR,u);var d={mp4:T.isTypeSupported("video/mp4"),mpeg:T.isTypeSupported("audio/mpeg"),mp3:T.isTypeSupported('audio/mp4; codecs="mp3"')},c=navigator.vendor;if(S.enableWorker&&"undefined"!=typeof Worker){var I;i.logger.log("demuxing in webworker");try{I=this.worker=a("./src/demux/transmuxer-worker.ts"),this.onwmsg=this.onWorkerMessage.bind(this),I.addEventListener("message",this.onwmsg),I.onerror=function(t){e.trigger(n.Events.ERROR,{type:s.ErrorTypes.OTHER_ERROR,details:s.ErrorDetails.INTERNAL_EXCEPTION,fatal:!0,event:"demuxerWorker",error:new Error(t.message+" ("+t.filename+":"+t.lineno+")")})},I.postMessage({cmd:"init",typeSupported:d,vendor:c,id:t,config:JSON.stringify(S)})}catch(e){i.logger.warn("Error in worker:",e),i.logger.error("Error while initializing DemuxerWorker, fallback to inline"),I&&self.URL.revokeObjectURL(I.objectURL),this.transmuxer=new r.default(this.observer,d,S,c,t),this.worker=null}}else this.transmuxer=new r.default(this.observer,d,S,c,t)}var t=e.prototype;return t.destroy=function(){var e=this.worker;if(e)e.removeEventListener("message",this.onwmsg),e.terminate(),this.worker=null,this.onwmsg=void 0;else{var t=this.transmuxer;t&&(t.destroy(),this.transmuxer=null)}var o=this.observer;o&&o.removeAllListeners(),this.frag=null,this.observer=null,this.hls=null},t.push=function(e,t,o,a,n,s,E,_,T,l){var S,u,d=this;T.transmuxing.start=self.performance.now();var c=this.transmuxer,I=this.worker,A=s?s.start:n.start,O=n.decryptdata,N=this.frag,m=!(N&&n.cc===N.cc),R=!(N&&T.level===N.level),p=N?T.sn-N.sn:-1,h=this.part?T.part-this.part.index:-1,f=0===p&&T.id>1&&T.id===(null==N?void 0:N.stats.chunkCount),L=!R&&(1===p||0===p&&(1===h||f&&h<=0)),C=self.performance.now();(R||p||0===n.stats.parsing.start)&&(n.stats.parsing.start=C),!s||!h&&L||(s.stats.parsing.start=C);var D=!(N&&(null===(S=n.initSegment)||void 0===S?void 0:S.url)===(null===(u=N.initSegment)||void 0===u?void 0:u.url)),g=new r.TransmuxState(m,L,_,R,A,D);if(!L||m||D){i.logger.log("[transmuxer-interface, "+n.type+"]: Starting new transmux session for sn: "+T.sn+" p: "+T.part+" level: "+T.level+" id: "+T.id+"\n discontinuity: "+m+"\n trackSwitch: "+R+"\n contiguous: "+L+"\n accurateTimeOffset: "+_+"\n timeOffset: "+A+"\n initSegmentChange: "+D);var v=new r.TransmuxConfig(o,a,t,E,l);this.configureTransmuxer(v)}if(this.frag=n,this.part=s,I)I.postMessage({cmd:"demux",data:e,decryptdata:O,chunkMeta:T,state:g},e instanceof ArrayBuffer?[e]:[]);else if(c){var y=c.push(e,O,T,g);Object(r.isPromise)(y)?y.then((function(e){d.handleTransmuxComplete(e)})):this.handleTransmuxComplete(y)}},t.flush=function(e){var t=this;e.transmuxing.start=self.performance.now();var o=this.transmuxer,a=this.worker;if(a)a.postMessage({cmd:"flush",chunkMeta:e});else if(o){var n=o.flush(e);Object(r.isPromise)(n)?n.then((function(o){t.handleFlushResult(o,e)})):this.handleFlushResult(n,e)}},t.handleFlushResult=function(e,t){var o=this;e.forEach((function(e){o.handleTransmuxComplete(e)})),this.onFlush(t)},t.onWorkerMessage=function(e){var t=e.data,o=this.hls;switch(t.event){case"init":self.URL.revokeObjectURL(this.worker.objectURL);break;case"transmuxComplete":this.handleTransmuxComplete(t.data);break;case"flush":this.onFlush(t.data);break;case"workerLog":i.logger[t.data.logType]&&i.logger[t.data.logType](t.data.message);break;default:t.data=t.data||{},t.data.frag=this.frag,t.data.id=this.id,o.trigger(t.event,t.data)}},t.configureTransmuxer=function(e){var t=this.worker,o=this.transmuxer;t?t.postMessage({cmd:"configure",config:e}):o&&o.configure(e)},t.handleTransmuxComplete=function(e){e.chunkMeta.transmuxing.end=self.performance.now(),this.onTransmuxComplete(e)},e})()},"./src/demux/transmuxer-worker.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return s}));var a=o("./src/demux/transmuxer.ts"),n=o("./src/events.ts"),r=o("./src/utils/logger.ts"),i=o("./node_modules/eventemitter3/index.js");function s(e){var t=new i.EventEmitter,o=function(t,o){e.postMessage({event:t,data:o})};t.on(n.Events.FRAG_DECRYPTED,o),t.on(n.Events.ERROR,o),e.addEventListener("message",(function(n){var i=n.data;switch(i.cmd){case"init":var s=JSON.parse(i.config);e.transmuxer=new a.default(t,i.typeSupported,s,i.vendor,i.id),Object(r.enableLogs)(s.debug),(function(){var e=function(e){r.logger[e]=function(t){o("workerLog",{logType:e,message:t})}};for(var t in r.logger)e(t)})(),o("init",null);break;case"configure":e.transmuxer.configure(i.config);break;case"demux":var _=e.transmuxer.push(i.data,i.decryptdata,i.chunkMeta,i.state);Object(a.isPromise)(_)?_.then((function(t){E(e,t)})):E(e,_);break;case"flush":var l=i.chunkMeta,S=e.transmuxer.flush(l);Object(a.isPromise)(S)?S.then((function(t){T(e,t,l)})):T(e,S,l)}}))}function E(e,t){if(!((o=t.remuxResult).audio||o.video||o.text||o.id3||o.initSegment))return!1;var o,a=[],n=t.remuxResult,r=n.audio,i=n.video;return r&&_(a,r),i&&_(a,i),e.postMessage({event:"transmuxComplete",data:t},a),!0}function _(e,t){t.data1&&e.push(t.data1.buffer),t.data2&&e.push(t.data2.buffer)}function T(e,t,o){t.reduce((function(t,o){return E(e,o)||t}),!1)||e.postMessage({event:"transmuxComplete",data:t[0]}),e.postMessage({event:"flush",data:o})}},"./src/demux/transmuxer.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return c})),o.d(t,"isPromise",(function(){return A})),o.d(t,"TransmuxConfig",(function(){return O})),o.d(t,"TransmuxState",(function(){return N}));var a,n=o("./src/events.ts"),r=o("./src/errors.ts"),i=o("./src/crypt/decrypter.ts"),s=o("./src/demux/aacdemuxer.ts"),E=o("./src/demux/mp4demuxer.ts"),_=o("./src/demux/tsdemuxer.ts"),T=o("./src/demux/mp3demuxer.ts"),l=o("./src/remux/mp4-remuxer.ts"),S=o("./src/remux/passthrough-remuxer.ts"),u=o("./src/utils/logger.ts");try{a=self.performance.now.bind(self.performance)}catch(e){u.logger.debug("Unable to use Performance API on this environment"),a=self.Date.now}var d=[{demux:_.default,remux:l.default},{demux:E.default,remux:S.default},{demux:s.default,remux:l.default},{demux:T.default,remux:l.default}],c=(function(){function e(e,t,o,a,n){this.observer=void 0,this.typeSupported=void 0,this.config=void 0,this.vendor=void 0,this.id=void 0,this.demuxer=void 0,this.remuxer=void 0,this.decrypter=void 0,this.probe=void 0,this.decryptionPromise=null,this.transmuxConfig=void 0,this.currentTransmuxState=void 0,this.observer=e,this.typeSupported=t,this.config=o,this.vendor=a,this.id=n}var t=e.prototype;return t.configure=function(e){this.transmuxConfig=e,this.decrypter&&this.decrypter.reset()},t.push=function(e,t,o,n){var r=this,i=o.transmuxing;i.executeStart=a();var s=new Uint8Array(e),E=this.config,_=this.currentTransmuxState,T=this.transmuxConfig;n&&(this.currentTransmuxState=n);var l=n||_,S=l.contiguous,u=l.discontinuity,d=l.trackSwitch,c=l.accurateTimeOffset,A=l.timeOffset,O=l.initSegmentChange,N=T.audioCodec,m=T.videoCodec,R=T.defaultInitPts,p=T.duration,h=T.initSegmentData;(u||d||O)&&this.resetInitSegment(h,N,m,p),(u||O)&&this.resetInitialTimestamp(R),S||this.resetContiguity();var f=(function(e,t){var o=null;return e.byteLength>0&&null!=t&&null!=t.key&&null!==t.iv&&null!=t.method&&(o=t),o})(s,t);if(f&&"AES-128"===f.method){var L=this.getDecrypter();if(!E.enableSoftwareAES)return this.decryptionPromise=L.webCryptoDecrypt(s,f.key.buffer,f.iv.buffer).then((function(e){var t=r.push(e,null,o);return r.decryptionPromise=null,t})),this.decryptionPromise;var C=L.softwareDecrypt(s,f.key.buffer,f.iv.buffer);if(!C)return i.executeEnd=a(),I(o);s=new Uint8Array(C)}this.needsProbing(s,u,d)&&this.configureTransmuxer(s,T);var D=this.transmux(s,f,A,c,o),g=this.currentTransmuxState;return g.contiguous=!0,g.discontinuity=!1,g.trackSwitch=!1,i.executeEnd=a(),D},t.flush=function(e){var t=this,o=e.transmuxing;o.executeStart=a();var i=this.decrypter,s=this.currentTransmuxState,E=this.decryptionPromise;if(E)return E.then((function(){return t.flush(e)}));var _=[],T=s.timeOffset;if(i){var l=i.flush();l&&_.push(this.push(l,null,e))}var S=this.demuxer,u=this.remuxer;if(!S||!u)return this.observer.emit(n.Events.ERROR,n.Events.ERROR,{type:r.ErrorTypes.MEDIA_ERROR,details:r.ErrorDetails.FRAG_PARSING_ERROR,fatal:!0,reason:"no demux matching with content found"}),o.executeEnd=a(),[I(e)];var d=S.flush(T);return A(d)?d.then((function(o){return t.flushRemux(_,o,e),_})):(this.flushRemux(_,d,e),_)},t.flushRemux=function(e,t,o){var n=t.audioTrack,r=t.videoTrack,i=t.id3Track,s=t.textTrack,E=this.currentTransmuxState,_=E.accurateTimeOffset,T=E.timeOffset;u.logger.log("[transmuxer.ts]: Flushed fragment "+o.sn+(o.part>-1?" p: "+o.part:"")+" of level "+o.level);var l=this.remuxer.remux(n,r,i,s,T,_,!0,this.id);e.push({remuxResult:l,chunkMeta:o}),o.transmuxing.executeEnd=a()},t.resetInitialTimestamp=function(e){var t=this.demuxer,o=this.remuxer;t&&o&&(t.resetTimeStamp(e),o.resetTimeStamp(e))},t.resetContiguity=function(){var e=this.demuxer,t=this.remuxer;e&&t&&(e.resetContiguity(),t.resetNextTimestamp())},t.resetInitSegment=function(e,t,o,a){var n=this.demuxer,r=this.remuxer;n&&r&&(n.resetInitSegment(e,t,o,a),r.resetInitSegment(e,t,o))},t.destroy=function(){this.demuxer&&(this.demuxer.destroy(),this.demuxer=void 0),this.remuxer&&(this.remuxer.destroy(),this.remuxer=void 0)},t.transmux=function(e,t,o,a,n){return t&&"SAMPLE-AES"===t.method?this.transmuxSampleAes(e,t,o,a,n):this.transmuxUnencrypted(e,o,a,n)},t.transmuxUnencrypted=function(e,t,o,a){var n=this.demuxer.demux(e,t,!1,!this.config.progressive),r=n.audioTrack,i=n.videoTrack,s=n.id3Track,E=n.textTrack;return{remuxResult:this.remuxer.remux(r,i,s,E,t,o,!1,this.id),chunkMeta:a}},t.transmuxSampleAes=function(e,t,o,a,n){var r=this;return this.demuxer.demuxSampleAes(e,t,o).then((function(e){return{remuxResult:r.remuxer.remux(e.audioTrack,e.videoTrack,e.id3Track,e.textTrack,o,a,!1,r.id),chunkMeta:n}}))},t.configureTransmuxer=function(e,t){for(var o,a=this.config,n=this.observer,r=this.typeSupported,i=this.vendor,s=t.audioCodec,_=t.defaultInitPts,T=t.duration,l=t.initSegmentData,c=t.videoCodec,I=0,A=d.length;I>4>1){if((y=D+5+e[D+4])===D+188)continue}else y=D+4;switch(v){case u:g&&(d&&(n=A(d))&&this.parseAVCPES(r,S,n,!1),d={data:[],size:0}),d&&(d.data.push(e.subarray(y,D+188)),d.size+=D+188-y);break;case O:if(g){if(m&&(n=A(m)))switch(i.segmentCodec){case"aac":this.parseAACPES(i,n);break;case"mp3":this.parseMPEGPES(i,n)}m={data:[],size:0}}m&&(m.data.push(e.subarray(y,D+188)),m.size+=D+188-y);break;case N:g&&(R&&(n=A(R))&&this.parseID3PES(l,n),R={data:[],size:0}),R&&(R.data.push(e.subarray(y,D+188)),R.size+=D+188-y);break;case 0:g&&(y+=e[y]+1),f=this._pmtId=c(e,y);break;case f:g&&(y+=e[y]+1);var P=I(e,y,this.typeSupported,o);(u=P.avc)>0&&(r.pid=u),(O=P.audio)>0&&(i.pid=O,i.segmentCodec=P.segmentCodec),(N=P.id3)>0&&(l.pid=N),null===p||h||(_.logger.log("unknown PID '"+p+"' in TS found"),p=null),h=this.pmtParsed=!0;break;case 17:case 8191:break;default:p=v}}else C++;C>0&&this.observer.emit(s.Events.ERROR,s.Events.ERROR,{type:T.ErrorTypes.MEDIA_ERROR,details:T.ErrorDetails.FRAG_PARSING_ERROR,fatal:!1,reason:"Found "+C+" TS packet/s that do not start with 0x47"}),r.pesData=d,i.pesData=m,l.pesData=R;var B={audioTrack:i,videoTrack:r,id3Track:l,textTrack:S};return a&&this.extractRemainingSamples(B),B},t.flush=function(){var e,t=this.remainderData;return this.remainderData=null,e=t?this.demux(t,-1,!1,!0):{videoTrack:this._avcTrack,audioTrack:this._audioTrack,id3Track:this._id3Track,textTrack:this._txtTrack},this.extractRemainingSamples(e),this.sampleAes?this.decrypt(e,this.sampleAes):e},t.extractRemainingSamples=function(e){var t,o=e.audioTrack,a=e.videoTrack,n=e.id3Track,r=e.textTrack,i=a.pesData,s=o.pesData,E=n.pesData;if(i&&(t=A(i))?(this.parseAVCPES(a,r,t,!0),a.pesData=null):a.pesData=i,s&&(t=A(s))){switch(o.segmentCodec){case"aac":this.parseAACPES(o,t);break;case"mp3":this.parseMPEGPES(o,t)}o.pesData=null}else null!=s&&s.size&&_.logger.log("last AAC PES packet truncated,might overlap between fragments"),o.pesData=s;E&&(t=A(E))?(this.parseID3PES(n,t),n.pesData=null):n.pesData=E},t.demuxSampleAes=function(e,t,o){var a=this.demux(e,o,!0,!this.config.progressive),n=this.sampleAes=new i.default(this.observer,this.config,t);return this.decrypt(a,n)},t.decrypt=function(e,t){return new Promise((function(o){var a=e.audioTrack,n=e.videoTrack;a.samples&&"aac"===a.segmentCodec?t.decryptAacSamples(a.samples,0,(function(){n.samples?t.decryptAvcSamples(n.samples,0,0,(function(){o(e)})):o(e)})):n.samples&&t.decryptAvcSamples(n.samples,0,0,(function(){o(e)}))}))},t.destroy=function(){this._duration=0},t.parseAVCPES=function(e,t,o,a){var n,i=this,s=this.parseAVCNALu(e,o.data),_=this.avcSample,T=!1;o.data=null,_&&s.length&&!e.audFound&&(O(_,e),_=this.avcSample=d(!1,o.pts,o.dts,"")),s.forEach((function(a){switch(a.type){case 1:n=!0,_||(_=i.avcSample=d(!0,o.pts,o.dts,"")),_.frame=!0;var s=a.data;if(T&&s.length>4){var l=new r.default(s).readSliceType();2!==l&&4!==l&&7!==l&&9!==l||(_.key=!0)}break;case 5:n=!0,_||(_=i.avcSample=d(!0,o.pts,o.dts,"")),_.key=!0,_.frame=!0;break;case 6:n=!0,Object(E.parseSEIMessageFromNALu)(N(a.data),o.pts,t.samples);break;case 7:if(n=!0,T=!0,!e.sps){var S=new r.default(a.data).readSPS();e.width=S.width,e.height=S.height,e.pixelRatio=S.pixelRatio,e.sps=[a.data],e.duration=i._duration;for(var u=a.data.subarray(1,4),c="avc1.",I=0;I<3;I++){var A=u[I].toString(16);A.length<2&&(A="0"+A),c+=A}e.codec=c}break;case 8:n=!0,e.pps||(e.pps=[a.data]);break;case 9:n=!1,e.audFound=!0,_&&O(_,e),_=i.avcSample=d(!1,o.pts,o.dts,"");break;case 12:n=!0;break;default:n=!1,_&&(_.debug+="unknown NAL "+a.type+" ")}_&&n&&_.units.push(a)})),a&&_&&(O(_,e),this.avcSample=null)},t.getLastNalUnit=function(e){var t,o,a=this.avcSample;if(a&&0!==a.units.length||(a=e[e.length-1]),null!==(t=a)&&void 0!==t&&t.units){var n=a.units;o=n[n.length-1]}return o},t.parseAVCNALu=function(e,t){var o,a,n=t.byteLength,r=e.naluState||0,i=r,s=[],E=0,_=-1,T=0;for(-1===r&&(_=0,T=31&t[0],r=0,E=1);E=0){var l={data:t.subarray(_,E-r-1),type:T};s.push(l)}else{var S=this.getLastNalUnit(e.samples);if(S&&(i&&E<=4-i&&S.state&&(S.data=S.data.subarray(0,S.data.byteLength-i)),(a=E-r-1)>0)){var u=new Uint8Array(S.data.byteLength+a);u.set(S.data,0),u.set(t.subarray(0,a),S.data.byteLength),S.data=u,S.state=0}}E=0&&r>=0){var d={data:t.subarray(_,n),type:T,state:r};s.push(d)}if(0===s.length){var c=this.getLastNalUnit(e.samples);if(c){var I=new Uint8Array(c.data.byteLength+t.byteLength);I.set(c.data,0),I.set(t,c.data.byteLength),c.data=I}}return e.naluState=r,s},t.parseAACPES=function(e,t){var o,n,r,i,E,l=0,S=this.aacOverFlow,u=t.data;if(S){this.aacOverFlow=null;var d=S.missing,c=S.sample.unit.byteLength;if(-1===d){var I=new Uint8Array(c+u.byteLength);I.set(S.sample.unit,0),I.set(u,c),u=I}else{var A=c-d;S.sample.unit.set(u.subarray(0,d),A),e.samples.push(S.sample),l=S.missing}}for(o=l,n=u.length;o1;){var E=new Uint8Array(s[0].length+s[1].length);E.set(s[0]),E.set(s[1],s[0].length),s[0]=E,s.splice(1,1)}if(1===((t=s[0])[0]<<16)+(t[1]<<8)+t[2]){if((o=(t[4]<<8)+t[5])&&o>e.size-6)return null;var T=t[7];192&T&&(n=536870912*(14&t[9])+4194304*(255&t[10])+16384*(254&t[11])+128*(255&t[12])+(254&t[13])/2,64&T?n-(r=536870912*(14&t[14])+4194304*(255&t[15])+16384*(254&t[16])+128*(255&t[17])+(254&t[18])/2)>54e5&&(_.logger.warn(Math.round((n-r)/9e4)+"s delta between PTS and DTS, align them"),n=r):r=n);var l=(a=t[8])+9;if(e.size<=l)return null;e.size-=l;for(var S=new Uint8Array(e.size),u=0,d=s.length;uc){l-=c;continue}t=t.subarray(l),c-=l,l=0}S.set(t,i),i+=c}return o&&(o-=a+3),{data:S,pts:n,dts:r,len:o}}return null}function O(e,t){if(e.units.length&&e.frame){if(void 0===e.pts){var o=t.samples,a=o.length;if(!a)return void t.dropped++;var n=o[a-1];e.pts=n.pts,e.dts=n.dts}t.samples.push(e)}e.debug.length&&_.logger.log(e.pts+"/"+e.dts+":"+e.debug)}function N(e){for(var t=e.byteLength,o=[],a=1;a=t)return a;return 0}},{key:"maxAutoLevel",get:function(){var e=this.levels,t=this.autoLevelCapping;return-1===t&&e&&e.length?e.length-1:t}},{key:"nextAutoLevel",get:function(){return Math.min(Math.max(this.abrController.nextAutoLevel,this.minAutoLevel),this.maxAutoLevel)},set:function(e){this.abrController.nextAutoLevel=Math.max(this.minAutoLevel,e)}},{key:"playingDate",get:function(){return this.streamController.currentProgramDateTime}},{key:"audioTracks",get:function(){var e=this.audioTrackController;return e?e.audioTracks:[]}},{key:"audioTrack",get:function(){var e=this.audioTrackController;return e?e.audioTrack:-1},set:function(e){var t=this.audioTrackController;t&&(t.audioTrack=e)}},{key:"subtitleTracks",get:function(){var e=this.subtitleTrackController;return e?e.subtitleTracks:[]}},{key:"subtitleTrack",get:function(){var e=this.subtitleTrackController;return e?e.subtitleTrack:-1},set:function(e){var t=this.subtitleTrackController;t&&(t.subtitleTrack=e)}},{key:"media",get:function(){return this._media}},{key:"subtitleDisplay",get:function(){var e=this.subtitleTrackController;return!!e&&e.subtitleDisplay},set:function(e){var t=this.subtitleTrackController;t&&(t.subtitleDisplay=e)}},{key:"lowLatencyMode",get:function(){return this.config.lowLatencyMode},set:function(e){this.config.lowLatencyMode=e}},{key:"liveSyncPosition",get:function(){return this.latencyController.liveSyncPosition}},{key:"latency",get:function(){return this.latencyController.latency}},{key:"maxLatency",get:function(){return this.latencyController.maxLatency}},{key:"targetLatency",get:function(){return this.latencyController.targetLatency}},{key:"drift",get:function(){return this.latencyController.drift}},{key:"forceStartLoad",get:function(){return this.streamController.forceStartLoad}}])&&A(t.prototype,o),O&&A(t,O),Object.defineProperty(t,"prototype",{writable:!1}),e})();O.defaultConfig=void 0},"./src/is-supported.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"isSupported",(function(){return r})),o.d(t,"changeTypeSupported",(function(){return i}));var a=o("./src/utils/mediasource-helper.ts");function n(){return self.SourceBuffer||self.WebKitSourceBuffer}function r(){var e=Object(a.getMediaSource)();if(!e)return!1;var t=n(),o=e&&"function"==typeof e.isTypeSupported&&e.isTypeSupported('video/mp4; codecs="avc1.42E01E,mp4a.40.2"'),r=!t||t.prototype&&"function"==typeof t.prototype.appendBuffer&&"function"==typeof t.prototype.remove;return!!o&&!!r}function i(){var e,t=n();return"function"==typeof(null==t||null===(e=t.prototype)||void 0===e?void 0:e.changeType)}},"./src/loader/date-range.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"DateRangeAttribute",(function(){return a})),o.d(t,"DateRange",(function(){return _}));var a,n=o("./src/polyfills/number.ts"),r=o("./src/utils/attr-list.ts"),i=o("./src/utils/logger.ts");function s(){return s=Object.assign?Object.assign.bind():function(e){for(var t=1;t=0)&&(!this.endOnNext||!!this.class)}}])&&E(t.prototype,o),_&&E(t,_),Object.defineProperty(t,"prototype",{writable:!1}),e})()},"./src/loader/fragment-loader.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return l})),o.d(t,"LoadError",(function(){return u}));var a=o("./src/polyfills/number.ts"),n=o("./src/errors.ts");function r(e){var t="function"==typeof Map?new Map:void 0;return r=function(e){if(null===e||(o=e,-1===Function.toString.call(o).indexOf("[native code]")))return e;var o;if("function"!=typeof e)throw new TypeError("Super expression must either be null or a function");if(void 0!==t){if(t.has(e))return t.get(e);t.set(e,a)}function a(){return i(e,arguments,_(this).constructor)}return a.prototype=Object.create(e.prototype,{constructor:{value:a,enumerable:!1,writable:!0,configurable:!0}}),E(a,e)},r(e)}function i(e,t,o){return i=s()?Reflect.construct.bind():function(e,t,o){var a=[null];a.push.apply(a,t);var n=new(Function.bind.apply(e,a));return o&&E(n,o.prototype),n},i.apply(null,arguments)}function s(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(e){return!1}}function E(e,t){return E=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,t){return e.__proto__=t,e},E(e,t)}function _(e){return _=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(e){return e.__proto__||Object.getPrototypeOf(e)},_(e)}var T=Math.pow(2,17),l=(function(){function e(e){this.config=void 0,this.loader=null,this.partLoadTimeout=-1,this.config=e}var t=e.prototype;return t.destroy=function(){this.loader&&(this.loader.destroy(),this.loader=null)},t.abort=function(){this.loader&&this.loader.abort()},t.load=function(e,t){var o=this,a=e.url;if(!a)return Promise.reject(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.FRAG_LOAD_ERROR,fatal:!1,frag:e,networkDetails:null},"Fragment does not have a "+(a?"part list":"url")));this.abort();var r=this.config,i=r.fLoader,s=r.loader;return new Promise((function(a,E){o.loader&&o.loader.destroy();var _=o.loader=e.loader=i?new i(r):new s(r),l=S(e),d={timeout:r.fragLoadingTimeOut,maxRetry:0,retryDelay:0,maxRetryDelay:r.fragLoadingMaxRetryTimeout,highWaterMark:"initSegment"===e.sn?1/0:T};e.stats=_.stats,_.load(l,d,{onSuccess:function(t,n,r,i){o.resetLoader(e,_),a({frag:e,part:null,payload:t.data,networkDetails:i})},onError:function(t,a,r){o.resetLoader(e,_),E(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.FRAG_LOAD_ERROR,fatal:!1,frag:e,response:t,networkDetails:r}))},onAbort:function(t,a,r){o.resetLoader(e,_),E(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.INTERNAL_ABORTED,fatal:!1,frag:e,networkDetails:r}))},onTimeout:function(t,a,r){o.resetLoader(e,_),E(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.FRAG_LOAD_TIMEOUT,fatal:!1,frag:e,networkDetails:r}))},onProgress:function(o,a,n,r){t&&t({frag:e,part:null,payload:n,networkDetails:r})}})}))},t.loadPart=function(e,t,o){var a=this;this.abort();var r=this.config,i=r.fLoader,s=r.loader;return new Promise((function(E,_){a.loader&&a.loader.destroy();var l=a.loader=e.loader=i?new i(r):new s(r),d=S(e,t),c={timeout:r.fragLoadingTimeOut,maxRetry:0,retryDelay:0,maxRetryDelay:r.fragLoadingMaxRetryTimeout,highWaterMark:T};t.stats=l.stats,l.load(d,c,{onSuccess:function(n,r,i,s){a.resetLoader(e,l),a.updateStatsFromPart(e,t);var _={frag:e,part:t,payload:n.data,networkDetails:s};o(_),E(_)},onError:function(o,r,i){a.resetLoader(e,l),_(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.FRAG_LOAD_ERROR,fatal:!1,frag:e,part:t,response:o,networkDetails:i}))},onAbort:function(o,r,i){e.stats.aborted=t.stats.aborted,a.resetLoader(e,l),_(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.INTERNAL_ABORTED,fatal:!1,frag:e,part:t,networkDetails:i}))},onTimeout:function(o,r,i){a.resetLoader(e,l),_(new u({type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.FRAG_LOAD_TIMEOUT,fatal:!1,frag:e,part:t,networkDetails:i}))}})}))},t.updateStatsFromPart=function(e,t){var o=e.stats,a=t.stats,n=a.total;if(o.loaded+=a.loaded,n){var r=Math.round(e.duration/t.duration),i=Math.min(Math.round(o.loaded/n),r),s=(r-i)*Math.round(o.loaded/i);o.total=o.loaded+s}else o.total=Math.max(o.loaded,o.total);var E=o.loading,_=a.loading;E.start?E.first+=_.first-_.start:(E.start=_.start,E.first=_.first),E.end=_.end},t.resetLoader=function(e,t){e.loader=null,this.loader===t&&(self.clearTimeout(this.partLoadTimeout),this.loader=null),t.destroy()},e})();function S(e,t){void 0===t&&(t=null);var o=t||e,n={frag:e,part:t,responseType:"arraybuffer",url:o.url,headers:{},rangeStart:0,rangeEnd:0},r=o.byteRangeStartOffset,i=o.byteRangeEndOffset;return Object(a.isFiniteNumber)(r)&&Object(a.isFiniteNumber)(i)&&(n.rangeStart=r,n.rangeEnd=i),n}var u=(function(e){var t,o;function a(t){for(var o,a=arguments.length,n=new Array(a>1?a-1:0),r=1;r>8*(15-o)&255;return t},o.setDecryptDataFromLevelKey=function(e,t){var o=e;return"AES-128"===(null==e?void 0:e.method)&&e.uri&&!e.iv&&((o=s.LevelKey.fromURI(e.uri)).method=e.method,o.iv=this.createInitializationVector(t),o.keyFormat="identity"),o},o.setElementaryStreamInfo=function(e,t,o,a,n,r){void 0===r&&(r=!1);var i=this.elementaryStreams,s=i[e];s?(s.startPTS=Math.min(s.startPTS,t),s.endPTS=Math.max(s.endPTS,o),s.startDTS=Math.min(s.startDTS,a),s.endDTS=Math.max(s.endDTS,n)):i[e]={startPTS:t,endPTS:o,startDTS:a,endDTS:n,partial:r}},o.clearElementaryStreamInfo=function(){var e=this.elementaryStreams;e[a.AUDIO]=null,e[a.VIDEO]=null,e[a.AUDIOVIDEO]=null},S(t,[{key:"decryptdata",get:function(){if(!this.levelkey&&!this._decryptdata)return null;if(!this._decryptdata&&this.levelkey){var e=this.sn;"number"!=typeof e&&(this.levelkey&&"AES-128"===this.levelkey.method&&!this.levelkey.iv&&i.logger.warn('missing IV for initialization segment with method="'+this.levelkey.method+'" - compliance issue'),e=0),this._decryptdata=this.setDecryptDataFromLevelKey(this.levelkey,e)}return this._decryptdata}},{key:"end",get:function(){return this.start+this.duration}},{key:"endProgramDateTime",get:function(){if(null===this.programDateTime)return null;if(!Object(n.isFiniteNumber)(this.programDateTime))return null;var e=Object(n.isFiniteNumber)(this.duration)?this.duration:0;return this.programDateTime+1e3*e}},{key:"encrypted",get:function(){var e;return!(null===(e=this.decryptdata)||void 0===e||!e.keyFormat||!this.decryptdata.uri)}}]),t})(u),c=(function(e){function t(t,o,a,n,r){var i;(i=e.call(this,a)||this).fragOffset=0,i.duration=0,i.gap=!1,i.independent=!1,i.relurl=void 0,i.fragment=void 0,i.index=void 0,i.stats=new E.LoadStats,i.duration=t.decimalFloatingPoint("DURATION"),i.gap=t.bool("GAP"),i.independent=t.bool("INDEPENDENT"),i.relurl=t.enumeratedString("URI"),i.fragment=o,i.index=n;var s=t.enumeratedString("BYTERANGE");return s&&i.setByteRange(s,r),r&&(i.fragOffset=r.fragOffset+r.duration),i}return _(t,e),S(t,[{key:"start",get:function(){return this.fragment.start+this.fragOffset}},{key:"end",get:function(){return this.start+this.duration}},{key:"loaded",get:function(){var e=this.elementaryStreams;return!!(e.audio||e.video||e.audiovideo)}}]),t})(u)},"./src/loader/key-loader.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return i}));var a=o("./src/events.ts"),n=o("./src/errors.ts"),r=o("./src/utils/logger.ts"),i=(function(){function e(e){this.hls=void 0,this.loaders={},this.decryptkey=null,this.decrypturl=null,this.hls=e,this.registerListeners()}var t=e.prototype;return t.startLoad=function(e){},t.stopLoad=function(){this.destroyInternalLoaders()},t.registerListeners=function(){this.hls.on(a.Events.KEY_LOADING,this.onKeyLoading,this)},t.unregisterListeners=function(){this.hls.off(a.Events.KEY_LOADING,this.onKeyLoading)},t.destroyInternalLoaders=function(){for(var e in this.loaders){var t=this.loaders[e];t&&t.destroy()}this.loaders={}},t.destroy=function(){this.unregisterListeners(),this.destroyInternalLoaders()},t.onKeyLoading=function(e,t){var o=t.frag,n=o.type,i=this.loaders[n];if(o.decryptdata){var s=o.decryptdata.uri;if(s!==this.decrypturl||null===this.decryptkey){var E=this.hls.config;if(i&&(r.logger.warn("abort previous key loader for type:"+n),i.abort()),!s)return void r.logger.warn("key uri is falsy");var _=E.loader,T=o.loader=this.loaders[n]=new _(E);this.decrypturl=s,this.decryptkey=null;var l={url:s,frag:o,responseType:"arraybuffer"},S={timeout:E.fragLoadingTimeOut,maxRetry:0,retryDelay:E.fragLoadingRetryDelay,maxRetryDelay:E.fragLoadingMaxRetryTimeout,highWaterMark:0},u={onSuccess:this.loadsuccess.bind(this),onError:this.loaderror.bind(this),onTimeout:this.loadtimeout.bind(this)};T.load(l,S,u)}else this.decryptkey&&(o.decryptdata.key=this.decryptkey,this.hls.trigger(a.Events.KEY_LOADED,{frag:o}))}else r.logger.warn("Missing decryption data on fragment in onKeyLoading")},t.loadsuccess=function(e,t,o){var n=o.frag;n.decryptdata?(this.decryptkey=n.decryptdata.key=new Uint8Array(e.data),n.loader=null,delete this.loaders[n.type],this.hls.trigger(a.Events.KEY_LOADED,{frag:n})):r.logger.error("after key load, decryptdata unset")},t.loaderror=function(e,t){var o=t.frag,r=o.loader;r&&r.abort(),delete this.loaders[o.type],this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.KEY_LOAD_ERROR,fatal:!1,frag:o,response:e})},t.loadtimeout=function(e,t){var o=t.frag,r=o.loader;r&&r.abort(),delete this.loaders[o.type],this.hls.trigger(a.Events.ERROR,{type:n.ErrorTypes.NETWORK_ERROR,details:n.ErrorDetails.KEY_LOAD_TIMEOUT,fatal:!1,frag:o})},e})()},"./src/loader/level-details.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"LevelDetails",(function(){return r}));var a=o("./src/polyfills/number.ts");function n(e,t){for(var o=0;oe.endSN||t>0||0===t&&o>0,this.updated||this.advanced?this.misses=Math.floor(.6*e.misses):this.misses=e.misses+1,this.availabilityDelay=e.availabilityDelay},t=e,(o=[{key:"hasProgramDateTime",get:function(){return!!this.fragments.length&&Object(a.isFiniteNumber)(this.fragments[this.fragments.length-1].programDateTime)}},{key:"levelTargetDuration",get:function(){return this.averagetargetduration||this.targetduration||10}},{key:"drift",get:function(){var e=this.driftEndTime-this.driftStartTime;return e>0?1e3*(this.driftEnd-this.driftStart)/e:1}},{key:"edge",get:function(){return this.partEnd||this.fragmentEnd}},{key:"partEnd",get:function(){var e;return null!==(e=this.partList)&&void 0!==e&&e.length?this.partList[this.partList.length-1].end:this.fragmentEnd}},{key:"fragmentEnd",get:function(){var e;return null!==(e=this.fragments)&&void 0!==e&&e.length?this.fragments[this.fragments.length-1].end:0}},{key:"age",get:function(){return this.advancedDateTime?Math.max(Date.now()-this.advancedDateTime,0)/1e3:0}},{key:"lastPartIndex",get:function(){var e;return null!==(e=this.partList)&&void 0!==e&&e.length?this.partList[this.partList.length-1].index:-1}},{key:"lastPartSn",get:function(){var e;return null!==(e=this.partList)&&void 0!==e&&e.length?this.partList[this.partList.length-1].fragment.sn:this.endSN}}])&&n(t.prototype,o),r&&n(t,r),Object.defineProperty(t,"prototype",{writable:!1}),e})()},"./src/loader/level-key.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"LevelKey",(function(){return r}));var a=o("./node_modules/url-toolkit/src/url-toolkit.js");function n(e,t){for(var o=0;o2){var o=t.shift()+".";return o+=parseInt(t.shift()).toString(16),o+=("000"+parseInt(t.shift()).toString(16)).slice(-4)}return e},e.resolve=function(e,t){return n.buildAbsoluteURL(t,e,{alwaysNormalize:!0})},e.parseMasterPlaylist=function(t,o){var a,n=[],r={},i=!1;for(S.lastIndex=0;null!=(a=S.exec(t));)if(a[1]){var s=new _.AttrList(a[1]),E={attrs:s,bitrate:s.decimalInteger("AVERAGE-BANDWIDTH")||s.decimalInteger("BANDWIDTH"),name:s.NAME,url:e.resolve(a[2],o)},T=s.decimalResolution("RESOLUTION");T&&(E.width=T.width,E.height=T.height),O((s.CODECS||"").split(/[ ,]+/).filter((function(e){return e})),E),E.videoCodec&&-1!==E.videoCodec.indexOf("avc1")&&(E.videoCodec=e.convertAVC1ToAVCOTI(E.videoCodec)),n.push(E)}else if(a[3]){var l=new _.AttrList(a[3]);l["DATA-ID"]&&(i=!0,r[l["DATA-ID"]]=l)}return{levels:n,sessionData:i?r:null}},e.parseMasterPlaylistMedia=function(t,o,a,n){var r;void 0===n&&(n=[]);var i=[],s=0;for(u.lastIndex=0;null!==(r=u.exec(t));){var E=new _.AttrList(r[1]);if(E.TYPE===a){var T={attrs:E,bitrate:0,id:s++,groupId:E["GROUP-ID"],instreamId:E["INSTREAM-ID"],name:E.NAME||E.LANGUAGE||"",type:a,default:E.bool("DEFAULT"),autoselect:E.bool("AUTOSELECT"),forced:E.bool("FORCED"),lang:E.LANGUAGE,url:E.URI?e.resolve(E.URI,o):""};if(n.length){var l=e.findGroup(n,T.groupId)||n[0];N(T,l,"audioCodec"),N(T,l,"textCodec")}i.push(T)}}return i},e.parseLevelPlaylist=function(e,t,o,l,S){var u,A,O,N=new s.LevelDetails(t),p=N.fragments,h=null,f=0,L=0,C=0,D=0,g=null,v=new i.Fragment(l,t),y=-1,P=!1;for(d.lastIndex=0,N.m3u8=e;null!==(u=d.exec(e));){P&&(P=!1,(v=new i.Fragment(l,t)).start=C,v.sn=f,v.cc=D,v.level=o,h&&(v.initSegment=h,v.rawProgramDateTime=h.rawProgramDateTime,h.rawProgramDateTime=null));var B=u[1];if(B){v.duration=parseFloat(B);var b=(" "+u[2]).slice(1);v.title=b||null,v.tagList.push(b?["INF",B,b]:["INF",B])}else if(u[3])Object(a.isFiniteNumber)(v.duration)&&(v.start=C,O&&(v.levelkey=O),v.sn=f,v.level=o,v.cc=D,v.urlId=S,p.push(v),v.relurl=(" "+u[3]).slice(1),m(v,g),g=v,C+=v.duration,f++,L=0,P=!0);else if(u[4]){var M=(" "+u[4]).slice(1);g?v.setByteRange(M,g):v.setByteRange(M)}else if(u[5])v.rawProgramDateTime=(" "+u[5]).slice(1),v.tagList.push(["PROGRAM-DATE-TIME",v.rawProgramDateTime]),-1===y&&(y=p.length);else{if(!(u=u[0].match(c))){T.logger.warn("No matches on slow regex match for level playlist!");continue}for(A=1;A-1){T.logger.warn("Keyformat "+q+" is not supported from the manifest");continue}if("identity"!==q)continue;K&&(O=E.LevelKey.fromURL(t,j),j&&["AES-128","SAMPLE-AES","SAMPLE-AES-CENC"].indexOf(K)>=0&&(O.method=K,O.keyFormat=q,$&&(O.keyID=$),X&&(O.keyFormatVersions=X),O.iv=Q));break;case"START":var J=new _.AttrList(W).decimalFloatingPoint("TIME-OFFSET");Object(a.isFiniteNumber)(J)&&(N.startTimeOffset=J);break;case"MAP":var Z=new _.AttrList(W);if(v.duration){var ee=new i.Fragment(l,t);R(ee,Z,o,O),h=ee,v.initSegment=h,h.rawProgramDateTime&&!v.rawProgramDateTime&&(v.rawProgramDateTime=h.rawProgramDateTime)}else R(v,Z,o,O),h=v,P=!0;break;case"SERVER-CONTROL":var te=new _.AttrList(W);N.canBlockReload=te.bool("CAN-BLOCK-RELOAD"),N.canSkipUntil=te.optionalFloat("CAN-SKIP-UNTIL",0),N.canSkipDateRanges=N.canSkipUntil>0&&te.bool("CAN-SKIP-DATERANGES"),N.partHoldBack=te.optionalFloat("PART-HOLD-BACK",0),N.holdBack=te.optionalFloat("HOLD-BACK",0);break;case"PART-INF":var oe=new _.AttrList(W);N.partTarget=oe.decimalFloatingPoint("PART-TARGET");break;case"PART":var ae=N.partList;ae||(ae=N.partList=[]);var ne=L>0?ae[ae.length-1]:void 0,re=L++,ie=new i.Part(new _.AttrList(W),v,t,re,ne);ae.push(ie),v.duration+=ie.duration;break;case"PRELOAD-HINT":var se=new _.AttrList(W);N.preloadHint=se;break;case"RENDITION-REPORT":var Ee=new _.AttrList(W);N.renditionReports=N.renditionReports||[],N.renditionReports.push(Ee);break;default:T.logger.warn("line parsed but not handled: "+u)}}}g&&!g.relurl?(p.pop(),C-=g.duration,N.partList&&(N.fragmentHint=g)):N.partList&&(m(v,g),v.cc=D,N.fragmentHint=v);var _e=p.length,Te=p[0],le=p[_e-1];if((C+=N.skippedSegments*N.targetduration)>0&&_e&&le){N.averagetargetduration=C/_e;var Se=le.sn;N.endSN="initSegment"!==Se?Se:0,Te&&(N.startCC=Te.cc,Te.initSegment||N.fragments.every((function(e){return e.relurl&&(t=e.relurl,I.test(null!=(o=null===(a=n.parseURL(t))||void 0===a?void 0:a.path)?o:""));var t,o,a}))&&(T.logger.warn("MP4 fragments found but no init segment (probably no MAP, incomplete M3U8), trying to fetch SIDX"),(v=new i.Fragment(l,t)).relurl=le.relurl,v.level=o,v.sn="initSegment",Te.initSegment=v,N.needSidxRanges=!0))}else N.endSN=0,N.startCC=0;return N.fragmentHint&&(C+=N.fragmentHint.duration),N.totalduration=C,N.endCC=D,y>0&&(function(e,t){for(var o=e[t],a=t;a--;){var n=e[a];if(!n)return;n.programDateTime=o.programDateTime-1e3*n.duration,o=n}})(p,y),N},e})();function O(e,t){["video","audio","text"].forEach((function(o){var a=e.filter((function(e){return Object(l.isCodecType)(e,o)}));if(a.length){var n=a.filter((function(e){return 0===e.lastIndexOf("avc1",0)||0===e.lastIndexOf("mp4a",0)}));t[o+"Codec"]=n.length>0?n[0]:a[0],e=e.filter((function(e){return-1===a.indexOf(e)}))}})),t.unknownCodecs=e}function N(e,t,o){var a=t[o];a&&(e[o]=a)}function m(e,t){e.rawProgramDateTime?e.programDateTime=Date.parse(e.rawProgramDateTime):null!=t&&t.programDateTime&&(e.programDateTime=t.endProgramDateTime),Object(a.isFiniteNumber)(e.programDateTime)||(e.programDateTime=null,e.rawProgramDateTime=null)}function R(e,t,o,a){e.relurl=t.URI,t.BYTERANGE&&e.setByteRange(t.BYTERANGE),e.level=o,e.sn="initSegment",a&&(e.levelkey=a),e.initSegment=null}},"./src/loader/playlist-loader.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/polyfills/number.ts"),n=o("./src/events.ts"),r=o("./src/errors.ts"),i=o("./src/utils/logger.ts"),s=o("./src/utils/mp4-tools.ts"),E=o("./src/loader/m3u8-parser.ts"),_=o("./src/types/loader.ts"),T=o("./src/utils/attr-list.ts");function l(e,t){var o=e.url;return void 0!==o&&0!==o.indexOf("data:")||(o=t.url),o}var S=(function(){function e(e){this.hls=void 0,this.loaders=Object.create(null),this.hls=e,this.registerListeners()}var t=e.prototype;return t.startLoad=function(e){},t.stopLoad=function(){this.destroyInternalLoaders()},t.registerListeners=function(){var e=this.hls;e.on(n.Events.MANIFEST_LOADING,this.onManifestLoading,this),e.on(n.Events.LEVEL_LOADING,this.onLevelLoading,this),e.on(n.Events.AUDIO_TRACK_LOADING,this.onAudioTrackLoading,this),e.on(n.Events.SUBTITLE_TRACK_LOADING,this.onSubtitleTrackLoading,this)},t.unregisterListeners=function(){var e=this.hls;e.off(n.Events.MANIFEST_LOADING,this.onManifestLoading,this),e.off(n.Events.LEVEL_LOADING,this.onLevelLoading,this),e.off(n.Events.AUDIO_TRACK_LOADING,this.onAudioTrackLoading,this),e.off(n.Events.SUBTITLE_TRACK_LOADING,this.onSubtitleTrackLoading,this)},t.createInternalLoader=function(e){var t=this.hls.config,o=t.pLoader,a=t.loader,n=new(o||a)(t);return e.loader=n,this.loaders[e.type]=n,n},t.getInternalLoader=function(e){return this.loaders[e.type]},t.resetInternalLoader=function(e){this.loaders[e]&&delete this.loaders[e]},t.destroyInternalLoaders=function(){for(var e in this.loaders){var t=this.loaders[e];t&&t.destroy(),this.resetInternalLoader(e)}},t.destroy=function(){this.unregisterListeners(),this.destroyInternalLoaders()},t.onManifestLoading=function(e,t){var o=t.url;this.load({id:null,groupId:null,level:0,responseType:"text",type:_.PlaylistContextType.MANIFEST,url:o,deliveryDirectives:null})},t.onLevelLoading=function(e,t){var o=t.id,a=t.level,n=t.url,r=t.deliveryDirectives;this.load({id:o,groupId:null,level:a,responseType:"text",type:_.PlaylistContextType.LEVEL,url:n,deliveryDirectives:r})},t.onAudioTrackLoading=function(e,t){var o=t.id,a=t.groupId,n=t.url,r=t.deliveryDirectives;this.load({id:o,groupId:a,level:null,responseType:"text",type:_.PlaylistContextType.AUDIO_TRACK,url:n,deliveryDirectives:r})},t.onSubtitleTrackLoading=function(e,t){var o=t.id,a=t.groupId,n=t.url,r=t.deliveryDirectives;this.load({id:o,groupId:a,level:null,responseType:"text",type:_.PlaylistContextType.SUBTITLE_TRACK,url:n,deliveryDirectives:r})},t.load=function(e){var t,o,a,n,r,s,E=this.hls.config,T=this.getInternalLoader(e);if(T){var l=T.context;if(l&&l.url===e.url)return void i.logger.trace("[playlist-loader]: playlist request ongoing");i.logger.log("[playlist-loader]: aborting previous loader for type: "+e.type),T.abort()}switch(e.type){case _.PlaylistContextType.MANIFEST:o=E.manifestLoadingMaxRetry,a=E.manifestLoadingTimeOut,n=E.manifestLoadingRetryDelay,r=E.manifestLoadingMaxRetryTimeout;break;case _.PlaylistContextType.LEVEL:case _.PlaylistContextType.AUDIO_TRACK:case _.PlaylistContextType.SUBTITLE_TRACK:o=0,a=E.levelLoadingTimeOut;break;default:o=E.levelLoadingMaxRetry,a=E.levelLoadingTimeOut,n=E.levelLoadingRetryDelay,r=E.levelLoadingMaxRetryTimeout}if(T=this.createInternalLoader(e),null!==(t=e.deliveryDirectives)&&void 0!==t&&t.part&&(e.type===_.PlaylistContextType.LEVEL&&null!==e.level?s=this.hls.levels[e.level].details:e.type===_.PlaylistContextType.AUDIO_TRACK&&null!==e.id?s=this.hls.audioTracks[e.id].details:e.type===_.PlaylistContextType.SUBTITLE_TRACK&&null!==e.id&&(s=this.hls.subtitleTracks[e.id].details),s)){var S=s.partTarget,u=s.targetduration;S&&u&&(a=Math.min(1e3*Math.max(3*S,.8*u),a))}var d={timeout:a,maxRetry:o,retryDelay:n,maxRetryDelay:r,highWaterMark:0},c={onSuccess:this.loadsuccess.bind(this),onError:this.loaderror.bind(this),onTimeout:this.loadtimeout.bind(this)};T.load(e,d,c)},t.loadsuccess=function(e,t,o,a){if(void 0===a&&(a=null),o.isSidxRequest)return this.handleSidxRequest(e,o),void this.handlePlaylistLoaded(e,t,o,a);this.resetInternalLoader(o.type);var n=e.data;0===n.indexOf("#EXTM3U")?(t.parsing.start=performance.now(),n.indexOf("#EXTINF:")>0||n.indexOf("#EXT-X-TARGETDURATION:")>0?this.handleTrackOrLevelPlaylist(e,t,o,a):this.handleMasterPlaylist(e,t,o,a)):this.handleManifestParsingError(e,o,"no EXTM3U delimiter",a)},t.loaderror=function(e,t,o){void 0===o&&(o=null),this.handleNetworkError(t,o,!1,e)},t.loadtimeout=function(e,t,o){void 0===o&&(o=null),this.handleNetworkError(t,o,!0)},t.handleMasterPlaylist=function(e,t,o,a){var r=this.hls,s=e.data,_=l(e,o),S=E.default.parseMasterPlaylist(s,_),u=S.levels,d=S.sessionData;if(u.length){var c=u.map((function(e){return{id:e.attrs.AUDIO,audioCodec:e.audioCodec}})),I=u.map((function(e){return{id:e.attrs.SUBTITLES,textCodec:e.textCodec}})),A=E.default.parseMasterPlaylistMedia(s,_,"AUDIO",c),O=E.default.parseMasterPlaylistMedia(s,_,"SUBTITLES",I),N=E.default.parseMasterPlaylistMedia(s,_,"CLOSED-CAPTIONS");A.length&&(A.some((function(e){return!e.url}))||!u[0].audioCodec||u[0].attrs.AUDIO||(i.logger.log("[playlist-loader]: audio codec signaled in quality level, but no embedded audio track signaled, create one"),A.unshift({type:"main",name:"main",default:!1,autoselect:!1,forced:!1,id:-1,attrs:new T.AttrList({}),bitrate:0,url:""}))),r.trigger(n.Events.MANIFEST_LOADED,{levels:u,audioTracks:A,subtitles:O,captions:N,url:_,stats:t,networkDetails:a,sessionData:d})}else this.handleManifestParsingError(e,o,"no level found in manifest",a)},t.handleTrackOrLevelPlaylist=function(e,t,o,i){var s=this.hls,S=o.id,u=o.level,d=o.type,c=l(e,o),I=Object(a.isFiniteNumber)(S)?S:0,A=Object(a.isFiniteNumber)(u)?u:I,O=(function(e){switch(e.type){case _.PlaylistContextType.AUDIO_TRACK:return _.PlaylistLevelType.AUDIO;case _.PlaylistContextType.SUBTITLE_TRACK:return _.PlaylistLevelType.SUBTITLE;default:return _.PlaylistLevelType.MAIN}})(o),N=E.default.parseLevelPlaylist(e.data,c,A,O,I);if(N.fragments.length){if(d===_.PlaylistContextType.MANIFEST){var m={attrs:new T.AttrList({}),bitrate:0,details:N,name:"",url:c};s.trigger(n.Events.MANIFEST_LOADED,{levels:[m],audioTracks:[],url:c,stats:t,networkDetails:i,sessionData:null})}if(t.parsing.end=performance.now(),N.needSidxRanges){var R,p=null===(R=N.fragments[0].initSegment)||void 0===R?void 0:R.url;this.load({url:p,isSidxRequest:!0,type:d,level:u,levelDetails:N,id:S,groupId:null,rangeStart:0,rangeEnd:2048,responseType:"arraybuffer",deliveryDirectives:null})}else o.levelDetails=N,this.handlePlaylistLoaded(e,t,o,i)}else s.trigger(n.Events.ERROR,{type:r.ErrorTypes.NETWORK_ERROR,details:r.ErrorDetails.LEVEL_EMPTY_ERROR,fatal:!1,url:c,reason:"no fragments found in level",level:"number"==typeof o.level?o.level:void 0})},t.handleSidxRequest=function(e,t){var o=new Uint8Array(e.data),a=Object(s.findBox)(o,["sidx"])[0];if(a){var n=Object(s.parseSegmentIndex)(a);if(n){var r=n.references,i=t.levelDetails;r.forEach((function(e,t){var a=e.info,n=i.fragments[t];if(0===n.byteRange.length&&n.setByteRange(String(1+a.end-a.start)+"@"+String(a.start)),n.initSegment){var r=Object(s.findBox)(o,["moov"])[0],E=r?r.length:null;n.initSegment.setByteRange(String(E)+"@0")}}))}}},t.handleManifestParsingError=function(e,t,o,a){this.hls.trigger(n.Events.ERROR,{type:r.ErrorTypes.NETWORK_ERROR,details:r.ErrorDetails.MANIFEST_PARSING_ERROR,fatal:t.type===_.PlaylistContextType.MANIFEST,url:e.url,reason:o,response:e,context:t,networkDetails:a})},t.handleNetworkError=function(e,t,o,a){void 0===o&&(o=!1),i.logger.warn("[playlist-loader]: A network "+(o?"timeout":"error")+" occurred while loading "+e.type+" level: "+e.level+" id: "+e.id+' group-id: "'+e.groupId+'"');var s=r.ErrorDetails.UNKNOWN,E=!1,T=this.getInternalLoader(e);switch(e.type){case _.PlaylistContextType.MANIFEST:s=o?r.ErrorDetails.MANIFEST_LOAD_TIMEOUT:r.ErrorDetails.MANIFEST_LOAD_ERROR,E=!0;break;case _.PlaylistContextType.LEVEL:s=o?r.ErrorDetails.LEVEL_LOAD_TIMEOUT:r.ErrorDetails.LEVEL_LOAD_ERROR,E=!1;break;case _.PlaylistContextType.AUDIO_TRACK:s=o?r.ErrorDetails.AUDIO_TRACK_LOAD_TIMEOUT:r.ErrorDetails.AUDIO_TRACK_LOAD_ERROR,E=!1;break;case _.PlaylistContextType.SUBTITLE_TRACK:s=o?r.ErrorDetails.SUBTITLE_TRACK_LOAD_TIMEOUT:r.ErrorDetails.SUBTITLE_LOAD_ERROR,E=!1}T&&this.resetInternalLoader(e.type);var l={type:r.ErrorTypes.NETWORK_ERROR,details:s,fatal:E,url:e.url,loader:T,context:e,networkDetails:t};a&&(l.response=a),this.hls.trigger(n.Events.ERROR,l)},t.handlePlaylistLoaded=function(e,t,o,a){var r=o.type,i=o.level,s=o.id,E=o.groupId,T=o.loader,l=o.levelDetails,S=o.deliveryDirectives;if(null!=l&&l.targetduration){if(T)switch(l.live&&(T.getCacheAge&&(l.ageHeader=T.getCacheAge()||0),T.getCacheAge&&!isNaN(l.ageHeader)||(l.ageHeader=0)),r){case _.PlaylistContextType.MANIFEST:case _.PlaylistContextType.LEVEL:this.hls.trigger(n.Events.LEVEL_LOADED,{details:l,level:i||0,id:s||0,stats:t,networkDetails:a,deliveryDirectives:S});break;case _.PlaylistContextType.AUDIO_TRACK:this.hls.trigger(n.Events.AUDIO_TRACK_LOADED,{details:l,id:s||0,groupId:E||"",stats:t,networkDetails:a,deliveryDirectives:S});break;case _.PlaylistContextType.SUBTITLE_TRACK:this.hls.trigger(n.Events.SUBTITLE_TRACK_LOADED,{details:l,id:s||0,groupId:E||"",stats:t,networkDetails:a,deliveryDirectives:S})}}else this.handleManifestParsingError(e,o,"invalid target duration",a)},e})();t.default=S},"./src/polyfills/number.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"isFiniteNumber",(function(){return a})),o.d(t,"MAX_SAFE_INTEGER",(function(){return n}));var a=Number.isFinite||function(e){return"number"==typeof e&&isFinite(e)},n=Number.MAX_SAFE_INTEGER||9007199254740991},"./src/remux/aac-helper.ts":function(e,t,o){"use strict";o.r(t);var a=(function(){function e(){}return e.getSilentFrame=function(e,t){if("mp4a.40.2"===e){if(1===t)return new Uint8Array([0,200,0,128,35,128]);if(2===t)return new Uint8Array([33,0,73,144,2,25,0,35,128]);if(3===t)return new Uint8Array([0,200,0,128,32,132,1,38,64,8,100,0,142]);if(4===t)return new Uint8Array([0,200,0,128,32,132,1,38,64,8,100,0,128,44,128,8,2,56]);if(5===t)return new Uint8Array([0,200,0,128,32,132,1,38,64,8,100,0,130,48,4,153,0,33,144,2,56]);if(6===t)return new Uint8Array([0,200,0,128,32,132,1,38,64,8,100,0,130,48,4,153,0,33,144,2,0,178,0,32,8,224])}else{if(1===t)return new Uint8Array([1,64,34,128,163,78,230,128,186,8,0,0,0,28,6,241,193,10,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,94]);if(2===t)return new Uint8Array([1,64,34,128,163,94,230,128,186,8,0,0,0,0,149,0,6,241,161,10,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,94]);if(3===t)return new Uint8Array([1,64,34,128,163,94,230,128,186,8,0,0,0,0,149,0,6,241,161,10,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,90,94])}},e})();t.default=a},"./src/remux/mp4-generator.ts":function(e,t,o){"use strict";o.r(t);var a=Math.pow(2,32)-1,n=(function(){function e(){}return e.init=function(){var t;for(t in e.types={avc1:[],avcC:[],btrt:[],dinf:[],dref:[],esds:[],ftyp:[],hdlr:[],mdat:[],mdhd:[],mdia:[],mfhd:[],minf:[],moof:[],moov:[],mp4a:[],".mp3":[],mvex:[],mvhd:[],pasp:[],sdtp:[],stbl:[],stco:[],stsc:[],stsd:[],stsz:[],stts:[],tfdt:[],tfhd:[],traf:[],trak:[],trun:[],trex:[],tkhd:[],vmhd:[],smhd:[]},e.types)e.types.hasOwnProperty(t)&&(e.types[t]=[t.charCodeAt(0),t.charCodeAt(1),t.charCodeAt(2),t.charCodeAt(3)]);var o=new Uint8Array([0,0,0,0,0,0,0,0,118,105,100,101,0,0,0,0,0,0,0,0,0,0,0,0,86,105,100,101,111,72,97,110,100,108,101,114,0]),a=new Uint8Array([0,0,0,0,0,0,0,0,115,111,117,110,0,0,0,0,0,0,0,0,0,0,0,0,83,111,117,110,100,72,97,110,100,108,101,114,0]);e.HDLR_TYPES={video:o,audio:a};var n=new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,12,117,114,108,32,0,0,0,1]),r=new Uint8Array([0,0,0,0,0,0,0,0]);e.STTS=e.STSC=e.STCO=r,e.STSZ=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0]),e.VMHD=new Uint8Array([0,0,0,1,0,0,0,0,0,0,0,0]),e.SMHD=new Uint8Array([0,0,0,0,0,0,0,0]),e.STSD=new Uint8Array([0,0,0,0,0,0,0,1]);var i=new Uint8Array([105,115,111,109]),s=new Uint8Array([97,118,99,49]),E=new Uint8Array([0,0,0,1]);e.FTYP=e.box(e.types.ftyp,i,E,i,s),e.DINF=e.box(e.types.dinf,e.box(e.types.dref,n))},e.box=function(e){for(var t=8,o=arguments.length,a=new Array(o>1?o-1:0),n=1;n>24&255,s[1]=t>>16&255,s[2]=t>>8&255,s[3]=255&t,s.set(e,4),r=0,t=8;r>24&255,t>>16&255,t>>8&255,255&t,n>>24,n>>16&255,n>>8&255,255&n,r>>24,r>>16&255,r>>8&255,255&r,85,196,0,0]))},e.mdia=function(t){return e.box(e.types.mdia,e.mdhd(t.timescale,t.duration),e.hdlr(t.type),e.minf(t))},e.mfhd=function(t){return e.box(e.types.mfhd,new Uint8Array([0,0,0,0,t>>24,t>>16&255,t>>8&255,255&t]))},e.minf=function(t){return"audio"===t.type?e.box(e.types.minf,e.box(e.types.smhd,e.SMHD),e.DINF,e.stbl(t)):e.box(e.types.minf,e.box(e.types.vmhd,e.VMHD),e.DINF,e.stbl(t))},e.moof=function(t,o,a){return e.box(e.types.moof,e.mfhd(t),e.traf(a,o))},e.moov=function(t){for(var o=t.length,a=[];o--;)a[o]=e.trak(t[o]);return e.box.apply(null,[e.types.moov,e.mvhd(t[0].timescale,t[0].duration)].concat(a).concat(e.mvex(t)))},e.mvex=function(t){for(var o=t.length,a=[];o--;)a[o]=e.trex(t[o]);return e.box.apply(null,[e.types.mvex].concat(a))},e.mvhd=function(t,o){o*=t;var n=Math.floor(o/(a+1)),r=Math.floor(o%(a+1)),i=new Uint8Array([1,0,0,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,3,t>>24&255,t>>16&255,t>>8&255,255&t,n>>24,n>>16&255,n>>8&255,255&n,r>>24,r>>16&255,r>>8&255,255&r,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,255,255,255,255]);return e.box(e.types.mvhd,i)},e.sdtp=function(t){var o,a,n=t.samples||[],r=new Uint8Array(4+n.length);for(o=0;o>>8&255),r.push(255&n),r=r.concat(Array.prototype.slice.call(a));for(o=0;o>>8&255),i.push(255&n),i=i.concat(Array.prototype.slice.call(a));var s=e.box(e.types.avcC,new Uint8Array([1,r[3],r[4],r[5],255,224|t.sps.length].concat(r).concat([t.pps.length]).concat(i))),E=t.width,_=t.height,T=t.pixelRatio[0],l=t.pixelRatio[1];return e.box(e.types.avc1,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,E>>8&255,255&E,_>>8&255,255&_,0,72,0,0,0,72,0,0,0,0,0,0,0,1,18,100,97,105,108,121,109,111,116,105,111,110,47,104,108,115,46,106,115,0,0,0,0,0,0,0,0,0,0,0,0,0,0,24,17,17]),s,e.box(e.types.btrt,new Uint8Array([0,28,156,128,0,45,198,192,0,45,198,192])),e.box(e.types.pasp,new Uint8Array([T>>24,T>>16&255,T>>8&255,255&T,l>>24,l>>16&255,l>>8&255,255&l])))},e.esds=function(e){var t=e.config.length;return new Uint8Array([0,0,0,0,3,23+t,0,1,0,4,15+t,64,21,0,0,0,0,0,0,0,0,0,0,0,5].concat([t]).concat(e.config).concat([6,1,2]))},e.mp4a=function(t){var o=t.samplerate;return e.box(e.types.mp4a,new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,o>>8&255,255&o,0,0]),e.box(e.types.esds,e.esds(t)))},e.mp3=function(t){var o=t.samplerate;return e.box(e.types[".mp3"],new Uint8Array([0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,t.channelCount,0,16,0,0,0,0,o>>8&255,255&o,0,0]))},e.stsd=function(t){return"audio"===t.type?"mp3"===t.segmentCodec&&"mp3"===t.codec?e.box(e.types.stsd,e.STSD,e.mp3(t)):e.box(e.types.stsd,e.STSD,e.mp4a(t)):e.box(e.types.stsd,e.STSD,e.avc1(t))},e.tkhd=function(t){var o=t.id,n=t.duration*t.timescale,r=t.width,i=t.height,s=Math.floor(n/(a+1)),E=Math.floor(n%(a+1));return e.box(e.types.tkhd,new Uint8Array([1,0,0,7,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,3,o>>24&255,o>>16&255,o>>8&255,255&o,0,0,0,0,s>>24,s>>16&255,s>>8&255,255&s,E>>24,E>>16&255,E>>8&255,255&E,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,64,0,0,0,r>>8&255,255&r,0,0,i>>8&255,255&i,0,0]))},e.traf=function(t,o){var n=e.sdtp(t),r=t.id,i=Math.floor(o/(a+1)),s=Math.floor(o%(a+1));return e.box(e.types.traf,e.box(e.types.tfhd,new Uint8Array([0,0,0,0,r>>24,r>>16&255,r>>8&255,255&r])),e.box(e.types.tfdt,new Uint8Array([1,0,0,0,i>>24,i>>16&255,i>>8&255,255&i,s>>24,s>>16&255,s>>8&255,255&s])),e.trun(t,n.length+16+20+8+16+8+8),n)},e.trak=function(t){return t.duration=t.duration||4294967295,e.box(e.types.trak,e.tkhd(t),e.mdia(t))},e.trex=function(t){var o=t.id;return e.box(e.types.trex,new Uint8Array([0,0,0,0,o>>24,o>>16&255,o>>8&255,255&o,0,0,0,1,0,0,0,0,0,0,0,0,0,1,0,1]))},e.trun=function(t,o){var a,n,r,i,s,E,_=t.samples||[],T=_.length,l=12+16*T,S=new Uint8Array(l);for(o+=8+l,S.set(["video"===t.type?1:0,0,15,1,T>>>24&255,T>>>16&255,T>>>8&255,255&T,o>>>24&255,o>>>16&255,o>>>8&255,255&o],0),a=0;a>>24&255,r>>>16&255,r>>>8&255,255&r,i>>>24&255,i>>>16&255,i>>>8&255,255&i,s.isLeading<<2|s.dependsOn,s.isDependedOn<<6|s.hasRedundancy<<4|s.paddingValue<<1|s.isNonSync,61440&s.degradPrio,15&s.degradPrio,E>>>24&255,E>>>16&255,E>>>8&255,255&E],12+16*a);return e.box(e.types.trun,S)},e.initSegment=function(t){e.types||e.init();var o=e.moov(t),a=new Uint8Array(e.FTYP.byteLength+o.byteLength);return a.set(e.FTYP),a.set(o,e.FTYP.byteLength),a},e})();n.types=void 0,n.HDLR_TYPES=void 0,n.STTS=void 0,n.STSC=void 0,n.STCO=void 0,n.STSZ=void 0,n.VMHD=void 0,n.SMHD=void 0,n.STSD=void 0,n.FTYP=void 0,n.DINF=void 0,t.default=n},"./src/remux/mp4-remuxer.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return d})),o.d(t,"normalizePts",(function(){return c})),o.d(t,"flushTextTrackMetadataCueSamples",(function(){return I})),o.d(t,"flushTextTrackUserdataCueSamples",(function(){return A}));var a=o("./src/polyfills/number.ts"),n=o("./src/remux/aac-helper.ts"),r=o("./src/remux/mp4-generator.ts"),i=o("./src/events.ts"),s=o("./src/errors.ts"),E=o("./src/utils/logger.ts"),_=o("./src/types/loader.ts"),T=o("./src/utils/timescale-conversion.ts");function l(){return l=Object.assign?Object.assign.bind():function(e){for(var t=1;t0?e:o.pts}),e[0].pts);return t&&E.logger.debug("PTS rollover detected"),o},t.remux=function(e,t,o,a,n,r,i,s){var T,l,S,u,d,O,N=n,m=n,R=e.pid>-1,p=t.pid>-1,h=t.samples.length,f=e.samples.length>0,L=i&&h>0||h>1;if((!R||f)&&(!p||L)||this.ISGenerated||i){this.ISGenerated||(S=this.generateIS(e,t,n));var C,D=this.isVideoContiguous,g=-1;if(L&&(g=(function(e){for(var t=0;t0){E.logger.warn("[mp4-remuxer]: Dropped "+g+" out of "+h+" video samples due to a missing keyframe");var v=this.getVideoStartPts(t.samples);t.samples=t.samples.slice(g),t.dropped+=g,C=m+=(t.samples[0].pts-v)/t.inputTimeScale}else-1===g&&(E.logger.warn("[mp4-remuxer]: No keyframe found out of "+h+" video samples"),O=!1);if(this.ISGenerated){if(f&&L){var y=this.getVideoStartPts(t.samples),P=(c(e.samples[0].pts,y)-y)/t.inputTimeScale;N+=Math.max(0,P),m+=Math.max(0,-P)}if(f){if(e.samplerate||(E.logger.warn("[mp4-remuxer]: regenerate InitSegment as audio detected"),S=this.generateIS(e,t,n)),l=this.remuxAudio(e,N,this.isAudioContiguous,r,p||L||s===_.PlaylistLevelType.AUDIO?m:void 0),L){var B=l?l.endPTS-l.startPTS:0;t.inputTimeScale||(E.logger.warn("[mp4-remuxer]: regenerate InitSegment as video detected"),S=this.generateIS(e,t,n)),T=this.remuxVideo(t,m,D,B)}}else L&&(T=this.remuxVideo(t,m,D,0));T&&(T.firstKeyFrame=g,T.independent=-1!==g,T.firstKeyFramePTS=C)}}return this.ISGenerated&&(o.samples.length&&(d=I(o,n,this._initPTS,this._initDTS)),a.samples.length&&(u=A(a,n,this._initPTS))),{audio:l,video:T,initSegment:S,independent:O,text:u,id3:d}},t.generateIS=function(e,t,o){var n,i,s,E=e.samples,_=t.samples,T=this.typeSupported,l={},S=!Object(a.isFiniteNumber)(this._initPTS),u="audio/mp4";if(S&&(n=i=1/0),e.config&&E.length&&(e.timescale=e.samplerate,"mp3"===e.segmentCodec&&(T.mpeg?(u="audio/mpeg",e.codec=""):T.mp3&&(e.codec="mp3")),l.audio={id:"audio",container:u,codec:e.codec,initSegment:"mp3"===e.segmentCodec&&T.mpeg?new Uint8Array(0):r.default.initSegment([e]),metadata:{channelCount:e.channelCount}},S&&(s=e.inputTimeScale,n=i=E[0].pts-Math.round(s*o))),t.sps&&t.pps&&_.length&&(t.timescale=t.inputTimeScale,l.video={id:"main",container:"video/mp4",codec:t.codec,initSegment:r.default.initSegment([t]),metadata:{width:t.width,height:t.height}},S)){s=t.inputTimeScale;var d=this.getVideoStartPts(_),I=Math.round(s*o);i=Math.min(i,c(_[0].dts,d)-I),n=Math.min(n,d-I)}if(Object.keys(l).length)return this.ISGenerated=!0,S&&(this._initPTS=n,this._initDTS=i),{tracks:l,initPTS:n,timescale:s}},t.remuxVideo=function(e,t,o,a){var n,_,d=e.inputTimeScale,I=e.samples,A=[],N=I.length,m=this._initPTS,R=this.nextAvcDts,p=8,h=this.videoSampleDuration,f=Number.POSITIVE_INFINITY,L=Number.NEGATIVE_INFINITY,C=!1;o&&null!==R||(R=t*d-(I[0].pts-c(I[0].dts,I[0].pts)));for(var D=0;D0?D-1:D].dts&&(C=!0)}C&&I.sort((function(e,t){var o=e.dts-t.dts,a=e.pts-t.pts;return o||a})),n=I[0].dts;var v=(_=I[I.length-1].dts)-n,y=v?Math.round(v/(N-1)):h||e.inputTimeScale/30;if(o){var P=n-R,B=P>y;if(B||P<-1){B?E.logger.warn("AVC: "+Object(T.toMsFromMpegTsClock)(P,!0)+" ms ("+P+"dts) hole between fragments detected, filling it"):E.logger.warn("AVC: "+Object(T.toMsFromMpegTsClock)(-P,!0)+" ms ("+P+"dts) overlapping between fragments detected"),n=R;var b=I[0].pts-P;I[0].dts=n,I[0].pts=b,E.logger.log("Video: First PTS/DTS adjusted: "+Object(T.toMsFromMpegTsClock)(b,!0)+"/"+Object(T.toMsFromMpegTsClock)(n,!0)+", delta: "+Object(T.toMsFromMpegTsClock)(P,!0)+" ms")}}n=Math.max(0,n);for(var M=0,U=0,W=0;W0?q.dts-I[$-1].dts:y;if(re=$>0?q.pts-I[$-1].pts:y,ie.stretchShortVideoTrack&&null!==this.nextAudioPts){var Ee=Math.floor(ie.maxBufferHole*d),_e=(a?f+a*d:this.nextAudioPts)-q.pts;_e>Ee?((h=_e-se)<0?h=se:x=!0,E.logger.log("[mp4-remuxer]: It is approximately "+_e/90+" ms to the next segment; using duration "+h/90+" ms for the last video frame.")):h=se}else h=se}var Te=Math.round(q.pts-q.dts);K=Math.min(K,h),Q=Math.max(Q,h),j=Math.min(j,re),X=Math.max(X,re),A.push(new O(q.key,h,Z,Te))}if(A.length)if(S){if(S<70){var le=A[0].flags;le.dependsOn=2,le.isNonSync=0}}else if(u&&X-j0&&(a&&Math.abs(f-h)<9e3||Math.abs(c(R[0].pts-I,f)-h)<20*d),R.forEach((function(e){e.pts=c(e.pts-I,f)})),!o||h<0){if(R=R.filter((function(e){return e.pts>=0})),!R.length)return;h=0===_?0:a&&!m?Math.max(0,f):R[0].pts}if("aac"===e.segmentCodec)for(var L=this.config.maxAudioFramesDrift,C=0,D=h;C=L*d&&P<1e4&&m){var B=Math.round(y/d);(D=v-B*d)<0&&(B--,D+=d),0===C&&(this.nextAudioPts=h=D),E.logger.warn("[mp4-remuxer]: Injecting "+B+" audio frame @ "+(D/T).toFixed(3)+"s due to "+Math.round(1e3*y/T)+" ms gap.");for(var b=0;b0))return;k+=p;try{W=new Uint8Array(k)}catch(e){return void this.observer.emit(i.Events.ERROR,i.Events.ERROR,{type:s.ErrorTypes.MUX_ERROR,details:s.ErrorDetails.REMUX_ALLOC_ERROR,fatal:!1,bytes:k,reason:"fail allocating audio mdat "+k})}A||(new DataView(W.buffer).setUint32(0,k),W.set(r.default.types.mdat,4))}W.set(z,p);var K=z.byteLength;p+=K,N.push(new O(!0,u,K,0)),F=x}var j=N.length;if(j){var Q=N[N.length-1];this.nextAudioPts=h=F+S*Q.duration;var X=A?new Uint8Array(0):r.default.moof(e.sequenceNumber++,G/S,l({},e,{samples:N}));e.samples=[];var $=G/T,q=h/T,J={data1:X,data2:W,startPTS:$,endPTS:q,startDTS:$,endDTS:q,type:"audio",hasAudio:!0,hasVideo:!1,nb:j};return this.isAudioContiguous=!0,console.assert(W.length,"MDAT length must not be zero"),J}},t.remuxEmptyAudio=function(e,t,o,a){var r=e.inputTimeScale,i=r/(e.samplerate?e.samplerate:r),s=this.nextAudioPts,_=(null!==s?s:a.startDTS*r)+this._initDTS,T=a.endDTS*r+this._initDTS,l=1024*i,S=Math.ceil((T-_)/l),u=n.default.getSilentFrame(e.manifestCodec||e.codec,e.channelCount);if(E.logger.warn("[mp4-remuxer]: remux empty Audio"),u){for(var d=[],c=0;c4294967296;)e+=o;return e}function I(e,t,o,a){var n=e.samples.length;if(n){for(var r=e.inputTimeScale,i=0;i0?this.lastEndTime=N:(s.logger.warn("Duration parsed from mp4 should be greater than zero"),this.resetNextTimestamp());var m=!!c.audio,R=!!c.video,p="";m&&(p+="audio"),R&&(p+="video");var h={data1:u,startPTS:O,startDTS:O,endPTS:N,endDTS:N,type:p,hasAudio:m,hasVideo:R,nb:1,dropped:0};S.audio="audio"===h.type?h:void 0,S.video="audio"!==h.type?h:void 0,S.initSegment=d;var f=null!=(_=this.initPTS)?_:0;return S.id3=Object(n.flushTextTrackMetadataCueSamples)(o,E,f,f),i.samples.length&&(S.text=Object(n.flushTextTrackUserdataCueSamples)(i,E,f)),S},e})();function _(e,t){var o=null==e?void 0:e.codec;return o&&o.length>4?o:"hvc1"===o||"hev1"===o?"hvc1.1.c.L120.90":"av01"===o?"av01.0.04M.08":"avc1"===o||t===i.ElementaryStreamTypes.VIDEO?"avc1.42e01e":"mp4a.40.5"}t.default=E},"./src/task-loop.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return a}));var a=(function(){function e(){this._boundTick=void 0,this._tickTimer=null,this._tickInterval=null,this._tickCallCount=0,this._boundTick=this.tick.bind(this)}var t=e.prototype;return t.destroy=function(){this.onHandlerDestroying(),this.onHandlerDestroyed()},t.onHandlerDestroying=function(){this.clearNextTick(),this.clearInterval()},t.onHandlerDestroyed=function(){},t.hasInterval=function(){return!!this._tickInterval},t.hasNextTick=function(){return!!this._tickTimer},t.setInterval=function(e){return!this._tickInterval&&(this._tickInterval=self.setInterval(this._boundTick,e),!0)},t.clearInterval=function(){return!!this._tickInterval&&(self.clearInterval(this._tickInterval),this._tickInterval=null,!0)},t.clearNextTick=function(){return!!this._tickTimer&&(self.clearTimeout(this._tickTimer),this._tickTimer=null,!0)},t.tick=function(){this._tickCallCount++,1===this._tickCallCount&&(this.doTick(),this._tickCallCount>1&&this.tickImmediate(),this._tickCallCount=0)},t.tickImmediate=function(){this.clearNextTick(),this._tickTimer=self.setTimeout(this._boundTick,0)},t.doTick=function(){},e})()},"./src/types/cmcd.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"CMCDVersion",(function(){return i})),o.d(t,"CMCDObjectType",(function(){return a})),o.d(t,"CMCDStreamingFormat",(function(){return n})),o.d(t,"CMCDStreamType",(function(){return r}));var a,n,r,i=1;!(function(e){e.MANIFEST="m",e.AUDIO="a",e.VIDEO="v",e.MUXED="av",e.INIT="i",e.CAPTION="c",e.TIMED_TEXT="tt",e.KEY="k",e.OTHER="o"})(a||(a={})),(function(e){e.DASH="d",e.HLS="h",e.SMOOTH="s",e.OTHER="o"})(n||(n={})),(function(e){e.VOD="v",e.LIVE="l"})(r||(r={}))},"./src/types/demuxer.ts":function(e,t,o){"use strict";var a;o.r(t),o.d(t,"MetadataSchema",(function(){return a})),(function(e){e.audioId3="org.id3",e.dateRange="com.apple.quicktime.HLS",e.emsg="https://aomedia.org/emsg/ID3"})(a||(a={}))},"./src/types/level.ts":function(e,t,o){"use strict";function a(e,t){for(var o=0;oNumber.MAX_SAFE_INTEGER?1/0:t},t.hexadecimalInteger=function(e){if(this[e]){var t=(this[e]||"0x").slice(2);t=(1&t.length?"0":"")+t;for(var o=new Uint8Array(t.length/2),a=0;aNumber.MAX_SAFE_INTEGER?1/0:t},t.decimalFloatingPoint=function(e){return parseFloat(this[e])},t.optionalFloat=function(e,t){var o=this[e];return o?parseFloat(o):t},t.enumeratedString=function(e){return this[e]},t.bool=function(e){return"YES"===this[e]},t.decimalResolution=function(e){var t=a.exec(this[e]);if(null!==t)return{width:parseInt(t[1],10),height:parseInt(t[2],10)}},e.parseAttrList=function(e){var t,o={};for(n.lastIndex=0;null!==(t=n.exec(e));){var a=t[2];0===a.indexOf('"')&&a.lastIndexOf('"')===a.length-1&&(a=a.slice(1,-1)),o[t[1]]=a}return o},e})()},"./src/utils/binary-search.ts":function(e,t,o){"use strict";o.r(t),t.default={search:function(e,t){for(var o=0,a=e.length-1,n=null,r=null;o<=a;){var i=t(r=e[n=(o+a)/2|0]);if(i>0)o=n+1;else{if(!(i<0))return r;a=n-1}}return null}}},"./src/utils/buffer-helper.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"BufferHelper",(function(){return r}));var a=o("./src/utils/logger.ts"),n={length:0,start:function(){return 0},end:function(){return 0}},r=(function(){function e(){}return e.isBuffered=function(t,o){try{if(t)for(var a=e.getBuffered(t),n=0;n=a.start(n)&&o<=a.end(n))return!0}catch(e){}return!1},e.bufferInfo=function(t,o,a){try{if(t){var n,r=e.getBuffered(t),i=[];for(n=0;ni&&(a[r-1].end=e[n].end):a.push(e[n])}else a.push(e[n])}else a=e;for(var s,E=0,_=t,T=t,l=0;l=S&&t=e&&n.logger.log(this.time+" ["+e+"] "+t)},e})(),c=function(e){for(var t=[],o=0;oE&&(this.logger.log(a.DEBUG,"Too large cursor position "+this.pos),this.pos=E)},t.moveCursor=function(e){var t=this.pos+e;if(e>1)for(var o=this.pos+1;o=144&&this.backSpace();var t=i(e);this.pos>=E?this.logger.log(a.ERROR,"Cannot insert "+e.toString(16)+" ("+t+") at position "+this.pos+". Skipping it!"):(this.chars[this.pos].setChar(t,this.currPenState),this.moveCursor(1))},t.clearFromPos=function(e){var t;for(t=e;t0&&(o=e?"["+t.join(" | ")+"]":t.join("\n")),o},t.getTextAndFormat=function(){return this.rows},e})(),m=(function(){function e(e,t,o){this.chNr=void 0,this.outputFilter=void 0,this.mode=void 0,this.verbose=void 0,this.displayedMemory=void 0,this.nonDisplayedMemory=void 0,this.lastOutputScreen=void 0,this.currRollUpRow=void 0,this.writeScreen=void 0,this.cueStartTime=void 0,this.logger=void 0,this.chNr=e,this.outputFilter=t,this.mode=null,this.verbose=0,this.displayedMemory=new N(o),this.nonDisplayedMemory=new N(o),this.lastOutputScreen=new N(o),this.currRollUpRow=this.displayedMemory.rows[14],this.writeScreen=this.displayedMemory,this.mode=null,this.cueStartTime=null,this.logger=o}var t=e.prototype;return t.reset=function(){this.mode=null,this.displayedMemory.reset(),this.nonDisplayedMemory.reset(),this.lastOutputScreen.reset(),this.outputFilter.reset(),this.currRollUpRow=this.displayedMemory.rows[14],this.writeScreen=this.displayedMemory,this.mode=null,this.cueStartTime=null},t.getHandler=function(){return this.outputFilter},t.setHandler=function(e){this.outputFilter=e},t.setPAC=function(e){this.writeScreen.setPAC(e)},t.setBkgData=function(e){this.writeScreen.setBkgData(e)},t.setMode=function(e){e!==this.mode&&(this.mode=e,this.logger.log(a.INFO,"MODE="+e),"MODE_POP-ON"===this.mode?this.writeScreen=this.nonDisplayedMemory:(this.writeScreen=this.displayedMemory,this.writeScreen.reset()),"MODE_ROLL-UP"!==this.mode&&(this.displayedMemory.nrRollUpRows=null,this.nonDisplayedMemory.nrRollUpRows=null),this.mode=e)},t.insertChars=function(e){for(var t=0;t=46,t.italics)t.foreground="white";else{var o=Math.floor(e/2)-16;t.foreground=["white","green","blue","cyan","red","yellow","magenta"][o]}this.logger.log(a.INFO,"MIDROW: "+JSON.stringify(t)),this.writeScreen.setPen(t)},t.outputDataUpdate=function(e){void 0===e&&(e=!1);var t=this.logger.time;null!==t&&this.outputFilter&&(null!==this.cueStartTime||this.displayedMemory.isEmpty()?this.displayedMemory.equals(this.lastOutputScreen)||(this.outputFilter.newCue(this.cueStartTime,t,this.lastOutputScreen),e&&this.outputFilter.dispatchCue&&this.outputFilter.dispatchCue(),this.cueStartTime=this.displayedMemory.isEmpty()?null:t):this.cueStartTime=t,this.lastOutputScreen.copy(this.displayedMemory))},t.cueSplitAtTime=function(e){this.outputFilter&&(this.displayedMemory.isEmpty()||(this.outputFilter.newCue&&this.outputFilter.newCue(this.cueStartTime,e,this.displayedMemory),this.cueStartTime=e))},e})(),R=(function(){function e(e,t,o){this.channels=void 0,this.currentChannel=0,this.cmdHistory=void 0,this.logger=void 0;var a=new d;this.channels=[null,new m(e,t,a),new m(e+1,o,a)],this.cmdHistory={a:null,b:null},this.logger=a}var t=e.prototype;return t.getHandler=function(e){return this.channels[e].getHandler()},t.setHandler=function(e,t){this.channels[e].setHandler(t)},t.addData=function(e,t){var o,n,r,i=!1;this.logger.time=e;for(var s=0;s ("+c([n,r])+")"),(o=this.parseCmd(n,r))||(o=this.parseMidrow(n,r)),o||(o=this.parsePAC(n,r)),o||(o=this.parseBackgroundAttributes(n,r)),!o&&(i=this.parseChars(n,r))){var E=this.currentChannel;E&&E>0?this.channels[E].insertChars(i):this.logger.log(a.WARNING,"No channel found yet. TEXT-MODE?")}o||i||this.logger.log(a.WARNING,"Couldn't parse cleaned data "+c([n,r])+" orig: "+c([t[s],t[s+1]]))}},t.parseCmd=function(e,t){var o=this.cmdHistory;if(!((20===e||28===e||21===e||29===e)&&t>=32&&t<=47||(23===e||31===e)&&t>=33&&t<=35))return!1;if(h(e,t,o))return p(null,null,o),this.logger.log(a.DEBUG,"Repeated command ("+c([e,t])+") is dropped"),!0;var n=20===e||21===e||23===e?1:2,r=this.channels[n];return 20===e||21===e||28===e||29===e?32===t?r.ccRCL():33===t?r.ccBS():34===t?r.ccAOF():35===t?r.ccAON():36===t?r.ccDER():37===t?r.ccRU(2):38===t?r.ccRU(3):39===t?r.ccRU(4):40===t?r.ccFON():41===t?r.ccRDC():42===t?r.ccTR():43===t?r.ccRTD():44===t?r.ccEDM():45===t?r.ccCR():46===t?r.ccENM():47===t&&r.ccEOC():r.ccTO(t-32),p(e,t,o),this.currentChannel=n,!0},t.parseMidrow=function(e,t){var o=0;if((17===e||25===e)&&t>=32&&t<=47){if((o=17===e?1:2)!==this.currentChannel)return this.logger.log(a.ERROR,"Mismatch channel in midrow parsing"),!1;var n=this.channels[o];return!!n&&(n.ccMIDROW(t),this.logger.log(a.DEBUG,"MIDROW ("+c([e,t])+")"),!0)}return!1},t.parsePAC=function(e,t){var o,a=this.cmdHistory;if(!((e>=17&&e<=23||e>=25&&e<=31)&&t>=64&&t<=127||(16===e||24===e)&&t>=64&&t<=95))return!1;if(h(e,t,a))return p(null,null,a),!0;var n=e<=23?1:2;o=t>=64&&t<=95?1===n?_[e]:l[e]:1===n?T[e]:S[e];var r=this.channels[n];return!!r&&(r.setPAC(this.interpretPAC(o,t)),p(e,t,a),this.currentChannel=n,!0)},t.interpretPAC=function(e,t){var o,a={color:null,italics:!1,indent:null,underline:!1,row:e};return o=t>95?t-96:t-64,a.underline=1==(1&o),o<=13?a.color=["white","green","blue","cyan","red","yellow","magenta","white"][Math.floor(o/2)]:o<=15?(a.italics=!0,a.color="white"):a.indent=4*Math.floor((o-16)/2),a},t.parseChars=function(e,t){var o,n,r=null,s=null;if(e>=25?(o=2,s=e-8):(o=1,s=e),s>=17&&s<=19?(n=17===s?t+80:18===s?t+112:t+144,this.logger.log(a.INFO,"Special char '"+i(n)+"' in channel "+o),r=[n]):e>=32&&e<=127&&(r=0===t?[e]:[e,t]),r){var E=c(r);this.logger.log(a.DEBUG,"Char codes = "+E.join(",")),p(e,t,this.cmdHistory)}return r},t.parseBackgroundAttributes=function(e,t){var o;if(!((16===e||24===e)&&t>=32&&t<=47||(23===e||31===e)&&t>=45&&t<=47))return!1;var a={};16===e||24===e?(o=Math.floor((t-32)/2),a.background=u[o],t%2==1&&(a.background=a.background+"_semi")):45===t?a.background="transparent":(a.foreground="black",47===t&&(a.underline=!0));var n=e<=23?1:2;return this.channels[n].setBkgData(a),p(e,t,this.cmdHistory),!0},t.reset=function(){for(var e=0;e=16?l--:l++;var A=Object(a.fixLineBreaks)(S.trim()),O=Object(n.generateCueId)(t,o,A);e&&e.cues&&e.cues.getCueById(O)||((_=new d(t,o,A)).id=O,_.line=c+1,_.align="left",_.position=10+Math.min(80,10*Math.floor(8*l/32)),u.push(_))}return e&&u.length&&(u.sort((function(e,t){return"auto"===e.line||"auto"===t.line?0:e.line>8&&t.line>8?t.line-e.line:e.line-t.line})),u.forEach((function(t){return Object(r.addCueToTrack)(e,t)}))),u}};t.default=s},"./src/utils/discontinuities.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"findFirstFragWithCC",(function(){return i})),o.d(t,"shouldAlignOnDiscontinuities",(function(){return s})),o.d(t,"findDiscontinuousReferenceFrag",(function(){return E})),o.d(t,"adjustSlidingStart",(function(){return T})),o.d(t,"alignStream",(function(){return l})),o.d(t,"alignPDT",(function(){return S})),o.d(t,"alignFragmentByPDTDelta",(function(){return u})),o.d(t,"alignMediaPlaylistByPDT",(function(){return d}));var a=o("./src/polyfills/number.ts"),n=o("./src/utils/logger.ts"),r=o("./src/controller/level-helper.ts");function i(e,t){for(var o=null,a=0,n=e.length;ao.startCC||e&&e.cc=this.minWeight_},t.getEstimate=function(){return this.canEstimate()?Math.min(this.fast_.getEstimate(),this.slow_.getEstimate()):this.defaultEstimate_},t.destroy=function(){},e})();t.default=n},"./src/utils/ewma.ts":function(e,t,o){"use strict";o.r(t);var a=(function(){function e(e,t,o){void 0===t&&(t=0),void 0===o&&(o=0),this.halfLife=void 0,this.alpha_=void 0,this.estimate_=void 0,this.totalWeight_=void 0,this.halfLife=e,this.alpha_=e?Math.exp(Math.log(.5)/e):0,this.estimate_=t,this.totalWeight_=o}var t=e.prototype;return t.sample=function(e,t){var o=Math.pow(this.alpha_,e);this.estimate_=t*(1-o)+o*this.estimate_,this.totalWeight_+=e},t.getTotalWeight=function(){return this.totalWeight_},t.getEstimate=function(){if(this.alpha_){var e=1-Math.pow(this.alpha_,this.totalWeight_);if(e)return this.estimate_/e}return this.estimate_},e})();t.default=a},"./src/utils/fetch-loader.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"fetchSupported",(function(){return S}));var a=o("./src/polyfills/number.ts"),n=o("./src/loader/load-stats.ts"),r=o("./src/demux/chunk-cache.ts");function i(e){var t="function"==typeof Map?new Map:void 0;return i=function(e){if(null===e||(o=e,-1===Function.toString.call(o).indexOf("[native code]")))return e;var o;if("function"!=typeof e)throw new TypeError("Super expression must either be null or a function");if(void 0!==t){if(t.has(e))return t.get(e);t.set(e,a)}function a(){return s(e,arguments,T(this).constructor)}return a.prototype=Object.create(e.prototype,{constructor:{value:a,enumerable:!1,writable:!0,configurable:!0}}),_(a,e)},i(e)}function s(e,t,o){return s=E()?Reflect.construct.bind():function(e,t,o){var a=[null];a.push.apply(a,t);var n=new(Function.bind.apply(e,a));return o&&_(n,o.prototype),n},s.apply(null,arguments)}function E(){if("undefined"==typeof Reflect||!Reflect.construct)return!1;if(Reflect.construct.sham)return!1;if("function"==typeof Proxy)return!0;try{return Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],(function(){}))),!0}catch(e){return!1}}function _(e,t){return _=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,t){return e.__proto__=t,e},_(e,t)}function T(e){return T=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(e){return e.__proto__||Object.getPrototypeOf(e)},T(e)}function l(){return l=Object.assign?Object.assign.bind():function(e){for(var t=1;t=a&&n(t,o,i.flush(),e)):n(t,o,E,e),r()})).catch((function(){return Promise.reject()}))})()},e})();function d(e,t){return new self.Request(e.url,t)}var c=(function(e){var t,o;function a(t,o,a){var n;return(n=e.call(this,t)||this).code=void 0,n.details=void 0,n.code=o,n.details=a,n}return o=e,(t=a).prototype=Object.create(o.prototype),t.prototype.constructor=t,_(t,o),a})(i(Error));t.default=u},"./src/utils/imsc1-ttml-parser.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"IMSC1_CODEC",(function(){return T})),o.d(t,"parseIMSC1",(function(){return d}));var a=o("./src/utils/mp4-tools.ts"),n=o("./src/utils/vttparser.ts"),r=o("./src/utils/vttcue.ts"),i=o("./src/demux/id3.ts"),s=o("./src/utils/timescale-conversion.ts"),E=o("./src/utils/webvtt-parser.ts");function _(){return _=Object.assign?Object.assign.bind():function(e){for(var t=1;t"):a}function s(e){if(self.console&&!0===e||"object"==typeof e){!(function(e){for(var t=arguments.length,o=new Array(t>1?t-1:0),a=1;a>24,e[t+1]=o>>16&255,e[t+2]=o>>8&255,e[t+3]=255&o}function d(e,t){var o=[];if(!t.length)return o;for(var a=e.byteLength,n=0;n1?n+r:a;if(_(e.subarray(n+4,n+8))===t[0])if(1===t.length)o.push(e.subarray(n+8,i));else{var E=d(e.subarray(n+8,i),t.slice(1));E.length&&s.apply(o,E)}n=i}return o}function c(e){var t=[],o=e[0],a=8,n=l(e,a);a+=4,a+=0===o?8:16,a+=2;var r=e.length+0,i=T(e,a);a+=2;for(var s=0;s>>31)return console.warn("SIDX has hierarchical references (not supported)"),null;var u=l(e,E);E+=4,t.push({referenceSize:S,subsegmentDuration:u,info:{duration:u/n,start:r,end:r+S-1}}),r+=S,a=E+=4}return{earliestPresentationTime:0,timescale:n,version:o,referencesCount:i,references:t}}function I(e){for(var t=[],o=d(e,["moov","trak"]),a=0;a=a.length)break;i+=_=a[n++]}while(255===_);s=0;do{if(n>=a.length)break;s+=_=a[n++]}while(255===_);var S=a.length-n;if(!E&&4===i&&n16){for(var R=[],p=0;p<16;p++){var h=a[n++].toString(16);R.push(1==h.length?"0"+h:h),3!==p&&5!==p&&7!==p&&9!==p||R.push("-")}for(var f=s-16,L=new Uint8Array(f),C=0;CS)break}}function C(e){var t=e[0],o="",a="",n=0,r=0,i=0,s=0,E=0,T=0;if(0===t){for(;"\0"!==_(e.subarray(T,T+1));)o+=_(e.subarray(T,T+1)),T+=1;for(o+=_(e.subarray(T,T+1)),T+=1;"\0"!==_(e.subarray(T,T+1));)a+=_(e.subarray(T,T+1)),T+=1;a+=_(e.subarray(T,T+1)),T+=1,n=l(e,12),r=l(e,16),s=l(e,20),E=l(e,24),T=28}else if(1===t){n=l(e,T+=4);var S=l(e,T+=4),u=l(e,T+=4);for(T+=4,i=Math.pow(2,32)*S+u,Number.isSafeInteger(i)||(i=Number.MAX_SAFE_INTEGER,console.warn("Presentation time exceeds safe integer limit and wrapped to max safe integer in parsing emsg box")),s=l(e,T),E=l(e,T+=4),T+=4;"\0"!==_(e.subarray(T,T+1));)o+=_(e.subarray(T,T+1)),T+=1;for(o+=_(e.subarray(T,T+1)),T+=1;"\0"!==_(e.subarray(T,T+1));)a+=_(e.subarray(T,T+1)),T+=1;a+=_(e.subarray(T,T+1)),T+=1}return{schemeIdUri:o,value:a,timeScale:n,presentationTime:i,presentationTimeDelta:r,eventDuration:s,id:E,payload:e.subarray(T,e.byteLength)}}},"./src/utils/output-filter.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"default",(function(){return a}));var a=(function(){function e(e,t){this.timelineController=void 0,this.cueRanges=[],this.trackName=void 0,this.startTime=null,this.endTime=null,this.screen=null,this.timelineController=e,this.trackName=t}var t=e.prototype;return t.dispatchCue=function(){null!==this.startTime&&(this.timelineController.addCues(this.trackName,this.startTime,this.endTime,this.screen,this.cueRanges),this.startTime=null)},t.newCue=function(e,t,o){(null===this.startTime||this.startTime>e)&&(this.startTime=e),this.endTime=t,this.screen=o,this.timelineController.createCaptionsTrack(this.trackName)},t.reset=function(){this.cueRanges=[],this.startTime=null},e})()},"./src/utils/texttrack-utils.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"sendAddTrackEvent",(function(){return n})),o.d(t,"addCueToTrack",(function(){return r})),o.d(t,"clearCurrentCues",(function(){return i})),o.d(t,"removeCuesInRange",(function(){return s})),o.d(t,"getCuesInRange",(function(){return E}));var a=o("./src/utils/logger.ts");function n(e,t){var o;try{o=new Event("addtrack")}catch(e){(o=document.createEvent("Event")).initEvent("addtrack",!1,!1)}o.track=e,t.dispatchEvent(o)}function r(e,t){var o=e.mode;if("disabled"===o&&(e.mode="hidden"),e.cues&&!e.cues.getCueById(t.id))try{if(e.addCue(t),!e.cues.getCueById(t.id))throw new Error("addCue is failed for: "+t)}catch(o){a.logger.debug("[texttrack-utils]: "+o);var n=new self.TextTrackCue(t.startTime,t.endTime,t.text);n.id=t.id,e.addCue(n)}"disabled"===o&&(e.mode=o)}function i(e){var t=e.mode;if("disabled"===t&&(e.mode="hidden"),e.cues)for(var o=e.cues.length;o--;)e.removeCue(e.cues[o]);"disabled"===t&&(e.mode=t)}function s(e,t,o,a){var n=e.mode;if("disabled"===n&&(e.mode="hidden"),e.cues&&e.cues.length>0)for(var r=E(e.cues,t,o),i=0;ie[o].endTime)return-1;for(var a=0,n=o;a<=n;){var r=Math.floor((n+a)/2);if(te[r].startTime&&a-1)for(var r=n,i=e.length;r=t&&s.endTime<=o)a.push(s);else if(s.startTime>o)return a}return a}},"./src/utils/time-ranges.ts":function(e,t,o){"use strict";o.r(t),t.default={toString:function(e){for(var t="",o=e.length,a=0;a1?t-1:0),a=1;a100)throw new Error("Position must be between 0 and 100.");N=e,this.hasBeenReset=!0}})),Object.defineProperty(s,"positionAlign",n({},E,{get:function(){return m},set:function(e){var t=a(e);if(!t)throw new SyntaxError("An invalid or illegal string was specified.");m=t,this.hasBeenReset=!0}})),Object.defineProperty(s,"size",n({},E,{get:function(){return R},set:function(e){if(e<0||e>100)throw new Error("Size must be between 0 and 100.");R=e,this.hasBeenReset=!0}})),Object.defineProperty(s,"align",n({},E,{get:function(){return p},set:function(e){var t=a(e);if(!t)throw new SyntaxError("An invalid or illegal string was specified.");p=t,this.hasBeenReset=!0}})),s.displayState=void 0}return r.prototype.getCueAsHTML=function(){return self.WebVTT.convertCueToDOMTree(self,this.text)},r})()},"./src/utils/vttparser.ts":function(e,t,o){"use strict";o.r(t),o.d(t,"parseTimeStamp",(function(){return r})),o.d(t,"fixLineBreaks",(function(){return l})),o.d(t,"VTTParser",(function(){return S}));var a=o("./src/utils/vttcue.ts"),n=(function(){function e(){}return e.prototype.decode=function(e,t){if(!e)return"";if("string"!=typeof e)throw new Error("Error - expected string data.");return decodeURIComponent(encodeURIComponent(e))},e})();function r(e){function t(e,t,o,a){return 3600*(0|e)+60*(0|t)+(0|o)+parseFloat(a||0)}var o=e.match(/^(?:(\d+):)?(\d{2}):(\d{2})(\.\d+)?/);return o?parseFloat(o[2])>59?t(o[2],o[3],0,o[4]):t(o[1],o[2],o[3],o[4]):null}var i=(function(){function e(){this.values=Object.create(null)}var t=e.prototype;return t.set=function(e,t){this.get(e)||""===t||(this.values[e]=t)},t.get=function(e,t,o){return o?this.has(e)?this.values[e]:t[o]:this.has(e)?this.values[e]:t},t.has=function(e){return e in this.values},t.alt=function(e,t,o){for(var a=0;a=0&&o<=100)return this.set(e,o),!0}return!1},e})();function s(e,t,o,a){var n=a?e.split(a):[e];for(var r in n)if("string"==typeof n[r]){var i=n[r].split(o);2===i.length&&t(i[0],i[1])}}var E=new a.default(0,0,""),_="middle"===E.align?"middle":"center";function T(e,t,o){var a=e;function n(){var t=r(e);if(null===t)throw new Error("Malformed timestamp: "+a);return e=e.replace(/^[^\sa-zA-Z-]+/,""),t}function T(){e=e.replace(/^\s+/,"")}if(T(),t.startTime=n(),T(),"--\x3e"!==e.slice(0,3))throw new Error("Malformed time stamp (time stamps must be separated by '--\x3e'): "+a);e=e.slice(3),T(),t.endTime=n(),T(),(function(e,t){var a=new i;s(e,(function(e,t){var n;switch(e){case"region":for(var r=o.length-1;r>=0;r--)if(o[r].id===t){a.set(e,o[r].region);break}break;case"vertical":a.alt(e,t,["rl","lr"]);break;case"line":n=t.split(","),a.integer(e,n[0]),a.percent(e,n[0])&&a.set("snapToLines",!1),a.alt(e,n[0],["auto"]),2===n.length&&a.alt("lineAlign",n[1],["start",_,"end"]);break;case"position":n=t.split(","),a.percent(e,n[0]),2===n.length&&a.alt("positionAlign",n[1],["start",_,"end","line-left","line-right","auto"]);break;case"size":a.percent(e,t);break;case"align":a.alt(e,t,["start",_,"end","left","right"])}}),/:/,/\s/),t.region=a.get("region",null),t.vertical=a.get("vertical","");var n=a.get("line","auto");"auto"===n&&-1===E.line&&(n=-1),t.line=n,t.lineAlign=a.get("lineAlign","start"),t.snapToLines=a.get("snapToLines",!0),t.size=a.get("size",100),t.align=a.get("align",_);var r=a.get("position","auto");"auto"===r&&50===E.position&&(r="start"===t.align||"left"===t.align?0:"end"===t.align||"right"===t.align?100:50),t.position=r})(e,t)}function l(e){return e.replace(//gi,"\n")}var S=(function(){function e(){this.state="INITIAL",this.buffer="",this.decoder=new n,this.regionList=[],this.cue=null,this.oncue=void 0,this.onparsingerror=void 0,this.onflush=void 0}var t=e.prototype;return t.parse=function(e){var t=this;function o(){var e=t.buffer,o=0;for(e=l(e);o>>0).toString()};function l(e,t,o){return T(e.toString())+T(t.toString())+T(o)}function S(e,t,o,T,S,u,d,c){var I,A=new n.VTTParser,O=Object(r.utf8ArrayToStr)(new Uint8Array(e)).trim().replace(E,"\n").split("\n"),N=[],m=Object(i.toMpegTsClockFromTimescale)(t,o),R="00:00.000",p=0,h=0,f=!0;A.oncue=function(e){var t=T[S],o=T.ccOffset,a=(p-m)/9e4;null!=t&&t.new&&(void 0!==h?o=T.ccOffset=t.start:(function(e,t,o){var a=e[t],n=e[a.prevCC];if(!n||!n.new&&a.new)return e.ccOffset=e.presentationOffset=a.start,void(a.new=!1);for(;null!==(r=n)&&void 0!==r&&r.new;){var r;e.ccOffset+=a.start-n.start,a.new=!1,n=e[(a=n).prevCC]}e.presentationOffset=o})(T,S,a)),a&&(o=a-T.presentationOffset);var n=e.endTime-e.startTime,r=Object(s.normalizePts)(9e4*(e.startTime+o-h),9e4*u)/9e4;e.startTime=Math.max(r,0),e.endTime=Math.max(r+n,0);var i=e.text.trim();e.text=decodeURIComponent(encodeURIComponent(i)),e.id||(e.id=l(e.startTime,e.endTime,i)),e.endTime>0&&N.push(e)},A.onparsingerror=function(e){I=e},A.onflush=function(){I?c(I):d(N)},O.forEach((function(e){if(f){if(_(e,"X-TIMESTAMP-MAP=")){f=!1,e.slice(16).split(",").forEach((function(e){_(e,"LOCAL:")?R=e.slice(6):_(e,"MPEGTS:")&&(p=parseInt(e.slice(7)))}));try{h=(function(e){var t=parseInt(e.slice(-3)),o=parseInt(e.slice(-6,-4)),n=parseInt(e.slice(-9,-7)),r=e.length>9?parseInt(e.substring(0,e.indexOf(":"))):0;if(!(Object(a.isFiniteNumber)(t)&&Object(a.isFiniteNumber)(o)&&Object(a.isFiniteNumber)(n)&&Object(a.isFiniteNumber)(r)))throw Error("Malformed X-TIMESTAMP-MAP: Local:"+e);return t+=1e3*o,(t+=6e4*n)+36e5*r})(R)/1e3}catch(e){I=e}return}""===e&&(f=!1)}A.parse(e+"\n")})),A.flush()}},"./src/utils/xhr-loader.ts":function(e,t,o){"use strict";o.r(t);var a=o("./src/utils/logger.ts"),n=o("./src/loader/load-stats.ts"),r=/^age:\s*[\d.]+\s*$/m,i=(function(){function e(e){this.xhrSetup=void 0,this.requestTimeout=void 0,this.retryTimeout=void 0,this.retryDelay=void 0,this.config=null,this.callbacks=null,this.context=void 0,this.loader=null,this.stats=void 0,this.xhrSetup=e?e.xhrSetup:null,this.stats=new n.LoadStats,this.retryDelay=0}var t=e.prototype;return t.destroy=function(){this.callbacks=null,this.abortInternal(),this.loader=null,this.config=null},t.abortInternal=function(){var e=this.loader;self.clearTimeout(this.requestTimeout),self.clearTimeout(this.retryTimeout),e&&(e.onreadystatechange=null,e.onprogress=null,4!==e.readyState&&(this.stats.aborted=!0,e.abort()))},t.abort=function(){var e;this.abortInternal(),null!==(e=this.callbacks)&&void 0!==e&&e.onAbort&&this.callbacks.onAbort(this.stats,this.context,this.loader)},t.load=function(e,t,o){if(this.stats.loading.start)throw new Error("Loader can only be used once.");this.stats.loading.start=self.performance.now(),this.context=e,this.config=t,this.callbacks=o,this.retryDelay=t.retryDelay,this.loadInternal()},t.loadInternal=function(){var e=this.config,t=this.context;if(e){var o=this.loader=new self.XMLHttpRequest,a=this.stats;a.loading.first=0,a.loaded=0;var n=this.xhrSetup;try{if(n)try{n(o,t.url)}catch(e){o.open("GET",t.url,!0),n(o,t.url)}o.readyState||o.open("GET",t.url,!0);var r=this.context.headers;if(r)for(var i in r)o.setRequestHeader(i,r[i])}catch(e){return void this.callbacks.onError({code:o.status,text:e.message},t,o)}t.rangeEnd&&o.setRequestHeader("Range","bytes="+t.rangeStart+"-"+(t.rangeEnd-1)),o.onreadystatechange=this.readystatechange.bind(this),o.onprogress=this.loadprogress.bind(this),o.responseType=t.responseType,self.clearTimeout(this.requestTimeout),this.requestTimeout=self.setTimeout(this.loadtimeout.bind(this),e.timeout),o.send()}},t.readystatechange=function(){var e=this.context,t=this.loader,o=this.stats;if(e&&t){var n=t.readyState,r=this.config;if(!o.aborted&&n>=2)if(self.clearTimeout(this.requestTimeout),0===o.loading.first&&(o.loading.first=Math.max(self.performance.now(),o.loading.start)),4===n){t.onreadystatechange=null,t.onprogress=null;var i=t.status;if(i>=200&&i<300){var s,E;if(o.loading.end=Math.max(self.performance.now(),o.loading.first),E="arraybuffer"===e.responseType?(s=t.response).byteLength:(s=t.responseText).length,o.loaded=o.total=E,!this.callbacks)return;var _=this.callbacks.onProgress;if(_&&_(o,e,s,t),!this.callbacks)return;var T={url:t.responseURL,data:s};this.callbacks.onSuccess(T,o,e,t)}else o.retry>=r.maxRetry||i>=400&&i<499?(a.logger.error(i+" while loading "+e.url),this.callbacks.onError({code:i,text:t.statusText},e,t)):(a.logger.warn(i+" while loading "+e.url+", retrying in "+this.retryDelay+"..."),this.abortInternal(),this.loader=null,self.clearTimeout(this.retryTimeout),this.retryTimeout=self.setTimeout(this.loadInternal.bind(this),this.retryDelay),this.retryDelay=Math.min(2*this.retryDelay,r.maxRetryDelay),o.retry++)}else self.clearTimeout(this.requestTimeout),this.requestTimeout=self.setTimeout(this.loadtimeout.bind(this),r.timeout)}},t.loadtimeout=function(){a.logger.warn("timeout while loading "+this.context.url);var e=this.callbacks;e&&(this.abortInternal(),e.onTimeout(this.stats,this.context,this.loader))},t.loadprogress=function(e){var t=this.stats;t.loaded=e.loaded,e.lengthComputable&&(t.total=e.total)},t.getCacheAge=function(){var e=null;if(this.loader&&r.test(this.loader.getAllResponseHeaders())){var t=this.loader.getResponseHeader("age");e=t?parseFloat(t):null}return e},e})();t.default=i}}).default},e.exports=t())},2047:e=>{"use strict";e.exports={abbr:"abbr",accept:"accept",acceptCharset:"accept-charset",accessKey:"accesskey",action:"action",allowFullScreen:"allowfullscreen",allowTransparency:"allowtransparency",alt:"alt",async:"async",autoComplete:"autocomplete",autoFocus:"autofocus",autoPlay:"autoplay",cellPadding:"cellpadding",cellSpacing:"cellspacing",challenge:"challenge",charset:"charset",checked:"checked",cite:"cite",class:"class",className:"class",cols:"cols",colSpan:"colspan",command:"command",content:"content",contentEditable:"contenteditable",contextMenu:"contextmenu",controls:"controls",coords:"coords",crossOrigin:"crossorigin",data:"data",dateTime:"datetime",default:"default",defer:"defer",dir:"dir",disabled:"disabled",download:"download",draggable:"draggable",dropzone:"dropzone",encType:"enctype",for:"for",form:"form",formAction:"formaction",formEncType:"formenctype",formMethod:"formmethod",formNoValidate:"formnovalidate",formTarget:"formtarget",frameBorder:"frameBorder",headers:"headers",height:"height",hidden:"hidden",high:"high",href:"href",hrefLang:"hreflang",htmlFor:"for",httpEquiv:"http-equiv",icon:"icon",id:"id",inputMode:"inputmode",isMap:"ismap",itemId:"itemid",itemProp:"itemprop",itemRef:"itemref",itemScope:"itemscope",itemType:"itemtype",kind:"kind",label:"label",lang:"lang",list:"list",loop:"loop",manifest:"manifest",max:"max",maxLength:"maxlength",media:"media",mediaGroup:"mediagroup",method:"method",min:"min",minLength:"minlength",multiple:"multiple",muted:"muted",name:"name",noValidate:"novalidate",open:"open",optimum:"optimum",pattern:"pattern",ping:"ping",placeholder:"placeholder",poster:"poster",preload:"preload",radioGroup:"radiogroup",readOnly:"readonly",rel:"rel",required:"required",role:"role",rows:"rows",rowSpan:"rowspan",sandbox:"sandbox",scope:"scope",scoped:"scoped",scrolling:"scrolling",seamless:"seamless",selected:"selected",shape:"shape",size:"size",sizes:"sizes",sortable:"sortable",span:"span",spellCheck:"spellcheck",src:"src",srcDoc:"srcdoc",srcSet:"srcset",start:"start",step:"step",style:"style",tabIndex:"tabindex",target:"target",title:"title",translate:"translate",type:"type",typeMustMatch:"typemustmatch",useMap:"usemap",value:"value",width:"width",wmode:"wmode",wrap:"wrap"}},1613:(e,t,o)=>{"use strict";o.r(t),o.d(t,{default:()=>S});var a=o(1739),n=o.n(a),r=/\s([^'"/\s><]+?)[\s/>]|([^\s=]+)=\s?(".*?"|'.*?')/g;function i(e){var t={type:"tag",name:"",voidElement:!1,attrs:{},children:[]},o=e.match(/<\/?([^\s]+?)[/\s>]/);if(o&&(t.name=o[1],(n()[o[1]]||"/"===e.charAt(e.length-2))&&(t.voidElement=!0),t.name.startsWith("!--"))){var a=e.indexOf("--\x3e");return{type:"comment",comment:-1!==a?e.slice(4,a):""}}for(var i=new RegExp(r),s=null;null!==(s=i.exec(e));)if(s[0].trim())if(s[1]){var E=s[1].trim(),_=[E,""];E.indexOf("=")>-1&&(_=E.split("=")),t.attrs[_[0]]=_[1],i.lastIndex--}else s[2]&&(t.attrs[s[2]]=s[3].trim().substring(1,s[3].length-1));return t}var s=/<[a-zA-Z0-9\-\!\/](?:"[^"]*"|'[^']*'|[^'">])*>/g,E=/^\s*$/,_=Object.create(null);function T(e,t){switch(t.type){case"text":return e+t.content;case"tag":return e+="<"+t.name+(t.attrs?(function(e){var t=[];for(var o in e)t.push(o+'="'+e[o]+'"');return t.length?" "+t.join(" "):""})(t.attrs):"")+(t.voidElement?"/>":">"),t.voidElement?e:e+t.children.reduce(T,"")+"";case"comment":return e+"\x3c!--"+t.comment+"--\x3e"}}var l={parse:function(e,t){t||(t={}),t.components||(t.components=_);var o,a=[],n=[],r=-1,T=!1;if(0!==e.indexOf("<")){var l=e.indexOf("<");a.push({type:"text",content:-1===l?e:e.substring(0,l)})}return e.replace(s,(function(s,_){if(T){if(s!=="")return;T=!1}var l,S="/"!==s.charAt(1),u=s.startsWith("\x3c!--"),d=_+s.length,c=e.charAt(d);if(u){var I=i(s);return r<0?(a.push(I),a):((l=n[r]).children.push(I),a)}if(S&&(r++,"tag"===(o=i(s)).type&&t.components[o.name]&&(o.type="component",T=!0),o.voidElement||T||!c||"<"===c||o.children.push({type:"text",content:e.slice(d,e.indexOf("<",d))}),0===r&&a.push(o),(l=n[r-1])&&l.children.push(o),n[r]=o),(!S||o.voidElement)&&(r>-1&&(o.voidElement||o.name===s.slice(2,-1))&&(r--,o=-1===r?a:n[r]),!T&&"<"!==c&&c)){l=-1===r?a:n[r].children;var A=e.indexOf("<",d),O=e.slice(d,-1===A?void 0:A);E.test(O)&&(O=" "),(A>-1&&r+l.length>=0||" "!==O)&&l.push({type:"text",content:O})}})),a},stringify:function(e){return e.reduce((function(e,t){return e+T("",t)}),"")}};const S=l},6073:(e,t,o)=>{"use strict";var a=o(7021),n=o(949),r=o(4813),i=o(5627),s=o(6433),E=o(8542),_=o(2411),T=o(2401),l=o(9394);function S(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var u=S(a),d=S(n),c=S(r),I=S(i),A=S(s),O=S(E),N=S(_),m=S(T),R=S(l);function p(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function h(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:{};d.default(this,e),this.init(t,o)}return c.default(e,[{key:"init",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.prefix=t.prefix||"i18next:",this.logger=e||f,this.options=t,this.debug=t.debug}},{key:"setDebug",value:function(e){this.debug=e}},{key:"log",value:function(){for(var e=arguments.length,t=new Array(e),o=0;o1?t-1:0),a=1;a-1?e.replace(/###/g,"."):e}function n(){return!e||"string"==typeof e}for(var r="string"!=typeof t?[].concat(t):t.split(".");r.length>1;){if(n())return{};var i=a(r.shift());!e[i]&&o&&(e[i]=new o),e=Object.prototype.hasOwnProperty.call(e,i)?e[i]:{}}return n()?{}:{obj:e,k:a(r.shift())}}function P(e,t,o){var a=y(e,t,Object);a.obj[a.k]=o}function B(e,t){var o=y(e,t),a=o.obj,n=o.k;if(a)return a[n]}function b(e,t,o){var a=B(e,o);return void 0!==a?a:B(t,o)}function M(e,t,o){for(var a in t)"__proto__"!==a&&"constructor"!==a&&(a in e?"string"==typeof e[a]||e[a]instanceof String||"string"==typeof t[a]||t[a]instanceof String?o&&(e[a]=t[a]):M(e[a],t[a],o):e[a]=t[a]);return e}function U(e){return e.replace(/[\-\[\]\/\{\}\(\)\*\+\?\.\\\^\$\|]/g,"\\$&")}var W={"&":"&","<":"<",">":">",'"':""","'":"'","/":"/"};function G(e){return"string"==typeof e?e.replace(/[&<>"'\/]/g,(function(e){return W[e]})):e}var F="undefined"!=typeof window&&window.navigator&&void 0===window.navigator.userAgentData&&window.navigator.userAgent&&window.navigator.userAgent.indexOf("MSIE")>-1,k=[" ",",","?","!",";"];function w(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function H(e){for(var t=1;t2&&void 0!==arguments[2]?arguments[2]:".";if(e){if(e[t])return e[t];for(var a=t.split(o),n=e,r=0;rr+i;)i++,E=n[s=a.slice(r,r+i).join(o)];if(void 0===E)return;if(null===E)return null;if(t.endsWith(s)){if("string"==typeof E)return E;if(s&&"string"==typeof E[s])return E[s]}var _=a.slice(r+i).join(o);return _?Y(E,_,o):void 0}n=n[a[r]]}return n}}var z=(function(e){A.default(o,e);var t=V(o);function o(e){var a,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{ns:["translation"],defaultNS:"translation"};return d.default(this,o),a=t.call(this),F&&C.call(I.default(a)),a.data=e||{},a.options=n,void 0===a.options.keySeparator&&(a.options.keySeparator="."),void 0===a.options.ignoreJSONStructure&&(a.options.ignoreJSONStructure=!0),a}return c.default(o,[{key:"addNamespaces",value:function(e){this.options.ns.indexOf(e)<0&&this.options.ns.push(e)}},{key:"removeNamespaces",value:function(e){var t=this.options.ns.indexOf(e);t>-1&&this.options.ns.splice(t,1)}},{key:"getResource",value:function(e,t,o){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},n=void 0!==a.keySeparator?a.keySeparator:this.options.keySeparator,r=void 0!==a.ignoreJSONStructure?a.ignoreJSONStructure:this.options.ignoreJSONStructure,i=[e,t];o&&"string"!=typeof o&&(i=i.concat(o)),o&&"string"==typeof o&&(i=i.concat(n?o.split(n):o)),e.indexOf(".")>-1&&(i=e.split("."));var s=B(this.data,i);return s||!r||"string"!=typeof o?s:Y(this.data&&this.data[e]&&this.data[e][t],o,n)}},{key:"addResource",value:function(e,t,o,a){var n=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{silent:!1},r=this.options.keySeparator;void 0===r&&(r=".");var i=[e,t];o&&(i=i.concat(r?o.split(r):o)),e.indexOf(".")>-1&&(a=t,t=(i=e.split("."))[1]),this.addNamespaces(t),P(this.data,i,a),n.silent||this.emit("added",e,t,o,a)}},{key:"addResources",value:function(e,t,o){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{silent:!1};for(var n in o)"string"!=typeof o[n]&&"[object Array]"!==Object.prototype.toString.apply(o[n])||this.addResource(e,t,n,o[n],{silent:!0});a.silent||this.emit("added",e,t,o)}},{key:"addResourceBundle",value:function(e,t,o,a,n){var r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{silent:!1},i=[e,t];e.indexOf(".")>-1&&(a=o,o=t,t=(i=e.split("."))[1]),this.addNamespaces(t);var s=B(this.data,i)||{};a?M(s,o,n):s=H(H({},s),o),P(this.data,i,s),r.silent||this.emit("added",e,t,o)}},{key:"removeResourceBundle",value:function(e,t){this.hasResourceBundle(e,t)&&delete this.data[e][t],this.removeNamespaces(t),this.emit("removed",e,t)}},{key:"hasResourceBundle",value:function(e,t){return void 0!==this.getResource(e,t)}},{key:"getResourceBundle",value:function(e,t){return t||(t=this.options.defaultNS),"v1"===this.options.compatibilityAPI?H(H({},{}),this.getResource(e,t)):this.getResource(e,t)}},{key:"getDataByLanguage",value:function(e){return this.data[e]}},{key:"hasLanguageSomeTranslations",value:function(e){var t=this.getDataByLanguage(e);return!!(t&&Object.keys(t)||[]).find((function(e){return t[e]&&Object.keys(t[e]).length>0}))}},{key:"toJSON",value:function(){return this.data}}]),o})(C),x={processors:{},addPostProcessor:function(e){this.processors[e.name]=e},handle:function(e,t,o,a,n){var r=this;return e.forEach((function(e){r.processors[e]&&(t=r.processors[e].process(t,o,a,n))})),t}};function K(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function j(e){for(var t=1;t1&&void 0!==arguments[1]?arguments[1]:{};return d.default(this,o),a=t.call(this),F&&C.call(I.default(a)),v(["resourceStore","languageUtils","pluralResolver","interpolator","backendConnector","i18nFormat","utils"],e,I.default(a)),a.options=n,void 0===a.options.keySeparator&&(a.options.keySeparator="."),a.logger=L.create("translator"),a}return c.default(o,[{key:"changeLanguage",value:function(e){e&&(this.language=e)}},{key:"exists",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{interpolation:{}};if(null==e)return!1;var o=this.resolve(e,t);return o&&void 0!==o.res}},{key:"extractFromKey",value:function(e,t){var o=void 0!==t.nsSeparator?t.nsSeparator:this.options.nsSeparator;void 0===o&&(o=":");var a=void 0!==t.keySeparator?t.keySeparator:this.options.keySeparator,n=t.ns||this.options.defaultNS||[],r=o&&e.indexOf(o)>-1,i=!(this.options.userDefinedKeySeparator||t.keySeparator||this.options.userDefinedNsSeparator||t.nsSeparator||(function(e,t,o){t=t||"",o=o||"";var a=k.filter((function(e){return t.indexOf(e)<0&&o.indexOf(e)<0}));if(0===a.length)return!0;var n=new RegExp("(".concat(a.map((function(e){return"?"===e?"\\?":e})).join("|"),")")),r=!n.test(e);if(!r){var i=e.indexOf(o);i>0&&!n.test(e.substring(0,i))&&(r=!0)}return r})(e,o,a));if(r&&!i){var s=e.match(this.interpolator.nestingRegexp);if(s&&s.length>0)return{key:e,namespaces:n};var E=e.split(o);(o!==a||o===a&&this.options.ns.indexOf(E[0])>-1)&&(n=E.shift()),e=E.join(a)}return"string"==typeof n&&(n=[n]),{key:e,namespaces:n}}},{key:"translate",value:function(e,t,a){var n=this;if("object"!==u.default(t)&&this.options.overloadTranslationOptionHandler&&(t=this.options.overloadTranslationOptionHandler(arguments)),t||(t={}),null==e)return"";Array.isArray(e)||(e=[String(e)]);var r=void 0!==t.returnDetails?t.returnDetails:this.options.returnDetails,i=void 0!==t.keySeparator?t.keySeparator:this.options.keySeparator,s=this.extractFromKey(e[e.length-1],t),E=s.key,_=s.namespaces,T=_[_.length-1],l=t.lng||this.language,S=t.appendNamespaceToCIMode||this.options.appendNamespaceToCIMode;if(l&&"cimode"===l.toLowerCase()){if(S){var d=t.nsSeparator||this.options.nsSeparator;return r?(c.res="".concat(T).concat(d).concat(E),c):"".concat(T).concat(d).concat(E)}return r?(c.res=E,c):E}var c=this.resolve(e,t),I=c&&c.res,A=c&&c.usedKey||E,O=c&&c.exactUsedKey||E,N=Object.prototype.toString.apply(I),m=["[object Number]","[object Function]","[object RegExp]"],R=void 0!==t.joinArrays?t.joinArrays:this.options.joinArrays,p=!this.i18nFormat||this.i18nFormat.handleAsObject,h="string"!=typeof I&&"boolean"!=typeof I&&"number"!=typeof I;if(p&&I&&h&&m.indexOf(N)<0&&("string"!=typeof R||"[object Array]"!==N)){if(!t.returnObjects&&!this.options.returnObjects){this.options.returnedObjectHandler||this.logger.warn("accessing an object - but returnObjects options is not enabled!");var f=this.options.returnedObjectHandler?this.options.returnedObjectHandler(A,I,j(j({},t),{},{ns:_})):"key '".concat(E," (").concat(this.language,")' returned an object instead of string.");return r?(c.res=f,c):f}if(i){var L="[object Array]"===N,C=L?[]:{},D=L?O:A;for(var g in I)if(Object.prototype.hasOwnProperty.call(I,g)){var v="".concat(D).concat(i).concat(g);C[g]=this.translate(v,j(j({},t),{joinArrays:!1,ns:_})),C[g]===v&&(C[g]=I[g])}I=C}}else if(p&&"string"==typeof R&&"[object Array]"===N)(I=I.join(R))&&(I=this.extendTranslation(I,e,t,a));else{var y=!1,P=!1,B=void 0!==t.count&&"string"!=typeof t.count,b=o.hasDefaultValue(t),M=B?this.pluralResolver.getSuffix(l,t.count,t):"",U=t["defaultValue".concat(M)]||t.defaultValue;!this.isValidLookup(I)&&b&&(y=!0,I=U),this.isValidLookup(I)||(P=!0,I=E);var W=t.missingKeyNoValueFallbackToKey||this.options.missingKeyNoValueFallbackToKey,G=W&&P?void 0:I,F=b&&U!==I&&this.options.updateMissing;if(P||y||F){if(this.logger.log(F?"updateKey":"missingKey",l,T,E,F?U:I),i){var k=this.resolve(E,j(j({},t),{},{keySeparator:!1}));k&&k.res&&this.logger.warn("Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.")}var w=[],H=this.languageUtils.getFallbackCodes(this.options.fallbackLng,t.lng||this.language);if("fallback"===this.options.saveMissingTo&&H&&H[0])for(var V=0;V1&&void 0!==arguments[1]?arguments[1]:{};return"string"==typeof e&&(e=[e]),e.forEach((function(e){if(!i.isValidLookup(t)){var E=i.extractFromKey(e,s),_=E.key;o=_;var T=E.namespaces;i.options.fallbackNS&&(T=T.concat(i.options.fallbackNS));var l=void 0!==s.count&&"string"!=typeof s.count,S=l&&!s.ordinal&&0===s.count&&i.pluralResolver.shouldUseIntlApi(),u=void 0!==s.context&&("string"==typeof s.context||"number"==typeof s.context)&&""!==s.context,d=s.lngs?s.lngs:i.languageUtils.toResolveHierarchy(s.lng||i.language,s.fallbackLng);T.forEach((function(e){i.isValidLookup(t)||(r=e,!X["".concat(d[0],"-").concat(e)]&&i.utils&&i.utils.hasLoadedNamespace&&!i.utils.hasLoadedNamespace(r)&&(X["".concat(d[0],"-").concat(e)]=!0,i.logger.warn('key "'.concat(o,'" for languages "').concat(d.join(", "),'" won\'t get resolved as namespace "').concat(r,'" was not yet loaded'),"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!")),d.forEach((function(o){if(!i.isValidLookup(t)){n=o;var r,E=[_];if(i.i18nFormat&&i.i18nFormat.addLookupKeys)i.i18nFormat.addLookupKeys(E,_,o,e,s);else{var T;l&&(T=i.pluralResolver.getSuffix(o,s.count,s));var d="".concat(i.options.pluralSeparator,"zero");if(l&&(E.push(_+T),S&&E.push(_+d)),u){var c="".concat(_).concat(i.options.contextSeparator).concat(s.context);E.push(c),l&&(E.push(c+T),S&&E.push(c+d))}}for(;r=E.pop();)i.isValidLookup(t)||(a=r,t=i.getResource(o,e,r,s))}})))}))}})),{res:t,usedKey:o,exactUsedKey:a,usedLng:n,usedNS:r}}},{key:"isValidLookup",value:function(e){return!(void 0===e||!this.options.returnNull&&null===e||!this.options.returnEmptyString&&""===e)}},{key:"getResource",value:function(e,t,o){var a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};return this.i18nFormat&&this.i18nFormat.getResource?this.i18nFormat.getResource(e,t,o,a):this.resourceStore.getResource(e,t,o,a)}}],[{key:"hasDefaultValue",value:function(e){var t="defaultValue";for(var o in e)if(Object.prototype.hasOwnProperty.call(e,o)&&t===o.substring(0,t.length)&&void 0!==e[o])return!0;return!1}}]),o})(C);function q(e){return e.charAt(0).toUpperCase()+e.slice(1)}var J=(function(){function e(t){d.default(this,e),this.options=t,this.supportedLngs=this.options.supportedLngs||!1,this.logger=L.create("languageUtils")}return c.default(e,[{key:"getScriptPartFromCode",value:function(e){if(!e||e.indexOf("-")<0)return null;var t=e.split("-");return 2===t.length?null:(t.pop(),"x"===t[t.length-1].toLowerCase()?null:this.formatLanguageCode(t.join("-")))}},{key:"getLanguagePartFromCode",value:function(e){if(!e||e.indexOf("-")<0)return e;var t=e.split("-");return this.formatLanguageCode(t[0])}},{key:"formatLanguageCode",value:function(e){if("string"==typeof e&&e.indexOf("-")>-1){var t=["hans","hant","latn","cyrl","cans","mong","arab"],o=e.split("-");return this.options.lowerCaseLng?o=o.map((function(e){return e.toLowerCase()})):2===o.length?(o[0]=o[0].toLowerCase(),o[1]=o[1].toUpperCase(),t.indexOf(o[1].toLowerCase())>-1&&(o[1]=q(o[1].toLowerCase()))):3===o.length&&(o[0]=o[0].toLowerCase(),2===o[1].length&&(o[1]=o[1].toUpperCase()),"sgn"!==o[0]&&2===o[2].length&&(o[2]=o[2].toUpperCase()),t.indexOf(o[1].toLowerCase())>-1&&(o[1]=q(o[1].toLowerCase())),t.indexOf(o[2].toLowerCase())>-1&&(o[2]=q(o[2].toLowerCase()))),o.join("-")}return this.options.cleanCode||this.options.lowerCaseLng?e.toLowerCase():e}},{key:"isSupportedCode",value:function(e){return("languageOnly"===this.options.load||this.options.nonExplicitSupportedLngs)&&(e=this.getLanguagePartFromCode(e)),!this.supportedLngs||!this.supportedLngs.length||this.supportedLngs.indexOf(e)>-1}},{key:"getBestMatchFromCodes",value:function(e){var t,o=this;return e?(e.forEach((function(e){if(!t){var a=o.formatLanguageCode(e);o.options.supportedLngs&&!o.isSupportedCode(a)||(t=a)}})),!t&&this.options.supportedLngs&&e.forEach((function(e){if(!t){var a=o.getLanguagePartFromCode(e);if(o.isSupportedCode(a))return t=a;t=o.options.supportedLngs.find((function(e){if(0===e.indexOf(a))return e}))}})),t||(t=this.getFallbackCodes(this.options.fallbackLng)[0]),t):null}},{key:"getFallbackCodes",value:function(e,t){if(!e)return[];if("function"==typeof e&&(e=e(t)),"string"==typeof e&&(e=[e]),"[object Array]"===Object.prototype.toString.apply(e))return e;if(!t)return e.default||[];var o=e[t];return o||(o=e[this.getScriptPartFromCode(t)]),o||(o=e[this.formatLanguageCode(t)]),o||(o=e[this.getLanguagePartFromCode(t)]),o||(o=e.default),o||[]}},{key:"toResolveHierarchy",value:function(e,t){var o=this,a=this.getFallbackCodes(t||this.options.fallbackLng||[],e),n=[],r=function(e){e&&(o.isSupportedCode(e)?n.push(e):o.logger.warn("rejecting language code not found in supportedLngs: ".concat(e)))};return"string"==typeof e&&e.indexOf("-")>-1?("languageOnly"!==this.options.load&&r(this.formatLanguageCode(e)),"languageOnly"!==this.options.load&&"currentOnly"!==this.options.load&&r(this.getScriptPartFromCode(e)),"currentOnly"!==this.options.load&&r(this.getLanguagePartFromCode(e))):"string"==typeof e&&r(this.formatLanguageCode(e)),a.forEach((function(e){n.indexOf(e)<0&&r(o.formatLanguageCode(e))})),n}}]),e})(),Z=[{lngs:["ach","ak","am","arn","br","fil","gun","ln","mfe","mg","mi","oc","pt","pt-BR","tg","tl","ti","tr","uz","wa"],nr:[1,2],fc:1},{lngs:["af","an","ast","az","bg","bn","ca","da","de","dev","el","en","eo","es","et","eu","fi","fo","fur","fy","gl","gu","ha","hi","hu","hy","ia","it","kk","kn","ku","lb","mai","ml","mn","mr","nah","nap","nb","ne","nl","nn","no","nso","pa","pap","pms","ps","pt-PT","rm","sco","se","si","so","son","sq","sv","sw","ta","te","tk","ur","yo"],nr:[1,2],fc:2},{lngs:["ay","bo","cgg","fa","ht","id","ja","jbo","ka","km","ko","ky","lo","ms","sah","su","th","tt","ug","vi","wo","zh"],nr:[1],fc:3},{lngs:["be","bs","cnr","dz","hr","ru","sr","uk"],nr:[1,2,5],fc:4},{lngs:["ar"],nr:[0,1,2,3,11,100],fc:5},{lngs:["cs","sk"],nr:[1,2,5],fc:6},{lngs:["csb","pl"],nr:[1,2,5],fc:7},{lngs:["cy"],nr:[1,2,3,8],fc:8},{lngs:["fr"],nr:[1,2],fc:9},{lngs:["ga"],nr:[1,2,3,7,11],fc:10},{lngs:["gd"],nr:[1,2,3,20],fc:11},{lngs:["is"],nr:[1,2],fc:12},{lngs:["jv"],nr:[0,1],fc:13},{lngs:["kw"],nr:[1,2,3,4],fc:14},{lngs:["lt"],nr:[1,2,10],fc:15},{lngs:["lv"],nr:[1,2,0],fc:16},{lngs:["mk"],nr:[1,2],fc:17},{lngs:["mnk"],nr:[0,1,2],fc:18},{lngs:["mt"],nr:[1,2,11,20],fc:19},{lngs:["or"],nr:[2,1],fc:2},{lngs:["ro"],nr:[1,2,20],fc:20},{lngs:["sl"],nr:[5,1,2,3],fc:21},{lngs:["he","iw"],nr:[1,2,20,21],fc:22}],ee={1:function(e){return Number(e>1)},2:function(e){return Number(1!=e)},3:function(e){return 0},4:function(e){return Number(e%10==1&&e%100!=11?0:e%10>=2&&e%10<=4&&(e%100<10||e%100>=20)?1:2)},5:function(e){return Number(0==e?0:1==e?1:2==e?2:e%100>=3&&e%100<=10?3:e%100>=11?4:5)},6:function(e){return Number(1==e?0:e>=2&&e<=4?1:2)},7:function(e){return Number(1==e?0:e%10>=2&&e%10<=4&&(e%100<10||e%100>=20)?1:2)},8:function(e){return Number(1==e?0:2==e?1:8!=e&&11!=e?2:3)},9:function(e){return Number(e>=2)},10:function(e){return Number(1==e?0:2==e?1:e<7?2:e<11?3:4)},11:function(e){return Number(1==e||11==e?0:2==e||12==e?1:e>2&&e<20?2:3)},12:function(e){return Number(e%10!=1||e%100==11)},13:function(e){return Number(0!==e)},14:function(e){return Number(1==e?0:2==e?1:3==e?2:3)},15:function(e){return Number(e%10==1&&e%100!=11?0:e%10>=2&&(e%100<10||e%100>=20)?1:2)},16:function(e){return Number(e%10==1&&e%100!=11?0:0!==e?1:2)},17:function(e){return Number(1==e||e%10==1&&e%100!=11?0:1)},18:function(e){return Number(0==e?0:1==e?1:2)},19:function(e){return Number(1==e?0:0==e||e%100>1&&e%100<11?1:e%100>10&&e%100<20?2:3)},20:function(e){return Number(1==e?0:0==e||e%100>0&&e%100<20?1:2)},21:function(e){return Number(e%100==1?1:e%100==2?2:e%100==3||e%100==4?3:0)},22:function(e){return Number(1==e?0:2==e?1:(e<0||e>10)&&e%10==0?2:3)}},te=["v1","v2","v3"],oe={zero:0,one:1,two:2,few:3,many:4,other:5};function ae(){var e={};return Z.forEach((function(t){t.lngs.forEach((function(o){e[o]={numbers:t.nr,plurals:ee[t.fc]}}))})),e}var ne=(function(){function e(t){var o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};d.default(this,e),this.languageUtils=t,this.options=o,this.logger=L.create("pluralResolver"),this.options.compatibilityJSON&&"v4"!==this.options.compatibilityJSON||"undefined"!=typeof Intl&&Intl.PluralRules||(this.options.compatibilityJSON="v3",this.logger.error("Your environment seems not to be Intl API compatible, use an Intl.PluralRules polyfill. Will fallback to the compatibilityJSON v3 format handling.")),this.rules=ae()}return c.default(e,[{key:"addRule",value:function(e,t){this.rules[e]=t}},{key:"getRule",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(this.shouldUseIntlApi())try{return new Intl.PluralRules(e,{type:t.ordinal?"ordinal":"cardinal"})}catch(e){return}return this.rules[e]||this.rules[this.languageUtils.getLanguagePartFromCode(e)]}},{key:"needsPlural",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},o=this.getRule(e,t);return this.shouldUseIntlApi()?o&&o.resolvedOptions().pluralCategories.length>1:o&&o.numbers.length>1}},{key:"getPluralFormsOfKey",value:function(e,t){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};return this.getSuffixes(e,o).map((function(e){return"".concat(t).concat(e)}))}},{key:"getSuffixes",value:function(e){var t=this,o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},a=this.getRule(e,o);return a?this.shouldUseIntlApi()?a.resolvedOptions().pluralCategories.sort((function(e,t){return oe[e]-oe[t]})).map((function(e){return"".concat(t.options.prepend).concat(e)})):a.numbers.map((function(a){return t.getSuffix(e,a,o)})):[]}},{key:"getSuffix",value:function(e,t){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},a=this.getRule(e,o);return a?this.shouldUseIntlApi()?"".concat(this.options.prepend).concat(a.select(t)):this.getSuffixRetroCompatible(a,t):(this.logger.warn("no plural rule found for: ".concat(e)),"")}},{key:"getSuffixRetroCompatible",value:function(e,t){var o=this,a=e.noAbs?e.plurals(t):e.plurals(Math.abs(t)),n=e.numbers[a];this.options.simplifyPluralSuffix&&2===e.numbers.length&&1===e.numbers[0]&&(2===n?n="plural":1===n&&(n=""));var r=function(){return o.options.prepend&&n.toString()?o.options.prepend+n.toString():n.toString()};return"v1"===this.options.compatibilityJSON?1===n?"":"number"==typeof n?"_plural_".concat(n.toString()):r():"v2"===this.options.compatibilityJSON||this.options.simplifyPluralSuffix&&2===e.numbers.length&&1===e.numbers[0]?r():this.options.prepend&&a.toString()?this.options.prepend+a.toString():a.toString()}},{key:"shouldUseIntlApi",value:function(){return!te.includes(this.options.compatibilityJSON)}}]),e})();function re(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function ie(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:{};d.default(this,e),this.logger=L.create("interpolator"),this.options=t,this.format=t.interpolation&&t.interpolation.format||function(e){return e},this.init(t)}return c.default(e,[{key:"init",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};e.interpolation||(e.interpolation={escapeValue:!0});var t=e.interpolation;this.escape=void 0!==t.escape?t.escape:G,this.escapeValue=void 0===t.escapeValue||t.escapeValue,this.useRawValueToEscape=void 0!==t.useRawValueToEscape&&t.useRawValueToEscape,this.prefix=t.prefix?U(t.prefix):t.prefixEscaped||"{{",this.suffix=t.suffix?U(t.suffix):t.suffixEscaped||"}}",this.formatSeparator=t.formatSeparator?t.formatSeparator:t.formatSeparator||",",this.unescapePrefix=t.unescapeSuffix?"":t.unescapePrefix||"-",this.unescapeSuffix=this.unescapePrefix?"":t.unescapeSuffix||"",this.nestingPrefix=t.nestingPrefix?U(t.nestingPrefix):t.nestingPrefixEscaped||U("$t("),this.nestingSuffix=t.nestingSuffix?U(t.nestingSuffix):t.nestingSuffixEscaped||U(")"),this.nestingOptionsSeparator=t.nestingOptionsSeparator?t.nestingOptionsSeparator:t.nestingOptionsSeparator||",",this.maxReplaces=t.maxReplaces?t.maxReplaces:1e3,this.alwaysFormat=void 0!==t.alwaysFormat&&t.alwaysFormat,this.resetRegExp()}},{key:"reset",value:function(){this.options&&this.init(this.options)}},{key:"resetRegExp",value:function(){var e="".concat(this.prefix,"(.+?)").concat(this.suffix);this.regexp=new RegExp(e,"g");var t="".concat(this.prefix).concat(this.unescapePrefix,"(.+?)").concat(this.unescapeSuffix).concat(this.suffix);this.regexpUnescape=new RegExp(t,"g");var o="".concat(this.nestingPrefix,"(.+?)").concat(this.nestingSuffix);this.nestingRegexp=new RegExp(o,"g")}},{key:"interpolate",value:function(e,t,o,a){var n,r,i,s=this,E=this.options&&this.options.interpolation&&this.options.interpolation.defaultVariables||{};function _(e){return e.replace(/\$/g,"$$$$")}var T=function(e){if(e.indexOf(s.formatSeparator)<0){var n=b(t,E,e);return s.alwaysFormat?s.format(n,void 0,o,ie(ie(ie({},a),t),{},{interpolationkey:e})):n}var r=e.split(s.formatSeparator),i=r.shift().trim(),_=r.join(s.formatSeparator).trim();return s.format(b(t,E,i),_,o,ie(ie(ie({},a),t),{},{interpolationkey:i}))};this.resetRegExp();var l=a&&a.missingInterpolationHandler||this.options.missingInterpolationHandler,S=a&&a.interpolation&&void 0!==a.interpolation.skipOnVariables?a.interpolation.skipOnVariables:this.options.interpolation.skipOnVariables;return[{regex:this.regexpUnescape,safeValue:function(e){return _(e)}},{regex:this.regexp,safeValue:function(e){return s.escapeValue?_(s.escape(e)):_(e)}}].forEach((function(t){for(i=0;n=t.regex.exec(e);){var o=n[1].trim();if(void 0===(r=T(o)))if("function"==typeof l){var E=l(e,n,a);r="string"==typeof E?E:""}else if(a&&a.hasOwnProperty(o))r="";else{if(S){r=n[0];continue}s.logger.warn("missed to pass in variable ".concat(o," for interpolating ").concat(e)),r=""}else"string"==typeof r||s.useRawValueToEscape||(r=g(r));var _=t.safeValue(r);if(e=e.replace(n[0],_),S?(t.regex.lastIndex+=r.length,t.regex.lastIndex-=n[0].length):t.regex.lastIndex=0,++i>=s.maxReplaces)break}})),e}},{key:"nest",value:function(e,t){var o,a,n,r=this,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};function s(e,t){var o=this.nestingOptionsSeparator;if(e.indexOf(o)<0)return e;var a=e.split(new RegExp("".concat(o,"[ ]*{"))),r="{".concat(a[1]);e=a[0];var i=(r=this.interpolate(r,n)).match(/'/g),s=r.match(/"/g);(i&&i.length%2==0&&!s||s.length%2!=0)&&(r=r.replace(/'/g,'"'));try{n=JSON.parse(r),t&&(n=ie(ie({},t),n))}catch(t){return this.logger.warn("failed parsing options string in nesting for key ".concat(e),t),"".concat(e).concat(o).concat(r)}return delete n.defaultValue,e}for(;o=this.nestingRegexp.exec(e);){var E=[];(n=ie({},i)).applyPostProcessor=!1,delete n.defaultValue;var _=!1;if(-1!==o[0].indexOf(this.formatSeparator)&&!/{.*}/.test(o[1])){var T=o[1].split(this.formatSeparator).map((function(e){return e.trim()}));o[1]=T.shift(),E=T,_=!0}if((a=t(s.call(this,o[1].trim(),n),n))&&o[0]===e&&"string"!=typeof a)return a;"string"!=typeof a&&(a=g(a)),a||(this.logger.warn("missed to resolve ".concat(o[1]," for nesting ").concat(e)),a=""),_&&(a=E.reduce((function(e,t){return r.format(e,t,i.lng,ie(ie({},i),{},{interpolationkey:o[1].trim()}))}),a.trim())),e=e.replace(o[0],a),this.regexp.lastIndex=0}return e}}]),e})();function Ee(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function _e(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:{};d.default(this,e),this.logger=L.create("formatter"),this.options=t,this.formats={number:Te((function(e,t){var o=new Intl.NumberFormat(e,t);return function(e){return o.format(e)}})),currency:Te((function(e,t){var o=new Intl.NumberFormat(e,_e(_e({},t),{},{style:"currency"}));return function(e){return o.format(e)}})),datetime:Te((function(e,t){var o=new Intl.DateTimeFormat(e,_e({},t));return function(e){return o.format(e)}})),relativetime:Te((function(e,t){var o=new Intl.RelativeTimeFormat(e,_e({},t));return function(e){return o.format(e,t.range||"day")}})),list:Te((function(e,t){var o=new Intl.ListFormat(e,_e({},t));return function(e){return o.format(e)}}))},this.init(t)}return c.default(e,[{key:"init",value:function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{interpolation:{}},o=t.interpolation;this.formatSeparator=o.formatSeparator?o.formatSeparator:o.formatSeparator||","}},{key:"add",value:function(e,t){this.formats[e.toLowerCase().trim()]=t}},{key:"addCached",value:function(e,t){this.formats[e.toLowerCase().trim()]=Te(t)}},{key:"format",value:function(e,t,o,a){var n=this;return t.split(this.formatSeparator).reduce((function(e,t){var r=(function(e){var t=e.toLowerCase().trim(),o={};if(e.indexOf("(")>-1){var a=e.split("(");t=a[0].toLowerCase().trim();var n=a[1].substring(0,a[1].length-1);"currency"===t&&n.indexOf(":")<0?o.currency||(o.currency=n.trim()):"relativetime"===t&&n.indexOf(":")<0?o.range||(o.range=n.trim()):n.split(";").forEach((function(e){if(e){var t=e.split(":"),a=R.default(t),n=a[0],r=a.slice(1).join(":").trim().replace(/^'+|'+$/g,"");o[n.trim()]||(o[n.trim()]=r),"false"===r&&(o[n.trim()]=!1),"true"===r&&(o[n.trim()]=!0),isNaN(r)||(o[n.trim()]=parseInt(r,10))}}))}return{formatName:t,formatOptions:o}})(t),i=r.formatName,s=r.formatOptions;if(n.formats[i]){var E=e;try{var _=a&&a.formatParams&&a.formatParams[a.interpolationkey]||{},T=_.locale||_.lng||a.locale||a.lng||o;E=n.formats[i](e,T,_e(_e(_e({},s),a),_))}catch(e){n.logger.warn(e)}return E}return n.logger.warn("there was no format function for ".concat(i)),e}),e)}}]),e})();function Se(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function ue(e){for(var t=1;t3&&void 0!==arguments[3]?arguments[3]:{};return d.default(this,o),r=t.call(this),F&&C.call(I.default(r)),r.backend=e,r.store=a,r.services=n,r.languageUtils=n.languageUtils,r.options=i,r.logger=L.create("backendConnector"),r.waitingReads=[],r.maxParallelReads=i.maxParallelReads||10,r.readingCalls=0,r.maxRetries=i.maxRetries>=0?i.maxRetries:5,r.retryTimeout=i.retryTimeout>=1?i.retryTimeout:350,r.state={},r.queue=[],r.backend&&r.backend.init&&r.backend.init(n,i.backend,i),r}return c.default(o,[{key:"queueLoad",value:function(e,t,o,a){var n=this,r={},i={},s={},E={};return e.forEach((function(e){var a=!0;t.forEach((function(t){var s="".concat(e,"|").concat(t);!o.reload&&n.store.hasResourceBundle(e,t)?n.state[s]=2:n.state[s]<0||(1===n.state[s]?void 0===i[s]&&(i[s]=!0):(n.state[s]=1,a=!1,void 0===i[s]&&(i[s]=!0),void 0===r[s]&&(r[s]=!0),void 0===E[t]&&(E[t]=!0)))})),a||(s[e]=!0)})),(Object.keys(r).length||Object.keys(i).length)&&this.queue.push({pending:i,pendingCount:Object.keys(i).length,loaded:{},errors:[],callback:a}),{toLoad:Object.keys(r),pending:Object.keys(i),toLoadLanguages:Object.keys(s),toLoadNamespaces:Object.keys(E)}}},{key:"loaded",value:function(e,t,o){var a=e.split("|"),n=a[0],r=a[1];t&&this.emit("failedLoading",n,r,t),o&&this.store.addResourceBundle(n,r,o),this.state[e]=t?-1:2;var i={};this.queue.forEach((function(o){var a,s,E,_,T,l;a=o.loaded,s=r,_=y(a,[n],Object),T=_.obj,l=_.k,T[l]=T[l]||[],E&&(T[l]=T[l].concat(s)),E||T[l].push(s),(function(e,t){void 0!==e.pending[t]&&(delete e.pending[t],e.pendingCount--)})(o,e),t&&o.errors.push(t),0!==o.pendingCount||o.done||(Object.keys(o.loaded).forEach((function(e){i[e]||(i[e]={});var t=o.loaded[e];t.length&&t.forEach((function(t){void 0===i[e][t]&&(i[e][t]=!0)}))})),o.done=!0,o.errors.length?o.callback(o.errors):o.callback())})),this.emit("loaded",i),this.queue=this.queue.filter((function(e){return!e.done}))}},{key:"read",value:function(e,t,o){var a=this,n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:0,r=arguments.length>4&&void 0!==arguments[4]?arguments[4]:this.retryTimeout,i=arguments.length>5?arguments[5]:void 0;if(!e.length)return i(null,{});if(this.readingCalls>=this.maxParallelReads)this.waitingReads.push({lng:e,ns:t,fcName:o,tried:n,wait:r,callback:i});else{this.readingCalls++;var s=function(s,E){if(a.readingCalls--,a.waitingReads.length>0){var _=a.waitingReads.shift();a.read(_.lng,_.ns,_.fcName,_.tried,_.wait,_.callback)}s&&E&&n2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3?arguments[3]:void 0;if(!this.backend)return this.logger.warn("No backend was added via i18next.use. Will not load resources."),n&&n();"string"==typeof e&&(e=this.languageUtils.toResolveHierarchy(e)),"string"==typeof t&&(t=[t]);var r=this.queueLoad(e,t,a,n);if(!r.toLoad.length)return r.pending.length||n(),null;r.toLoad.forEach((function(e){o.loadOne(e)}))}},{key:"load",value:function(e,t,o){this.prepareLoading(e,t,{},o)}},{key:"reload",value:function(e,t,o){this.prepareLoading(e,t,{reload:!0},o)}},{key:"loadOne",value:function(e){var t=this,o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",a=e.split("|"),n=a[0],r=a[1];this.read(n,r,"read",void 0,void 0,(function(a,i){a&&t.logger.warn("".concat(o,"loading namespace ").concat(r," for language ").concat(n," failed"),a),!a&&i&&t.logger.log("".concat(o,"loaded namespace ").concat(r," for language ").concat(n),i),t.loaded(e,a,i)}))}},{key:"saveMissing",value:function(e,t,o,a,n){var r=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},i=arguments.length>6&&void 0!==arguments[6]?arguments[6]:function(){};if(this.services.utils&&this.services.utils.hasLoadedNamespace&&!this.services.utils.hasLoadedNamespace(t))this.logger.warn('did not save key "'.concat(o,'" as the namespace "').concat(t,'" was not yet loaded'),"This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!");else if(null!=o&&""!==o){if(this.backend&&this.backend.create){var s=ue(ue({},r),{},{isUpdate:n}),E=this.backend.create.bind(this.backend);if(E.length<6)try{var _;(_=5===E.length?E(e,t,o,a,s):E(e,t,o,a))&&"function"==typeof _.then?_.then((function(e){return i(null,e)})).catch(i):i(null,_)}catch(e){i(e)}else E(e,t,o,a,i,s)}e&&e[0]&&this.store.addResource(e[0],t,o,a)}}}]),o})(C);function Ie(){return{debug:!1,initImmediate:!0,ns:["translation"],defaultNS:["translation"],fallbackLng:["dev"],fallbackNS:!1,supportedLngs:!1,nonExplicitSupportedLngs:!1,load:"all",preload:!1,simplifyPluralSuffix:!0,keySeparator:".",nsSeparator:":",pluralSeparator:"_",contextSeparator:"_",partialBundledLanguages:!1,saveMissing:!1,updateMissing:!1,saveMissingTo:"fallback",saveMissingPlurals:!0,missingKeyHandler:!1,missingInterpolationHandler:!1,postProcess:!1,postProcessPassResolved:!1,returnNull:!0,returnEmptyString:!0,returnObjects:!1,joinArrays:!1,returnedObjectHandler:!1,parseMissingKeyHandler:!1,appendNamespaceToMissingKey:!1,appendNamespaceToCIMode:!1,overloadTranslationOptionHandler:function(e){var t={};if("object"===u.default(e[1])&&(t=e[1]),"string"==typeof e[1]&&(t.defaultValue=e[1]),"string"==typeof e[2]&&(t.tDescription=e[2]),"object"===u.default(e[2])||"object"===u.default(e[3])){var o=e[3]||e[2];Object.keys(o).forEach((function(e){t[e]=o[e]}))}return t},interpolation:{escapeValue:!0,format:function(e,t,o,a){return e},prefix:"{{",suffix:"}}",formatSeparator:",",unescapePrefix:"-",nestingPrefix:"$t(",nestingSuffix:")",nestingOptionsSeparator:",",maxReplaces:1e3,skipOnVariables:!0}}}function Ae(e){return"string"==typeof e.ns&&(e.ns=[e.ns]),"string"==typeof e.fallbackLng&&(e.fallbackLng=[e.fallbackLng]),"string"==typeof e.fallbackNS&&(e.fallbackNS=[e.fallbackNS]),e.supportedLngs&&e.supportedLngs.indexOf("cimode")<0&&(e.supportedLngs=e.supportedLngs.concat(["cimode"])),e}function Oe(e,t){var o=Object.keys(e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);t&&(a=a.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),o.push.apply(o,a)}return o}function Ne(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1?arguments[1]:void 0;if(d.default(this,o),e=t.call(this),F&&C.call(I.default(e)),e.options=Ae(a),e.services={},e.logger=L,e.modules={external:[]},pe(I.default(e)),n&&!e.isInitialized&&!a.isClone){if(!e.options.initImmediate)return e.init(a,n),O.default(e,I.default(e));setTimeout((function(){e.init(a,n)}),0)}return e}return c.default(o,[{key:"init",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},o=arguments.length>1?arguments[1]:void 0;"function"==typeof t&&(o=t,t={}),!t.defaultNS&&!1!==t.defaultNS&&t.ns&&("string"==typeof t.ns?t.defaultNS=t.ns:t.ns.indexOf("translation")<0&&(t.defaultNS=t.ns[0]));var a=Ie();function n(e){return e?"function"==typeof e?new e:e:null}if(this.options=Ne(Ne(Ne({},a),this.options),Ae(t)),"v1"!==this.options.compatibilityAPI&&(this.options.interpolation=Ne(Ne({},a.interpolation),this.options.interpolation)),void 0!==t.keySeparator&&(this.options.userDefinedKeySeparator=t.keySeparator),void 0!==t.nsSeparator&&(this.options.userDefinedNsSeparator=t.nsSeparator),!this.options.isClone){var r;this.modules.logger?L.init(n(this.modules.logger),this.options):L.init(null,this.options),this.modules.formatter?r=this.modules.formatter:"undefined"!=typeof Intl&&(r=le);var i=new J(this.options);this.store=new z(this.options.resources,this.options);var s=this.services;s.logger=L,s.resourceStore=this.store,s.languageUtils=i,s.pluralResolver=new ne(i,{prepend:this.options.pluralSeparator,compatibilityJSON:this.options.compatibilityJSON,simplifyPluralSuffix:this.options.simplifyPluralSuffix}),!r||this.options.interpolation.format&&this.options.interpolation.format!==a.interpolation.format||(s.formatter=n(r),s.formatter.init(s,this.options),this.options.interpolation.format=s.formatter.format.bind(s.formatter)),s.interpolator=new se(this.options),s.utils={hasLoadedNamespace:this.hasLoadedNamespace.bind(this)},s.backendConnector=new ce(n(this.modules.backend),s.resourceStore,s,this.options),s.backendConnector.on("*",(function(t){for(var o=arguments.length,a=new Array(o>1?o-1:0),n=1;n1?o-1:0),n=1;n0&&"dev"!==E[0]&&(this.options.lng=E[0])}this.services.languageDetector||this.options.lng||this.logger.warn("init: no languageDetector is used and no lng is defined");var _=["getResource","hasResourceBundle","getResourceBundle","getDataByLanguage"];_.forEach((function(t){e[t]=function(){var o;return(o=e.store)[t].apply(o,arguments)}}));var T=["addResource","addResources","addResourceBundle","removeResourceBundle"];T.forEach((function(t){e[t]=function(){var o;return(o=e.store)[t].apply(o,arguments),e}}));var l=D(),S=function(){var t=function(t,a){e.isInitialized&&!e.initializedStoreOnce&&e.logger.warn("init: i18next is already initialized. You should call init just once!"),e.isInitialized=!0,e.options.isClone||e.logger.log("initialized",e.options),e.emit("initialized",e.options),l.resolve(a),o(t,a)};if(e.languages&&"v1"!==e.options.compatibilityAPI&&!e.isInitialized)return t(null,e.t.bind(e));e.changeLanguage(e.options.lng,t)};return this.options.resources||!this.options.initImmediate?S():setTimeout(S,0),l}},{key:"loadResources",value:function(e){var t=this,o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Re,a=o,n="string"==typeof e?e:this.language;if("function"==typeof e&&(a=e),!this.options.resources||this.options.partialBundledLanguages){if(n&&"cimode"===n.toLowerCase())return a();var r=[],i=function(e){e&&t.services.languageUtils.toResolveHierarchy(e).forEach((function(e){r.indexOf(e)<0&&r.push(e)}))};if(n)i(n);else{var s=this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);s.forEach((function(e){return i(e)}))}this.options.preload&&this.options.preload.forEach((function(e){return i(e)})),this.services.backendConnector.load(r,this.options.ns,(function(e){e||t.resolvedLanguage||!t.language||t.setResolvedLanguage(t.language),a(e)}))}else a(null)}},{key:"reloadResources",value:function(e,t,o){var a=D();return e||(e=this.languages),t||(t=this.options.ns),o||(o=Re),this.services.backendConnector.reload(e,t,(function(e){a.resolve(),o(e)})),a}},{key:"use",value:function(e){if(!e)throw new Error("You are passing an undefined module! Please check the object you are passing to i18next.use()");if(!e.type)throw new Error("You are passing a wrong module! Please check the object you are passing to i18next.use()");return"backend"===e.type&&(this.modules.backend=e),("logger"===e.type||e.log&&e.warn&&e.error)&&(this.modules.logger=e),"languageDetector"===e.type&&(this.modules.languageDetector=e),"i18nFormat"===e.type&&(this.modules.i18nFormat=e),"postProcessor"===e.type&&x.addPostProcessor(e),"formatter"===e.type&&(this.modules.formatter=e),"3rdParty"===e.type&&this.modules.external.push(e),this}},{key:"setResolvedLanguage",value:function(e){if(e&&this.languages&&!(["cimode","dev"].indexOf(e)>-1))for(var t=0;t-1)&&this.store.hasLanguageSomeTranslations(o)){this.resolvedLanguage=o;break}}}},{key:"changeLanguage",value:function(e,t){var o=this;this.isLanguageChangingTo=e;var a=D();this.emit("languageChanging",e);var n=function(e){o.language=e,o.languages=o.services.languageUtils.toResolveHierarchy(e),o.resolvedLanguage=void 0,o.setResolvedLanguage(e)},r=function(r){e||r||!o.services.languageDetector||(r=[]);var i="string"==typeof r?r:o.services.languageUtils.getBestMatchFromCodes(r);i&&(o.language||n(i),o.translator.language||o.translator.changeLanguage(i),o.services.languageDetector&&o.services.languageDetector.cacheUserLanguage&&o.services.languageDetector.cacheUserLanguage(i)),o.loadResources(i,(function(e){!(function(e,r){r?(n(r),o.translator.changeLanguage(r),o.isLanguageChangingTo=void 0,o.emit("languageChanged",r),o.logger.log("languageChanged",r)):o.isLanguageChangingTo=void 0,a.resolve((function(){return o.t.apply(o,arguments)})),t&&t(e,(function(){return o.t.apply(o,arguments)}))})(e,i)}))};return e||!this.services.languageDetector||this.services.languageDetector.async?!e&&this.services.languageDetector&&this.services.languageDetector.async?0===this.services.languageDetector.detect.length?this.services.languageDetector.detect().then(r):this.services.languageDetector.detect(r):r(e):r(this.services.languageDetector.detect()),a}},{key:"getFixedT",value:function(e,t,o){var a=this,n=function e(t,n){var r;if("object"!==u.default(n)){for(var i=arguments.length,s=new Array(i>2?i-2:0),E=2;E1&&void 0!==arguments[1]?arguments[1]:{};if(!this.isInitialized)return this.logger.warn("hasLoadedNamespace: i18next was not initialized",this.languages),!1;if(!this.languages||!this.languages.length)return this.logger.warn("hasLoadedNamespace: i18n.languages were undefined or empty",this.languages),!1;var a=this.resolvedLanguage||this.languages[0],n=!!this.options&&this.options.fallbackLng,r=this.languages[this.languages.length-1];if("cimode"===a.toLowerCase())return!0;var i=function(e,o){var a=t.services.backendConnector.state["".concat(e,"|").concat(o)];return-1===a||2===a};if(o.precheck){var s=o.precheck(this,i);if(void 0!==s)return s}return!!this.hasResourceBundle(a,e)||(!(this.services.backendConnector.backend&&(!this.options.resources||this.options.partialBundledLanguages))||!(!i(a,e)||n&&!i(r,e)))}},{key:"loadNamespaces",value:function(e,t){var o=this,a=D();return this.options.ns?("string"==typeof e&&(e=[e]),e.forEach((function(e){o.options.ns.indexOf(e)<0&&o.options.ns.push(e)})),this.loadResources((function(e){a.resolve(),t&&t(e)})),a):(t&&t(),Promise.resolve())}},{key:"loadLanguages",value:function(e,t){var o=D();"string"==typeof e&&(e=[e]);var a=this.options.preload||[],n=e.filter((function(e){return a.indexOf(e)<0}));return n.length?(this.options.preload=a.concat(n),this.loadResources((function(e){o.resolve(),t&&t(e)})),o):(t&&t(),Promise.resolve())}},{key:"dir",value:function(e){if(e||(e=this.resolvedLanguage||(this.languages&&this.languages.length>0?this.languages[0]:this.language)),!e)return"rtl";var t=this.services&&this.services.languageUtils||new J(Ie());return["ar","shu","sqr","ssh","xaa","yhd","yud","aao","abh","abv","acm","acq","acw","acx","acy","adf","ads","aeb","aec","afb","ajp","apc","apd","arb","arq","ars","ary","arz","auz","avl","ayh","ayl","ayn","ayp","bbz","pga","he","iw","ps","pbt","pbu","pst","prp","prd","ug","ur","ydd","yds","yih","ji","yi","hbo","men","xmn","fa","jpr","peo","pes","prs","dv","sam","ckb"].indexOf(t.getLanguagePartFromCode(e))>-1||e.toLowerCase().indexOf("-arab")>1?"rtl":"ltr"}},{key:"cloneInstance",value:function(){var e=this,t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:Re,n=Ne(Ne(Ne({},this.options),t),{isClone:!0}),r=new o(n);void 0===t.debug&&void 0===t.prefix||(r.logger=r.logger.clone(t));var i=["store","services","language"];return i.forEach((function(t){r[t]=e[t]})),r.services=Ne({},this.services),r.services.utils={hasLoadedNamespace:r.hasLoadedNamespace.bind(r)},r.translator=new $(r.services,r.options),r.translator.on("*",(function(e){for(var t=arguments.length,o=new Array(t>1?t-1:0),a=1;a0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1?arguments[1]:void 0;return new he(e,t)}));var fe=he.createInstance();fe.createInstance=he.createInstance,e.exports=fe},645:(e,t)=>{t.read=function(e,t,o,a,n){var r,i,s=8*n-a-1,E=(1<>1,T=-7,l=o?n-1:0,S=o?-1:1,u=e[t+l];for(l+=S,r=u&(1<<-T)-1,u>>=-T,T+=s;T>0;r=256*r+e[t+l],l+=S,T-=8);for(i=r&(1<<-T)-1,r>>=-T,T+=a;T>0;i=256*i+e[t+l],l+=S,T-=8);if(0===r)r=1-_;else{if(r===E)return i?NaN:1/0*(u?-1:1);i+=Math.pow(2,a),r-=_}return(u?-1:1)*i*Math.pow(2,r-a)},t.write=function(e,t,o,a,n,r){var i,s,E,_=8*r-n-1,T=(1<<_)-1,l=T>>1,S=23===n?Math.pow(2,-24)-Math.pow(2,-77):0,u=a?0:r-1,d=a?1:-1,c=t<0||0===t&&1/t<0?1:0;for(t=Math.abs(t),isNaN(t)||t===1/0?(s=isNaN(t)?1:0,i=T):(i=Math.floor(Math.log(t)/Math.LN2),t*(E=Math.pow(2,-i))<1&&(i--,E*=2),(t+=i+l>=1?S/E:S*Math.pow(2,1-l))*E>=2&&(i++,E/=2),i+l>=T?(s=0,i=T):i+l>=1?(s=(t*E-1)*Math.pow(2,n),i+=l):(s=t*Math.pow(2,l-1)*Math.pow(2,n),i=0));n>=8;e[o+u]=255&s,u+=d,s/=256,n-=8);for(i=i<0;e[o+u]=255&i,u+=d,i/=256,_-=8);e[o+u-d]|=128*c}},5457:e=>{e.exports=[{name:"Abkhaz",local:"Аҧсуа",1:"ab",2:"abk","2T":"abk","2B":"abk",3:"abk"},{name:"Afar",local:"Afaraf",1:"aa",2:"aar","2T":"aar","2B":"aar",3:"aar"},{name:"Afrikaans",local:"Afrikaans",1:"af",2:"afr","2T":"afr","2B":"afr",3:"afr"},{name:"Akan",local:"Akan",1:"ak",2:"aka","2T":"aka","2B":"aka",3:"aka"},{name:"Albanian",local:"Shqip",1:"sq",2:"sqi","2T":"sqi","2B":"alb",3:"sqi"},{name:"Amharic",local:"አማርኛ",1:"am",2:"amh","2T":"amh","2B":"amh",3:"amh"},{name:"Arabic",local:"العربية",1:"ar",2:"ara","2T":"ara","2B":"ara",3:"ara"},{name:"Aragonese",local:"Aragonés",1:"an",2:"arg","2T":"arg","2B":"arg",3:"arg"},{name:"Armenian",local:"Հայերեն",1:"hy",2:"hye","2T":"hye","2B":"arm",3:"hye"},{name:"Assamese",local:"অসমীয়া",1:"as",2:"asm","2T":"asm","2B":"asm",3:"asm"},{name:"Avaric",local:"Авар",1:"av",2:"ava","2T":"ava","2B":"ava",3:"ava"},{name:"Avestan",local:"avesta",1:"ae",2:"ave","2T":"ave","2B":"ave",3:"ave"},{name:"Aymara",local:"Aymar",1:"ay",2:"aym","2T":"aym","2B":"aym",3:"aym"},{name:"Azerbaijani",local:"Azərbaycanca",1:"az",2:"aze","2T":"aze","2B":"aze",3:"aze"},{name:"Bambara",local:"Bamanankan",1:"bm",2:"bam","2T":"bam","2B":"bam",3:"bam"},{name:"Bashkir",local:"Башҡортса",1:"ba",2:"bak","2T":"bak","2B":"bak",3:"bak"},{name:"Basque",local:"Euskara",1:"eu",2:"eus","2T":"eus","2B":"baq",3:"eus"},{name:"Belarusian",local:"Беларуская",1:"be",2:"bel","2T":"bel","2B":"bel",3:"bel"},{name:"Bengali",local:"বাংলা",1:"bn",2:"ben","2T":"ben","2B":"ben",3:"ben"},{name:"Bihari",local:"भोजपुरी",1:"bh",2:"bih","2T":"bih","2B":"bih",3:"bih"},{name:"Bislama",local:"Bislama",1:"bi",2:"bis","2T":"bis","2B":"bis",3:"bis"},{name:"Bosnian",local:"Bosanski",1:"bs",2:"bos","2T":"bos","2B":"bos",3:"bos"},{name:"Breton",local:"Brezhoneg",1:"br",2:"bre","2T":"bre","2B":"bre",3:"bre"},{name:"Bulgarian",local:"Български",1:"bg",2:"bul","2T":"bul","2B":"bul",3:"bul"},{name:"Burmese",local:"မြန်မာဘာသာ",1:"my",2:"mya","2T":"mya","2B":"bur",3:"mya"},{name:"Catalan",local:"Català",1:"ca",2:"cat","2T":"cat","2B":"cat",3:"cat"},{name:"Chamorro",local:"Chamoru",1:"ch",2:"cha","2T":"cha","2B":"cha",3:"cha"},{name:"Chechen",local:"Нохчийн",1:"ce",2:"che","2T":"che","2B":"che",3:"che"},{name:"Chichewa",local:"Chichewa",1:"ny",2:"nya","2T":"nya","2B":"nya",3:"nya"},{name:"Chinese",local:"中文",1:"zh",2:"zho","2T":"zho","2B":"chi",3:"zho"},{name:"Chuvash",local:"Чӑвашла",1:"cv",2:"chv","2T":"chv","2B":"chv",3:"chv"},{name:"Cornish",local:"Kernewek",1:"kw",2:"cor","2T":"cor","2B":"cor",3:"cor"},{name:"Corsican",local:"Corsu",1:"co",2:"cos","2T":"cos","2B":"cos",3:"cos"},{name:"Cree",local:"ᓀᐦᐃᔭᐍᐏᐣ",1:"cr",2:"cre","2T":"cre","2B":"cre",3:"cre"},{name:"Croatian",local:"Hrvatski",1:"hr",2:"hrv","2T":"hrv","2B":"hrv",3:"hrv"},{name:"Czech",local:"Čeština",1:"cs",2:"ces","2T":"ces","2B":"cze",3:"ces"},{name:"Danish",local:"Dansk",1:"da",2:"dan","2T":"dan","2B":"dan",3:"dan"},{name:"Divehi",local:"Divehi",1:"dv",2:"div","2T":"div","2B":"div",3:"div"},{name:"Dutch",local:"Nederlands",1:"nl",2:"nld","2T":"nld","2B":"dut",3:"nld"},{name:"Dzongkha",local:"རྫོང་ཁ",1:"dz",2:"dzo","2T":"dzo","2B":"dzo",3:"dzo"},{name:"English",local:"English",1:"en",2:"eng","2T":"eng","2B":"eng",3:"eng"},{name:"Esperanto",local:"Esperanto",1:"eo",2:"epo","2T":"epo","2B":"epo",3:"epo"},{name:"Estonian",local:"Eesti",1:"et",2:"est","2T":"est","2B":"est",3:"est"},{name:"Ewe",local:"Eʋegbe",1:"ee",2:"ewe","2T":"ewe","2B":"ewe",3:"ewe"},{name:"Faroese",local:"Føroyskt",1:"fo",2:"fao","2T":"fao","2B":"fao",3:"fao"},{name:"Fijian",local:"Na Vosa Vaka-Viti",1:"fj",2:"fij","2T":"fij","2B":"fij",3:"fij"},{name:"Finnish",local:"Suomi",1:"fi",2:"fin","2T":"fin","2B":"fin",3:"fin"},{name:"French",local:"Français",1:"fr",2:"fra","2T":"fra","2B":"fre",3:"fra"},{name:"Fula",local:"Fulfulde",1:"ff",2:"ful","2T":"ful","2B":"ful",3:"ful"},{name:"Galician",local:"Galego",1:"gl",2:"glg","2T":"glg","2B":"glg",3:"glg"},{name:"Georgian",local:"ქართული",1:"ka",2:"kat","2T":"kat","2B":"geo",3:"kat"},{name:"German",local:"Deutsch",1:"de",2:"deu","2T":"deu","2B":"ger",3:"deu"},{name:"Greek",local:"Ελληνικά",1:"el",2:"ell","2T":"ell","2B":"gre",3:"ell"},{name:"Guaraní",local:"Avañe'ẽ",1:"gn",2:"grn","2T":"grn","2B":"grn",3:"grn"},{name:"Gujarati",local:"ગુજરાતી",1:"gu",2:"guj","2T":"guj","2B":"guj",3:"guj"},{name:"Haitian",local:"Kreyòl Ayisyen",1:"ht",2:"hat","2T":"hat","2B":"hat",3:"hat"},{name:"Hausa",local:"هَوُسَ",1:"ha",2:"hau","2T":"hau","2B":"hau",3:"hau"},{name:"Hebrew",local:"עברית",1:"he",2:"heb","2T":"heb","2B":"heb",3:"heb"},{name:"Herero",local:"Otjiherero",1:"hz",2:"her","2T":"her","2B":"her",3:"her"},{name:"Hindi",local:"हिन्दी",1:"hi",2:"hin","2T":"hin","2B":"hin",3:"hin"},{name:"Hiri Motu",local:"Hiri Motu",1:"ho",2:"hmo","2T":"hmo","2B":"hmo",3:"hmo"},{name:"Hungarian",local:"Magyar",1:"hu",2:"hun","2T":"hun","2B":"hun",3:"hun"},{name:"Interlingua",local:"Interlingua",1:"ia",2:"ina","2T":"ina","2B":"ina",3:"ina"},{name:"Indonesian",local:"Bahasa Indonesia",1:"id",2:"ind","2T":"ind","2B":"ind",3:"ind"},{name:"Interlingue",local:"Interlingue",1:"ie",2:"ile","2T":"ile","2B":"ile",3:"ile"},{name:"Irish",local:"Gaeilge",1:"ga",2:"gle","2T":"gle","2B":"gle",3:"gle"},{name:"Igbo",local:"Igbo",1:"ig",2:"ibo","2T":"ibo","2B":"ibo",3:"ibo"},{name:"Inupiaq",local:"Iñupiak",1:"ik",2:"ipk","2T":"ipk","2B":"ipk",3:"ipk"},{name:"Ido",local:"Ido",1:"io",2:"ido","2T":"ido","2B":"ido",3:"ido"},{name:"Icelandic",local:"Íslenska",1:"is",2:"isl","2T":"isl","2B":"ice",3:"isl"},{name:"Italian",local:"Italiano",1:"it",2:"ita","2T":"ita","2B":"ita",3:"ita"},{name:"Inuktitut",local:"ᐃᓄᒃᑎᑐᑦ",1:"iu",2:"iku","2T":"iku","2B":"iku",3:"iku"},{name:"Japanese",local:"日本語",1:"ja",2:"jpn","2T":"jpn","2B":"jpn",3:"jpn"},{name:"Javanese",local:"Basa Jawa",1:"jv",2:"jav","2T":"jav","2B":"jav",3:"jav"},{name:"Kalaallisut",local:"Kalaallisut",1:"kl",2:"kal","2T":"kal","2B":"kal",3:"kal"},{name:"Kannada",local:"ಕನ್ನಡ",1:"kn",2:"kan","2T":"kan","2B":"kan",3:"kan"},{name:"Kanuri",local:"Kanuri",1:"kr",2:"kau","2T":"kau","2B":"kau",3:"kau"},{name:"Kashmiri",local:"كشميري",1:"ks",2:"kas","2T":"kas","2B":"kas",3:"kas"},{name:"Kazakh",local:"Қазақша",1:"kk",2:"kaz","2T":"kaz","2B":"kaz",3:"kaz"},{name:"Khmer",local:"ភាសាខ្មែរ",1:"km",2:"khm","2T":"khm","2B":"khm",3:"khm"},{name:"Kikuyu",local:"Gĩkũyũ",1:"ki",2:"kik","2T":"kik","2B":"kik",3:"kik"},{name:"Kinyarwanda",local:"Kinyarwanda",1:"rw",2:"kin","2T":"kin","2B":"kin",3:"kin"},{name:"Kyrgyz",local:"Кыргызча",1:"ky",2:"kir","2T":"kir","2B":"kir",3:"kir"},{name:"Komi",local:"Коми",1:"kv",2:"kom","2T":"kom","2B":"kom",3:"kom"},{name:"Kongo",local:"Kongo",1:"kg",2:"kon","2T":"kon","2B":"kon",3:"kon"},{name:"Korean",local:"한국어",1:"ko",2:"kor","2T":"kor","2B":"kor",3:"kor"},{name:"Kurdish",local:"Kurdî",1:"ku",2:"kur","2T":"kur","2B":"kur",3:"kur"},{name:"Kwanyama",local:"Kuanyama",1:"kj",2:"kua","2T":"kua","2B":"kua",3:"kua"},{name:"Latin",local:"Latina",1:"la",2:"lat","2T":"lat","2B":"lat",3:"lat"},{name:"Luxembourgish",local:"Lëtzebuergesch",1:"lb",2:"ltz","2T":"ltz","2B":"ltz",3:"ltz"},{name:"Ganda",local:"Luganda",1:"lg",2:"lug","2T":"lug","2B":"lug",3:"lug"},{name:"Limburgish",local:"Limburgs",1:"li",2:"lim","2T":"lim","2B":"lim",3:"lim"},{name:"Lingala",local:"Lingála",1:"ln",2:"lin","2T":"lin","2B":"lin",3:"lin"},{name:"Lao",local:"ພາສາລາວ",1:"lo",2:"lao","2T":"lao","2B":"lao",3:"lao"},{name:"Lithuanian",local:"Lietuvių",1:"lt",2:"lit","2T":"lit","2B":"lit",3:"lit"},{name:"Luba-Katanga",local:"Tshiluba",1:"lu",2:"lub","2T":"lub","2B":"lub",3:"lub"},{name:"Latvian",local:"Latviešu",1:"lv",2:"lav","2T":"lav","2B":"lav",3:"lav"},{name:"Manx",local:"Gaelg",1:"gv",2:"glv","2T":"glv","2B":"glv",3:"glv"},{name:"Macedonian",local:"Македонски",1:"mk",2:"mkd","2T":"mkd","2B":"mac",3:"mkd"},{name:"Malagasy",local:"Malagasy",1:"mg",2:"mlg","2T":"mlg","2B":"mlg",3:"mlg"},{name:"Malay",local:"Bahasa Melayu",1:"ms",2:"msa","2T":"msa","2B":"may",3:"msa"},{name:"Malayalam",local:"മലയാളം",1:"ml",2:"mal","2T":"mal","2B":"mal",3:"mal"},{name:"Maltese",local:"Malti",1:"mt",2:"mlt","2T":"mlt","2B":"mlt",3:"mlt"},{name:"Māori",local:"Māori",1:"mi",2:"mri","2T":"mri","2B":"mao",3:"mri"},{name:"Marathi",local:"मराठी",1:"mr",2:"mar","2T":"mar","2B":"mar",3:"mar"},{name:"Marshallese",local:"Kajin M̧ajeļ",1:"mh",2:"mah","2T":"mah","2B":"mah",3:"mah"},{name:"Mongolian",local:"Монгол",1:"mn",2:"mon","2T":"mon","2B":"mon",3:"mon"},{name:"Nauru",local:"Dorerin Naoero",1:"na",2:"nau","2T":"nau","2B":"nau",3:"nau"},{name:"Navajo",local:"Diné Bizaad",1:"nv",2:"nav","2T":"nav","2B":"nav",3:"nav"},{name:"Northern Ndebele",local:"isiNdebele",1:"nd",2:"nde","2T":"nde","2B":"nde",3:"nde"},{name:"Nepali",local:"नेपाली",1:"ne",2:"nep","2T":"nep","2B":"nep",3:"nep"},{name:"Ndonga",local:"Owambo",1:"ng",2:"ndo","2T":"ndo","2B":"ndo",3:"ndo"},{name:"Norwegian Bokmål",local:"Norsk (Bokmål)",1:"nb",2:"nob","2T":"nob","2B":"nob",3:"nob"},{name:"Norwegian Nynorsk",local:"Norsk (Nynorsk)",1:"nn",2:"nno","2T":"nno","2B":"nno",3:"nno"},{name:"Norwegian",local:"Norsk",1:"no",2:"nor","2T":"nor","2B":"nor",3:"nor"},{name:"Nuosu",local:"ꆈꌠ꒿ Nuosuhxop",1:"ii",2:"iii","2T":"iii","2B":"iii",3:"iii"},{name:"Southern Ndebele",local:"isiNdebele",1:"nr",2:"nbl","2T":"nbl","2B":"nbl",3:"nbl"},{name:"Occitan",local:"Occitan",1:"oc",2:"oci","2T":"oci","2B":"oci",3:"oci"},{name:"Ojibwe",local:"ᐊᓂᔑᓈᐯᒧᐎᓐ",1:"oj",2:"oji","2T":"oji","2B":"oji",3:"oji"},{name:"Old Church Slavonic",local:"Словѣ́ньскъ",1:"cu",2:"chu","2T":"chu","2B":"chu",3:"chu"},{name:"Oromo",local:"Afaan Oromoo",1:"om",2:"orm","2T":"orm","2B":"orm",3:"orm"},{name:"Oriya",local:"ଓଡି଼ଆ",1:"or",2:"ori","2T":"ori","2B":"ori",3:"ori"},{name:"Ossetian",local:"Ирон æвзаг",1:"os",2:"oss","2T":"oss","2B":"oss",3:"oss"},{name:"Panjabi",local:"ਪੰਜਾਬੀ",1:"pa",2:"pan","2T":"pan","2B":"pan",3:"pan"},{name:"Pāli",local:"पाऴि",1:"pi",2:"pli","2T":"pli","2B":"pli",3:"pli"},{name:"Persian",local:"فارسی",1:"fa",2:"fas","2T":"fas","2B":"per",3:"fas"},{name:"Polish",local:"Polski",1:"pl",2:"pol","2T":"pol","2B":"pol",3:"pol"},{name:"Pashto",local:"پښتو",1:"ps",2:"pus","2T":"pus","2B":"pus",3:"pus"},{name:"Portuguese",local:"Português",1:"pt",2:"por","2T":"por","2B":"por",3:"por"},{name:"Quechua",local:"Runa Simi",1:"qu",2:"que","2T":"que","2B":"que",3:"que"},{name:"Romansh",local:"Rumantsch",1:"rm",2:"roh","2T":"roh","2B":"roh",3:"roh"},{name:"Kirundi",local:"Kirundi",1:"rn",2:"run","2T":"run","2B":"run",3:"run"},{name:"Romanian",local:"Română",1:"ro",2:"ron","2T":"ron","2B":"rum",3:"ron"},{name:"Russian",local:"Русский",1:"ru",2:"rus","2T":"rus","2B":"rus",3:"rus"},{name:"Sanskrit",local:"संस्कृतम्",1:"sa",2:"san","2T":"san","2B":"san",3:"san"},{name:"Sardinian",local:"Sardu",1:"sc",2:"srd","2T":"srd","2B":"srd",3:"srd"},{name:"Sindhi",local:"سنڌي‎",1:"sd",2:"snd","2T":"snd","2B":"snd",3:"snd"},{name:"Northern Sami",local:"Sámegiella",1:"se",2:"sme","2T":"sme","2B":"sme",3:"sme"},{name:"Samoan",local:"Gagana Sāmoa",1:"sm",2:"smo","2T":"smo","2B":"smo",3:"smo"},{name:"Sango",local:"Sängö",1:"sg",2:"sag","2T":"sag","2B":"sag",3:"sag"},{name:"Serbian",local:"Српски",1:"sr",2:"srp","2T":"srp","2B":"srp",3:"srp"},{name:"Gaelic",local:"Gàidhlig",1:"gd",2:"gla","2T":"gla","2B":"gla",3:"gla"},{name:"Shona",local:"ChiShona",1:"sn",2:"sna","2T":"sna","2B":"sna",3:"sna"},{name:"Sinhala",local:"සිංහල",1:"si",2:"sin","2T":"sin","2B":"sin",3:"sin"},{name:"Slovak",local:"Slovenčina",1:"sk",2:"slk","2T":"slk","2B":"slo",3:"slk"},{name:"Slovene",local:"Slovenščina",1:"sl",2:"slv","2T":"slv","2B":"slv",3:"slv"},{name:"Somali",local:"Soomaaliga",1:"so",2:"som","2T":"som","2B":"som",3:"som"},{name:"Southern Sotho",local:"Sesotho",1:"st",2:"sot","2T":"sot","2B":"sot",3:"sot"},{name:"Spanish",local:"Español",1:"es",2:"spa","2T":"spa","2B":"spa",3:"spa"},{name:"Sundanese",local:"Basa Sunda",1:"su",2:"sun","2T":"sun","2B":"sun",3:"sun"},{name:"Swahili",local:"Kiswahili",1:"sw",2:"swa","2T":"swa","2B":"swa",3:"swa"},{name:"Swati",local:"SiSwati",1:"ss",2:"ssw","2T":"ssw","2B":"ssw",3:"ssw"},{name:"Swedish",local:"Svenska",1:"sv",2:"swe","2T":"swe","2B":"swe",3:"swe"},{name:"Tamil",local:"தமிழ்",1:"ta",2:"tam","2T":"tam","2B":"tam",3:"tam"},{name:"Telugu",local:"తెలుగు",1:"te",2:"tel","2T":"tel","2B":"tel",3:"tel"},{name:"Tajik",local:"Тоҷикӣ",1:"tg",2:"tgk","2T":"tgk","2B":"tgk",3:"tgk"},{name:"Thai",local:"ภาษาไทย",1:"th",2:"tha","2T":"tha","2B":"tha",3:"tha"},{name:"Tigrinya",local:"ትግርኛ",1:"ti",2:"tir","2T":"tir","2B":"tir",3:"tir"},{name:"Tibetan Standard",local:"བོད་ཡིག",1:"bo",2:"bod","2T":"bod","2B":"tib",3:"bod"},{name:"Turkmen",local:"Türkmençe",1:"tk",2:"tuk","2T":"tuk","2B":"tuk",3:"tuk"},{name:"Tagalog",local:"Tagalog",1:"tl",2:"tgl","2T":"tgl","2B":"tgl",3:"tgl"},{name:"Tswana",local:"Setswana",1:"tn",2:"tsn","2T":"tsn","2B":"tsn",3:"tsn"},{name:"Tonga",local:"faka Tonga",1:"to",2:"ton","2T":"ton","2B":"ton",3:"ton"},{name:"Turkish",local:"Türkçe",1:"tr",2:"tur","2T":"tur","2B":"tur",3:"tur"},{name:"Tsonga",local:"Xitsonga",1:"ts",2:"tso","2T":"tso","2B":"tso",3:"tso"},{name:"Tatar",local:"Татарча",1:"tt",2:"tat","2T":"tat","2B":"tat",3:"tat"},{name:"Twi",local:"Twi",1:"tw",2:"twi","2T":"twi","2B":"twi",3:"twi"},{name:"Tahitian",local:"Reo Mā’ohi",1:"ty",2:"tah","2T":"tah","2B":"tah",3:"tah"},{name:"Uyghur",local:"ئۇيغۇرچه",1:"ug",2:"uig","2T":"uig","2B":"uig",3:"uig"},{name:"Ukrainian",local:"Українська",1:"uk",2:"ukr","2T":"ukr","2B":"ukr",3:"ukr"},{name:"Urdu",local:"اردو",1:"ur",2:"urd","2T":"urd","2B":"urd",3:"urd"},{name:"Uzbek",local:"O‘zbek",1:"uz",2:"uzb","2T":"uzb","2B":"uzb",3:"uzb"},{name:"Venda",local:"Tshivenḓa",1:"ve",2:"ven","2T":"ven","2B":"ven",3:"ven"},{name:"Vietnamese",local:"Tiếng Việt",1:"vi",2:"vie","2T":"vie","2B":"vie",3:"vie"},{name:"Volapük",local:"Volapük",1:"vo",2:"vol","2T":"vol","2B":"vol",3:"vol"},{name:"Walloon",local:"Walon",1:"wa",2:"wln","2T":"wln","2B":"wln",3:"wln"},{name:"Welsh",local:"Cymraeg",1:"cy",2:"cym","2T":"cym","2B":"wel",3:"cym"},{name:"Wolof",local:"Wolof",1:"wo",2:"wol","2T":"wol","2B":"wol",3:"wol"},{name:"Western Frisian",local:"Frysk",1:"fy",2:"fry","2T":"fry","2B":"fry",3:"fry"},{name:"Xhosa",local:"isiXhosa",1:"xh",2:"xho","2T":"xho","2B":"xho",3:"xho"},{name:"Yiddish",local:"ייִדיש",1:"yi",2:"yid","2T":"yid","2B":"yid",3:"yid"},{name:"Yoruba",local:"Yorùbá",1:"yo",2:"yor","2T":"yor","2B":"yor",3:"yor"},{name:"Zhuang",local:"Cuengh",1:"za",2:"zha","2T":"zha","2B":"zha",3:"zha"},{name:"Zulu",local:"isiZulu",1:"zu",2:"zul","2T":"zul","2B":"zul",3:"zul"}]},7576:(e,t,o)=>{var a=o(5457),n={all:function(){return a},has:function(e,t){return void 0!==r(e,t)},codes:function(e){if((function(e){return-1!==[1,2,3,"1","2","2B","2T","3"].indexOf(e)})(e))return i(a,(function(t){return t[e]}))},names:function(e){return i(a,(function(t){return e?t.local:t.name}))},where:r};function r(e,t){for(var o=0;o{e=o.nmd(e);var a="__lodash_hash_undefined__",n=9007199254740991,r="[object Arguments]",i="[object Boolean]",s="[object Date]",E="[object Function]",_="[object GeneratorFunction]",T="[object Map]",l="[object Number]",S="[object Object]",u="[object Promise]",d="[object RegExp]",c="[object Set]",I="[object String]",A="[object Symbol]",O="[object WeakMap]",N="[object ArrayBuffer]",m="[object DataView]",R="[object Float32Array]",p="[object Float64Array]",h="[object Int8Array]",f="[object Int16Array]",L="[object Int32Array]",C="[object Uint8Array]",D="[object Uint8ClampedArray]",g="[object Uint16Array]",v="[object Uint32Array]",y=/\w*$/,P=/^\[object .+?Constructor\]$/,B=/^(?:0|[1-9]\d*)$/,b={};b[r]=b["[object Array]"]=b[N]=b[m]=b[i]=b[s]=b[R]=b[p]=b[h]=b[f]=b[L]=b[T]=b[l]=b[S]=b[d]=b[c]=b[I]=b[A]=b[C]=b[D]=b[g]=b[v]=!0,b["[object Error]"]=b[E]=b[O]=!1;var M="object"==typeof o.g&&o.g&&o.g.Object===Object&&o.g,U="object"==typeof self&&self&&self.Object===Object&&self,W=M||U||Function("return this")(),G=t&&!t.nodeType&&t,F=G&&e&&!e.nodeType&&e,k=F&&F.exports===G;function w(e,t){return e.set(t[0],t[1]),e}function H(e,t){return e.add(t),e}function V(e,t,o,a){var n=-1,r=e?e.length:0;for(a&&r&&(o=e[++n]);++n-1},De.prototype.set=function(e,t){var o=this.__data__,a=Be(o,e);return a<0?o.push([e,t]):o[a][1]=t,this},ge.prototype.clear=function(){this.__data__={hash:new Ce,map:new(de||De),string:new Ce}},ge.prototype.delete=function(e){return Ge(this,e).delete(e)},ge.prototype.get=function(e){return Ge(this,e).get(e)},ge.prototype.has=function(e){return Ge(this,e).has(e)},ge.prototype.set=function(e,t){return Ge(this,e).set(e,t),this},ve.prototype.clear=function(){this.__data__=new De},ve.prototype.delete=function(e){return this.__data__.delete(e)},ve.prototype.get=function(e){return this.__data__.get(e)},ve.prototype.has=function(e){return this.__data__.has(e)},ve.prototype.set=function(e,t){var o=this.__data__;if(o instanceof De){var a=o.__data__;if(!de||a.length<199)return a.push([e,t]),this;o=this.__data__=new ge(a)}return o.set(e,t),this};var ke=Te?x(Te,Object):function(){return[]},we=function(e){return te.call(e)};function He(e,t){return!!(t=null==t?n:t)&&("number"==typeof e||B.test(e))&&e>-1&&e%1==0&&e-1&&e%1==0&&e<=n})(e.length)&&!Qe(e)}var je=le||function(){return!1};function Qe(e){var t=Xe(e)?te.call(e):"";return t==E||t==_}function Xe(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function $e(e){return Ke(e)?ye(e):(function(e){if(!Ve(e))return Se(e);var t=[];for(var o in Object(e))ee.call(e,o)&&"constructor"!=o&&t.push(o);return t})(e)}e.exports=function(e){return be(e,!0,!0)}},1296:(e,t,o)=>{var a=/^\s+|\s+$/g,n=/^[-+]0x[0-9a-f]+$/i,r=/^0b[01]+$/i,i=/^0o[0-7]+$/i,s=parseInt,E="object"==typeof o.g&&o.g&&o.g.Object===Object&&o.g,_="object"==typeof self&&self&&self.Object===Object&&self,T=E||_||Function("return this")(),l=Object.prototype.toString,S=Math.max,u=Math.min,d=function(){return T.Date.now()};function c(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function I(e){if("number"==typeof e)return e;if((function(e){return"symbol"==typeof e||(function(e){return!!e&&"object"==typeof e})(e)&&"[object Symbol]"==l.call(e)})(e))return NaN;if(c(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=c(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(a,"");var o=r.test(e);return o||i.test(e)?s(e.slice(2),o?2:8):n.test(e)?NaN:+e}e.exports=function(e,t,o){var a,n,r,i,s,E,_=0,T=!1,l=!1,A=!0;if("function"!=typeof e)throw new TypeError("Expected a function");function O(t){var o=a,r=n;return a=n=void 0,_=t,i=e.apply(r,o)}function N(e){return _=e,s=setTimeout(R,t),T?O(e):i}function m(e){var o=e-E;return void 0===E||o>=t||o<0||l&&e-_>=r}function R(){var e=d();if(m(e))return p(e);s=setTimeout(R,(function(e){var o=t-(e-E);return l?u(o,r-(e-_)):o})(e))}function p(e){return s=void 0,A&&a?O(e):(a=n=void 0,i)}function h(){var e=d(),o=m(e);if(a=arguments,n=this,E=e,o){if(void 0===s)return N(E);if(l)return s=setTimeout(R,t),O(E)}return void 0===s&&(s=setTimeout(R,t)),i}return t=I(t)||0,c(o)&&(T=!!o.leading,r=(l="maxWait"in o)?S(I(o.maxWait)||0,t):r,A="trailing"in o?!!o.trailing:A),h.cancel=function(){void 0!==s&&clearTimeout(s),_=0,a=E=n=s=void 0},h.flush=function(){return void 0===s?i:p(d())},h}},394:(e,t,o)=>{var a="__lodash_hash_undefined__",n=9007199254740991,r=/^\[object .+?Constructor\]$/,i="object"==typeof o.g&&o.g&&o.g.Object===Object&&o.g,s="object"==typeof self&&self&&self.Object===Object&&self,E=i||s||Function("return this")();function _(e,t,o){switch(o.length){case 0:return e.call(t);case 1:return e.call(t,o[0]);case 2:return e.call(t,o[0],o[1]);case 3:return e.call(t,o[0],o[1],o[2])}return e.apply(t,o)}function T(e,t){return!!(e?e.length:0)&&(function(e,t,o){if(t!=t)return(function(e,t,o,a){var n=e.length,r=o+(a?1:-1);for(;a?r--:++r-1}function l(e,t,o){for(var a=-1,n=e?e.length:0;++a-1&&e%1==0&&e<=n})(e.length)&&!Y(e)})(e)})(e)?e:[]}function F(e,t){var o,a,n=e.__data__;return("string"==(a=typeof(o=t))||"number"==a||"symbol"==a||"boolean"==a?"__proto__"!==o:null===o)?n["string"==typeof t?"string":"hash"]:n.map}function k(e,t){var o=(function(e,t){return null==e?void 0:e[t]})(e,t);return W(o)?o:void 0}P.prototype.clear=function(){this.__data__=y?y(null):{}},P.prototype.delete=function(e){return this.has(e)&&delete this.__data__[e]},P.prototype.get=function(e){var t=this.__data__;if(y){var o=t[e];return o===a?void 0:o}return h.call(t,e)?t[e]:void 0},P.prototype.has=function(e){var t=this.__data__;return y?void 0!==t[e]:h.call(t,e)},P.prototype.set=function(e,t){return this.__data__[e]=y&&void 0===t?a:t,this},B.prototype.clear=function(){this.__data__=[]},B.prototype.delete=function(e){var t=this.__data__,o=U(t,e);return!(o<0)&&(o==t.length-1?t.pop():C.call(t,o,1),!0)},B.prototype.get=function(e){var t=this.__data__,o=U(t,e);return o<0?void 0:t[o][1]},B.prototype.has=function(e){return U(this.__data__,e)>-1},B.prototype.set=function(e,t){var o=this.__data__,a=U(o,e);return a<0?o.push([e,t]):o[a][1]=t,this},b.prototype.clear=function(){this.__data__={hash:new P,map:new(v||B),string:new P}},b.prototype.delete=function(e){return F(this,e).delete(e)},b.prototype.get=function(e){return F(this,e).get(e)},b.prototype.has=function(e){return F(this,e).has(e)},b.prototype.set=function(e,t){return F(this,e).set(e,t),this},M.prototype.add=M.prototype.push=function(e){return this.__data__.set(e,a),this},M.prototype.has=function(e){return this.__data__.has(e)};var w,H,V=(w=function(e){var t=S(e,G);return t.length&&t[0]===e[0]?(function(e,t,o){for(var a=o?l:T,n=e[0].length,r=e.length,i=r,s=Array(r),E=1/0,_=[];i--;){var u=e[i];i&&t&&(u=S(u,d(t))),E=g(u.length,E),s[i]=!o&&(t||n>=120&&u.length>=120)?new M(i&&u):void 0}u=e[0];var I=-1,A=s[0];e:for(;++I{e=o.nmd(e);var a="__lodash_hash_undefined__",n=9007199254740991,r="[object Arguments]",i="[object Array]",s="[object Boolean]",E="[object Date]",_="[object Error]",T="[object Function]",l="[object Map]",S="[object Number]",u="[object Object]",d="[object Promise]",c="[object RegExp]",I="[object Set]",A="[object String]",O="[object Symbol]",N="[object WeakMap]",m="[object ArrayBuffer]",R="[object DataView]",p=/^\[object .+?Constructor\]$/,h=/^(?:0|[1-9]\d*)$/,f={};f["[object Float32Array]"]=f["[object Float64Array]"]=f["[object Int8Array]"]=f["[object Int16Array]"]=f["[object Int32Array]"]=f["[object Uint8Array]"]=f["[object Uint8ClampedArray]"]=f["[object Uint16Array]"]=f["[object Uint32Array]"]=!0,f[r]=f[i]=f[m]=f[s]=f[R]=f[E]=f[_]=f[T]=f[l]=f[S]=f[u]=f[c]=f[I]=f[A]=f[N]=!1;var L="object"==typeof o.g&&o.g&&o.g.Object===Object&&o.g,C="object"==typeof self&&self&&self.Object===Object&&self,D=L||C||Function("return this")(),g=t&&!t.nodeType&&t,v=g&&e&&!e.nodeType&&e,y=v&&v.exports===g,P=y&&L.process,B=(function(){try{return P&&P.binding&&P.binding("util")}catch(e){}})(),b=B&&B.isTypedArray;function M(e,t){for(var o=-1,a=null==e?0:e.length;++os))return!1;var _=r.get(e);if(_&&r.get(t))return _==t;var T=-1,l=!0,S=2&o?new me:void 0;for(r.set(e,t),r.set(t,e);++T-1},Oe.prototype.set=function(e,t){var o=this.__data__,a=he(o,e);return a<0?(++this.size,o.push([e,t])):o[a][1]=t,this},Ne.prototype.clear=function(){this.size=0,this.__data__={hash:new Ae,map:new(re||Oe),string:new Ae}},Ne.prototype.delete=function(e){var t=Pe(this,e).delete(e);return this.size-=t?1:0,t},Ne.prototype.get=function(e){return Pe(this,e).get(e)},Ne.prototype.has=function(e){return Pe(this,e).has(e)},Ne.prototype.set=function(e,t){var o=Pe(this,e),a=o.size;return o.set(e,t),this.size+=o.size==a?0:1,this},me.prototype.add=me.prototype.push=function(e){return this.__data__.set(e,a),this},me.prototype.has=function(e){return this.__data__.has(e)},Re.prototype.clear=function(){this.__data__=new Oe,this.size=0},Re.prototype.delete=function(e){var t=this.__data__,o=t.delete(e);return this.size=t.size,o},Re.prototype.get=function(e){return this.__data__.get(e)},Re.prototype.has=function(e){return this.__data__.has(e)},Re.prototype.set=function(e,t){var o=this.__data__;if(o instanceof Oe){var a=o.__data__;if(!re||a.length<199)return a.push([e,t]),this.size=++o.size,this;o=this.__data__=new Ne(a)}return o.set(e,t),this.size=o.size,this};var be=te?function(e){return null==e?[]:(e=Object(e),(function(e,t){for(var o=-1,a=null==e?0:e.length,n=0,r=[];++o-1&&e%1==0&&e-1&&e%1==0&&e<=n}function Ye(e){var t=typeof e;return null!=e&&("object"==t||"function"==t)}function ze(e){return null!=e&&"object"==typeof e}var xe=b?(function(e){return function(t){return e(t)}})(b):function(e){return ze(e)&&Ve(e.length)&&!!f[fe(e)]};function Ke(e){return null!=(t=e)&&Ve(t.length)&&!He(t)?pe(e):ge(e);var t}e.exports=function(e,t){return Ce(e,t)}},3096:(e,t,o)=>{var a="Expected a function",n=/^\s+|\s+$/g,r=/^[-+]0x[0-9a-f]+$/i,i=/^0b[01]+$/i,s=/^0o[0-7]+$/i,E=parseInt,_="object"==typeof o.g&&o.g&&o.g.Object===Object&&o.g,T="object"==typeof self&&self&&self.Object===Object&&self,l=_||T||Function("return this")(),S=Object.prototype.toString,u=Math.max,d=Math.min,c=function(){return l.Date.now()};function I(e,t,o){var n,r,i,s,E,_,T=0,l=!1,S=!1,I=!0;if("function"!=typeof e)throw new TypeError(a);function N(t){var o=n,a=r;return n=r=void 0,T=t,s=e.apply(a,o)}function m(e){return T=e,E=setTimeout(p,t),l?N(e):s}function R(e){var o=e-_;return void 0===_||o>=t||o<0||S&&e-T>=i}function p(){var e=c();if(R(e))return h(e);E=setTimeout(p,(function(e){var o=t-(e-_);return S?d(o,i-(e-T)):o})(e))}function h(e){return E=void 0,I&&n?N(e):(n=r=void 0,s)}function f(){var e=c(),o=R(e);if(n=arguments,r=this,_=e,o){if(void 0===E)return m(_);if(S)return E=setTimeout(p,t),N(_)}return void 0===E&&(E=setTimeout(p,t)),s}return t=O(t)||0,A(o)&&(l=!!o.leading,i=(S="maxWait"in o)?u(O(o.maxWait)||0,t):i,I="trailing"in o?!!o.trailing:I),f.cancel=function(){void 0!==E&&clearTimeout(E),T=0,n=_=r=E=void 0},f.flush=function(){return void 0===E?s:h(c())},f}function A(e){var t=typeof e;return!!e&&("object"==t||"function"==t)}function O(e){if("number"==typeof e)return e;if((function(e){return"symbol"==typeof e||(function(e){return!!e&&"object"==typeof e})(e)&&"[object Symbol]"==S.call(e)})(e))return NaN;if(A(e)){var t="function"==typeof e.valueOf?e.valueOf():e;e=A(t)?t+"":t}if("string"!=typeof e)return 0===e?e:+e;e=e.replace(n,"");var o=i.test(e);return o||s.test(e)?E(e.slice(2),o?2:8):r.test(e)?NaN:+e}e.exports=function(e,t,o){var n=!0,r=!0;if("function"!=typeof e)throw new TypeError(a);return A(o)&&(n="leading"in o?!!o.leading:n,r="trailing"in o?!!o.trailing:r),I(e,t,{leading:n,maxWait:t,trailing:r})}},9566:(e,t,o)=>{var a=o(8764).Buffer;e.exports=i,e.exports.decode=i,e.exports.encode=function(e){e=Object.assign({},e);let t=new Set;e.xt&&"string"==typeof e.xt&&t.add(e.xt);e.xt&&Array.isArray(e.xt)&&(t=new Set(e.xt));e.infoHashBuffer&&t.add(`urn:btih:${e.infoHashBuffer.toString("hex")}`);e.infoHash&&t.add(`urn:btih:${e.infoHash}`);e.infoHashV2Buffer&&t.add(e.xt=`urn:btmh:1220${e.infoHashV2Buffer.toString("hex")}`);e.infoHashV2&&t.add(`urn:btmh:1220${e.infoHashV2}`);const o=Array.from(t);1===o.length&&(e.xt=o[0]);o.length>1&&(e.xt=o);e.publicKeyBuffer&&(e.xs=`urn:btpk:${e.publicKeyBuffer.toString("hex")}`);e.publicKey&&(e.xs=`urn:btpk:${e.publicKey}`);e.name&&(e.dn=e.name);e.keywords&&(e.kt=e.keywords);e.announce&&(e.tr=e.announce);e.urlList&&(e.ws=e.urlList,delete e.as);e.peerAddresses&&(e["x.pe"]=e.peerAddresses);let a="magnet:?";return Object.keys(e).filter((e=>2===e.length||"x.pe"===e)).forEach(((t,o)=>{const n=Array.isArray(e[t])?e[t]:[e[t]];n.forEach(((e,n)=>{(o>0||n>0)&&("kt"!==t&&"so"!==t||0===n)&&(a+="&"),"dn"===t&&(e=encodeURIComponent(e).replace(/%20/g,"+")),"tr"!==t&&"as"!==t&&"ws"!==t||(e=encodeURIComponent(e)),"xs"!==t||e.startsWith("urn:btpk:")||(e=encodeURIComponent(e)),"kt"===t&&(e=encodeURIComponent(e)),"so"!==t&&(a+="kt"===t&&n>0?`+${e}`:`${t}=${e}`)})),"so"===t&&(a+=`${t}=${r.compose(n)}`)})),a};const n=o(5017),r=o(7500);function i(e){const t={},o=e.split("magnet:?")[1];let i;if((o&&o.length>=0?o.split("&"):[]).forEach((e=>{const o=e.split("=");if(2!==o.length)return;const a=o[0];let n=o[1];"dn"===a&&(n=decodeURIComponent(n).replace(/\+/g," ")),"tr"!==a&&"xs"!==a&&"as"!==a&&"ws"!==a||(n=decodeURIComponent(n)),"kt"===a&&(n=decodeURIComponent(n).split("+")),"ix"===a&&(n=Number(n)),"so"===a&&(n=r.parse(decodeURIComponent(n).split(","))),t[a]?(Array.isArray(t[a])||(t[a]=[t[a]]),t[a].push(n)):t[a]=n})),t.xt){(Array.isArray(t.xt)?t.xt:[t.xt]).forEach((e=>{if(i=e.match(/^urn:btih:(.{40})/))t.infoHash=i[1].toLowerCase();else if(i=e.match(/^urn:btih:(.{32})/)){const e=n.decode(i[1]);t.infoHash=a.from(e,"binary").toString("hex")}else(i=e.match(/^urn:btmh:1220(.{64})/))&&(t.infoHashV2=i[1].toLowerCase())}))}if(t.xs){(Array.isArray(t.xs)?t.xs:[t.xs]).forEach((e=>{(i=e.match(/^urn:btpk:(.{64})/))&&(t.publicKey=i[1].toLowerCase())}))}return t.infoHash&&(t.infoHashBuffer=a.from(t.infoHash,"hex")),t.infoHashV2&&(t.infoHashV2Buffer=a.from(t.infoHashV2,"hex")),t.publicKey&&(t.publicKeyBuffer=a.from(t.publicKey,"hex")),t.dn&&(t.name=t.dn),t.kt&&(t.keywords=t.kt),t.announce=[],("string"==typeof t.tr||Array.isArray(t.tr))&&(t.announce=t.announce.concat(t.tr)),t.urlList=[],("string"==typeof t.as||Array.isArray(t.as))&&(t.urlList=t.urlList.concat(t.as)),("string"==typeof t.ws||Array.isArray(t.ws))&&(t.urlList=t.urlList.concat(t.ws)),t.peerAddresses=[],("string"==typeof t["x.pe"]||Array.isArray(t["x.pe"]))&&(t.peerAddresses=t.peerAddresses.concat(t["x.pe"])),t.announce=Array.from(new Set(t.announce)),t.urlList=Array.from(new Set(t.urlList)),t.peerAddresses=Array.from(new Set(t.peerAddresses)),t}},6499:e=>{e.exports={"error-container":"error-container-OJnoc","error-image":"error-image-qU9Qo","error-message":"error-message-kW59Z","buttons-container":"buttons-container-tQonN","button-container":"button-container-vLSQK",label:"label-Up_te"}},9448:e=>{e.exports={"fade-in":"fade-in-pFkt_","toasts-container":"toasts-container-oKECy",router:"router-_65XU","error-container":"error-container-VZXwH","loader-container":"loader-container-vwvnb"}},8135:e=>{e.exports={"addon-details-container":"addon-details-container-ZQqDB","title-container":"title-container-fR02m",icon:"icon-ScXNu",logo:"logo-BujW_","name-container":"name-container-Gfhqw",name:"name-XNqfo",version:"version-w_xoN","section-container":"section-container-l3YaI","section-header":"section-header-bs8iy","section-label":"section-label-rYxQh","transport-url-label":"transport-url-label-EW7I5","disclaimer-label":"disclaimer-label-IGdd3"}},355:e=>{e.exports={"addon-details-modal-container":"addon-details-modal-container-_bwQ0","addon-details-container":"addon-details-container-AmNx2","addon-details-message-container":"addon-details-message-container-VEzeN","cancel-button":"cancel-button-luYIO","install-button":"install-button-XUzqz","uninstall-button":"uninstall-button-X2JXr"}},4520:e=>{e.exports={"button-container":"button-container-HNufV"}},1726:e=>{e.exports={"checkbox-container":"checkbox-container-heGq4",icon:"icon-NUvac"}},4809:e=>{e.exports={"color-picker-container":"color-picker-container-deFkW"}},5461:e=>{e.exports={"color-input-container":"color-input-container-jRZsi","transparent-label-container":"transparent-label-container-Tx2fI","transparent-label":"transparent-label-omLaY","color-picker-container":"color-picker-container-C4puR"}},9684:e=>{e.exports={"main-nav-bars-container":"main-nav-bars-container-fA7pO","horizontal-nav-bar":"horizontal-nav-bar-x5sxp","vertical-nav-bar":"vertical-nav-bar-JNw53","nav-content-container":"nav-content-container-VHwOU"}},4661:e=>{e.exports={"meta-item-container":"meta-item-container-drt6V","poster-shape-poster":"poster-shape-poster-F_CO5","poster-container":"poster-container-Fruke","poster-shape-square":"poster-shape-square-UCby3","poster-shape-landscape":"poster-shape-landscape-BPmb1","poster-image-layer":"poster-image-layer-CdxrT","poster-image":"poster-image-lt9zC","placeholder-icon":"placeholder-icon-uYwsv","play-icon-layer":"play-icon-layer-_75Lo","play-icon":"play-icon-d9_ll","progress-bar-layer":"progress-bar-layer-r81Qx","progress-bar":"progress-bar-E3QY9","title-bar-container":"title-bar-container-DFXJK","title-label":"title-label-dZZ_A","menu-label-container":"menu-label-container-dlL1I",icon:"icon-IfJ81"}},5883:e=>{e.exports={"action-button-container":"action-button-container-TmbQ2","icon-container":"icon-container-hvLw4",icon:"icon-DG4TM","label-container":"label-container-eh2bk",label:"label-YhHvD"}},7621:e=>{e.exports={"meta-links-container":"meta-links-container-wSrm1","label-container":"label-container-zWFke","links-container":"links-container-o4RUG","link-container":"link-container-HUDqV"}},6506:e=>{e.exports={"meta-preview-placeholder-container":"meta-preview-placeholder-container-AQ4ld","meta-info-container":"meta-info-container-pEOFb","logo-container":"logo-container-g5eNB","duration-release-info-container":"duration-release-info-container-lNaI6","duration-container":"duration-container-x2E01","release-info-container":"release-info-container-PEmeu","description-container":"description-container-yGOO4","description-label-container":"description-label-container-G_0pj","genres-container":"genres-container-v3H7A","genres-header-container":"genres-header-container-lsPLU","genre-label-container":"genre-label-container-z7kU8","action-buttons-container":"action-buttons-container-U3sbl","action-button-container":"action-button-container-xJmjB","action-button-icon":"action-button-icon-E7Epc","action-button-label":"action-button-label-R7UPL"}},6037:e=>{e.exports={"meta-preview-container":"meta-preview-container-bgBNf",compact:"compact-Wbl4Q","meta-info-container":"meta-info-container-tlmcb",logo:"logo-X9v1A","logo-placeholder":"logo-placeholder-kIy0x","runtime-release-info-container":"runtime-release-info-container-lXo3K","release-info-label":"release-info-label-XmqSY","runtime-label":"runtime-label-B29EN","description-container":"description-container-eSGft","action-buttons-container":"action-buttons-container-qQrnO","action-button":"action-button-R44aX","background-image-layer":"background-image-layer-GstuA","background-image":"background-image-B0d6i","imdb-button-container":"imdb-button-container-qCbl7",icon:"icon-MBu8k",label:"label-_DfnK","name-container":"name-container-HsS4c","meta-links":"meta-links-mTHUo","share-prompt":"share-prompt-F8qOC"}},7841:e=>{e.exports={"meta-row-placeholder-container":"meta-row-placeholder-container-wpHNk","header-container":"header-container-GCHdB","title-container":"title-container-Bjp93","see-all-container":"see-all-container-FnlIf",label:"label-dU3S2",icon:"icon-FLhtv","meta-items-container":"meta-items-container-dbGXx","meta-item":"meta-item-IegjY","poster-container":"poster-container-RlQMV","title-bar-container":"title-bar-container-YJZrl","title-label":"title-label-Ka1vs"}},676:e=>{e.exports={"meta-row-container":"meta-row-container-ucOuu","header-container":"header-container-RherZ","title-container":"title-container-SJ0nR","see-all-container":"see-all-container-HlJ4b",label:"label-isJw8",icon:"icon-PO0GH","message-container":"message-container-bIcjN","meta-items-container":"meta-items-container-TqzFs","meta-item":"meta-item-x28TU","poster-shape-poster":"poster-shape-poster-B1QR0","poster-shape-square":"poster-shape-square-m5r_O","poster-shape-landscape":"poster-shape-landscape-_FSOH"}},1621:e=>{e.exports={"modal-container":"modal-container-jZglc","modal-dialog-container":"modal-dialog-container-QgsId","close-button-container":"close-button-container-QrgQo",icon:"icon-hRjWc","title-container":"title-container-wqhp3","modal-dialog-content":"modal-dialog-content-ChXwF","buttons-container":"buttons-container-EJKJF","action-button":"action-button-bi6FL",label:"label-_ADoX"}},7409:e=>{e.exports={"label-container":"label-container-ZHk2S",label:"label-kz1K0",icon:"icon-YGvLz","modal-container":"modal-container-BQwj3","menu-container":"menu-container-Z1Pou","option-container":"option-container-yVj1o","no-options-container":"no-options-container-NYx9Z"}},8147:e=>{e.exports={"nav-menu-container":"nav-menu-container-VSzwW","user-info-container":"user-info-container-BR8yb","avatar-container":"avatar-container-jmlBM","email-container":"email-container-fvFrL","email-label":"email-label-WBX2T","logout-button-container":"logout-button-container-hSW_i","logout-label":"logout-label-dUa8B","nav-menu-section":"nav-menu-section-oMELF","nav-menu-option-container":"nav-menu-option-container-gZ1gT",icon:"icon-OSgm6","nav-menu-option-label":"nav-menu-option-label-XNuY6"}},7551:e=>{e.exports={"search-bar-container":"search-bar-container-TNPzI","search-input":"search-input-aOiJ2","placeholder-label":"placeholder-label-Irklk","submit-button-container":"submit-button-container-jPP5J",icon:"icon-FT4bG"}},4887:e=>{e.exports={"horizontal-nav-bar-container":"horizontal-nav-bar-container-jFw5Y","logo-container":"logo-container-fnFzY",logo:"logo-RVSxt",spacing:"spacing-jzj7t",title:"title-_UxXH","search-bar":"search-bar-NopQ6","button-container":"button-container-B23qB","back-button-container":"back-button-container-K9AwF",icon:"icon-wrBcp","menu-button-container":"menu-button-container-WWcwa"}},9842:e=>{e.exports={"nav-tab-button-container":"nav-tab-button-container-r8HUb",icon:"icon-vxKmB",label:"label-mc9eB",logo:"logo-ST06l"}},7636:e=>{e.exports={"vertical-nav-bar-container":"vertical-nav-bar-container-AsGLM","nav-tab-button":"nav-tab-button-noMv6"}},2168:e=>{e.exports={"pagination-input-container":"pagination-input-container-vXhi6","next-button-container":"next-button-container-zNwG6","prev-button-container":"prev-button-container-qmJ1m",icon:"icon-UoyQ9","label-container":"label-container-VwInD",label:"label-cJKC1"}},9192:e=>{e.exports={background:"background-FNyrF",icon:"icon-XXj2q"}},194:e=>{e.exports={"label-container":"label-container-iBMb9","menu-container":"menu-container-bfvDO","menu-direction-top-left":"menu-direction-top-left-KpAQN","menu-direction-bottom-left":"menu-direction-bottom-left-Uw06K","menu-direction-top-right":"menu-direction-top-right-jOtwq","menu-direction-bottom-right":"menu-direction-bottom-right-XZ9Ch"}},3109:e=>{e.exports={"search-bar-container":"search-bar-container-Vb_fz","search-input":"search-input-BWyeG",icon:"icon-poa62"}},330:e=>{e.exports={"search-bar-container":"search-bar-container-MpNBA","search-input":"search-input-ge2wu",icon:"icon-Z_Hni"}},4530:e=>{e.exports={"share-prompt-container":"share-prompt-container-YsJwl","buttons-container":"buttons-container-Oc7PG","button-container":"button-container-oMOnv",icon:"icon-FVvQH",label:"label-iOGrs","facebook-button":"facebook-button-KaNwb","twitter-button":"twitter-button-pJka2","url-container":"url-container-fMSp4","url-text-input":"url-text-input-Yka4x","copy-button":"copy-button-ShwCB"}},5036:e=>{e.exports={"active-slider-within":"active-slider-within-lQFc1","slider-container":"slider-container-aRzVq","track-before":"track-before-FwOXh",track:"track-jWhBI",thumb:"thumb-tfDk6",layer:"layer-FqnD7"}},7985:e=>{e.exports={"warning-container":"warning-container-FIITF","warning-statement":"warning-statement-I7pdD","warning-button":"warning-button-zlx_V","warning-label":"warning-label-XJnBc"}},5725:e=>{e.exports={"text-input":"text-input-jR2Nr"}},9775:e=>{e.exports={"toast-item-container":"toast-item-container-nG0uk",success:"success-eIDTa","icon-container":"icon-container-rjAiH",icon:"icon-Y4I_O",error:"error-quyOd","info-container":"info-container-xD9V6","title-container":"title-container-VFReJ","message-container":"message-container-znkCj","close-button-container":"close-button-container-YtyYE"}},2638:e=>{e.exports={"addon-container":"addon-container-lC5KN","logo-container":"logo-container-ZcSSC",logo:"logo-WrsGF",icon:"icon-GxVbY","info-container":"info-container-AdMB6","name-container":"name-container-qIAg8","version-container":"version-container-zdPyN","types-container":"types-container-DaOrg","description-container":"description-container-v7Jhe","buttons-container":"buttons-container-g0xXr","action-buttons-container":"action-buttons-container-xMVmz","configure-button-container":"configure-button-container-VwVAQ","install-button-container":"install-button-container-yfcq5","share-button-container":"share-button-container-s3gwP","uninstall-button-container":"uninstall-button-container-oV4Yo",label:"label-OnWh2"}},5531:e=>{e.exports={"addons-container":"addons-container-ogGYu","addons-content":"addons-content-zhFBl","selectable-inputs-container":"selectable-inputs-container-tUul1","add-button-container":"add-button-container-SkafT",icon:"icon-HsyZS","add-button-label":"add-button-label-NN6bu","select-input-container":"select-input-container-KqG8N",spacing:"spacing-wH1w5","search-bar":"search-bar-k7MXd","filter-button":"filter-button-lLJ1X","filter-icon":"filter-icon-LUDTS","message-container":"message-container-GBw0P","addons-list-container":"addons-list-container-Ovr2Z",addon:"addon-whmdO","filters-modal":"filters-modal-w6oWY","add-addon-modal-container":"add-addon-modal-container-KR5ny",notice:"notice-UQkO1","addon-url-input":"addon-url-input-ucetZ","cancel-button":"cancel-button-R2AxR","share-modal-container":"share-modal-container-DkzPM","title-container":"title-container-La49g",logo:"logo-PmYDP","name-container":"name-container-m_Sz0",name:"name-YD0xd",version:"version-wuAFB","share-prompt-container":"share-prompt-container-vaK4P"}},969:e=>{e.exports={"board-container":"board-container-DTN_b","board-content-container":"board-content-container-ToQTz","board-content":"board-content-nPWv1","board-row":"board-row-CoJrZ","board-warning-container":"board-warning-container-a4m04","board-row-landscape":"board-row-landscape-FRGXx","board-row-poster":"board-row-poster-QPQqC","board-row-square":"board-row-square-pgaZ3","continue-watching-row":"continue-watching-row-ZiNSa"}},820:e=>{e.exports={"discover-container":"discover-container-L6OGL","discover-content":"discover-content-CRsRg","catalog-container":"catalog-container-VNK_T","selectable-inputs-container":"selectable-inputs-container-IRz50","select-input":"select-input-CHDbe","filter-container":"filter-container-BVkqT","filter-icon":"filter-icon-zlFnX","missing-addon-warning-container":"missing-addon-warning-container-IXGuv","warning-label":"warning-label-f19Jg","install-button":"install-button-SmJe1",label:"label-ToW4S","message-container":"message-container-Zv9eF",image:"image-txC9E","message-label":"message-label-mRyRX","meta-items-container":"meta-items-container-n8vNz","meta-item-placeholder":"meta-item-placeholder-wxG4I","poster-container":"poster-container-Dch4R","title-bar-container":"title-bar-container-dtDnk","title-label":"title-label-vHdQd","meta-preview-container":"meta-preview-container-CoWs5","selectable-inputs-modal":"selectable-inputs-modal-ChpOa"}},6947:e=>{e.exports={"consent-checkbox-container":"consent-checkbox-container-WV60T",label:"label-l3LSw",link:"link-UppYg"}},9070:e=>{e.exports={"password-reset-modal-container":"password-reset-modal-container-KzJPQ","credentials-text-input":"credentials-text-input-ncrIR","error-message":"error-message-DkekN","cancel-button":"cancel-button-AneJE"}},8999:e=>{e.exports={"intro-container":"intro-container-tkNS6","form-container":"form-container-HMlEh","logo-container":"logo-container-W49kt",logo:"logo-WJ36F",name:"name-BNo9R","form-button":"form-button-vyqqj",icon:"icon-L_6b6",label:"label-uHD7L","facebook-button":"facebook-button-LZ_kG","login-form-button":"login-form-button-DqJUV","login-label":"login-label-AelYq","credentials-text-input":"credentials-text-input-QMCZz","forgot-password-link-container":"forgot-password-link-container-ygZqb","forgot-password-link":"forgot-password-link-NxNUD","error-message":"error-message-cKdzB","submit-button":"submit-button-x3L8z","guest-login-button":"guest-login-button-D8DWZ","signup-form-button":"signup-form-button-UGmSk","loading-modal-container":"loading-modal-container-eLyTm","loader-container":"loader-container-oe8rU",flash:"flash-wUFXY"}},1596:e=>{e.exports={"library-container":"library-container-zM_bj","library-content":"library-content-PgX4O","selectable-inputs-container":"selectable-inputs-container-hR3or","select-input-container":"select-input-container-H1VZ1","filter-container":"filter-container-oRBlw","filter-icon":"filter-icon-ZhMyS",spacing:"spacing-Rdiyt","pagination-input":"pagination-input-DvMtv","pagination-input-placeholder":"pagination-input-placeholder-vZeuq","message-container":"message-container-MhY5t","no-user-message-container":"no-user-message-container-KMLpE","login-button-container":"login-button-container-RoEh7",label:"label-QqYmf",image:"image-csRHm","message-label":"message-label-UExl3","meta-items-container":"meta-items-container-IKrND","selectable-inputs-modal":"selectable-inputs-modal-rHlo7"}},1384:e=>{e.exports={"stream-placeholder-container":"stream-placeholder-container-T1nxv","addon-container":"addon-container-pm1P0","addon-name":"addon-name-zAOKP","info-container":"info-container-Z1Dl6","description-container":"description-container-ZOMcn","play-icon":"play-icon-MXqj3"}},3458:e=>{e.exports={"stream-container":"stream-container-JPdah","play-icon":"play-icon-w1yb5","addon-name-container":"addon-name-container-IZ2De","thumbnail-container":"thumbnail-container-ptbAk",thumbnail:"thumbnail-whoms","placeholder-icon":"placeholder-icon-znYz0","addon-name":"addon-name-tC8PX","info-container":"info-container-TihQo","progress-bar-container":"progress-bar-container-ADRp_","progress-bar":"progress-bar-XrEBL","stream-containerfocus":"stream-containerfocus-xiWVj"}},6796:e=>{e.exports={"streams-list-container":"streams-list-container-xYMJo","message-container":"message-container-f9_L4",image:"image-rIyu6",label:"label-luvnO","select-input-container":"select-input-container-irGn_","streams-container":"streams-container-bbSc4","install-button-container":"install-button-container-Q60yJ",icon:"icon-SoFgF"}},2180:e=>{e.exports={"seasons-bar-placeholder-container":"seasons-bar-placeholder-container-M81RN","next-season-button":"next-season-button-oGnlT","prev-season-button":"prev-season-button-TCbOq",icon:"icon-UzQjF",label:"label-lmBnj","seasons-popup-label-container":"seasons-popup-label-container-r2UDB","seasons-popup-label":"seasons-popup-label-xBinL","seasons-popup-icon":"seasons-popup-icon-p1T5d"}},6351:e=>{e.exports={"seasons-bar-container":"seasons-bar-container-nOZjG","next-season-button":"next-season-button-RrYAq","prev-season-button":"prev-season-button-bs1GQ",label:"label-uJbfD",icon:"icon-_ZBEE","seasons-popup-label-container":"seasons-popup-label-container-fZcu4"}},5507:e=>{e.exports={"video-placeholder-container":"video-placeholder-container-uDsav","info-container":"info-container-KTKtT","name-container":"name-container-Jvesr","released-container":"released-container-uoc4E"}},4486:e=>{e.exports={"video-container":"video-container-UBBpR","thumbnail-container":"thumbnail-container-n_jp7",thumbnail:"thumbnail-MiS3K","placeholder-icon":"placeholder-icon-LzVIO","info-container":"info-container-szYxP","title-container":"title-container-EMXpV","flex-row-container":"flex-row-container-ExEua","released-container":"released-container-zA91y","upcoming-watched-container":"upcoming-watched-container-y_ijd","upcoming-container":"upcoming-container-ASE1L","watched-container":"watched-container-LCso2","flag-label":"flag-label-dIdBb","progress-bar-container":"progress-bar-container-gMpiB","progress-bar":"progress-bar-Yhl4z","context-menu-content":"context-menu-content-MGBhW","context-menu-option-container":"context-menu-option-container-VlNjD","context-menu-option-label":"context-menu-option-label-hOUnH"}},2759:e=>{e.exports={"videos-list-container":"videos-list-container-NepX5","message-container":"message-container-_hhmQ",image:"image-_xAbP",label:"label-Ff1_X","seasons-bar":"seasons-bar-Ma8vp","search-bar":"search-bar-mZHWa","videos-container":"videos-container-msX8s"}},9514:e=>{e.exports={"metadetails-container":"metadetails-container-K_Dqa","nav-bar":"nav-bar-MH6Vk","metadetails-content":"metadetails-content-Uz5EV","vertical-nav-bar":"vertical-nav-bar-B39nq","background-image-layer":"background-image-layer-wJa90","background-image":"background-image-tSjYu","meta-message-container":"meta-message-container-MJZN5",image:"image-R1LcJ","message-label":"message-label-Uz4_P","meta-preview":"meta-preview-ES0h3",spacing:"spacing-rgIYg","streams-list":"streams-list-Y1lCM","videos-list":"videos-list-nE0LJ","meta-extension-modal-container":"meta-extension-modal-container-gHjqy","meta-extension-modal-iframe":"meta-extension-modal-iframe-GGHlm"}},5142:e=>{e.exports={"not-found-container":"not-found-container-Q1qsP","nav-bar":"nav-bar-Eu3_y","not-found-content":"not-found-content-z_Eza","not-found-image":"not-found-image-Qab4G","not-found-label":"not-found-label-mmwyZ"}},1391:e=>{e.exports={"buffering-loader-container":"buffering-loader-container-P7S0m","buffering-loader":"buffering-loader-fMSpb"}},8982:e=>{e.exports={"seek-bar-container":"seek-bar-container-JGGTa",slider:"slider-hBDOf",label:"label-QFbsS"}},6708:e=>{e.exports={"volume-slider":"volume-slider-G_xAt"}},578:e=>{e.exports={"control-bar-container":"control-bar-container-xsWA7","seek-bar":"seek-bar-I7WeY","control-bar-buttons-container":"control-bar-buttons-container-SWhkU","control-bar-button":"control-bar-button-FQUsj",icon:"icon-qy6I6","volume-slider":"volume-slider-U9jfo",spacing:"spacing-p8NJQ","control-bar-buttons-menu-button":"control-bar-buttons-menu-button-h0MWd","control-bar-buttons-menu-container":"control-bar-buttons-menu-container-M6L0_"}},3800:e=>{e.exports={"info-menu-container":"info-menu-container-R1QKH",stream:"stream-MY2Oy"}},5626:e=>{e.exports={"next-video-popup-container":"next-video-popup-container-H4wnL","slide-fade-in":"slide-fade-in-rk2M8","poster-container":"poster-container-tXZjA","poster-image":"poster-image-2D6wg","placeholder-icon":"placeholder-icon-fu1rK","info-container":"info-container-KLOMx","details-container":"details-container-bUOTZ",name:"name-sIiDL",description:"description-gIXiC","buttons-container":"buttons-container-iYrpZ",spacing:"spacing-iFwsN","button-container":"button-container-i4F7t","play-button":"play-button-Dluk6",icon:"icon-N3Ewm",label:"label-zOq_w"}},1530:e=>{e.exports={"option-container":"option-container-m_jZq",icon:"icon-krR0X",label:"label-cmqqu"}},8183:e=>{e.exports={"options-menu-container":"options-menu-container-qlzLt"}},4805:e=>{e.exports={option:"option-_O96j",icon:"icon-kqaPF",label:"label-FEOiu"}},9715:e=>{e.exports={"speed-menu-container":"speed-menu-container-ABjzc",title:"title-Hu2Dm","options-container":"options-container-DNn3D",option:"option-GcPlB"}},3283:e=>{e.exports={"discrete-input-container":"discrete-input-container-CMThy",header:"header-n0jWL","input-container":"input-container-TNuI2","button-container":"button-container-ciSB5",icon:"icon-JDltr","option-label":"option-label-tjeeT"}},3889:e=>{e.exports={"subtitles-menu-container":"subtitles-menu-container-PxBRZ","languages-container":"languages-container-NS7H9","subtitles-settings-container":"subtitles-settings-container-LhRGS","variants-container":"variants-container-XglzH","languages-header":"languages-header-jGNcK","settings-header":"settings-header-eaWnm","variants-header":"variants-header-TsVSR","languages-list":"languages-list-sxIwI","variants-list":"variants-list-yZo6B","language-option":"language-option-O1Yr9","variant-option":"variant-option-t7_LA","language-label":"language-label-FjjqA","variant-label":"variant-label-opjnP",icon:"icon-I1Ruh","no-variants-container":"no-variants-container-q6u1Q","no-variants-label":"no-variants-label-RmDKZ",spacing:"spacing-AWJpt","discrete-input":"discrete-input-fXELp","advanced-button":"advanced-button-YGN5T"}},4236:e=>{e.exports={"video-container":"video-container-v9_vA",video:"video-tkpQm"}},674:e=>{e.exports={"videos-menu-container":"videos-menu-container-ATzKq"}},9731:e=>{e.exports={"player-container":"player-container-wIELK",immersed:"immersed-Y0hn1","control-bar-layer":"control-bar-layer-m2jto","menu-layer":"menu-layer-HZFG9","nav-bar-layer":"nav-bar-layer-r9HT5",layer:"layer-qalDW","error-layer":"error-layer-RCEZC","error-label":"error-label-FPIMw","playlist-button":"playlist-button-CB2WC",icon:"icon-aMPEE",label:"label-njZqk"}},5532:e=>{e.exports={"search-container":"search-container-uXEFf","search-content":"search-content-LX6un","search-row":"search-row-EQLaD","search-hints-container":"search-hints-container-FHpPM","search-hint-container":"search-hint-container-kd8iX",icon:"icon-fOZZl",label:"label-l6wxz","message-container":"message-container-YAunr",image:"image-Xuwya","message-label":"message-label-K8LPz","search-row-landscape":"search-row-landscape-o3Lfv","search-row-poster":"search-row-poster-m7CUE","search-row-square":"search-row-square-VesJA"}},9819:e=>{e.exports={"settings-container":"settings-container-b0DCu","settings-content":"settings-content-lLXmk","side-menu-container":"side-menu-container-NG17D","side-menu-button":"side-menu-button-vbkJ1",selected:"selected-yhdng",spacing:"spacing-fpLUM","version-info-label":"version-info-label-uMkm7","sections-container":"sections-container-EUKAe","section-container":"section-container-twzKQ","section-title":"section-title-Nt71Z","option-container":"option-container-EGlcv","user-info-option-container":"user-info-option-container-oRLJc","avatar-container":"avatar-container-YWq9E","email-logout-container":"email-logout-container-kYQDM","email-label-container":"email-label-container-oVmiO","logout-button-container":"logout-button-container-jLrU2","email-label":"email-label-Q__sJ","logout-label":"logout-label-zo4ES","user-panel-container":"user-panel-container-kkrJG","user-panel-label":"user-panel-label-beAQl","option-input-container":"option-input-container-NPgpT","option-name-container":"option-name-container-exGMI",icon:"icon-REQkK",label:"label-FFamJ","button-container":"button-container-ENMae","multiselect-container":"multiselect-container-w0c9l","link-container":"link-container-ERYsD","checkbox-container":"checkbox-container-R9LLN","color-input-container":"color-input-container-WclA_","info-container":"info-container-wfFcS",selectable:"selectable-eucrJ","configure-input-container":"configure-input-container-PMyIY","configure-button-container":"configure-button-container-xGFgg","shortcut-container":"shortcut-container-ZSm5O","configure-server-url-modal-container":"configure-server-url-modal-container-vSL44","server-url-input":"server-url-input-Dfazw","cancel-button":"cancel-button-iydew"}},2703:(e,t,o)=>{"use strict";var a=o(414);function n(){}function r(){}r.resetWarningCache=n,e.exports=function(){function e(e,t,o,n,r,i){if(i!==a){var s=new Error("Calling PropTypes validators directly is not supported by the `prop-types` package. Use PropTypes.checkPropTypes() to call them. Read more at http://fb.me/use-check-prop-types");throw s.name="Invariant Violation",s}}function t(){return e}e.isRequired=e;var o={array:e,bool:e,func:e,number:e,object:e,string:e,symbol:e,any:e,arrayOf:t,element:e,elementType:e,instanceOf:t,node:e,objectOf:t,oneOf:t,oneOfType:t,shape:t,exact:t,checkPropTypes:r,resetWarningCache:n};return o.PropTypes=o,o}},5697:(e,t,o)=>{e.exports=o(2703)()},414:e=>{"use strict";e.exports="SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED"},4971:function(e,t,o){var a;e=o.nmd(e),(function(n){t&&t.nodeType,e&&e.nodeType;var r="object"==typeof o.g&&o.g;r.global!==r&&r.window!==r&&r.self;var i,s=2147483647,E=36,_=/^xn--/,T=/[^\x20-\x7E]/,l=/[\x2E\u3002\uFF0E\uFF61]/g,S={overflow:"Overflow: input needs wider integers to process","not-basic":"Illegal input >= 0x80 (not a basic code point)","invalid-input":"Invalid input"},u=Math.floor,d=String.fromCharCode;function c(e){throw RangeError(S[e])}function I(e,t){for(var o=e.length,a=[];o--;)a[o]=t(e[o]);return a}function A(e,t){var o=e.split("@"),a="";return o.length>1&&(a=o[0]+"@",e=o[1]),a+I((e=e.replace(l,".")).split("."),t).join(".")}function O(e){for(var t,o,a=[],n=0,r=e.length;n=55296&&t<=56319&&n65535&&(t+=d((e-=65536)>>>10&1023|55296),e=56320|1023&e),t+=d(e)})).join("")}function m(e,t){return e+22+75*(e<26)-((0!=t)<<5)}function R(e,t,o){var a=0;for(e=o?u(e/700):e>>1,e+=u(e/t);e>455;a+=E)e=u(e/35);return u(a+36*e/(e+38))}function p(e){var t,o,a,n,r,i,_,T,l,S,d,I=[],A=e.length,O=0,m=128,p=72;for((o=e.lastIndexOf("-"))<0&&(o=0),a=0;a=128&&c("not-basic"),I.push(e.charCodeAt(a));for(n=o>0?o+1:0;n=A&&c("invalid-input"),((T=(d=e.charCodeAt(n++))-48<10?d-22:d-65<26?d-65:d-97<26?d-97:E)>=E||T>u((s-O)/i))&&c("overflow"),O+=T*i,!(T<(l=_<=p?1:_>=p+26?26:_-p));_+=E)i>u(s/(S=E-l))&&c("overflow"),i*=S;p=R(O-r,t=I.length+1,0==r),u(O/t)>s-m&&c("overflow"),m+=u(O/t),O%=t,I.splice(O++,0,m)}return N(I)}function h(e){var t,o,a,n,r,i,_,T,l,S,I,A,N,p,h,f=[];for(A=(e=O(e)).length,t=128,o=0,r=72,i=0;i=t&&I<_&&(_=I);for(_-t>u((s-o)/(N=a+1))&&c("overflow"),o+=(_-t)*N,t=_,i=0;is&&c("overflow"),I==t){for(T=o,l=E;!(T<(S=l<=r?1:l>=r+26?26:l-r));l+=E)h=T-S,p=E-S,f.push(d(m(S+h%p,0))),T=u(h/p);f.push(d(m(T,0))),r=R(o,N,a==n),o=0,++a}++o,++t}return f.join("")}i={version:"1.3.2",ucs2:{decode:O,encode:N},decode:p,encode:h,toASCII:function(e){return A(e,(function(e){return T.test(e)?"xn--"+h(e):e}))},toUnicode:function(e){return A(e,(function(e){return _.test(e)?p(e.slice(4).toLowerCase()):e}))}},void 0===(a=function(){return i}.call(t,o,t,e))||(e.exports=a)})()},2587:e=>{"use strict";function t(e,t){return Object.prototype.hasOwnProperty.call(e,t)}e.exports=function(e,o,a,n){o=o||"&",a=a||"=";var r={};if("string"!=typeof e||0===e.length)return r;var i=/\+/g;e=e.split(o);var s=1e3;n&&"number"==typeof n.maxKeys&&(s=n.maxKeys);var E=e.length;s>0&&E>s&&(E=s);for(var _=0;_=0?(T=d.substr(0,c),l=d.substr(c+1)):(T=d,l=""),S=decodeURIComponent(T),u=decodeURIComponent(l),t(r,S)?Array.isArray(r[S])?r[S].push(u):r[S]=[r[S],u]:r[S]=u}return r}},2361:e=>{"use strict";var t=function(e){switch(typeof e){case"string":return e;case"boolean":return e?"true":"false";case"number":return isFinite(e)?e:"";default:return""}};e.exports=function(e,o,a,n){return o=o||"&",a=a||"=",null===e&&(e=void 0),"object"==typeof e?Object.keys(e).map((function(n){var r=encodeURIComponent(t(n))+a;return Array.isArray(e[n])?e[n].map((function(e){return r+encodeURIComponent(t(e))})).join(o):r+encodeURIComponent(t(e[n]))})).join(o):n?encodeURIComponent(t(n))+a+encodeURIComponent(t(e)):""}},7673:(e,t,o)=>{"use strict";t.decode=t.parse=o(2587),t.encode=t.stringify=o(2361)},4448:(e,t,o)=>{"use strict";var a=o(7294),n=o(3840);function r(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,o=1;o
الاتصال بنا .","WEBSITE_P2P_CONTACT_EXTRA":"سنكون سعداء لمساعدتك على دمج المحتوى الخاص بك مع Stremio!","WEBSITE_P2P":"من حين لآخر ، تأتي تقنية تغير اسم اللعبة. لقد استثمرنا الكثير من الوقت والجهد في بناء محرك دفق الفيديو من نظير إلى نظير (P2P) الذي يوفر أداءً رائعًا وتعدد الاستخدامات للتكيف مع أي حالة استخدام. \\n اتصل بنا للحصول على فيديو P2P ممكّن بواسطة DRM عند الطلب أو البث المباشر.","WEBSITE_THOUGHTS":"الأفكار التي نشاركها:","WEBSITE_SPREAD":"انشر الخبر حول Stremio:","WEBSITE_CONTACT":"اتصل بنا ، يسعدنا أن نسمع منك!","WEBSITE_OPENSOURCE":"لمشاريعنا مفتوحة المصدر ، انتقل إلى","WEBSITE_BITCOIN":"تبرع بعملة البيتكوين:","WEBSITE_FAQ":"أسئلة مكررة","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"أسئلة","WEBSITE_TOS":"تعليمات الاستخدام","WEBSITE_LEGAL":"قانوني","WEBSITE_PAGE_ABOUT":"حول","WEBSITE_PAGE_BECOME_PARTNER":"كن شريكا معنا","WEBSITE_ALL_YOU_CAN_WATCH":"حرية المشاهدة \\n كل ما تريد.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"ما هو Stremio ?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio هو مركز شامل لتجميع محتوى الفيديو. اكتشف ، نظم ، وشاهد الفيديو من جميع أنواع المصادر على أي جهاز تملكه.","WEBSITE_WHAT_IS_STREMIO_P2":"الأفلام والبرامج التلفزيونية والمسلسلات والتلفزيون المباشر أو قنوات الويب مثل YouTube و Twitch.tv - يمكنك العثور على كل هذا على Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio هو مركز وسائط حديث يمثل حلاً شاملاً لترفيه الفيديو الخاص بك. يمكنك اكتشاف محتوى الفيديو ومشاهدته وتنظيمه من الوظائف الإضافية سهلة التثبيت.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"الأفلام والبرامج التلفزيونية والتلفزيون المباشر أو قنوات الويب - ابحث عن كل هذا على Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"استمتع على جميع أجهزة الوسائط الخاصة بك","WEBSITE_DEVICES_COLLECT":"جمع من Stremio","WEBSITE_DEVICES_IMPORT_FB":"استيراد من فيسبوك","WEBSITE_DEVICES_LOCAL":"اضافة من القرص الصلب","WEBSITE_JOIN_THE_PARTY_NOW":"انضم إلى الحفلة الآن","WEBSITE_DEVICES_ALL":"سهل الاستخدام على جميع أجهزتك؛","WEBSITE_EXTENDABLE_CATALOG":"مجموعة كبيرة من الفيديوهات يمكنك توسعتها ايضا","WEBSITE_ORGANIZE_YOUR_MEDIA":"ميزات رائعة لتنظيم الوسائط الخاصة بك ؛","WEBSITE_AS_SEEN_ON":"كما شوهد على","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"معلومات عنا","WEBSITE_LINK_TECHNOLOGY":"التقنية","WEBSITE_LINK_APPS":"التطبيقات","WEBSITE_LINK_DOWNLOADS":"تنزيل","WEBSITE_MORE":"المزيد","WEBSITE_LINK_ADDONS":"الأضافات","WEBSITE_LINK_ADDON_SDK":"حزمة مساعدة لأنشاء أضافات","WEBSITE_LINK_CONTRIBUTE":"ساهم معنا","WEBSITE_LINK_COMMUNITY":"المجتمع","WEBSITE_LINK_BLOG":"المدونة","WEBSITE_MORE_MORE":"... و المزيد","WEBSITE_LINK_HELP":"مركز المساعدة","WEBSITE_LINK_CONTACTS":"استفسارات الأعمال","WEBSITE_LINK_TOS":"البنود و الشروط","WEBSITE_LINK_PRAVACY":"سياسة الخصوصية","WEBSITE_SUBSCRIBE":"اشتراك","WEBSITE_NEWSLETTER":"انضم إلى النشرة الإخبارية لدينا لأشياء مذهلة","WEBSITE_PLACEHOLDER_EMAIL":"بريدك الالكتروني","WEBSITE_COMMUNITY":"المجتمع","WEBSITE_LINK_PRAVACY_LEGAL":"الخصوصية والقانونية","WEBSITE_WHY":"لماذا نقوم بذلك","WEBSITE_WHY_P1":"في Stremio ، نأتي إلى العمل كل يوم لأننا نريد حل مشكلة مهمة لصناعة الفيديو عند الطلب. يتم نشر الكثير من المحتوى الجديد كل دقيقة بحيث يكاد يكون من المستحيل العثور على ما تريده.","WEBSITE_WHY_P2":"نحن نساعد الأشخاص على التنقل في هذا العالم الضخم من الترفيه بالفيديو واكتشاف محتوى جديد للاستمتاع به. تجمع تطبيقاتنا بين الأفلام والمسلسلات والبث التلفزيوني المباشر وقنوات الويب والمزيد. نحن ملتزمون بجعل من السهل جدًا على المستخدمين العثور على العناوين والمذيعين الذين يحبونهم.","WEBSITE_WHY_P3":"يمكنك استخدام خدمتنا على أي جهاز وفي أي وقت ، مما يجعل Stremio مركز الترفيه بالفيديو الوحيد الذي ستحتاج إليه على الإطلاق.","WEBSITE_TEAM":"الفريق","WEBSITE_TEAM_P":"فريق Stremio صغير ولكنه قوي: بين العشرة منا ، نقوم بالبرمجة بلغات X ، ونتشارك الخبرات في تطوير البرمجيات ، وتصميم UI و UX ، والتسويق والإعلان ، والأعمال التجارية والشركات الناشئة.","WEBSITE_FEATURES":"المميزات","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"اكتشف محتوى جديدًا بسهولة","WEBSITE_FEATURES_DISCOVER_P":"اكتشف بسهولة الأفلام والبرامج التلفزيونية والمسلسلات والقنوات الجديدة لمشاهدتها. تصفح حسب الفئة أو النوع أو التصنيف أو الحداثة أو ما إلى ذلك ، أو ببساطة اكتب اسمًا للبحث عنه. يجعل Stremio العثور على محتوى فيديو جديد بمثابة قطعة من الكعكة.","WEBSITE_FEATURES_ALL_CONTENT":"كل محتوى الفيديو الخاص بك على شاشة واحدة","WEBSITE_FEATURES_ALL_CONTENT_P1":"تعرف على الأفلام أو المسلسلات أو مقاطع الفيديو التي لم تنته واستمر في مشاهدتها ؛ الحصول على إشعارات بشأن الحلقات والإصدارات الجديدة ؛ وتصفح التوصيات التي ستحصل عليها بناءً على عادات المشاهدة لديك.","WEBSITE_FEATURES_LIBRARY":"تنظيم مكتبة الفيديو الخاصة بك","WEBSITE_FEATURES_LIBRARY_P1":"أضف أي عنوان إلى مكتبة Stremio الخاصة بك بنقرة واحدة وابحث عن طريقك حول المحتوى الخاص بك ، مرتبة بدقة حسب النوع أو الحداثة أو الترتيب الأبجدي.","WEBSITE_FEATURES_CALENDAR":"تتبع كل ما تشاهده","WEBSITE_FEATURES_CALENDAR_P1":"احصل على تصور تقويم لجميع الأفلام والمسلسلات التي تضيفها إلى مكتبتك. قم بتصدير تقويم Stremio الخاص بك وقم بمزامنته حتى تعرف دائمًا موعد حلقة جديدة أو عرض أول.","WEBSITE_FEATURES_BIG_SCREEN":"استمتع بمحتوى الفيديو الخاص بك على شاشة أكبر","WEBSITE_FEATURES_BIG_SCREEN_P1":"قم بإرسال كل ما تشاهده إلى جهاز آخر - سواء كان هاتفًا أو جهازًا لوحيًا أو تلفزيونًا بنقرة واحدة.","WEBSITE_FEATURES_SOURCES":"شاهد الفيديو من عدة مصادر مختلفة","WEBSITE_FEATURES_SOURCES_P":"قم بتثبيت الوظائف الإضافية الرسمية والمجتمعية للاستمتاع بمقاطع الفيديو التي يتم الحصول عليها من العديد من المزودين المختلفين - كل ذلك في تطبيق واحد أنيق وسهل الاستخدام.","WEBSITE_CREATE_AN_ADDON":"أنشاء أضافة","WEBSITE_FEATURES_SYNC":"قم بمزامنة مكتبتك عبر أجهزة مختلفة واستأنف التشغيل","WEBSITE_FEATURES_SYNC_P1":"قم بتسجيل الدخول بحسابك عبر جميع أجهزتك واستمتع بمكتبتك ووظائفك الإضافية والتشغيل والتقويم المتزامن.","WEBSITE_FEATURES_EXTENDABLE":"كتالوج الفيديو القابل للتوسيع من خلال الإضافات","WEBSITE_FEATURES_EXTENDABLE_P1":"يوفر كتالوج Stremio الملحق عددًا من الوظائف الإضافية لتثبيت ومشاهدة مجموعة متنوعة من محتوى الفيديو. يتضمن ذلك الأفلام والعروض والتلفزيون المباشر والرياضة والأخبار والبودكاست وقنوات الويب وألعاب الفيديو والمزيد.","WEBSITE_FEATURES_AUTO_SUBS":"ترجمة تلقائية","WEBSITE_FEATURES_AUTO_SUBS_P1":"من خلال إضافات الترجمة لدينا ، ستحصل تلقائيًا على خيارات محددة للغتك المفضلة.","WEBSITE_FEATURES_CHROMECAST":"الإرسال إلى Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"استمتع بمحتوى الفيديو الخاص بك على شاشة أكبر أو قم فقط بإرسال كل ما تشاهده إلى جهاز آخر.","WEBSITE_FEATURES_KEEP_TRACK":"تتبع البرامج التلفزيونية وقنوات الويب المفضلة لديك","WEBSITE_FEATURES_KEEP_TRACK_P1":"احصل على تصور للتقويم وإشعارات لحلقات جديدة من مسلسلاتك وقنوات الويب المفضلة لديك.","WEBSITE_FEATURES_POWER_USER":"ميزات المستخدم القوي","WEBSITE_FEATURES_POWER_USER_P1":"التشغيل على مشغل خارجي","WEBSITE_FEATURES_POWER_USER_P2":"التشغيل من رابط تورنيت","WEBSITE_FEATURES_POWER_USER_P3":"الاستيراد إلى مكتبتك من الإعجابات على Facebook أو القرص المحلي","WEBSITE_ADD_ONS":"الأضافات","WEBSITE_ADD_ONS_P1":"يتم الحصول على كل محتوى الفيديو الذي يوفره Stremio من خلال نظام إضافي - لم يتم تضمين أي محتوى أو مزود محتوى في التطبيق.","WEBSITE_ADD_ONS_P2":"هناك مجموعتان من الاضافات المتاحة: الاضافات الرسمية واضافات المجتمع.","WEBSITE_ADD_ONS_P3":"يتم تطوير الاضافات الرسمية واستضافتها بواسطة Stremio ، بينما يتم إنشاء الإضافات المجتمعية من قبل أعضاء مجتمعنا ، والذين يستضيفونها أيضًا.","WEBSITE_ADDONS_OFFICIAL":"الاضافات الرسمية","WEBSITE_ADDONS_WATCHUB":"قم ببث أفلامك ومسلسلاتك وعروضك المفضلة من مزودين مثل iTunes و Hulu و Amazon وغيرها من خدمات المملكة المتحدة / الولايات المتحدة.","WEBSITE_ADDONS_YOUTUBE":"شاهد قنوات YouTube المفضلة لديك بدون إعلانات واحصل على إشعارات بالتحميلات الجديدة من المساهمين الذين تتابعهم.","WEBSITE_ADDONS_FILMON":"شاهد البث التلفزيوني المباشر والأفلام والتلفزيون الاجتماعي مجانًا. 600 قناة تلفزيونية و 45000 فيلم مجاني ووثائقي وغير ذلك.","WEBSITE_ADDONS_OPENSUBTITLES":"ترجمات الأفلام والتلفزيون بلغات متعددة ، يتم تحميل آلاف الترجمات المترجمة كل يوم.","WEBSITE_ADDONS_COMMUNITY":"أضافات المجتمع","WEBSITE_ADDONS_FILMON_VOD":"شاهد الفيديو عند الطلب من Filmon.tv","WEBSITE_ADDONS_TWICH":"شاهد البث المباشر من Twitch.tv - منصة بث فيديو لصناعة الرياضة الإلكترونية.","WEBSITE_ADDONS_VODO":"مشاهدة الافلام المستقلة تماما مجانا.","WEBSITE_ADDONS_NETFLIX":"شاهد أفلام Netflix ومسلسلات الويب.","WEBSITE_ADDONS_CREATE":"أنشىء أضافة جديدة","WEBSITE_ADDONS_CREATE_P1":"إذا كنت ترغب في ذلك ، يمكنك تطوير الأضافة الخاصة بك. بهذه الطريقة ، يمكنك منح نفسك ومجتمعنا إمكانية الوصول إلى محتوى فيديو جديد والوصول إلى جمهور مستهدف جديد من ملايين المستخدمين حول العالم.","WEBSITE_ADDONS_START_CREATE":"للبدء ، قم بزيارة صفحة Stremio Addon SDK:","WEBSITE_DOWNLOADS":"التنزيلات","WEBSITE_DOWNLOADS_P1":"للحصول على الأداء الأمثل ، نوصي باستخدام أحدث إصدار متوفر من تطبيقات Stremio. ومع ذلك ، إذا كنت ترغب في استخدام إصدار أقدم لسبب ما ، فيمكنك تنزيله من هنا.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio لأجهزة الويندوز","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio لأجهزة ماك","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio لأجهزة لينوكس","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio لأجهزة الأندرويد","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio لأجهزة الأيفون (نسخة محدودة)","WEBSITE_CONTRIBUTE":"شارك في التطوير","WEBSITE_CONTRIBUTE_P1":"منصة Stremio مفتوحة المصدر ويمكنك بسهولة إنشاء أضافات للمحتوى غير المصدر حاليًا.","WEBSITE_CONTRIBUTE_WHY":"لماذا يجب عليك إنشاء أضافة ؟","WEBSITE_CONTRIBUTE_WHY_P1":"الوصول إلى جمهور جديد لمحتوى الفيديو الخاص بك","WEBSITE_CONTRIBUTE_WHY_P2":"تنمو قاعدة مستخدمي Stremio بسرعة - خلال العام الأول من الإطلاق ، اكتسبت Stremio مليون مستخدم حول العالم ، وفي العام الثاني من وجود النظام الأساسي ارتفع هذا الرقم إلى 2.5 مليون.","WEBSITE_CONTRIBUTE_WHY_P3":"باستخدام الأضافة الخاصة بك ، يمكنك الوصول بسهولة إلى هذا الجمهور وتوزيع محتوى الفيديو الخاص بك عليهم.","WEBSITE_CONTRIBUTE_ALL":"شاهد أفلامك ومقاطع الفيديو والمسلسلات والقنوات المفضلة لديك في مكان واحد.","WEBSITE_CONTRIBUTE_ALL_P1":"هل أنت معجب بنوع معين من المحتوى غير متوفر على Stremio حتى الآن؟ قم بإنشاء أضافة له واستمتع بمشاهدة مقاطع الفيديو المفضلة لديك في واحدة من أكبر وأسهل مراكز الترفيه في السوق من حيث الاستخدام.","WEBSITE_CONTRIBUTE_ALL_P2":"علاوة على ذلك ، ستحصل على الامتنان اللانهائي لأعضاء مجتمع Stremio الآخرين المتشابهين في التفكير.","WEBSITE_CONTRIBUTE_MONETIZE":"استثمر الأضافة الخاصة بك واكسب المال بمساعدته","WEBSITE_CONTRIBUTE_MONETIZE_P1":"بمجرد تطوير أضافة جديدة لـ Stremio ، يمكنك بسهولة تحقيق الدخل منه من خلال عدد من الطرق المختلفة. إذا كنت تفكر في ذلك ، فلا تتردد في الاتصال بنا على","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":"- يسعدنا أن نتشاور معك وننصحك بخيارات تحقيق الدخل الإضافي.","WEBSITE_CONTRIBUTE_TRANSLATE":"كن مترجمًا متطوعًا","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"إذا كنت ترغب في الاستمتاع بتطبيقات Stremio بلغات مختلفة ، فيمكنك الانضمام إلى مجتمع المترجمين المتطوعين لدينا. يساعدوننا في إضافة إصدارات من Stremio بعدة لغات مختلفة.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"هل أنت متشوق للبدء؟","WEBSITE_TRANSALTE_STREMIO":"ترجمة Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"المجتمع الرسمي","WEBSITE_COMMUNITY_OFFICIALS_P1":"كن جزءًا من مجتمع Stremio المتنامي. تابعنا على وسائل التواصل الاجتماعي ولا تخجل من إلقاء التحية - فنحن نحب أن نسمع من معجبينا!","WEBSITE_COMMUNITY_UNOFFICIALS":"المجتمعات غير الرسمية","STREMIO_COMMUNITY_NL":"Stremio في هولندا","STREMIO_COMMUNITY_BRASIL":"Stremio في البرازيل","STREMIO_COMMUNITY_GERMANY":"Stremio في المانيا","STREMIO_COMMUNITY_BELGIUM":"Stremio في بلجيكا","STREMIO_COMMUNITY_FRANCE":"Stremio في فرنسا","STREMIO_COMMUNITY_PORTUGAL":"Stremio في البرتغال","STREMIO_COMMUNITY_ITALY":"Stremio في ايطاليا","STREMIO_COMMUNITY_UK":"Stremio الممكلة المتحدة","STREMIO_COMMUNITY_USA":"Stremio الولايات المتحدة الأمريكية","STREMIO_COMMUNITY_MEXICO":"Stremio في المكسيك","STREMIO_COMMUNITY_ADDONS":"Stremio أضافات","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"الشركاء والداعمون","WEBSITE_COMMUNITY_GOODIES":"الأشياء الجيدة Stremio","WEBSITE_COMMUNITY_WALLPAPERS":"خلفيات الشاشة","WEBSITE_COMMUNITY_ART":"معرض الفنون","WEBSITE_LINK_ART":"معرض الفنون","WEBSITE_CONTACT_US":"تواصل معنا","WEBSITE_CONTACT_US_P1":"إذا كان لديك أي أسئلة أو تعليقات أو اقتراحات ، فلا تتردد في الاتصال بنا من خلال نموذج الاتصال أدناه.","WEBSITE_CONTACT_US_P2":"ضع في اعتبارك أننا موجودون في بلغاريا ، لذا قد يكون هناك تأخير في معالجة استفسارك بسبب اختلافات المنطقة الزمنية.","WEBSITE_CONTACT_US_SUCCESS":"تم ارسال رسالتك. سنعود إليك في أقرب وقت ممكن.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"يرجى إدخال البريد الإلكتروني الصحيح!","WEBSITE_CONTACT_US_Q_RELATED_TO":"بماذا يتعلق سؤالك؟","WEBSITE_CONTACT_US_Q_OS":"ما هو نظام التشغيل الخاص بك؟","WEBSITE_CONTACT_US_PH_EMAIL":"بريدك الالكتروني","WEBSITE_CONTACT_US_PH_MESSAGE":"رسالتك","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"أرسال","WEBSITE_CONTACT_US_Q_1":"كيفية التثبيت ؟","WEBSITE_CONTACT_US_Q_2":"كيفية ألغاء التثبيت ؟","WEBSITE_CONTACT_US_Q_3":"(HTML) كيف تصنع اللازانيا؟","WEBSITE_CONTACT_US_Q_4":"أضافات","WEBSITE_CONTACT_US_OS_1":"ويندوز","WEBSITE_CONTACT_US_OS_2":"ماك","WEBSITE_CONTACT_US_OS_3":"لينوكس","WEBSITE_CONTACT_US_OS_4":"أندرويد","WEBSITE_CONTACT_US_OS_5":"أيفون","WEBSITE_TECHNOLOGY":"التقنية","WEBSITE_TECHNOLOGY_P1":"نحن نحب التكنولوجيا والعلم المجنون.
هنا ما يمدك بالطاقة Stremio (كلها مفتوحة المصدر).","WEBSITE_TECHNOLOGY_P_QT":"تطوير البرامج عبر الأنظمة الأساسية في أفضل حالاتها.","WEBSITE_TECHNOLOGY_P_MPV":"مشغل وسائط مجاني ومفتوح المصدر ومتعدد المنصات.","WEBSITE_TECHNOLOGY_P_RN":"يتيح لك React Native إنشاء تطبيقات جوال باستخدام JavaScript فقط.","WEBSITE_TECHNOLOGY_P_VLC":"إطار الوسائط المضمن في التطبيق للحصول على الوسائط المتعددة.","WEBSITE_TECHNOLOGY_P_REALM":"Realm هي منصة متنقلة وبديل لبيانات SQLite & Core.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js هي بيئة تشغيل JavaScript مفتوحة المصدر ومتعددة المنصات.","WEBSITE_TECHNOLOGY_P_RUST":"Rust هي لغة برمجة نظام متعددة النماذج تركز على السلامة ، وخاصة التزامن الآمن.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"المساهمة في المشروع","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"هناك طريقتان يمكنك من خلالهما المساهمة في Stremio ومساعدتنا على تحسين المنتج.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"يمكنك التبرع بمهاراتك اللغوية القيمة من خلال ترجمة المنصة ...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"أو","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... يمكنك توظيف مهاراتك في البرمجة لإنشاء إضافات مجتمعية.","WEBSITE_TRANSLATE_STREMIO":"ترجمة Stremio","WEBSITE_404_OH_NO":"عذرًا! الصفحة التي تبحث عنها ليست هنا ...","WEBSITE_GO_HOME":"الرئيسية","WEBSITE_LINK_OTHER_DOWNLOADS":"تنزيلات أخرى","WEBSITE_FAQ_ABR":"أسئلة متكررة","WEBSITE_SUPPORT":"الدعم","WEBSITE_DOWNLOAD_4_0_BETA":"قم بتنزيل Stremio 4 beta الآن","WEBSITE_GET_FOR_DESKTOP":"احصل عليه للكمبيوتر","WEBSITE_LINK_ADDON_COMPETITION":"منافسة الأضافات","WEBSITE_LINK_ART_CONTEST":"مسابقه الفنون","WEBSITE_MY_ACCOUNT":"حسابي الشخصي","WEBSITE_MAINPAGE_FAQ_001_H1":"ما هو Stremio ؟ ","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio هو مركز وسائط حديث يمنحك حرية مشاهدة كل ما تريد.","WEBSITE_MAINPAGE_FAQ_002_H1":"كيف يعمل؟","WEBSITE_MAINPAGE_FAQ_002_P1":"بمجرد تثبيت Stremio على جهازك وإنشاء حساب ، كل ما عليك فعله هو زيارة الكتالوج الإضافي وتثبيت أي أداة إضافية تريدها ، وأنت على ما يرام!","WEBSITE_MAINPAGE_FAQ_002_P2":"بعد ذلك ، يمكنك الانتقال إلى قسم الأكتشاف أو لوحة التحكم لبدء استكشاف المحتوى.","WEBSITE_MAINPAGE_FAQ_003_H1":"ماذا يمكنني أن أشاهد هنا؟","WEBSITE_MAINPAGE_FAQ_003_P1":"الكثير: الأفلام والبرامج التلفزيونية وقنوات الويب والرياضة والقنوات التلفزيونية والاستماع إلى البودكاست والمزيد. بفضل نظام الأضافات الخاص بنا ، يمكنك الوصول إلى مجموعة متنوعة من المحتويات.","WEBSITE_MAINPAGE_FAQ_004_H1":"هل Stremio مفتوح المصدر؟","WEBSITE_MAINPAGE_FAQ_004_P1":"يمكنك التحقق من بعض الروابط : ${1}برنامج سطح المكتب${2} و ${3}GitHub المنظمة${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"هل Stremio آمن؟","WEBSITE_MAINPAGE_FAQ_005_P1":"نعم: نظرًا لأنه برنامج مفتوح المصدر ، فإن الكود قابل للتدقيق بشكل عام ويمكنك مراجعته بنفسك.","WEBSITE_MAINPAGE_FAQ_006_H1":"ماذا عن خصوصيتي؟","WEBSITE_MAINPAGE_FAQ_006_P1":"نحترم خصوصية المستخدمين ولا نجمع أي بيانات شخصية إلى جانب الحد الأدنى الأساسي لإنشاء حسابك ومزامنته.","WEBSITE_MAINPAGE_FAQ_006_P2":"يوجد أيضًا ${1} وضع الضيف ${2} عند التسجيل ، والذي لا يتطلب أي بيانات على الإطلاق: في هذا الوضع ، لا يتم إجراء مكالمات إلى الواجهة الخلفية لدينا. ومع ذلك ، فإنه يأتي على حساب الميزات المفيدة ، مثل القدرة على مزامنة مكتبتك عبر الأجهزة.","WEBSITE_MAINPAGE_FAQ_007_H1":"هل يمكنني ارسال البث إلى التلفزيون الخاص بي؟","WEBSITE_MAINPAGE_FAQ_007_P1":"نعم ، نحن ندعم Chromecast ويمكنك الإرسال من تطبيقات سطح المكتب والأجهزة المحمولة (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"كم عدد الإضافات التي يمتلكها Stremio؟","WEBSITE_MAINPAGE_FAQ_008_P1":"اعتبارًا من أواخر عام 2019 ، أكثر من 50 - لمزيد من المعلومات ، راجع كتالوج الملحقات الخاصة بنا.","WEBSITE_MAINPAGE_FAQ_009_H1":"هل يمكن تمديد Stremio بما يتجاوز ما هو موجود في الكتالوج الإضافي؟","WEBSITE_MAINPAGE_FAQ_009_P1":"نعم ، يجب عليك التحقق مما يلي: ${1} PimpMyStremio ${2} ، ${3} مجتمعات Reddit ${4} ، ${5} Stremio Downloader ${6} ، إلخ.","WEBSITE_MAINPAGE_FAQ_010_H1":"ما هي الأجهزة التي يدعمها Stremio؟","WEBSITE_MAINPAGE_FAQ_010_P1":"لدينا تطبيقات سطح مكتب لأنظمة Windows و Mac و Linux. بالنسبة للجوال ، ندعم Android و iOS ، على الرغم من أن ضع في اعتبارك أن وظائف iOS محدودة (لا تدعم معظم الوظائف الإضافية).","WEBSITE_MAINPAGE_FAQ_010_P2":"هناك العديد من الأجهزة التي تعمل بنظام Android والتي يمكنك تشغيل Stremio عليها ، مثل NVIDIA Shield و Amazon Fire Stick ، ​​لكننا لا ندعمها رسميًا.","WEBSITE_MAINPAGE_FAQ_011_H1":"هل يمكنك إضافة محتوى معين إلى Stremio؟","WEBSITE_MAINPAGE_FAQ_011_P1":"عذرًا ، لا نقدم أي محتوى بأنفسنا ، ولكن كلما قمت بتثبيت المزيد من إضافات Stremio ، ستتمكن من العثور على المزيد من المحتوى.","WEBSITE_MAINPAGE_FAQ_012_H1":"هل يستطيع Stremio تشغيل روابط التورنيت ؟","WEBSITE_MAINPAGE_FAQ_012_P1":"نعم ، ويمكنه أيضًا تشغيل روابط HTTP العادية وملفات التورنت (السحب والإفلات).","WEBSITE_MAINPAGE_FAQ_013_H1":"هل يمكنني تنزيل مقطع فيديو ومشاهدته بلا إنترنت؟","WEBSITE_MAINPAGE_FAQ_013_P1":"تعد الميزة المتاحة في وضع عدم الاتصال ميزة قادمة ، ولكن إذا سمحت لـ Stremio بالتخزين المؤقت على جهازك (من لوحة الإعدادات) ، يمكنك مشاهدة مقاطع الفيديو لاحقًا دون اتصال.","WEBSITE_MAINPAGE_FAQ_014_H1":"لا شيء يعمل ، ساعدني!","WEBSITE_MAINPAGE_FAQ_014_P1":"هل أنت متأكد أنك قمت بتثبيت الوظائف الإضافية؟ إذا كانت الإجابة بنعم ، فراجع ${1} مركز المساعدة ${2} الخاص بنا.","WEBSITE_MAINPAGE_FAQ_015_H1":"كيف يحافظ Stremio على عمليات التطوير الخاصة به؟","WEBSITE_MAINPAGE_FAQ_015_P1":"نعرض إعلانات غير تدخلية من خلال ${1} AdEx ${2} ، وهي شركة من نفس الفريق المؤسس الذي يركز على الحفاظ على الخصوصية والإعلانات الشفافة.","WEBSITE_MAINPAGE_FAQ_015_P2":"لمزيد من الأسئلة ، انتقل إلى مركز المساعدة $ {1}${2}.","HELP_LEARN_MORE":"ساعدنا في معرفة المزيد عنك.","LIFESTYLE":"أسلوب الحياة","SPORTS":"الرياضة","FOOD_HEALTH":"الطعام والصحة","BEAUTY_FASHION":"جمال و موضة","NEWS":"أخبار","GAMING":"ألعاب","SCIENCE_EDUCATION":"علم و تعليم","MUSIC":"موسيقى","TRAVEL":"السفر","LATE_NIGHT":"أخر الليل","REALITY":"واقعي","COMEDY":"كوميديا","DIY":"كيف تفعلها بنفسك","TECH":"تقنية","CINEMA":"سينيما","CONTINUE":"متابعة","SLOW_LOADING":"تحميل بطيئ ؟","I_GIVE_UP":"أنا أستسلم","LEARN_MORE":"معرفة المزيد","POOR_SOURCE":"هذا المصدر غير متاح بشكل جيد أو أن اتصالك بالإنترنت ليس سريعًا بما يكفي","PICK_CATEGORIES_ERR":"عليك أن تختار 3 فئات على الأقل","ADJUST_TIMING":"ضبط التوقيت باستخدام","ADJUST_SIZE":"ضبط الحجم مع","SEARCH_ANYTHING":"يمكنك البحث عن أي شيء ...","ALL_CATEGORIES":"الجميع","SEARCH_CATEGORIES":"أفلام ومسلسلات ويوتيوب وتلفزيون","SEARCH_PERSONS":"الممثلين والمخرجين والكتاب","SEARCH_PROTOCOLS":"روابط HTTP و التورنيت","SEARCH_TYPES":"IMDB / TVDB روابط","WATCHED":"تمت المشاهدة","SHOW_LESS":"إظهار أقل","LAST_SEARCHES":"أخر عمليات البحث","CLEAR_HISTORY":"مسح السجل","CHOOSE_SOME":"اختر بعضًا من هذا:","NO_WEB_REMOTE":"تعذر تحميل Web Remote","STREMIO_OFFLINE":"Stremio غير متصل","STREMIO_EXPENSIVE_CONNECTION":"لقد اكتشفنا أنك تستخدم اتصال بيانات الجوال ، هل تريد المتابعة؟","USE_DATA":"استخدم البيانات","WARNING":"تحذير","MORE_INFO":"مزيد من المعلومات ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"جار التحميل ...","STREMIO_TV_BACK_TO_LANGUAGES":"رجوع إلى اللغات","STREMIO_TV_REMOTE":"ريموت","STREMIO_TV_GO_TO":"أذهب الى:","STREMIO_TV_OR_SCAN":"أو قم بمسح:","STREMIO_TV_ADDON_INSTRUCTIONS":"يرجى اتباع التعليمات لتثبيت الإضافات المفضلة لديك.","STREMIO_TV_LIVE_TV":"تلفاز مباشر","STREMIO_TV_RESUME_WATCHING":"تابع المشاهدة","STREMIO_TV_LOADING_BACKGROUND":"التحميل في الخلفية","STREMIO_TV_CHECKING_AUTHENTICATION":"التحقق من المصادقة","STREMIO_TV_LOADING_BOARD":"تحميل لوحة التحكم","STREMIO_TV_LOGIN_HEADER_LINE_1":"نريد لمستخدمينا الحصول على أفضل تجربة شخصية ممكنة مع برنامجنا.","STREMIO_TV_LOGIN_HEADER_LINE_2":"لهذا السبب نطلب منك التفضل بإنشاء و / أو تسجيل الدخول إلى حسابك.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"شكرا لتفهمك،","STREMIO_TV_LOGIN_FOOTER_LINE_2":"فريق Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"من أجل استخدام Web Remote مع الهاتف الذكي / الجهاز اللوحي / سطح المكتب:","STREMIO_TV_WIFI_SETUP":"Wi-Fi ضبط","STREMIO_TV_WIFI_HEADER_LINE_1":"لم يكتشف Stremio Circle اتصالاً بالإنترنت.","STREMIO_TV_WIFI_DETAILS_1":"الاتصال بـ:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"استخدم كلمة المرور:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"افتح متصفح الويب بالرابط:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"تلقائي","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"باخر مرة تمت المشاهدة","STREMIO_TV_LIBRARY_SORT_NAME":"بالاسم","STREMIO_TV_LIBRARY_TIMES_WATCHED":"بعدد مرات المشاهدة","STREMIO_TV_DETAILS_SEASON_NUMBER":"موسم ${1}","STREMIO_TV_STREAMS_LOADING":"حملت ${1} / ${2} الاضافات...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} االاضافة لازالت قيد التحميل...","STREMIO_TV_PLAYER_SETTINGS":"اعدادات المشغل","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"تاخير الترجمة","STREMIO_TV_PLAYER_AUDIO_DELAY":"تاخير الصوت","STREMIO_TV_PLAYER_VIDEO_SCALING":"مقياس الفيديو","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"فشل فتح الرابط الحارجي","STREMIO_TV_PLAYER_PLAY_IN_EXO":"تشغيل بـ ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"تشغيل بـ libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"استعمل stremio على هاتفك او حاسوبك واعد تثبيت او اضبط الاضافات ثم اضغط على \\"اعادة المزامنة\\"","STREMIO_TV_ADDONS_SUBTITLE":"ملاحظة: تاكد من استعمال نفس حساب stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"مزامنة الاضافات","STREMIO_TV_ADDONS_SYNC_SUCCESS":"تمت مزامنة الاضافات بنجاح","STREMIO_TV_ADDONS_SYNC_FAILED":"فشل مزامنة الاضافات","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"لم يتم تحميل الفهرس بعد ...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"تم تحديث لغة الواجهة","STREMIO_TV_SETTINGS_THEME_UPDATED":"تم تحديث المظهر","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"اللغة المفضلة","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"اللغة المفضلة الثانية","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"بعض انواع الفيديوهات قد لا تعمل","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"المزامنة التلقائية لعدد الاطارات","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"تلقائي","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"سريع","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"سريع جدا","STREMIO_TV_SETTINGS_SERVER_URL":"رابط سارفر المشاهدة","STREMIO_TV_SETTINGS_SERVER_VERSION":"اصدار السارفر","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"مجهول","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio اصدار","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"تغير رابط السارفر","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"لقراءت سايسة الخصوصة زر:","STREMIO_TV_SETTINGS_TOS_TEXT":"لقراءت الاحكام والشروط زر:","STREMIO_TV_NAV_SEARCH":"البحث","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"اكتشاف","STREMIO_TV_NAV_LIBRARY":"المكتبة","STREMIO_TV_NAV_MOVIES":"افلام","STREMIO_TV_NAV_SERIES":"مسلسلات","STREMIO_TV_NAV_CHANNELS":"قنوات","STREMIO_TV_NAV_TV":"قنوات تلفزيونية مباشرة","STREMIO_TV_NAV_SETTINGS":"الاعدادات","STREMIO_TV_NAV_ADDONS":"اضافات","STREMIO_TV_LOGIN_TITLE":"ربط الحساب","STREMIO_TV_LOGIN_EXPIRES_IN":"تنتهي الصلاحية في","STREMIO_TV_LOGIN_STEP_ONE":"امسح QR Code اعلاه او اذهب الى","STREMIO_TV_LOGIN_STEP_TWO":"تسجيل الدحول لحساب Stremio الخاص بك","STREMIO_TV_LOGIN_NEW_LINK":"طلب رابط جديد","STREMIO_TV_LOGIN_LINK_REFRESHED":"تم تجديث كود تسجيل الدحول","STREMIO_TV_SEARCH_PLACEHOLDER":"اكتب شيئا ما","STREMIO_TV_SEARCH_NO_ADDONS":"لم يتم طلب اي اضافة لهذا الفهرس!","STREMIO_TV_SEARCH_BUTTON":"بحث","STREMIO_TV_SEARCH_KEY_DEL":"حذف","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"مسح","STREMIO_TV_SEARCH_HISTORY_TITLE":"سجل البحث","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"يمكنك البحث عن عناوين, ممثلين, قنوات والمزيد ...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"مسح سجل البحث","STREMIO_TV_FILTERS_DESCRIPTION":"اختر احد الفلترات اسفله","FILTERS":"قلترات","SETTINGS":"الاعدادات","ACCOUNT":"الحساب","LOGOUT":"تسجيل الخروج","THEMES":"مظاهر","PLAYBACK":"العرض","PLAYBACK_SPEED":"سرعة العرض","AUDIO_TRACKS":"مسار صوت","VIDEOS":"فديوهات","SERVER":"سارفر","LINKS":"روابط","ABOUT":"حول","INTERFACE":"الواجهة","ANIMATIONS":"Animations","STATUS":"الحالة","LANGUAGE":"اللغة","SIZE":"الحجم","DELAY":"التاخير","BOLD":"عريض","TEXT_COLOR":"لون الكتابة","OUTLINE_COLOR":"لون الخط الخارجي","BACKGROUND_COLOR":"لون الخلفية","BACKGROUND_BLUR":"ضبابية الخلفية","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"التشعيل التلقائي للحلقة القادمة","PLAY_NOW":"شغل الان","MARK_AS_WATCHED":"تعليم كتمت مشاهدته","MARK_AS_UNWATCHED":"تعليم كلم تتم مشاهدته","REWIND_TO_BEGINNING":"اعادة من الاول","CONTINUE_WATCHING":"اكمل المشاهدة","ALL":"الكل","SECONDS":"ثواني","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"تعديل الرابط","NONE":"None","EMBEDDED":"مضمن","REMOTE_SWITCH_DEVICES":"تبديل الأجهزة","REMOTE_VIDEOS":"فيديوهات","REMOTE_ADJUST_TIMING":"ضبط التوقيت","REMOTE_ADJUST_SIZE":"ضبط الحجم","REMOTE_COULD_NOT_BE_LOADED":"تعذر تحميل Web Remote","REMOTE_RETRY":"أعادة المحاولة","TORRENT_PROFILE_DEFAULT":"إفتراضي","TORRENT_PROFILE_SOFT":"معتدل","TORRENT_PROFILE_FAST":"سريع","TORRENT_PROFILE_ULTRA_FAST":"فائقة السرعة","FAQ_001_H1":"ما هو Stremio؟","FAQ_001_P1":"Stremio هو برنامج مركز وسائط مصمم للترفيه بالفيديو مع وضع سهولة الاستخدام في الاعتبار. يسمح لك Stremio بتنظيم شاهد مجموعتك الخاصة من الأفلام والمسلسلات والقنوات والبث التلفزيوني المباشر.","FAQ_001_P2":"يقوم Stremio بجمع المحتوى الذي يعرضه لك من القرص المحلي ونظام الوظائف الإضافية الخاص بنا.","FAQ_001_P3":"سيُعلمك أيضًا عند ظهور حلقات / مقاطع فيديو / أفلام جديدة تهتم بها ، ويقدم لك توصيات بشأن الأفلام.","FAQ_02_H1":"كيف يقارن Stremio بـ Kodi و Plex؟","FAQ_02_P1":"نحن مستوحون من هذين البرنامجين. لكن لدينا أهدافًا مختلفة - يستهدف Stremio بشكل خاص الفيديو الترفيهي ، ويسعى جاهداً ليصبح الحل السائد لذلك من خلال كونه سهل الاستخدام للغاية.","FAQ_02_P2":"لن يكون Stremio أبدًا قابلاً للتخصيص وغنيًا بالميزات مثل Kodi و Plex ، ولكنه أسهل كثيرًا في الاستخدام. فقط ${1} احصل عليه واطلع على ${2} :)","FAQ_03_H1":"كيف يقارن Stremio بـ Netflix؟","FAQ_03_P1":"مرة أخرى ، يعد Netflix أحد مصادر إلهامنا. نحن نسعى جاهدين لتحقيق تجربة مستخدم Netflix ، بالإضافة إلى الكثير من الأشياء الجيدة المضافة. ولكن الأهم من ذلك ، أننا نمنحك حرية إدارة مكتبتك الخاصة وإضافة مصادر محتوى جديدة باستخدام نظام الملحق الخاص بنا.","FAQ_03_P2":"هذا يجعل Stremio قابلًا للتمديد بشكل لا نهائي ، لذلك عندما تستخدم Stremio ، فأنت لا تقتصر أبدًا على المحتوى الذي تقرر Netflix ترخيصه. على سبيل المثال ، من خلال Stremio ، يمكنك مشاهدة محتوى من $ {1} Filmon.tv ${2} ، ${3} Twitch.tv ${4} ، ${5} YouTube ${6} ، ${7} Vodo ${8} وحتى ${9} Netflix ${10} نفسها!","FAQ_04_H1":"كيف يقارن Stremio بـ Flipboard؟","FAQ_04_P1":"لا نتلقى هذا السؤال كثيرًا ، إلا عند التحدث إلى أشخاص مبتدئين :)","FAQ_04_P2":"يعد Stremio عن طريق تصميم مجمع محتوى ، مما يجعله بشكل أساسي Flipboard للفيديو. هذا واضح جدًا في قسم Board الخاص بنا ، والذي يمنحك كتالوجات وإشعارات حلقة جديدة / فيديو جديد لما تتابعه ، تمامًا مثل Flipboard.","FAQ_05_H1":"كيف يقارن Stremio بـ Popcorn Time؟","FAQ_05_P1":"يتشابه كل من Stremio و Popcorn Time في واجهة المستخدم ، لأنه لا توجد طرق عديدة لعمل كتالوجات فيديو ترفيهية بشكل صحيح :)","FAQ_05_P2":"ولكن بينما يركز Popcorn Time على بث التورنت من مصادر محددة ، فإن Stremio غير مقيد وهو مجرد مجمع محتوى - فهو غير مقيد بمصدر محتوى معين.","FAQ_05_P3":"علاوة على ذلك ، نحن لا نقدم أي إضافات تورنت افتراضيًا ، لذلك لا يغطي Stremio حالة استخدام Popcorn Time بالوظائف الرسمية.","FAQ_05_P4":"الفرق الملحوظ الآخر هو أن Popcorn Time مفتوح المصدر بالكامل ، بينما Stremio ${1} مفتوح المصدر جزئيًا ${2}.","FAQ_06_H1":"هل ستضيف هذا الفيلم / المسلسل؟","FAQ_06_P1":"لا آسف :(","FAQ_06_P2":"كما هو مذكور في معظم الأسئلة الأخرى ، لا يوفر Stremio أي محتوى بمفرده - تتم إضافة كل شيء من خلال نظام الوظائف الإضافية. في حالة وجود طلب محتوى ، يمكنك استخدام الزر إبلاغ في المشغل ، والذي سيرسل بريدًا إلكترونيًا إلى مؤلف الوظيفة الإضافية التي تستخدمها حاليًا.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"هل ستقوم بإنشاء أضافة لـ X؟","FAQ_08_P1":"إنه ممكن تمامًا.","FAQ_08_P2":"إذا كانت لديك فكرة عن أضافة ، فأرسل لنا سطرًا على ${1}office@stremio.com ${2} ، ولكن يُرجى التأكد من أن فكرة الملحق لن تنتهك أي حقوق طبع ونشر أو شروط استخدام.","FAQ_08_P3":"في الوقت الحالي ، الأشياء التالية في خارطة الطريق هي الإضافات لـ FandangoNOW ، فيديو Filmon.tv عند الطلب و Crunchyroll.","FAQ_09_H1":"هل يستخدم Stremio برنامج BitTorrent؟","FAQ_09_P1":"نعم ، يدعم Stremio BitTorrent كبروتوكول دفق. يمكنك استخدام ذلك إما مع أضافة تورنت ، أو عن طريق سحب وإفلات ملف .torrent في Stremio ، أو عن طريق لصق رابط تورينت في شريط البحث.","FAQ_09_P2":"يرجى ملاحظة أن الملحق الرسمي الوحيد الذي يستخدم BitTorrent هو ${1} Vodo ${2} ، والذي يوفر محتوى مستقل ، وكلها مسموح بتوزيعها باستخدام BitTorrent.","FAQ_09_P3":"نحن لا ندعم استخدام أي أدوات إضافية لطرف ثالث والتي قد تتيح انتهاك حقوق النشر.","FAQ_10_H1":"ما الذي يمكنني مشاهدته في Stremio باستخدام الإضافات الرسمية؟","FAQ_10_P1":"بشكل افتراضي ، يمكنك مشاهدة محتوى Filmon.tv و YouTube و Vodo داخل Stremio نفسها ، باستخدام مشغلها المضمن. بالإضافة إلى ذلك ، لدينا ملحق لـ Twitch.tv وعدد قليل من البرامج الأخرى.","FAQ_10_P2":"يوفر هذا مجتمعة مجموعة مختارة من:","FAQ_10_L1":"قنوات تلفزيونية شهيرة ، تقدمها Filmon.tv - على سبيل المثال E4 و BBC و Bollyworld TV","FAQ_10_L2":"كل شيء من YouTube - على سبيل المثال BBC News و Top Gear و Vevo و PewDiePie","FAQ_10_L3":"الأفلام المستقلة مع Vodo","FAQ_10_L4":"يتم بث الألعاب عبر الإنترنت باستخدام Twitch.tv","FAQ_10_P3":"بالإضافة إلى ذلك ، هناك العديد من مصادر المحتوى المتوفرة مع Guidebox ووظائف Netflix الإضافية ، والتي لا تعمل بالكامل داخل Stremio ، ولكنها ستعيد التوجيه إلى الخدمة المحددة. على سبيل المثال ، ستمنحك الوظيفة الإضافية Guidebox مجموعة مختارة من الأفلام التي يمكنك بثها في الولايات المتحدة مجانًا ، من خدمات مثل TubiTV و Crackle.","FAQ_11_H1":"لن يتم تثبيت Stremio ، فماذا أفعل؟","FAQ_11_P1":"إذا كنت تستخدم نظام التشغيل Windows ، فجرّب ${1} أداة التثبيت البديلة هذه ${2}.","FAQ_11_P2":"إذا كنت تستخدم نظام التشغيل Mac OS X ، فيرجى العلم أننا لا ندعم أي شيء أقدم من OS X Mavericks (10.9).","FAQ_11_P3":"إذا كنت تستخدم نظام Linux ، فاعلم أننا ندعم نظام Linux 64 بت (x64) فقط في الوقت الحالي.","FAQ_11_P4":"إذا كنت لا تزال غير قادر على حل مشكلتك ، فيرجى مراسلتنا على ${1} Facebook group ${2}.","FAQ_12_H1":"لماذا يشتكي برنامج مكافحة الفيروسات الخاص بي؟ هل Stremio آمن؟","FAQ_12_P1":"نؤكد لك أن Stremio هو ${1} 100٪ نظيف ${2}.","FAQ_12_P2":"يشكو برنامج مكافحة الفيروسات الخاص بك لأننا نقوم بتضمين إعلانات في أداة التثبيت الخاصة بنا ، والتي تتعرف عليها بعض برامج مكافحة الفيروسات على أنها أدوات إعلانية.","FAQ_12_P3":"إذا كنت لا تزال غير متأكد ، فيمكنك تجربة ${1} المثبت البديل ${2}.","FAQ_13_H1":"كيف يمكنني عمل أضافة جديدة ؟","FAQ_13_P1":"بالنسبة للمبتدئين ، نوصيك بالتحقق من وحدة نظام الإضافات ${1} الخاصة بنا ${2} على GitHub.","FAQ_13_P2":"بعد ذلك ، يمكنك اتباع البرنامج التعليمي ${1} Hello World ${2}.","FAQ_13_P3":"إذا لم تكن لديك أي مهارات برمجية ، فالرجاء نشر فكرتك على ${1} مجتمع Reddit ${2} والاتصال بنا لتقديم فكرة الملحق الخاص بك على ${3}office@stremio.com${4}.","FAQ_14_H1":"كيف يتم نشر الإضافات؟","FAQ_14_P1":"عندما تنشئ ملحقًا ومضيفًا ، وتضع حقل نقطة نهاية في البيان الخاص بك ، والذي يشير إلى عنوان ملحق يعمل ، فإن الوظيفة الإضافية ستنشر نفسها تلقائيًا في كتالوج ${1} Addon ${2} .","FAQ_14_P2":"يحدث هذا لأن جزء الخادم من وحدة stremio-addons يقوم تلقائيًا بإجراء مكالمة إلى واجهة برمجة التطبيقات الخاصة بنا للإعلان عن الملحق. عندما تتحقق واجهة برمجة التطبيقات الخاصة بنا من نقطة النهاية كإضافة صالحة ، ستبدأ في الظهور في الكتالوج.","FAQ_15_H1":"هل يمكنني تشغيل Stremio في المتصفح الخاص بي؟","FAQ_15_P1":"ليس في الوقت الحالي ، لكن هذا قادم!","FAQ_15_P2":"إذا كنت مهتمًا برؤية ألفا ، فيمكنك رؤيته هنا: ${1} alpha4.strem.io ${2}. ضع في اعتبارك أن البث معطل في هذا الإصدار ألفا. نحن ندعم Chrome و Firefox و Opera و Edge.","FAQ_16_H1":"الإرسال إلى التلفزيون لا يعمل / لا تعمل الترجمة","FAQ_16_P1":"يستخدم Casting to TV تقنية DLNA وهي غير متسقة للغاية بين مختلف العلامات التجارية والموديلات. لهذا السبب ، ليس لدينا القدرة على اختباره في كل حالة ، لذا فهو بعيد عن الكمال. على الرغم من ذلك ، نحن نعمل على تحسينه باستمرار ولكن لا يمكننا منحك تقديرًا للوقت حول موعد بدء DLNA في العمل بشكل صحيح مع تلفزيونك.","FAQ_16_P2":"إذا كنت لا ترى التلفزيون الخاص بك في قائمة الإرسال ، فالرجاء محاولة تعطيل اتصال الشبكة وإعادة تمكينه (في Windows ، انقر بزر الماوس الأيمن فوق الشبكة واستخدم تمكين / تعطيل) ، وكذلك إعادة تشغيل جهاز التوجيه والتلفزيون والكمبيوتر .","FAQ_16_P3":"إذا كنت لا تزال تواجه مشكلات ، فيمكنك مساعدتنا عن طريق إرسال معلومات الطراز والعلامة التجارية التلفزيونية الخاصة بك على ${1}office@stremio.com${2}.","FAQ_16_P4":"في غضون ذلك ، نوصي باستخدام Chromecast ، الذي ندعمه جيدًا ، أو ببساطة قم بتوصيل التلفزيون بجهاز الكمبيوتر باستخدام كابل HDMI.","FAQ_17_H1":"يتجمد Stremio و / أو يتعطل ، ماذا يمكنني أن أفعل؟","FAQ_17_P1":"بادئ ذي بدء ، إذا كنت تستخدم Windows 7 مع برنامج مكافحة الفيروسات AVG: لدينا مشكلة في هذه المجموعة. المشكلة في AVG نفسه ، وليس هناك طريقة معقولة لحلها من جانبنا. لسوء الحظ ، لن تعمل الاستثناءات أو تعطيل برنامج مكافحة الفيروسات. الحل الوحيد هو استبدال AVG بشيء آخر.","FAQ_17_P2":"إذا لم تكن هذه هي المشكلة ، ولكنك لا تزال تستخدم Windows ، فيرجى التحديث إلى أحدث حزمة خدمة وتحديث / إعادة تثبيت برامج تشغيل GPU ، ثم حاول مرة أخرى.","FAQ_17_P3":"إذا لم يتم حل المشكلة بعد ، أو إذا كنت تستخدم نظام التشغيل Mac أو Linux ، فيرجى مراسلتنا للإبلاغ عن التفاصيل الدقيقة للمشكلة على ${1} مجموعة Facebook ${2}.","FAQ_18_H1":"كيف يمكنني عمل أضافة ؟","FAQ_18_P1":"بالنسبة للمبتدئين ، نوصيك بالتحقق من وحدة نظام الإضافات ${1} الخاصة بنا ${2} على GitHub.","FAQ_18_P2":"بعد ذلك ، يمكنك اتباع البرنامج التعليمي ${1} Hello World ${2}.","FAQ_18_P3":"إذا لم تكن لديك أي مهارات برمجية ، فالرجاء نشر فكرتك على ${1} مجتمع Reddit ${2} والاتصال بنا لتقديم فكرة الملحق الخاص بك على ${3}office@stremio.com${4}.","FAQ_19_H1":"لماذا يشغل Stremio مساحة على القرص؟","FAQ_19_P1":"يحتوي Stremio على ذاكرة تخزين مؤقت محلية للاحتفاظ مؤقتًا بملفات الفيديو التي تقوم بدفقها.","FAQ_19_P2":"هذا له فائدتان: أولاً ، يسمح لـ Stremio بالتخزين المؤقت للفيديو مسبقًا لضمان تدفق أكثر سلاسة. ثانيًا ، يحتفظ بمقاطع الفيديو في ذاكرة التخزين المؤقت المحلية حتى تتمكن من متابعة مشاهدتها في وضع عدم الاتصال.","FAQ_19_P3":"يعتمد مقدار ما يحتفظ به Stremio على إعداد ذاكرة التخزين المؤقت في لوحة الإعدادات. قد يحافظ Stremio على الكمية المحددة (على سبيل المثال 2 جيجا بايت) على القرص الخاص بك ، ما لم يكن الفيديو المتدفق حاليًا أكبر من ذلك ، وفي هذه الحالة يجب عليه تخصيص مساحة تخزين كافية للاحتفاظ به حتى تقوم بدفقه.","FAQ_20_H1":"أين هو مجلد ذاكرة التخزين المؤقت؟","FAQ_20_P1":"في Windows ، يكون stremio-cache في محرك الأقراص الذي اخترته في الإعدادات (مثال \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"على MacOS ، إنه \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"على Linux ، إنه \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"تلقيت خطأ لم يتم العثور على خادم البث ، فماذا أفعل؟","FAQ_21_P1":"إذا تلقيت هذا الخطأ ، فهذا يعني أحد الأشياء القليلة:","FAQ_21_P2":"1) أنت تحاول استخدام ملحق مدعوم من مصدر YouTube / BitTorrent ، من خلال إصدار الويب ${1} الخاص بنا ${2}. في هذه الحالة ، يجب عليك تثبيت إصدار سطح المكتب من $ {3} موقعنا $ {4}.","FAQ_21_P3":"2) هناك خطأ ما في تثبيت Stremio. في هذه الحالة ، حاول إعادة تثبيت أحدث إصدار لسطح المكتب من ${1} موقع الويب ${2}. إذا لم يساعدك ذلك ، فحاول تعطيل برامج مكافحة الفيروسات والجدران النارية وإعادة تشغيل الكمبيوتر والمحاولة مرة أخرى. إذا لم يفلح هذا أيضًا ، يرجى مراسلتنا على ${3} مجموعتنا على Facebook ${4}.","FAQ_22_H1":"لا يمكنني رؤية / استخدام معظم الوظائف الإضافية على iOS","FAQ_22_P1":"نظرًا للقيود الواردة في شروط وأحكام متجر تطبيقات Apple ، فقد قصرنا تطبيق iOS على مجموعة معينة من الوظائف الإضافية.","FAQ_22_P2":"لكن كن مطمئنًا - سيكون هناك المزيد من الوظائف الإضافية لنظام iOS في المستقبل ، وقد نضيف أيضًا تكاملًا يسمح لك باستخدام جميع إضافات Stremio بفضل توصيل تطبيق iOS بخادم Stremio Streaming Server."}')},7726:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Филм","TYPE_series":"Сериал","TYPE_tv":"TV канал","TYPE_channel":"Канал","TYPE_other":"Друго","TYPE_movie_PL":"Филми","TYPE_series_PL":"Сериали","TYPE_tv_PL":"TV канали","TYPE_channel_PL":"Канали","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Назад","MORE":"Още","DONE":"Готово","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Открий","Board":"Табло","Library":"Библиотека","My Library":"Моята библиотека","Calendar":"Календар","NOTIFICATION_ONLINE":"Вече сте онлайн","NOTIFICATION_OFFLINE":"В момента сте офлайн","INTERNET_CONNECTION":"Интернет връзка","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"търси","SEARCH_NO_RESULTS":"Не са намерени резултати","SEARCH_EXPLANATION_CONTENT":"Търсете за филми, сериали, TV и YouTube канали","SEARCH_EXPLANATION_PEOPLE":"Търсете за актьори и режисьори","SEARCH_PASTE_LINKS":"Поставете HTTP или Magnet линк","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Добави","REMOVE_FROM_LIB":"Премахни","ADDED_TO_LIB":"Добавено към библиотека","REMOVED_FROM_LIB":"Премахнато от библиотека","TRAILER":"Трейлър","WATCH_TRAILER":"Трейлър","WATCH_NOW":"Гледай","SHOW":"Покажи","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb рейтинг","YEAR":"Година","DIRECTOR":"Режисьор","WRITER":"Автор","LEAD_ACTORS":"В главните роли","CAST":"Състав","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Излъчено","SEASONS":"Сезони","GENRE":"Жанр","CATALOG":"Каталог","SUMMARY":"Описание","SHOW_MORE":"Show More","SIMILAR":"Подобни","UPCOMING":"Очаквайте","ENDED":"Прекратено","DURATION":"Продължителност","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"търси видеа","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"addon","ADDONS":"Addons","OFFICIAL":"официални","ADDONS_OFFICIAL":"Официални addon-и","ADDONS_POPULAR":"Популярни в района ви","ADDON_FREE":"безплатно","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"subscription","ADDON_STREAM_GEORESTRICTED":"недостъпно във вашия район","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Достъпни източници","NO_STREAM":"Няма достъпни източници","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Защитен addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Предупреждение: съществуващ addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Филмът е все още по кината","WATCH_IN_CINEMA":"Гледайте го в киното","IN_THEATER":"По кината","GET_TICKETS":"Купи билети","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Нямаме информация за този канал все още.
Върнете се след няколко минути.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Добавете го в библиотеката, за да получите известие.","GET_NOTIFIED_WHEN_AVAILABLE":"Ще получите известие като излезе.","WARNING_STREAMING_SERVER":"Предупреждение: локалният streaming server не е свързан. Не е възможно стриймване от YouTube и BitTorrent.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"Изглежда като","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"стриймваме от","CASTING_TO":"Възпроизвеждаме на","NETWORK_STATUS":"Мрежа","STREAM_SPEED":"Скорост:","STREAM_BUFFERED":"Буфер:","PEERS_INFO":"Пиърове","PEERS_ACTIVE":"Активни:","PEERS_CONNECTED":"Свързани:","PEERS_WAITING":"Чакащи:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"зареждане...","PLAYING_LOCAL":"възпроизвеждане от локален файл","PLAYING_CACHE":"възпроизвеждане от кеш","WRONG_SUBS":"Грешни субтитри?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Изберете устройство","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Телефон / Таблет","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Смени субтитрите на ","SUBTITLES_CHANGE_NONE":"Няма други субтитри за този език.","SUBTITLES_CHANGE_ACIVE":"В момента субтитри #{{subtitlesDialog.activeIdx + 1}} са активирани. Кликнете \\"Продължи\\" за да активирате #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Алтернативно,","SUBTITLES_ADJUST_DELAY":"Настройте забавяне на субтитрите:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Или използвайте G / H, за да настроите субтитрите.","SUBTITLES_ADJUST_DELAY_TIP":"Съвет: може да ползвате G / H, за да настроите субтитрите.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Сезон","EPISODE":"Епизод","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"популярни","SORT_RECENT":"последни","SORT_ALPHABET":"a-z","SORT_RATING":"рейтинг","SORT_WATCHED":"гледани","SORT_YEAR":"година","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"продължи","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Избрано","DISCOVER_TOP":"Топ","DISCOVER_OSCAR":"Носители на Оскар","DISCOVER_WARNING_TITLE":"Опа!","DISCOVER_EMPTY_CATALOG":"Този addon върна празно съдържание.","DISCOVER_ADULT_WARNING":"Това съдържание е достъпно само за възрастни. Имаш ли навършени 18 години?","DISCOVER_NOADDON_WARNING":"Внимание: няма активен Stremio addon за този тип съдържание. Тук виждате запазена информация, тя няма да се обнови.","DISCOVER_LOAD_ERR":"Съдържанието не може да се зареди. Възникна грешка.","DISCOVER_ADDON_UNINSTALLED":"Това съдържание вече не е достъпно. Може би addon-ът е премахнат.","UNINSTALL_THIS_ADDON":"Деинсталирай този addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Стартирай новата версия!","UPGRADE":"Достъпна е нова версия","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Обновете вашата версия на Stremio","MANUAL_UPDATE_LINE1":"Използвате стара версия на Stremio.","MANUAL_UPDATE_LINE2":"Моля обновете колкото може по-скоро.","BUTTON_UPDATE_LATTER":"По-късно","BUTTON_UPDATE_NOW":"Обнови сега","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Влизане с Facebook","FB_NOTHINGSHARED":"Нищо не се споделя без ваше разрешение.","FB_NOPOST":"We won’t post anything on your behalf","OR":"или","I_ACCEPT":"Прочетох и приемам","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Общите условия","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Паролите се разминават","SIGN_UP":"Регистрирай се","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Вход","LOG_OUT":"Отписване","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Влизане като гост","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"кликнете тук","WRONG_PASSWORD":"Грешна парола. В случай, че сте я забравили, ","SET_A_PASS":"сложете ваша парола","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"Този email е използван с Фейсбук логин.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Избраният адон не се поддържа на тази платформа.","ADDON_DISCLAIMER":"Използването на addon-и от трети лица е ваша отговорност.","ADDON_ACTIVATE":"Активирай този addon?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Какво ново?","BUTTON_CONTINUE":"Продължи","BUTTON_ACTIVATE":"Активирай","BUTTON_ACTIVATED":"Активирано","BUTTON_CANCEL":"Отказ","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Отхвърли всички","BUTTON_VIEW_ALL":"виж всички","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Библиотеката ви е празна. Открийте колко е полезна :) ","HOW_START":"Започнете така:","LIB_EMPTY_CAL":"Календарът показва епизоди от сериалите във вашата Библиотека.","HOW_START_CAL":"Ето как добавяте сериали:","LIB_EMPTY_BOARD":"Тук ще видите каталог от популярно съдържание, както и известия и препоръки, свързани с Библиотеката ви.","HOW_START_BOARD_WAIT":"Моля, добавете няколко канала/сериала и ни дайте няколко минути да съберем известия :)","HOW_START_BOARD":"Ето как добавяте филми и сериали в библиотеката:","IMPORT_FB":"Добавяне от Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Намерете интересни неща в Discover","IMPORT_DISK":"Сканирайте за филми и сериали от вашия локален диск","PLEASE_CREATE_ACC":"Моля, създайте акаунт, за да използвате Library и Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Настройки","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Промяна на парола","SETTINGS_TOS":"Условия за ползване","SETTINGS_SUPPORT":"Поддръжка","SETTING_LANGUAGE":"Език","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Спиране","CONNECTED":"Connected","AUTHENTICATE":"оторизация","CACHING":"Кеширане","SETTINGS_CACHING_DRIVE":"Изберете диск за кеш","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Януари","February":"Февруари","March":"Март","April":"Април","May":"Май","June":"Юни","July":"Юли","August":"Август","September":"Септември","October":"Октомври","November":"Ноември","December":"Декември","Monday":"Понеделник","Tuesday":"Вторник","Wednesday":"Сряда","Thursday":"Четвъртък","Friday":"Петък","Saturday":"Събота","Sunday":"Неделя","Action":"Екшън","Comedy":"Комедия","War":"Военни","Family":"Семейни","Animation":"Анимация","Adventure":"Приключенски","Fantasy":"Фентъзи","Crime":"Криминални","Mystery":"Мистерия","Romance":"Романтични","Drama":"Драма","Horror":"Ужаси","Thriller":"Трилъри","Sci-Fi":"Sci-Fi","Music":"Музикални","Biography":"Биографични","Documentary":"Документални","Sport":"Спортни","Musical":"Мюзикъли","Western":"Уестърн","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"ново видео","new episode":"нов епизод","new movie":"нов филм","recommended":"препоръчано","we recommend":"we recommend","offer of the day":"offer of the day","news":"новини","music video":"музикално видео","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Премахни известия","CTX_DISMISS_ALL":"Премахни всички","CTX_SHARE":"Сподели","CTX_COPY_SHARE_LINK":"Копирай линк за споделяне","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Покажи","CTX_PLAY":"Гледай","CTX_PLAY_IN":"Гледай в","CTX_PLAY_ON":"Гледай на","CTX_WATCH_ON":"Гледай на","CTX_WATCH":"Гледай","CTX_WATCHED":"Гледано","CTX_WATCH_BEGINNING":"Гледай от началото","CTX_WATCH_MOBILE":"Гледай на мобилно устройство","CTX_REWIND":"Превърти до началото","CTX_MARK_WATCHED":"Маркирай като гледано","CTX_MARK_NON_WATCHED":"Маркирай като негледано","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Получавай нови известия","CTX_REMOVE_CACHE":"Премахни от кеш","CTX_REMOVE_CACHE_EP":"Премахни епизод от кеш","CTX_OPEN_CONTAINING":"Отвори папка","CTX_REMOVE":"Премахни от библиотеката","CTX_AVAILABLE_OFFLINE":"Достъпно офлайн","CTX_PAUSED":"Пауза","CTX_ALWAYS_ON_TOP":"Винаги отгоре","CTX_FULLSCREEN":"Цял екран","CTX_WRONG_SUBS":"Грешни субтитри?","CTX_REPORT_ISSUES":"Докладвай проблем","CTX_COPY":"Копирай","CTX_PASTE":"Постави","CTX_CLEAR":"Изчисти","CTX_CLEAR_RECENT_SEARCHES":"Изчисти последни търсения","HELLO_THERE":"Здравейте","HOPE_YOU_ENJOY":"Надяваме се, че харесвате Stremio и вече ви е едно от любимите приложения!","WHO_ARE_WE":"Кои сме ние? Ние сме двама и работихме усилено всеки ден в последните 3 години, за да подобряваме този продукт.","SUPPORT_US":"Ако продуктът ни ви е полезен и ви прави щастливи, подкрепете ни!","SPREAD_THE_WORD":"Споделете с приятелите си, разгласете Stremio","MORE_PEOPLE":"Колкото повече хора ползват Stremio, толкова по-добро ще става!","SEND_A_LINK":"Или изпратете линк към уебсайта","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"Моите Addons","ADDON_COMMUNITY":"Неофициални Addons","ADDON_OFFICIAL":"Официални Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Търси addons","ADDON_INSTALL":"Инсталирай","ADDON_CONFIGURE":"Конфигурирай","ADDON_UNINSTALL":"Деинсталирай","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Инсталирано","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon страница","ADDON_TOP_CONTENT":"Най-доброто от този Addon","ADDON_PROVIDES":"предоставя","ADDON_WATCH":"Гледай #{types} сега!","ADDON_WATCH_FREE":"Гледай #{types} БЕЗПЛАТНО сега!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Повече #{types} в Discover","ADDON_PROVIDES_STREAMS":"Гледай #{types}","ADDON_PROVIDES_STREAMS_FREE":"Гледай #{types} БЕЗПЛАТНО","ADDON_PROVIDES_SUBTITLES":"Субтитри за #{types}","ADDON_CANTDETECT":"Не успяхме да засечем работещо Stremio, затова не можем да засечем кои addons са ви инсталирани.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Продължи да гледаш","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},8569:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Pel·lícula","TYPE_series":"Sèries","TYPE_tv":"Canal de TV","TYPE_channel":"Canal","TYPE_other":"Altres","TYPE_movie_PL":"Pel·lícules","TYPE_series_PL":"Sèries","TYPE_tv_PL":"Canals de TV","TYPE_channel_PL":"Canals","TYPE_other_PL":"Altres","TYPE_ALL":"All","VIDEO":"Vídeo","BACK":"Enrere","MORE":"Més","DONE":"Fet","COPY":"Copia","SETTINGS_CASTING_MODE_PICKER":"Mode d\'emissió","CASTING_MODE_HLSV2":"Per defecte","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"Sense transcodificació","Discover":"Descobrir","Board":"Panell","Library":"Biblioteca","My Library":"La meva Biblioteca","Calendar":"Calendari","NOTIFICATION_ONLINE":"Ara esteu en línia","NOTIFICATION_OFFLINE":"Ara esteu fora de línia","INTERNET_CONNECTION":"Connexió de xarxa","STORAGE_FULL_TITLE":"Advertència: Emmagatzematge ple!","STORAGE_FULL_TEXT":"Stremio no podrà desar la configuració, les preferències ni la informació d\'inici de sessió. Penseu a reiniciar o tornar a instal·lar Stremio.","SEARCH":"cerca","SEARCH_NO_RESULTS":"No s\'han trobat resultats","SEARCH_EXPLANATION_CONTENT":"Cerca pel·lícules, sèries, canals de YouTube i TV","SEARCH_EXPLANATION_PEOPLE":"Cerca actors, directors i escriptors","SEARCH_PASTE_LINKS":"Enganxa enllaços HTTP i Magnètics","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Afegir a la Biblioteca","REMOVE_FROM_LIB":"Elimina de la Biblioteca","ADDED_TO_LIB":"Afegit a la Biblioteca","REMOVED_FROM_LIB":"Eliminat de la Biblioteca","TRAILER":"Tràiler","WATCH_TRAILER":"Mirar el tràiler","WATCH_NOW":"Mirar ara","SHOW":"Mirar","SHOW_MOVIE":"Mirar Pel·lícula","WATCH_RANDOM":"Mirar aleatòriament","IMDB_RATING":"Qualificació IMDb","YEAR":"Any","DIRECTOR":"Director","WRITER":"Escriptor","LEAD_ACTORS":"Actors principals","CAST":"Elenc","CREW":"Equip tècnic","SHOW_MORE_CAST":"Mostra més »","AIRED":"Emès","SEASONS":"Temporades","GENRE":"Gènere","CATALOG":"Catàleg","SUMMARY":"Resum","SHOW_MORE":"Mostra Més","SIMILAR":"Similar","UPCOMING":"Properament","ENDED":"Finalitzat","DURATION":"Duració","FEATURED":"Destacat","METADATA":"Metadades","CATEGORY":"categoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"cercar vídeos","SEARCH_PLACEHOLDER":"cercar o enganxar URL","ADDON":"complement","ADDONS":"Complements","OFFICIAL":"oficial","ADDONS_OFFICIAL":"Complements Stremio oficials","ADDONS_POPULAR":"Popular a la vostra regió","ADDON_FREE":"gratuït","ADDON_PEERED":"compartit","ADDON_SUBSCRIPTION":"subscripció","ADDON_STREAM_GEORESTRICTED":"no disponible a la vostra regió","ADDON_STREAM_OFFLINECACHE":"Memòria cau fora de línia","ADDON_STREAM_LOCALFILE":"Fitxer local","SHARE_ADDON":"Comparteix el complement","AVAILABLE_STREAMS":"Streams disponibles","NO_STREAM":"No s\'ha trobat cap stream","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Per obtenir més streams, instal·leu més complements","STREAM_NOT_SUPPORTED":"El stream seleccionat no és compatible amb aquesta plataforma.","ADDON_CATALOGUE":"Mostra tots els complements »","ADDON_CATALOGUE_MORE":"Instal·la complements","REPO_ADDED":"Repositori afegit","ADDON_REPO_EXIST_ERR":"Aquesta col·lecció de complements ja existeix","ADDON_REPO_ERR":"S\'ha produït un error en afegir la col·lecció","ADDON_ADD_ERR":"S\'ha produït un error en afegir un complement","ERR_ADDON_PROTECTED":"No es pot desinstal·lar el complement, està protegit","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Hi ha hagut un problema - l\'autenticació pot haver fallat","ERR_NOT_COLLECTION_URL":"No és un URL de col·lecció","ERR_NOT_ADDON_URL":"No és un URL de complement vàlid","ERR_DETECTFROMURL":"No es pot trobar cap complement/col·lecció en aquest URL","ADDON_DUPLICATE_WARNING":"Advertència: complement duplicat","ADDON_COLLECTION_SET_FAILED":"Ha fallat la sincronització de complements instal·lats al vostre compte","SETTINGS_DATA_EXPORT":"Exporta dades d\'usuari","ADDON_PULL_FAILED":"Ha fallat la sincronització dels complements instal·lats del vostre compte","REFRESH_ON_CLICK":"Prem per reintentar","STILL_IN_THEATER":"Pel·lícula encara als cinemes","WATCH_IN_CINEMA":"Mireu-lo al vostre cinema local","IN_THEATER":"En el cinema","GET_TICKETS":"Obtenir entrades","UPCOMING_EPISODE":"Pròxim episodi","UPCOMING_EPISODE_MESSAGE":"Aquest episodi s’emetrà al","MISSING_DATE_EPISODE":"Falta la data de l\'episodi","MISSING_DATE_EPISODE_MESSAGE":"És possible que aquest episodi encara no s’hagi emès","CHANNEL_NOT_SCRAPED":"Aquest canal encara no s\'ha habilitat.
Si us plau, torneu d\'aquí a uns minuts.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Afegiu-lo a la vostra Biblioteca per rebre una notificació un cop estigui disponible.","GET_NOTIFIED_WHEN_AVAILABLE":"Rebràs una notificació un cop estigui disponible.","WARNING_STREAMING_SERVER":"Advertència: no s\'ha trobat el servidor d\'streaming local. L\'streaming des de fitxers locals, YouTube i BitTorrent no estarà disponible.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Advertència: és possible que aquest vídeo no sigui compatible amb el vostre maquinari. Tingueu en compte que la reproducció pot ser lenta.","PLAYER_ERROR":"Vaja, error del reproductor","PLAYER_ERROR_LOOKSLIKE":"Sembla que","PLAYER_ORIENTATION":"Orientació del reproductor","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Bloquejat","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"L\'orientació del reproductor bloquejada en horitzontal","PLAYER_ORIENTATION_SENSOR":"Orientació del reproductor automàtica (sensor)","PLAYER_PLAYBACK_SPEED":"Velocitat de reproducció","PLAYER_PLAYBACK_ERROR":"Error de reproducció, torneu-ho a provar","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Error desconegut","PLAYER_PLAYBACK_ERROR_DEFAULT":"Ho sentim, aquest vídeo no pot ser reproduït per {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"En directe","PLAYER_NEXT_VIDEO_TITLE":"A continuació","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Descartar","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Veure ara","STREAMING_FROM":"transmissió des de","CASTING_TO":"S\'està emetent a","NETWORK_STATUS":"Estat de la xarxa","STREAM_SPEED":"Velocitat del stream:","STREAM_BUFFERED":"Emmagatzemat:","PEERS_INFO":"Informació dels pars","PEERS_ACTIVE":"Actiu:","PEERS_CONNECTED":"Connectat:","PEERS_WAITING":"Esperant:","TRANSCODING_WARNING":"Advertència: transcodificant vídeo.","STREAM_LOADING":"carregant ...","PLAYING_LOCAL":"reproduint des del fitxer local","PLAYING_CACHE":"reproduint des de la memòria cau","WRONG_SUBS":"Subtítols incorrectes?","ERR_SUBS_LOADING_TITLE":"Error en carregar els subtítols","ERR_SUBS_LOADING":"Ha fallat la càrrega de subtítols: això podria ser un problema amb el complement que utilitzeu o amb la vostra connexió de xarxa","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Els següents complements de subtítols han fallat","ERR_CASTING_UPDATE_TITLE":"No s\'ha pogut actualitzar la informació del dispositiu d\'emissió: el servidor d\'streaming podria estar fora de línia","CHOOSE_DEVICE":"Trieu un dispositiu on mirar-lo","NO_CAST_DEVICES":"No hi ha dispositius d\'emissió disponibles.","NO_SETTINGS":"No hi ha cap configuració disponible.","PHONE_TABLET":"Telèfon / Tauleta","SUBTITLES":"Subtítols","SUBTITLES_CHANGE":"Canvia els subtítols per a ","SUBTITLES_CHANGE_NONE":"No hi ha cap altre subtítol en aquest idioma, ho sento.","SUBTITLES_CHANGE_ACIVE":"Actualment els subtítols #{{subtitlesDialog.activeIdx + 1}} estan activats. Prem \\"Continua\\" per activar els subtítols #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativament,","SUBTITLES_ADJUST_DELAY":"Ajustar el retard de subtítols:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"O usa les tecles G / H durant la reproducció per ajustar.","SUBTITLES_ADJUST_DELAY_TIP":"Nota: podeu utilitzar les tecles G / H durant la reproducció per ajustar.","SUBTITLES_DELAY":"Retard de subtítols:","SUBTITLES_LOADING":"Carregant els subtítols...","SUBTITLES_UNAVAILABLE":"No hi ha subtítols externs disponibles","SUBTITLES_DISABLED":"Desactivat","AUDIO":"Àudio","DEFAULT_LANGUAGE":"Idioma per Defecte","DEFAULT_SECONDARY_LANGUAGE":"Idioma Secundari per Defecte","SEASON":"Temporada","EPISODE":"Episodi","SPECIAL":"Especial","SORT":"ordenar","SORT_BY":"Ordenar per","FILTER":"filtrar","SORT_TRENDING":"tendències","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"qualificació","SORT_WATCHED":"vist","SORT_YEAR":"any","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nou per a tu","New Episodes":"Nous episodis","New Videos":"Nous vídeos","Recommendations":"Recomanacions","LIBRARY_RESUME":"Reprendre","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detalls","LIBRARY_RESUME_DISMISS":"Descartar","LIBRARY_CLEAR_PROGRESS":"Esborrar progrés","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Destacat","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Guanyadors d\'Oscar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Aquest complement ha retornat un contingut buit.","DISCOVER_ADULT_WARNING":"El contingut només és visible per a adults. Teniu més de 18 anys?","DISCOVER_NOADDON_WARNING":"Avís: no hi ha cap complement Stremio actiu per a aquest tipus. Mostrant elements desats, res d\'aquí s\'actualitzarà.","DISCOVER_LOAD_ERR":"El contingut no s\'ha carregat, s\'ha produït un error.","DISCOVER_ADDON_UNINSTALLED":"Aquest contingut ja no està disponible, és possible que hàgiu desinstal·lat el complement.","UNINSTALL_THIS_ADDON":"Desinstal·la aquest complement","ERR_ADDON_NOT_INSTALLED":"Aquest complement no està instal·lat. Instal·lar-lo ara?","DETAIL_RECEIVE_NOTIF_SERIES":"Rep notificacions d\'episodis nous","DETAIL_RECEIVE_NOTIF_VIDEOS":"Rep notificacions de vídeos nous","SIDEBAR_SHOW_STREAMS":"Mostra streams","RELAUNCH":"Rellançar ara!","UPGRADE":"Hi ha disponible una nova versió. Actualitzeu a la darrera versió d\'Stremio","RELOAD_UI":"Recarregar la interfície d\'usuari","MANUAL_UPDATE_TITLE":"Actualitza la teva versió d\'Stremio","MANUAL_UPDATE_LINE1":"Esteu executant una versió obsoleta d\'Stremio, que és molt poc recomanable.","MANUAL_UPDATE_LINE2":"Actualitzeu el més aviat possible.","BUTTON_UPDATE_LATTER":"Ara no","BUTTON_UPDATE_NOW":"Actualitza","ANONYMOUS_USER":"Usuari anònim","DONT_HAVE_ACC":"No teniu cap compte?","HAVE_ACC":"Ja tens un compte?","PASSWORD":"Contrasenya","PASSWORD_CONFIRM":"Confirma la contrasenya","EMAIL":"Correu electrònic","FB_LOGIN":"Continueu amb Facebook","FB_NOTHINGSHARED":"No es comparteix res sense el vostre permís","FB_NOPOST":"No publicarem res en nom vostre","OR":"o","I_ACCEPT":"Accepto els","I_ACCEPT_BY_CLICKING":"En fer clic al botó superior, declaro que accepto els ","TOS":"Termes i condicions","MUST_ACCEPT_TERMS":"Heu d\'acceptar els termes","PASSWORDS_NOMATCH":"Les contrasenyes no coincideixen","SIGN_UP":"Registra\'t","SIGN_UP_EMAIL":"Registra\'t amb el correu electrònic","CLICK_TO_SIGN_UP":"Feu clic aquí per registrar-vos.","LOG_IN":"Iniciar Sessió","LOG_OUT":"Tancar sessió","EXIT_FULLSCREEN":"Surt del mode de pantalla completa","ENTER_FULLSCREEN":"Introduïu el mode de pantalla completa","PLAY_URL_MAGNET_LINK":"Reprodueix URL/Enllaç magnètic","HELP_FEEDBACK":"Ajuda i comentaris","TERMS_OF_SERVICE":"Termes del servei","PRIVACY_POLICY":"Política de Privacitat","ABOUT_STREMIO":"Quant a Stremio","USER_PANEL":"Tauler d\'usuaris","LOGIN_LABEL":"Inicia sessió","GUEST_LOGIN":"Inici de sessió de convidat","GUEST_LOGIN_NOTICE":"No es recomana l\'inici de sessió de convidat. Si feu servir un inici de sessió habitual, Stremio pot sincronitzar la Biblioteca i rebre notificacions de sèries o canals preferits. Esteu segur que voleu continuar?","GUEST_LOGIN_NOTICE_2":"No es recomana l\'inici de sessió com a convidat: no tindreu notificacions sincronitzades de la Biblioteca i del fòrum, que són funcions fonamentals d\'Stremio. Esteu segur que voleu continuar?","CLICK_HERE":"clica aquí","WRONG_PASSWORD":"Correu electrònic o contrasenya incorrectes. En cas que hagueu oblidat la vostra contrasenya, ","SET_A_PASS":"definiu una contrasenya","RESET_PASSWORD":"Restablir la contrasenya","FORGOT_PASSWORD":"Has oblidat la contrasenya?","EMAIL_USED_WITH_FB":"Aquest correu electrònic s\'ha utilitzat amb un inici de sessió de Facebook.","INVALID_EMAIL":"si us plau, introdueixi una adreça de correu electrònic vàlida","INVALID_PASSWORD":"Introduïu una contrasenya vàlida","CONN_ERR":"Error de connexió - torneu-ho a provar més tard.\\n\\nSi això persisteix, desactiveu els tallafocs/antivirus (especialment Bitdefender).","IMPORT_FROM_GUEST":"Importeu la Biblioteca des del vostre compte de convidat","RECEIVE_UPDATES_EMAIL":"Rebeu actualitzacions al vostre correu electrònic des d\'Stremio","LOGIN_FAILED":"Error a l\'iniciar sessió.","SIGNUP_FAILED":"Ha fallat el registre.","SEARCH_FAILED":"La cerca ha fallat","EMAIL_USED":"Aquest correu electrònic ja està en ús.","WAITING_FB_LOGIN":"Iniciant la sessió amb Facebook...","EXTERNAL_PLAYER_TITLE":"Reprodueix en un reproductor extern","EXTERNAL_REMEMBER_PLAYER":"Voleu recordar la vostra elecció?","EXTERNAL_ALWAYS_PLAY":"Sí","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Millor encaix","FIT_SCREEN":"Encaixar la Pantalla","FILL":"Omplir","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Explica\'ns què t\'agrada","INTRO_TASTE_LONG":"Explica\'ns què voleu veure","INTRO_TASTE_PICK":"Selecciona {{interestsRemaining}} interessos","INTRO_TASTE_PICK_MORE":"Selecciona {{interestsRemaining}} interessos més","INTRO_TASTE_HELP_US":"Ajudeu-nos a aprendre més informació sobre vosaltres.","INTRO_TASTE_CHOOSE_THESE":"Trieu alguns d\'aquests:","INTRO_TASTE_CHOOSE_MIN":"Trieu com a mínim 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"Heu de triar almenys 3 categories.","INTRO_TASTE_LIFESTYLE":"Estil de vida","INTRO_TASTE_SPORTS":"Esports","INTRO_TASTE_FOOD_HEALTH":"Alimentació i Salut","INTRO_TASTE_BEAUTY_FASHION":"Bellesa i Moda","INTRO_TASTE_NEWS":"Notícies","INTRO_TASTE_GAMING":"Jocs","INTRO_TASTE_SCIENCE_EDU":"Ciència i Educació","INTRO_TASTE_MUSIC":"Música","INTRO_TASTE_TRAVEL":"Viatges","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comèdia","INTRO_TASTE_DIY":"Fes-ho tu mateix (DIY)","INTRO_TASTE_TECH":"Tecnologia","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Aquesta plataforma no admet el complement seleccionat.","ADDON_DISCLAIMER":"L\'ús de complements de tercers sempre estarà subjecte a la vostra responsabilitat i a la legislació vigent de la jurisdicció on esteu ubicat.","ADDON_ACTIVATE":"Activar aquest complement?","ADDON_REPO_ADD":"URL del repositori de complements","ADDON_ADD":"Afegir","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Que hi ha de nou","BUTTON_CONTINUE":"Continua","BUTTON_ACTIVATE":"Activa","BUTTON_ACTIVATED":"Activat","BUTTON_CANCEL":"Cancel·lar","BUTTON_SUBMIT":"Envia","BUTTON_DISMISS_ALL":"Descartar-ho tot","BUTTON_VIEW_ALL":"veure-ho tot","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"La vostra Biblioteca sembla buida. Esbrineu lo útil que és :)","HOW_START":"Així és com podeu començar:","LIB_EMPTY_CAL":"El vostre calendari mostra sèries a la Biblioteca.","HOW_START_CAL":"Així és com podeu afegir sèries:","LIB_EMPTY_BOARD":"El Tauler mostra notificacions i recomanacions relacionades amb la vostra Biblioteca.","HOW_START_BOARD_WAIT":"Afegiu unes quantes sèries o canals a la vostra Biblioteca i doneu-nos uns minuts per processar :)","HOW_START_BOARD":"Així és com podeu afegir-hi sèries i pel·lícules:","IMPORT_FB":"Importeu les coses que us agradin de Facebook","IMPORT_TRAKT":"Importeu la vostra biblioteca multimèdia de Trakt","IMPORT_DISCOVER":"Troba coses interessants de Descobrir","IMPORT_DISK":"Importeu pel·lícules o sèries que tingueu al disc local","PLEASE_CREATE_ACC":"Creeu un compte per habilitar la sincronització de la Biblioteca i el Tauler.","IMPORT_DISCOVER_SIGNUP":"Registreu-vos i trobeu coses interessants a Descobrir","IMPORT_DISK_SIGNUP":"Inscriviu-vos i importeu pel·lícules o espectacles que tingueu al vostre disc local","LIB_EMPTY_CLOUD":"Biblioteca al núvol","LIB_EMPTY_CLOUD_DESC":"Biblioteca personal al núvol sincronitzada a tots els dispositius","LIB_EMPTY_EARLY":"Accés aviat","LIB_EMPTY_EARLY_DESC":"Rep notificacions d\'episodis nous","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Obteniu recomanacions personalitzades","LIB_EMPTY_CALENDAR_DESC":"Programa el teu calendari de visualització personal","LIB_EMPTY_ALL":"Registreu-vos per obtenir tot això:","LIB_EMPTY_BEST":"Registreu-vos per obtenir el millor d\'Stremio","LIB_EMPTY_OTHER":"Registreu-vos per activar el calendari i altres funcions interessants","CALENDAR_ADDED":"El calendari d\'Stremio s\'ha afegit al calendari d\'escriptori predeterminat.","CALENDAR_ADDED_MSG":"Si això no funciona, afegiu aquest URL manualment a la vostra aplicació de calendari","TRAKT_EXPIRED":"L\'autenticació de Trakt ha caducat, aneu a Configuració i torneu a autenticar-la","TRAKT_REQUIRES_LOGIN":"Error de Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Cal iniciar sessió","SETTINGS_LABEL":"Configuració","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Reproductor","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Dreceres","SETTINGS_SHORTCUT_RELOAD_APP":"Recarregar l\'aplicació","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Obrir Configuració","SETTINGS_SHORTCUT_SWITCH_TABS":"Canviar Pestanya","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Mou Entre Pestanyes Cap Endavant","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Mou Entre Pestanyes Cap Enrere","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Sortir / Tornar enrere","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Commuta la Pantalla Completa","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Mostra els Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Reproduir / Pausa","SETTINGS_SHORTCUT_VOLUME_UP":"Pujar volum","SETTINGS_SHORTCUT_VOLUME_DOWN":"Baixar volum","SETTINGS_SHORTCUT_SEEK_NEXT":"Moure Endavant","SETTINGS_SHORTCUT_SEEK_PREV":"Moure Enrere","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Reproduir Següent","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Augmentar Mida Subtítols","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Disminuir Mida Subtítols","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Augmentar Retard Subtítols","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Disminuir Retard Subtítols","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Commutar Barra Lateral","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Iniciar al arrancar l\'equip","SETTINGS_VLC_DEFAULT":"Reproduir amb VLC","SETTINGS_UI_LANGUAGE":"Idioma de la interfície","SETTINGS_FULLSCREEN_EXIT":"Tecla per sortir de la pantalla completa","SETTINGS_GAMEPAD":"Activa la compatibilitat amb el gamepad","SETTINGS_CLOSE_WINDOW":"Tanca l\'aplicació quan la finestra estigui tancada","SETTINGS_SUBTITLES_LANGUAGE":"Idioma dels subtítols predeterminat","SETTINGS_SUBTITLES_SIZE":"Mida dels subtítols predeterminada","SETTINGS_SUBTITLES_BACKGROUND":"Fons dels subtítols","SETTINGS_SUBTITLES_COLOR":"Color dels subtítols","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Color de l\'esquema dels subtítols","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Color de fons dels subtítols","SETTINGS_SEEK_KEY":"Les tecles de fletxa et mouen en el temps","SETTINGS_SEEK_KEY_SHIFT":"Les tecles de fletxa et mouen en el temps quan es manté premuda la tecla Shift","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Reprodueix automàticament el proper episodi","SETTINGS_NEXT_VIDEO":"Mostra la notificació per iniciar el proper episodi","SETTINGS_NEXT_VIDEO_TRIGGER":"Mostra la notificació del següent episodi per a:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Canvieu la mida de la finestra abans de reproduir","SETTINGS_OVERRIDE_SERVER":"Substitueix l\'URL del servidor de transmissió (avançat)","SETTINGS_SERVER_URL":"URL del servidor de transmissió: ","SETTINGS_SERVER_AVAILABLE":"El servidor de transmissió està disponible.","SETTINGS_SERVER_UNAVAILABLE":"El servidor de transmissió no està disponible.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Endpoint de transmissió HTTPS: ","SETTINGS_USE_BETA":"Utilitzeu sempre l\'última versió Beta","SETTINGS_IMPORT_FB":"Importar de Facebook","SETTINGS_IMPORT_DISK":"Importar del disc local","SETTINGS_IMPORT_TRAKT":"Importar de Trakt","SETTINGS_PAUSE_MINIMIZED":"Pausar la reproducció quan es minimitzi","SETTINGS_HWDEC":"Descodificació accelerada per maquinari","SETTINGS_BACKGROUND":"Reproducció en segon pla","SETTINGS_SUBSCRIBE_CALENDAR":"Subscriu-te al calendari","SETTINGS_REQ_EXPORT":"Sol·licitar l\'exportació de dades","SETTINGS_ACC_DELETE":"Sol·licitar eliminació del compte","SETTINGS_CHANGE_PASSWORD":"Canvia la contrasenya","SETTINGS_TOS":"Termes del servei","SETTINGS_SUPPORT":"Contactar suport","SETTING_LANGUAGE":"Llenguatge","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Tanca la sessió de Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Escaneja el codi QR per obrir el comandament a distància","SETTINGS_DESKTOP_NOTIFICATIONS":"Notificacions d\'escriptori","SETTINGS_DATA_SAVER":"Estalviador de dades","SETTINGS_LANGUAGE_INTERFACE":"interfície","SETTINGS_LANGUAGE_SUBS":"subtítols per defecte","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Seleccionar Automàticament la Pista d\'Àudio","SETTINGS_DEFAULT_AUDIO_TRACK":"Pista d\'Àudio Predeterminada","SETTINGS_ACCOUNT":"compte","SETTINGS_VERSION":"versió","SETTINGS_MPV_WINDOW":"Inicia el reproductor en una finestra separada (avançat)","SETTINGS_PLAY_IN_EXTERNAL":"Inicieu sempre el vídeo en un reproductor extern","SETTINGS_STORAGE_BUTTON":"Esborra l\'emmagatzematge local","SETTINGS_STORAGE_MODAL_TITLE":"Estàs segur ?","SETTINGS_STORAGE_MODAL_MESSAGE":"Això esborrarà l\'emmagatzematge local i tancarà la sessió.","SETTINGS_HWDEC_PICKER":"Trieu la configuració de descodificació accelerada per maquinari","SETTINGS_HW_AUTOMATIC":"Automàtic","SETTINGS_HW_DISABLED":"Desactivat","SETTINGS_HW_ACCELERATED":"Acceleració de descodificació","SETTINGS_HW_FULL":"Acceleració total","SETTINGS_HW_LEGACY":"Heretat","SUBSPICKER_AUDIO":"Àudio","SUBSPICKER_SUBTITLES":"Subtítols dels complements","SUBSPICKER_BLACK_BACKGROUND":"Utilitzar negre com color de fons","SUBSPICKER_VERTICAL_OFFSET":"Desplaçament vertical","SUBSPICKER_SIZE":"Mida","SUBSPICKER_DELAY":"Retard","SUBSPICKER_EMBEDDED_SUBS":"Subtítols incrustats","MOBILE_PRIVACY_POLICY":"Política de privacitat","MOBILE_CRASH_REPORTING":"Informe de fallades","MOBILE_ZOOM_TO_FILL":"Ampliar per omplir la pantalla","MOBILE_PASSTHROUGH":"Sortida d\'àudio digital (passthrough)","MOBILE_RUN_LOW_BATTERY":"Executar amb bateria baixa","MOBILE_RUN_FOREGROUND":"Executar com a servei de primer pla","MOBILE_PERFORMANCE":"RENDIMENT I ESTABILITAT","MOBILE_SERVER_ONLINE":"En línia","MOBILE_SERVER_OFFLINE":"Fora de línia","MOBILE_QR_EXPIRES":"El codi QR caduca en ","MOBILE_LOG_INTO":"Iniciar sessió al compte Stremio ","MOBILE_SCAN_QR":"Escaneja el codi QR de dalt o ves a ","MOBILE_LINK_ACCOUNT":"Enllaçar el compte","MOBILE_SPEEDPICKER_CANCEL":"Cancel·lar","MOBILE_SPEEDPICKER_LABEL":"Seleccionar Velocitat de Reproducció","MOBILE_EMPTY_LIBRARY":"La teva biblioteca està buida","MOBILE_NO_ADDON_ACTIVE":"No hi ha cap complement Stremio actiu per a aquest tipus.","MOBILE_ORGANIZER_WARNING":"L\'aplicació Stremio Organizer ofereix una funcionalitat limitada. Per obtenir una llista de reproduccions i l\'experiència completa d\'Stremio, feu servir Stremio a l\'escriptori.","MOBILE_ADDON_LOADING":"encara està carregant","MOBILE_ADDONS_LOADING":"els complements encara estan carregant","MOBILE_ADDON":"Complement","MOBILE_CONFIGURE_ADDON":"Configura el teu complement","MOBILE_CONFIGURE_ADDON_LABEL":"Configurar Complement","MOBILE_ORGANIZER_ADDONS_WARNING":"L\'aplicació Stremio Organizer ofereix una selecció limitada de complements. Per gaudir de l\'experiència Stremio completa, utilitzeu Stremio a l\'escriptori.","MOBILE_DISCONNECT":"Desconnectar","MOBILE_LOOKING_FOR_DEVICES":"Buscant dispositius...","MOBILE_CAST_TO":"Emet a","NAVIGATION_ON":"Encès","NAVIGATION_OFF":"Apagat","MARKETING_AGREE":"Accepto rebre comunicacions de màrqueting d\'Stremio","QUIT":"Sortir","CONNECTED":"Connectat","AUTHENTICATE":"Autenticar","CACHING":"Memòria cau","SETTINGS_CACHING_DRIVE":"Disc de memòria cau","ENABLE_LOCAL_FILES_ADDON":"Activa el complement de fitxers locals (requereix un reinici)","LOCAL_ADDON_NOT_ENABLED":"El complement local no està habilitat. Feu clic aquí per anar a la configuració i activar-lo","ENABLE_REMOTE_HTTPS_CONN":"Activeu les connexions HTTPS remotes","TORRENT_PROFILE":"Perfil del torrent","DATA_CACHING":"Memòria cau emmagatzemada","MAGNET_PARSING":"Analitzant un enllaç magnètic","January":"Gener","February":"Febrer","March":"Març","April":"Abril","May":"Maig","June":"Juny","July":"Juliol","August":"Agost","September":"Setembre","October":"Octubre","November":"Novembre","December":"Desembre","Monday":"Dilluns","Tuesday":"Dimarts","Wednesday":"Dimecres","Thursday":"Dijous","Friday":"Divendres","Saturday":"Dissabte","Sunday":"Diumenge","Action":"Acció","Comedy":"Comèdia","War":"Bèl·lic","Family":"Família","Animation":"Animació","Adventure":"Aventura","Fantasy":"Fantasia","Crime":"Crim","Mystery":"Misteri","Romance":"Romanç","Drama":"Drama","Horror":"Terror","Thriller":"Suspens","Sci-Fi":"Ciència-ficció","Music":"Musical","Biography":"Biogràfic","Documentary":"Documental","Sport":"Esports","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Notícies","History":"Història","Game-Show":"Concursos","Reality-TV":"Reality shows","Talk-Show":"Entrevistes","Film & Entertainment":"Cinema i entreteniment","Gaming":"Videojocs","From TV":"De la TV","Lifestyle":"Estil de vida","Science & Education":"Ciència i educació","Cooking & Health":"Cuina i salut","Beauty & Fashion":"Bellesa i moda","Sports":"Esports","News & Politics":"Notícies i política","How-to & DIY":"Com fer-ho i DIY","Tech":"Tecnologia","Automotive":"Automoció","Causes & Non-Profits":"Causes i organitzacions sense ànim de lucre","Movies":"Pel·lícules","Uk Live Tv":"TV britànica en directe","Fashion":"Moda","Business News Radio":"Ràdio - Notícies de negocis","Business Tv":"TV negocis","Cars & Auto":"Automòbils","Comedy Radio":"Ràdio - Comèdia","Lifestyle Radio":"Ràdio - Estil de vida","News Tv":"TV notícies","Food And Wine":"Menjar i Vi","Latino Tv":"TV Llatina","Shopping Tv":"TV compres","Religion":"Religió","Kids":"Nens","Body & Soul":"Cos i ànima","Education":"Educació","Indian Tv":"TV índia","Extreme Sports":"Esports extrems","Middle Eastern Tv":"TV de l\'Orient Mitjà","Celebrity Tv":"TV famosos","Science Tv":"TV ciència","Bikini babe":"Bikini babe","Outdoors":"A l\'aire lliure","German Tv":"TV alemanya","French Tv":"Tv francesa","Italian Tv":"TV italiana","Gamer Tv":"TV videojocs","Travel":"Viatges","Asian Tv":"TV asiàtica","Entertainment":"Entreteniment","News Radio":"Ràdio - Notícies","Music Radio":"Ràdio - Música","Language Learning":"Aprenentatge d\'idiomes","Science Radio":"Ràdio - Ciències","Tech Radio":"Ràdio - Tecnologia","Science & Technology Vod":"Ciència i tecnologia sota demanda","new video":"nou vídeo","new episode":"nou episodi","new movie":"nova pel·lícula","recommended":"recomanat","we recommend":"recomanem","offer of the day":"oferta del dia","news":"notícies","music video":"vídeo musical","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Descarta les notificacions","CTX_DISMISS_ALL":"Descarta-ho tot","CTX_SHARE":"Comparteix","CTX_COPY_SHARE_LINK":"Copia l\'enllaç per compartir","CTX_COPY_MAGNET_LINK":"Copia enllaç magnètic","CTX_COPY_STREAM_LINK":"Copia enllaç de l\'stream","CTX_DOWNLOAD_VIDEO":"Descarregar aquest vídeo","CTX_DOWNLOAD_SUBS":"Descarregar els subtítols","CTX_VIEW_ON_YOUTUBE":"Veure a YouTube","CTX_SHOW":"Mostra","CTX_PLAY":"Reproduir","CTX_PLAY_IN":"Reprodueix aquí","CTX_PLAY_ON":"Reprodueix a","CTX_WATCH_ON":"Veure a","CTX_WATCH":"Veure","CTX_WATCHED":"Vist","CTX_WATCH_BEGINNING":"Veure des del principi","CTX_WATCH_MOBILE":"Veure en un dispositiu mòbil","CTX_REWIND":"Rebobinar fins al començament","CTX_MARK_WATCHED":"Marca com a vist","CTX_MARK_NON_WATCHED":"Marca com a no vist","CTX_MARK_UNWATCHED":"Marca com sense mirar","CTX_MARK_REST":"Marca la resta com a vist","CTX_UNMARK_REST":"Marca la resta com a no vist","CTX_RECEIVE_NEW_NOTIF":"Rebre notificacions noves","CTX_REMOVE_CACHE":"Elimina de la memòria cau","CTX_REMOVE_CACHE_EP":"Elimina l\'episodi de la memòria cau","CTX_OPEN_CONTAINING":"Obre la carpeta que conté","CTX_REMOVE":"Elimina de la biblioteca","CTX_AVAILABLE_OFFLINE":"Disponible fora de línia","CTX_PAUSED":"En pausa","CTX_ALWAYS_ON_TOP":"Sempre a la part superior","CTX_FULLSCREEN":"Pantalla completa","CTX_WRONG_SUBS":"Subtítols incorrectes?","CTX_REPORT_ISSUES":"Informar del problema","CTX_COPY":"Copia","CTX_PASTE":"Enganxa","CTX_CLEAR":"Esborra","CTX_CLEAR_RECENT_SEARCHES":"Esborra les cerques recents","HELLO_THERE":"Hola","HOPE_YOU_ENJOY":"Esperem que gaudiu d\'Stremio i ja sigui una de les vostres aplicacions preferides.","WHO_ARE_WE":"Qui som? Som l\'equip que hi ha darrere: dos nois que treballen molt cada dia durant els darrers 3 anys per fer que aquest producte sigui cada vegada millor.","SUPPORT_US":"Si us agrada utilitzar Stremio, si Stremio és valuós per a vosaltres, correu la veu!","SPREAD_THE_WORD":"Comparteix amb els teus amics ara, difon la notícia sobre Stremio","MORE_PEOPLE":"Com més gent utilitzi Stremio, millor serà.","SEND_A_LINK":"O envieu un enllaç al nostre lloc web","TIP_LOCALFILES":"Consell: podeu arrossegar i deixar anar fitxers de vídeo locals a Stremio","ADDON_MY":"Els meus complements","ADDON_COMMUNITY":"Complements de la comunitat","ADDON_OFFICIAL":"Complements oficials","ADDON_REPOS":"Col·leccions de complements","ADDON_SEARCH":"Cerca de complements","ADDON_INSTALL":"Instal·la","ADDON_CONFIGURE":"Configura","ADDON_UNINSTALL":"Desinstal·la","ADDON_UPGRADE":"Actualitza","ADDON_INSTALLED":"Instal·lat","ADDON_INSTALLED_MSG":"Complement instal·lat!","ADDON_UPGRADED_MSG":"Complement actualitzat!","ADDON_UNKNOWN":"Desconegut","ADDON_ERR":"Error d\'instal·lació del complement!","ADDON_DISCONNECTED":"Desconnectat","ADDON_APP_MISSING":"l\'aplicació d\'aquesta font no està instal·lada. Voleu instal·lar-la ara?","ADDON_APP_INSTALL":"Instal·lar ara","ADDON_PAGE":"Pàgina del complement","ADDON_TOP_CONTENT":"El millor d\'aquest complement","ADDON_PROVIDES":"Aquest complement proporciona:","ADDON_WATCH":"Mireu #{types} ara!","ADDON_WATCH_FREE":"Mireu #{types} GRATIS ara!","ADDON_ADDON":"Complement","ADDON_SUPPORTED_TYPES":"Tipus compatibles","ADDON_SUPPORTED_CATALOGS":"Catàlegs compatibles","ADDON_PROVIDES_DISCOVER":"Més #{types} a Descobreix","ADDON_PROVIDES_STREAMS":"Mira #{types}","ADDON_PROVIDES_STREAMS_FREE":"Mireu #{types} GRATIS","ADDON_PROVIDES_SUBTITLES":"Subtítols per #{types}","ADDON_CANTDETECT":"No hem pogut detectar un Stremio en execució, de manera que no hem pogut detectar quins complements heu instal·lat.","ERR_NO_META":"No s\'ha trobat informació sobre això ","ERR_GETTING_META":"Error en recuperar informació sobre això.","ERR_CANT_PARSE_MAGNET":"No es pot analitzar l\'enllaç magnètic","ERR_NO_MAGNET_INFOHASH":"No hi ha cap hash d\'informació magnet vàlida","ERR_NO_FILE_PATH":"No es pot enviar la sol·licitud sense una ruta al fitxer","ERR_NO_TORRENT":"No s\'ha retornat cap torrent","ERR_NO_SUPPORTERD_FILES":"No s\'han trobat fitxers compatibles","ERR_OPENING_FILES":"No s\'han pogut obrir els fitxers externs","ERR_INVALID_LINK":"Enllaç invàlid","ERR_REGISTERED_ONLY":"Aquesta opció només està disponible per als usuaris registrats.","ERR_CLIPBOARD":"No es pot reproduir des del porta-retalls","ERR_CLIPBOARD_READ":"No es pot llegir el porta-retalls d\'aquesta plataforma","ERR_CLIPBOARD_GENERIC":"No s\'ha trobat cap URL reproduïble al porta-retalls. Copieu un URL (per exemple, un enllaç magnètic) a un vídeo.","BOARD_CONTINUE_WATCHING":"Continuar mirant","BOARD_EXPLANATION_RECOMMENDATIONS":"Pel·lícules seleccionades especialment per a vosaltres.
Aquesta pel·lícula és una recomanació d\'exemple.","BOARD_EXPLANATION_EPISODES":"Els nous episodis de les vostres Sèries preferides arriben aquí.
Afegiu sèries que seguiu a la Biblioteca.","BOARD_EXPLANATION_VIDEOS":"Els nous episodis dels vostres Canals preferits arriben aquí.
Afegiu a la Biblioteca els canals de YouTube que seguiu.","WEBSITE_SLOGAN_WATCH":"Veure instantàniament","WEBSITE_SLOGAN_ALL":"Tot el contingut de vídeo que gaudiu d\'un sol lloc","WEBSITE_SLOGAN_NEW":"Tot el que podeu veure","WEBSITE_SLOGAN_NEW_NEW":"Llibertat d\'emissió","WEBSITE_WATCH_FROM":"Veure des de","WEBSITE_DOWNLOAD":"Baixa-ho ara","WEBSITE_DOWNLOAD_FOR":"Baixeu-lo ara per","WEBSITE_IS_DESKTOP":"Stremio és una aplicació d\'escriptori, obriu aquesta pàgina al vostre PC i descarregueu-la","WEBSITE_DESKTOP_DEMO_VID":"Demostració d\'escriptori","WEBSITE_PAGE_HOME":"Inici","WEBSITE_PAGE_FEATURES":"Característiques","WEBSITE_PAGE_ADDONS":"Complements","WEBSITE_PAGE_TECH":"Tecnologia","WEBSITE_PAGE_CREATE_ADDON":"Crea un Complement","WEBSITE_PAGE_CONTACTS":"Contactes","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Pel·lícules","WEBSITE_TYPE_series_PL":"Sèries","WEBSITE_TYPE_tv":"TV en directe","WEBSITE_TYPE_channel":"Canals","WEBSITE_STREMIO_WHAT_IS":"Stremio és una aplicació que us ajuda a organitzar i veure a l\'instant els vostres vídeos, pel·lícules, sèries i canals de televisió preferits.","WEBSITE_FEATURES_WATCH":"Veure instantàniament en HD","WEBSITE_FEATURES_WATCH_DETAIL":"Feu clic i reproduïu els vostres pel·lícules, programes de televisió, vídeos i canals de TV preferits.","WEBSITE_FEATURES_SUBS":"Subtítols automàtics","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio selecciona automàticament els subtítols sincronitzats per al vostre idioma.","WEBSITE_FEATURES_SUBS_LABEL":"Tu mous, mestre.","WEBSITE_FEATURES_CAST":"Reprodueix a la TV i dispositius mòbils","WEBSITE_FEATURES_CAST_DETAIL":"Emet a AppleTV, Chromecast, Smart TV (DLNA/UPnP) i dispositius mòbils.","WEBSITE_LIB":"Gaudeix de la teva biblioteca personal sincronitzada en tots els teus dispositius","WEBSITE_LIB_COLLECT":"Recopila informació d\'Stremio","WEBSITE_LIB_IMPORT":"Importa de Facebook","WEBSITE_LIB_LOCAL":"Afegeix des del vostre disc local","WEBSITE_BOARD":"El tauler - El lloc principal per a Notificacions i Recomanacions","WEBSITE_BOARD_RECOMMEND":"Programa de televisió recomanat","WEBSITE_BOARD_TRENDING":"Tendències de pel·lícules","WEBSITE_BOARD_NEW":"Nou vídeo","WEBSITE_BOARD_EPISODE":"Nou episodi","WEBSITE_BOARD_1":"Busqueu alguna cosa interessant per veure? Obteniu recomanacions segons el vostre gust!","WEBSITE_BOARD_2":"Sigues notificat quan surti un nou episodi del vostre programa de televisió o canal de YouTube preferit.","WEBSITE_BOARD_YOUTUBE":"Nous vídeos de canals de YouTube","WEBSITE_BOARD_EPISODES":"Nous episodis de sèries que seguiu","WEBSITE_ADDONS":"Complements de contingut","WEBSITE_TECH_DETAIL":"Ens encanta la tecnologia, ens encanta la ciència boja!\\nStremio utilitza les següents tecnologies de codi obert:","WEBSITE_TECH_WCJS":"WebChimera.js permet a Stremio reproduir qualsevol format de vídeo amb un bon rendiment.","WEBSITE_TECH_WCJS_EXTRA":"Som col·laboradors principals del projecte","WEBSITE_TECH_ELECTRON":"Electron proporciona una plataforma innovadora per construir Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Som col·laboradors del projecte","WEBSITE_TECH_LINVODB":"Una tecnologia de base de dades que garanteix que les vostres dades estiguin organitzades i disponibles a qualsevol lloc on us inicieu la sessió.","WEBSITE_TECH_LINVODB_EXTRA":"Tecnologia pròpia","WEBSITE_CREATE_ADDON":"Creeu el vostre complement","WEBSITE_CREATE_ADDON_DETAIL":"Teniu un servei que proporcioni contingut de vídeo? Us ajudarem a beneficiar-vos de les funcions d\'Stremio creant el vostre complement","WEBSITE_CREATE_ADDON_BENEFITS":"Avantatges de crear un complement per a Stremio","WEBSITE_P2P_BEAUTY":"La bellesa de la transmissió d\'igual a igual (P2P)","WEBSITE_P2P_1":"Vídeo HD / 4K fiable i assequible a petició o en directe","WEBSITE_P2P_2":"Plataforma de distribució que proporciona una gran experiència d\'usuari","WEBSITE_P2P_3":"Crearem un complement que compleixi les vostres necessitats exactes","WEBSITE_P2P_CONTACT":"T\'interessa? Et convidem a contactar-nos.","WEBSITE_P2P_CONTACT_EXTRA":"Estarem encantats d\'ajudar-vos a integrar el vostre contingut amb Stremio!","WEBSITE_P2P":"De tant en tant, arriba una tecnologia que canvia el joc. Invertim tones de temps i esforç en la creació del nostre motor de transmissió de vídeo d\'igual a igual (P2P) que proporciona un gran rendiment i versatilitat a adapteu-vos amb qualsevol cas d\'ús.\\nContacteu amb nosaltres per obtenir vídeos P2P habilitats per a DRM a la carta o en directe.","WEBSITE_THOUGHTS":"Pensaments que compartim:","WEBSITE_SPREAD":"Difon la notícia sobre Stremio:","WEBSITE_CONTACT":"Poseu-vos en contacte amb nosaltres, estarem encantats de conèixer-vos!","WEBSITE_OPENSOURCE":"Per als nostres projectes de codi obert, aneu al nostre","WEBSITE_BITCOIN":"Feu una donació de bitcoins:","WEBSITE_FAQ":"Preguntes freqüents","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Preguntes","WEBSITE_TOS":"Condicions d\'ús","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"Quant a","WEBSITE_PAGE_BECOME_PARTNER":"Feu-vos soci","WEBSITE_ALL_YOU_CAN_WATCH":"Llibertat de visualització\\nTot el que desitgeu.","WEBSITE_FREEDOM_TO_STREAM":"Llibertat d\'emissió","WEBSITE_WHAT_IS_STREMIO":"Què és Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio és un centre únic per a l\'agregació de contingut de vídeo. Descobriu, organitzeu i mireu vídeos de tot tipus de fonts en qualsevol dispositiu que tingueu.","WEBSITE_WHAT_IS_STREMIO_P2":"Pel·lícules, programes de televisió, sèries, televisió en directe o canals web com YouTube i Twitch.tv - tot això ho podeu trobar a Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio és un modern centre multimèdia que és una solució única per al vostre entreteniment de vídeo. Descobriu, mireu i organitzeu contingut de vídeo des de complements fàcils d\'instal·lar.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Pel·lícules, programes de televisió, TV en directe o canals web: trobeu tot això a Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Gaudeix en tots els teus dispositius multimèdia","WEBSITE_DEVICES_COLLECT":"Recopila informació d\'Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importa de Facebook","WEBSITE_DEVICES_LOCAL":"Afegeix des del disc local","WEBSITE_JOIN_THE_PARTY_NOW":"Uniu-vos a la festa ara","WEBSITE_DEVICES_ALL":"Fàcil d\'utilitzar en tots els vostres dispositius;","WEBSITE_EXTENDABLE_CATALOG":"Catàleg de vídeo extensible infinitament;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Funcions fantàstiques per organitzar el vostre contingut multimèdia;","WEBSITE_AS_SEEN_ON":"Com es veu a","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Sobre nosaltres","WEBSITE_LINK_TECHNOLOGY":"Tecnologia","WEBSITE_LINK_APPS":"Aplicacions","WEBSITE_LINK_DOWNLOADS":"Descàrregues","WEBSITE_MORE":"Més","WEBSITE_LINK_ADDONS":"Complements","WEBSITE_LINK_ADDON_SDK":"SDK Complements","WEBSITE_LINK_CONTRIBUTE":"Contribuir","WEBSITE_LINK_COMMUNITY":"Comunitat","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... i més","WEBSITE_LINK_HELP":"Centre d\'ajuda","WEBSITE_LINK_CONTACTS":"Consultes empresarials","WEBSITE_LINK_TOS":"Termes i Condicions","WEBSITE_LINK_PRAVACY":"Política de privacitat","WEBSITE_SUBSCRIBE":"Subscriu-te","WEBSITE_NEWSLETTER":"Uniu-vos al nostre butlletí de coses increïbles","WEBSITE_PLACEHOLDER_EMAIL":"El teu correu electrònic","WEBSITE_COMMUNITY":"Comunitat","WEBSITE_LINK_PRAVACY_LEGAL":"Privadesa i legal","WEBSITE_WHY":"Per què ho fem?","WEBSITE_WHY_P1":"A Stremio, treballem cada dia perquè volem resoldre un problema important per a la indústria del vídeo a la carta. Hi ha tants continguts nous publicats cada minut que és pràcticament impossible trobar-hi el camí.","WEBSITE_WHY_P2":"Ajudem la gent a navegar per aquest enorme món d\'entreteniment en vídeo i a descobrir contingut nou per gaudir-ne. Les nostres aplicacions reuneixen pel·lícules, sèries, TV en directe, canals web i molt més. Ens dediquem a facilitar als usuaris la possibilitat de trobar títols i emissores que els encanten.","WEBSITE_WHY_P3":"Podeu utilitzar el nostre servei en qualsevol dispositiu i en qualsevol moment, cosa que converteix Stremio en l\'únic centre d\'entreteniment de vídeo que necessiteu.","WEBSITE_TEAM":"EQUIP","WEBSITE_TEAM_P":"L\'equip d\'Stremio és petit però potent: entre els deu programem en X idiomes i compartim experiència en desenvolupament de programari, disseny UI i UX, màrqueting i publicitat, i empreses i startups.","WEBSITE_FEATURES":"Característiques","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Descobriu contingut nou amb facilitat","WEBSITE_FEATURES_DISCOVER_P":"Descobriu fàcilment noves pel·lícules, programes de televisió, sèries i canals per veure. Navegueu per categoria, gènere, classificació, actualitat, etc. o simplement escriviu un nom per trobar-lo. Stremio fa que trobar contingut de vídeo nou sigui bufar i fer ampolles.","WEBSITE_FEATURES_ALL_CONTENT":"Tot el contingut de vídeo en una sola pantalla","WEBSITE_FEATURES_ALL_CONTENT_P1":"Vegeu quines pel·lícules, sèries o vídeos no heu acabat i continueu veient-les; rebre notificacions de nous episodis i llançaments; i navegueu per les recomanacions que obtindreu en funció dels vostres hàbits de visualització.","WEBSITE_FEATURES_LIBRARY":"Organitzeu la vostra videoteca","WEBSITE_FEATURES_LIBRARY_P1":"Afegiu qualsevol títol a la vostra biblioteca Stremio amb un sol clic i cerqueu el vostre contingut, ordenat per tipus, actualitat o ordre alfabètic.","WEBSITE_FEATURES_CALENDAR":"Feu un seguiment de tot el que mireu","WEBSITE_FEATURES_CALENDAR_P1":"Obteniu una visualització del calendari de totes les pel·lícules i sèries que afegiu a la biblioteca. Exporteu el calendari Stremio i sincronitzeu-lo perquè sempre sàpiga quan s\'ha de produir un episodi nou o una premier.","WEBSITE_FEATURES_BIG_SCREEN":"Gaudeix del teu contingut de vídeo en una pantalla més gran","WEBSITE_FEATURES_BIG_SCREEN_P1":"Emet qualsevol cosa que estigueu veient a un altre dispositiu, ja sigui un telèfon, una tauleta o un televisor amb un sol clic.","WEBSITE_FEATURES_SOURCES":"Mireu el vídeo de moltes fonts diferents","WEBSITE_FEATURES_SOURCES_P":"Instal·leu complements oficials i de la comunitat per gaudir de vídeos provinents de molts proveïdors diferents - tot en una aplicació elegant i fàcil d\'utilitzar.","WEBSITE_CREATE_AN_ADDON":"Creeu un complement","WEBSITE_FEATURES_SYNC":"Sincronitzeu la biblioteca entre diferents dispositius i repreneu la reproducció","WEBSITE_FEATURES_SYNC_P1":"Inicieu la sessió amb el vostre compte a tots els vostres dispositius i gaudiu de la vostra biblioteca, complements, reproducció i calendari sincronitzats.","WEBSITE_FEATURES_EXTENDABLE":"Catàleg de vídeo ampliable amb complements","WEBSITE_FEATURES_EXTENDABLE_P1":"El catàleg de complements Stremio proporciona diversos complements per instal·lar i veure una gran varietat de contingut de vídeo. Això inclou pel·lícules, programes, TV en directe, esports, notícies, podcasts, canals web, videojocs i molt més.","WEBSITE_FEATURES_AUTO_SUBS":"Subtítols automàtics","WEBSITE_FEATURES_AUTO_SUBS_P1":"Amb els nostres complements de subtítols obtindreu opcions seleccionades automàticament per al vostre idioma preferit.","WEBSITE_FEATURES_CHROMECAST":"Emetent a Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Gaudeix del contingut de vídeo en una pantalla més gran o simplement emet el que estiguis mirant a un altre dispositiu.","WEBSITE_FEATURES_KEEP_TRACK":"Feu un seguiment dels vostres programes de televisió i canals web preferits","WEBSITE_FEATURES_KEEP_TRACK_P1":"Obteniu una visualització del calendari i notificacions de capítols nous de les vostres sèries i canals web preferits.","WEBSITE_FEATURES_POWER_USER":"Funcions d\'usuari avançat","WEBSITE_FEATURES_POWER_USER_P1":"Reprodueix en un reproductor extern","WEBSITE_FEATURES_POWER_USER_P2":"Reprodueix des d\'un fitxer torrent o un enllaç magnètic","WEBSITE_FEATURES_POWER_USER_P3":"Importa a la teva biblioteca des de m\'agrada de Facebook o discs locals","WEBSITE_ADD_ONS":"Complements","WEBSITE_ADD_ONS_P1":"Tot el contingut de vídeo que proporciona Stremio s\'obté a través d\'un sistema de complements - no hi ha cap contingut ni proveïdor de contingut integrat a l\'aplicació.","WEBSITE_ADD_ONS_P2":"Hi ha dos grups de complements disponibles: complements oficials i de comunitat.","WEBSITE_ADD_ONS_P3":"Els oficials són desenvolupats i allotjats per Stremio, mentre que els complements de la comunitat els creen els membres de la comunitat, que també els allotgen.","WEBSITE_ADDONS_OFFICIAL":"Complements oficials","WEBSITE_ADDONS_WATCHUB":"Reprodueix les teves pel·lícules, sèries i programes preferits de proveïdors com iTunes, Hulu, Amazon i altres serveis del Regne Unit i dels Estats Units.","WEBSITE_ADDONS_YOUTUBE":"Mireu els vostres canals de YouTube preferits sense anuncis i obteniu notificacions de les contribucions que heu seguit sobre les càrregues noves.","WEBSITE_ADDONS_FILMON":"Mireu TV en directe, pel·lícules i televisió social de franc. 600 canals de televisió, 45.000 pel·lícules gratuïtes, documentals i molt més.","WEBSITE_ADDONS_OPENSUBTITLES":"Subtítols de pel·lícules i TV en diversos idiomes, milers de subtítols traduïts penjats cada dia.","WEBSITE_ADDONS_COMMUNITY":"Complements de la comunitat","WEBSITE_ADDONS_FILMON_VOD":"Mireu el vídeo a la carta de Filmon.tv","WEBSITE_ADDONS_TWICH":"Mireu en directe des de Twitch.tv - una plataforma de transmissió de vídeo per a la indústria dels esports electrònics.","WEBSITE_ADDONS_VODO":"Mireu pel·lícules independents de forma totalment gratuïta.","WEBSITE_ADDONS_NETFLIX":"Mireu pel·lícules i sèries web de Netflix.","WEBSITE_ADDONS_CREATE":"Creeu un complement","WEBSITE_ADDONS_CREATE_P1":"Si ho desitgeu, podeu desenvolupar el vostre propi complement. D\'aquesta manera, podeu oferir a vosaltres mateixos i a la nostra comunitat accés a contingut de vídeo nou i arribar a un públic nou i dirigit de milions d\'usuaris de tot el món.","WEBSITE_ADDONS_START_CREATE":"Per començar, visiteu la pàgina del SDK de Complements Stremio:","WEBSITE_DOWNLOADS":"Descàrregues","WEBSITE_DOWNLOADS_P1":"Per obtenir un rendiment òptim, us recomanem que utilitzeu la versió més recent disponible de les aplicacions Stremio. Tanmateix, si per algun motiu voleu utilitzar una versió anterior, la podeu descarregar aquí.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio per a Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio per a macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio per a Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio per a Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio per a Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio per a Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio per a Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio per a iOS (versió limitada)","WEBSITE_CONTRIBUTE":"Contribuir","WEBSITE_CONTRIBUTE_P1":"La plataforma Stremio és de codi obert i podeu crear fàcilment un complement per al contingut que actualment no existeix.","WEBSITE_CONTRIBUTE_WHY":"Per què heu de crear un complement?","WEBSITE_CONTRIBUTE_WHY_P1":"Arribeu a un públic nou pel contingut del vostre vídeo","WEBSITE_CONTRIBUTE_WHY_P2":"La base d\'usuaris d\'Stremio creix ràpidament - el primer any del llançament, Stremio va guanyat un milió d\'usuaris a tot el món i, el segon any d\'existència de la plataforma, aquest nombre va créixer fins als 2,5 milions.","WEBSITE_CONTRIBUTE_WHY_P3":"Amb el vostre complement, podeu arribar fàcilment a aquest públic i distribuir-hi el vostre contingut de vídeo.","WEBSITE_CONTRIBUTE_ALL":"Mireu les vostres pel·lícules, vídeos, sèries i canals preferits en un sol lloc.","WEBSITE_CONTRIBUTE_ALL_P1":"Sou fans d\'un tipus de contingut concret que encara no està disponible a Stremio? Crea un complement i gaudeix veient els teus vídeos preferits en un dels centres d\'entreteniment més grans i fàcils d\'utilitzar del mercat.","WEBSITE_CONTRIBUTE_ALL_P2":"A més, obtindreu l\'agraïment interminable d\'altres membres de la comunitat Stremio amb idees semblants.","WEBSITE_CONTRIBUTE_MONETIZE":"Obteniu ingressos del vostre complement i guanyeu diners amb la seva ajuda","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Un cop hàgiu desenvolupat un nou complement per a Stremio, podeu obtenir ingressos fàcilment a través de diverses maneres. Si ho teniu en compte, no dubteu a posar-vos en contacte amb nosaltres a ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - estarem encantats de consultar-los i assessorar-vos sobre les opcions de monetització dels complements.","WEBSITE_CONTRIBUTE_TRANSLATE":"Feu-vos traductor voluntari","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Si voleu gaudir de les aplicacions Stremio en diferents idiomes, podeu unir-vos a la nostra comunitat de traductors voluntaris. Ens ajuden a afegir versions d\'Stremio en molts idiomes diferents.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Teniu moltes ganes de començar?","WEBSITE_TRANSALTE_STREMIO":"Tradueix Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Comunitats oficials","WEBSITE_COMMUNITY_OFFICIALS_P1":"Formeu part de la creixent comunitat Stremio. Seguiu-nos a les xarxes socials i no tingueu por de saludar - ens encanta escoltar els nostres fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Comunitats no oficials","STREMIO_COMMUNITY_NL":"Stremio Països Baixos","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Alemanya","STREMIO_COMMUNITY_BELGIUM":"Stremio Bèlgica","STREMIO_COMMUNITY_FRANCE":"Stremio França","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Itàlia","STREMIO_COMMUNITY_UK":"Stremio Regne Unit","STREMIO_COMMUNITY_USA":"Stremio EUA","STREMIO_COMMUNITY_MEXICO":"Stremio Mèxic","STREMIO_COMMUNITY_ADDONS":"Complements Stremio","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Socis i simpatitzants","WEBSITE_COMMUNITY_GOODIES":"Llaminadures Stremio","WEBSITE_COMMUNITY_WALLPAPERS":"Fons de pantalla","WEBSITE_COMMUNITY_ART":"Galeria d\'Art de la Comunitat","WEBSITE_LINK_ART":"Galeria d\'art de la comunitat","WEBSITE_CONTACT_US":"Contacteu-nos","WEBSITE_CONTACT_US_P1":"Si teniu cap pregunta, comentari o suggeriment, no dubteu a posar-vos en contacte amb nosaltres a través del formulari de contacte següent.","WEBSITE_CONTACT_US_P2":"Tingueu en compte que estem ubicats a Bulgària, de manera que pot haver-hi un retard en atendre la vostra consulta a causa de les diferències de zona horària.","WEBSITE_CONTACT_US_SUCCESS":"El teu missatge ha estat enviat. Ens posarem en contacte amb vostè el més aviat possible.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Introduïu un correu electrònic vàlid!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Amb què està relacionada la vostra pregunta?","WEBSITE_CONTACT_US_Q_OS":"Quin és el vostre Sistema Operatiu?","WEBSITE_CONTACT_US_PH_EMAIL":"El teu correu electrònic","WEBSITE_CONTACT_US_PH_MESSAGE":"Missatge","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ENVIAR","WEBSITE_CONTACT_US_Q_1":"Com instal·lar?","WEBSITE_CONTACT_US_Q_2":"Com es desinstal·la?","WEBSITE_CONTACT_US_Q_3":"(HTML) Com fer lasanya?","WEBSITE_CONTACT_US_Q_4":"Complements","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Tecnologia","WEBSITE_TECHNOLOGY_P1":"Ens encanta la tecnologia i la ciència boja.
Això és el que potencia Stremio (tot és de codi obert).","WEBSITE_TECHNOLOGY_P_QT":"Desenvolupament de programari multiplataforma al màxim.","WEBSITE_TECHNOLOGY_P_MPV":"Un reproductor multimèdia gratuït, de codi obert i multiplataforma.","WEBSITE_TECHNOLOGY_P_RN":"React Native us permet crear aplicacions per a mòbils només amb JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Framework multimèdia incrustat a l\'aplicació per obtenir multimèdia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm és una plataforma mòbil i un substitut de SQLite i Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js és un entorn de temps d\'execució de JavaScript de multiplataforma i de codi obert.","WEBSITE_TECHNOLOGY_P_RUST":"Rust és un llenguatge de programació de sistemes multi-paradigma centrat en la seguretat, sobretot la concurrència.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribuir al projecte","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Hi ha dues maneres de contribuir a Stremio i ajudar-nos a millorar el producte.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Podeu donar les vostres valuoses habilitats lingüístiques traduint la plataforma ...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"o bé","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... podeu emprar les vostres habilitats de codificació per crear complements de la comunitat. ","WEBSITE_TRANSLATE_STREMIO":"Tradueix Stremio","WEBSITE_404_OH_NO":"Uh-oh! La pàgina que cerqueu no és aquí...","WEBSITE_GO_HOME":"Anar a l\'inici","WEBSITE_LINK_OTHER_DOWNLOADS":"Altres descàrregues","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Suport","WEBSITE_DOWNLOAD_4_0_BETA":"Descarregueu Stremio 4 beta ara","WEBSITE_GET_FOR_DESKTOP":"Per a escriptori","WEBSITE_LINK_ADDON_COMPETITION":"Competició de complements","WEBSITE_LINK_ART_CONTEST":"Concurs d\'art","WEBSITE_MY_ACCOUNT":"El meu compte","WEBSITE_MAINPAGE_FAQ_001_H1":"Què és Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio és un modern centre de comunicació que us ofereix la llibertat de veure tot el que desitgeu.","WEBSITE_MAINPAGE_FAQ_002_H1":"Com funciona?","WEBSITE_MAINPAGE_FAQ_002_P1":"Un cop instal·leu Stremio al dispositiu i creeu un compte, tot el que heu de fer és visitar el catàleg de complements i instal·lar qualsevol que vulgueu, i llestos!","WEBSITE_MAINPAGE_FAQ_002_P2":"Després d\'això, podeu anar a les seccions Descobreix o Tauler per començar a explorar el contingut.","WEBSITE_MAINPAGE_FAQ_003_H1":"Què puc veure aquí?","WEBSITE_MAINPAGE_FAQ_003_P1":"Molt: pel·lícules, programes de televisió, canals web, esports, canals de TV, escoltar podcasts i molt més. Gràcies al nostre sistema de complements, podeu accedir a diversos continguts.","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio és de codi obert?","WEBSITE_MAINPAGE_FAQ_004_P1":"Sí, podeu consultar els enllaços següents: ${1}aplicació d\'escriptori${2} i ${3}organització GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"És segur Stremio?","WEBSITE_MAINPAGE_FAQ_005_P1":"Sí: com que és programari de codi obert, el codi es pot auditar públicament i el podeu revisar vosaltres mateixos.","WEBSITE_MAINPAGE_FAQ_006_H1":"I la meva privadesa?","WEBSITE_MAINPAGE_FAQ_006_P1":"Respectem la privadesa dels usuaris i no recopilem cap dada personal a més del mínim essencial per crear i sincronitzar el vostre compte.","WEBSITE_MAINPAGE_FAQ_006_P2":"També hi ha un ${1}mode de convidat${2} al registre, que no requereix cap mena de dades: en aquest mode, no es realitzen crides al nostre backend. No obstant, a costa de funcions útils com ara poder sincronitzar la biblioteca entre dispositius.","WEBSITE_MAINPAGE_FAQ_007_H1":"Puc emetre al meu televisor?","WEBSITE_MAINPAGE_FAQ_007_P1":"Sí, donem suport a Chromecast i podeu emetre-les des d\'aplicacions d\'escriptori i mòbils (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Quants complements té Stremio?","WEBSITE_MAINPAGE_FAQ_008_P1":"A finals de 2019, més de 50 - per a més informació, consulteu el nostre catàleg de complements.","WEBSITE_MAINPAGE_FAQ_009_H1":"Es pot ampliar Stremio més enllà del que hi ha al catàleg de complements?","WEBSITE_MAINPAGE_FAQ_009_P1":"Sí, hauríeu de comprovar els següents: ${1}PimpMyStremio${2}, ${3}comunitats Reddit${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"Quins dispositius admeten Stremio?","WEBSITE_MAINPAGE_FAQ_010_P1":"Disposem d\'aplicacions d\'escriptori per a Windows, Mac i Linux. Per a mòbils, admetem Android i iOS, tot i que tingueu en compte que la funcionalitat d\'IOS és limitada (no admet la majoria dels complements).","WEBSITE_MAINPAGE_FAQ_010_P2":"Hi ha molts dispositius basats en Android en els quals podeu executar Stremio, com NVIDIA Shield i Amazon Fire Stick, però no els admetem oficialment.","WEBSITE_MAINPAGE_FAQ_011_H1":"Podeu afegir un determinat contingut a Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Ho sentim, nosaltres mateixos no proporcionem contingut, però com més complements Stremio tingueu instal·lats, més contingut podreu trobar.","WEBSITE_MAINPAGE_FAQ_012_H1":"Pot Stremio reproduir enllaços magnètics?","WEBSITE_MAINPAGE_FAQ_012_P1":"Sí, i també pot reproduir enllaços HTTP normals i fitxers torrent (arrossegar i deixar anar)..","WEBSITE_MAINPAGE_FAQ_013_H1":"Puc descarregar un vídeo i mirar-lo fora de línia?","WEBSITE_MAINPAGE_FAQ_013_P1":"Disponible fora de línia és una característica pròxima, però si permeteu que Stremio emmagatzemi memòria cau al dispositiu (des del tauler de configuració) podreu veure els vídeos més endavant sense connexió.","WEBSITE_MAINPAGE_FAQ_014_H1":"Res funciona, ajuda\'m!","WEBSITE_MAINPAGE_FAQ_014_P1":"Esteu segur que teniu instal·lats complements? Si és així, consulteu el nostre ${1}centre d\'ajuda${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Com manté Stremio les seves operacions de desenvolupament?","WEBSITE_MAINPAGE_FAQ_015_P1":"Publiquem anuncis no intrusius a través de ${1}AdEx${2}, que és una empresa del mateix equip fundador que se centra en anuncis transparents que preserven la privadesa.","WEBSITE_MAINPAGE_FAQ_015_P2":"Per obtenir més preguntes, aneu al nostre ${1}centre d\'ajuda${2}.","HELP_LEARN_MORE":"Ajudeu-nos a obtenir més informació sobre vosaltres.","LIFESTYLE":"Estil de vida","SPORTS":"Esports","FOOD_HEALTH":"Alimentació i salut","BEAUTY_FASHION":"Bellesa i moda","NEWS":"Notícies","GAMING":"Videojocs","SCIENCE_EDUCATION":"Ciència i educació","MUSIC":"Música","TRAVEL":"Viatges","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comèdia","DIY":"Fes-ho tu mateix (DIY)","TECH":"Tecnologia","CINEMA":"Cinema","CONTINUE":"Continua","SLOW_LOADING":"CÀRREGA LENTA?","I_GIVE_UP":"EM RENDEIXO","LEARN_MORE":"Aprèn més","POOR_SOURCE":"Aquesta font té poca disponibilitat o la vostra connexió a Internet no és prou ràpida","PICK_CATEGORIES_ERR":"Heu de triar com a mínim 3 categories","ADJUST_TIMING":"Ajusteu el temps amb ","ADJUST_SIZE":"Ajusta la mida amb ","SEARCH_ANYTHING":"Podeu cercar qualsevol cosa...","ALL_CATEGORIES":"Tots","SEARCH_CATEGORIES":"Pel·lícules, Sèries, YouTube i TV","SEARCH_PERSONS":"Actors, directors i escriptors","SEARCH_PROTOCOLS":"Enllaços HTTP i magnètics","SEARCH_TYPES":"Enllaços IMDB / TVDB","WATCHED":"Vist","SHOW_LESS":"Mostrar menys","LAST_SEARCHES":"Darreres cerques","CLEAR_HISTORY":"Neteja l’historial","CHOOSE_SOME":"TRIA ALGUNS D\'AQUEST:","NO_WEB_REMOTE":"No s\'ha pogut carregar el comandament a distància web","STREMIO_OFFLINE":"Stremio està fora de línia","STREMIO_EXPENSIVE_CONNECTION":"Hem detectat que utilitzeu una connexió de dades mòbils, voleu continuar?","USE_DATA":"Utilitzeu dades","WARNING":"Avís","MORE_INFO":"Més informació ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Carregant ...","STREMIO_TV_BACK_TO_LANGUAGES":"Torna als idiomes","STREMIO_TV_REMOTE":"Remot","STREMIO_TV_GO_TO":"Anar a:","STREMIO_TV_OR_SCAN":"o escaneja:","STREMIO_TV_ADDON_INSTRUCTIONS":"Seguiu les instruccions per instal·lar els vostres complements preferits.","STREMIO_TV_LIVE_TV":"TV en directe","STREMIO_TV_RESUME_WATCHING":"Reprèn la visualització","STREMIO_TV_LOADING_BACKGROUND":"Carregant el fons","STREMIO_TV_CHECKING_AUTHENTICATION":"Comprovant l\'autenticació","STREMIO_TV_LOADING_BOARD":"Carregant el Tauler","STREMIO_TV_LOGIN_HEADER_LINE_1":"Volem que els nostres usuaris tinguin la millor experiència personalitzada possible amb el nostre programari.","STREMIO_TV_LOGIN_HEADER_LINE_2":"És per aquest motiu que us demanem que creeu i/o inicieu sessió al vostre compte.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Gràcies per la comprensió,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"L\'equip d\'Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Per utilitzar el comandament a distància web amb el vostre telèfon / tauleta / escriptori:","STREMIO_TV_WIFI_SETUP":"Configuració Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle no ha detectat connexió a Internet.","STREMIO_TV_WIFI_DETAILS_1":"Connecta\'t amb:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Utilitzeu la contrasenya:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Obriu un navegador web amb l\'enllaç:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Per defecte","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Per Última Visualització","STREMIO_TV_LIBRARY_SORT_NAME":"Per Nom","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Per Cops Vist","STREMIO_TV_DETAILS_SEASON_NUMBER":"Temporada ${1}","STREMIO_TV_STREAMS_LOADING":"Carregat ${1} / ${2} complements...","STREMIO_TV_STREAMS_STILL_LOADING":"Complement ${1} encara està carregant...","STREMIO_TV_PLAYER_SETTINGS":"Configuració del Reproductor","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Retard dels subtítols","STREMIO_TV_PLAYER_AUDIO_DELAY":"Retard d\'àudio","STREMIO_TV_PLAYER_VIDEO_SCALING":"Escalat de vídeo","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Font de reproducció no compatible","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"No s\'ha pogut obrir l\'enllaç extern","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Reprodueix amb ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Reprodueix amb el reproductor libVLC","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Canviant al reproductor libVLC a causa d\'un error de reproducció","STREMIO_TV_ADDONS_TITLE":"Utilitzeu Stremio al vostre telèfon o PC per instal·lar o configurar complements i premeu \\"Sincronitza complements\\"","STREMIO_TV_ADDONS_SUBTITLE":"Nota: assegureu-vos que feu servir el mateix compte de Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sincronitza complements","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Els complements s\'han sincronitzat correctament","STREMIO_TV_ADDONS_SYNC_FAILED":"No s\'han pogut sincronitzar els complements","STREMIO_TV_META_LINK_FAILED":"No s\'ha pogut obrir el metaenllaç","STREMIO_TV_CATALOG_LOADING":"El catàleg encara s\'està carregant...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Idioma de la interfície actualitzat","STREMIO_TV_SETTINGS_THEME_UPDATED":"Tema actualitzat","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Reproductor per Defecte","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"Reproductor Extern","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Idioma preferit","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Idioma secundari preferit","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Reproducció en túnel","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possibles problemes de reproducció en alguns dispositius","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"És possible que alguns formats de vídeo no funcionin","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Concordança automàtica de velocitat de fotogrames","STREMIO_TV_SETTINGS_NO_CACHING":"Sense memòria cau","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Per defecte","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Suau","STREMIO_TV_SETTINGS_PROFILE_FAST":"Ràpid","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra-Ràpid","STREMIO_TV_SETTINGS_SERVER_URL":"URL del servidor de transmissió","STREMIO_TV_SETTINGS_SERVER_VERSION":"Versió del servidor","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Desconegut","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Versió d\'Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edita l\'URL del servidor","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Introduïu l\'URL d\'un servidor de transmissió","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Per llegir la Política de Privadesa de Stremio, visiteu:","STREMIO_TV_SETTINGS_TOS_TEXT":"Per llegir els Termes i Condicions de Stremio, visiteu:","STREMIO_TV_NAV_SEARCH":"Cerca","STREMIO_TV_NAV_HOME":"Inici","STREMIO_TV_NAV_DISCOVER":"Descobreix","STREMIO_TV_NAV_LIBRARY":"Biblioteca","STREMIO_TV_NAV_MOVIES":"Pel·lícules","STREMIO_TV_NAV_SERIES":"Sèries","STREMIO_TV_NAV_CHANNELS":"Canals","STREMIO_TV_NAV_TV":"TV en directe","STREMIO_TV_NAV_SETTINGS":"Configuració","STREMIO_TV_NAV_ADDONS":"Complements","STREMIO_TV_LOGIN_TITLE":"Enllaça Compte","STREMIO_TV_LOGIN_EXPIRES_IN":"Caduca en","STREMIO_TV_LOGIN_STEP_ONE":"Escaneja el codi QR de dalt o ves a","STREMIO_TV_LOGIN_STEP_TWO":"Inicieu sessió al vostre compte Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Demana un enllaç nou","STREMIO_TV_LOGIN_LINK_REFRESHED":"S\'ha actualitzat el codi d\'inici de sessió","STREMIO_TV_SEARCH_PLACEHOLDER":"Escriu alguna cosa","STREMIO_TV_SEARCH_NO_ADDONS":"No s\'han demanat complements per als catàlegs!","STREMIO_TV_SEARCH_BUTTON":"Cerca","STREMIO_TV_SEARCH_KEY_DEL":"Supr","STREMIO_TV_SEARCH_KEY_SPACE":"Espai","STREMIO_TV_SEARCH_KEY_CLEAR":"Retrocés","STREMIO_TV_SEARCH_HISTORY_TITLE":"Historial de cerques","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Pots cercar Títols, Actors, Canals i més...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Esborrar l\'historial de cerques","STREMIO_TV_FILTERS_DESCRIPTION":"Trieu un dels filtres següents","FILTERS":"Filtres","SETTINGS":"Configuració","ACCOUNT":"Compte","LOGOUT":"Tancar sessió","THEMES":"Temes","PLAYBACK":"Reproducció","PLAYBACK_SPEED":"Velocitat de reproducció","AUDIO_TRACKS":"Pistes d\'Àudio","VIDEOS":"Vídeos","SERVER":"Servidor","LINKS":"Enllaços","ABOUT":"Quant a","INTERFACE":"Interfície","ANIMATIONS":"Animacions","STATUS":"Estat","LANGUAGE":"Idioma","SIZE":"Mida","DELAY":"Retard","BOLD":"Negreta","TEXT_COLOR":"Color del text","OUTLINE_COLOR":"Color del contorn","BACKGROUND_COLOR":"Color de fons","BACKGROUND_BLUR":"Desenfocament de fons","SEEK_TIME_DURATION":"Cerca la durada del temps","AUTO_PLAY":"Reprodueix automàticament el següent episodi","PLAY_NOW":"Reprodueix Ara","MARK_AS_WATCHED":"Marca com a Vist","MARK_AS_UNWATCHED":"Marca com a No vist","REWIND_TO_BEGINNING":"Rebobina al principi","CONTINUE_WATCHING":"Continuar Mirant","ALL":"Tot","SECONDS":"segons","ON":"ON","OFF":"OFF","RELOAD":"Recarrega","EDIT_URL":"Edita l\'URL","NONE":"Cap","EMBEDDED":"Incrustat","REMOTE_SWITCH_DEVICES":"Canviar dispositius","REMOTE_VIDEOS":"Vídeos","REMOTE_ADJUST_TIMING":"Ajusteu el temps","REMOTE_ADJUST_SIZE":"Ajusta la mida","REMOTE_COULD_NOT_BE_LOADED":"No s\'ha pogut carregar el comandament a distància web","REMOTE_RETRY":"Reintentar","TORRENT_PROFILE_DEFAULT":"Per defecte","TORRENT_PROFILE_SOFT":"Suau","TORRENT_PROFILE_FAST":"Ràpid","TORRENT_PROFILE_ULTRA_FAST":"Ultra-Ràpid","FAQ_001_H1":"Què és Stremio?","FAQ_001_P1":"Stremio és un centre multimèdia dissenyat per a l\'entreteniment en vídeo tenint en compte la facilitat d\'ús. Stremio us permet organitzar & mirar la vostra pròpia col·lecció de pel·lícules, sèries, canals i TV en directe.","FAQ_001_P2":"Stremio recopila el contingut que us mostra del vostre disc local i del nostre sistema de complements.","FAQ_001_P3":"També us notificarà quan surten nous episodis/vídeos/pel·lícules que us interessin i us recomanarà pel·lícules.","FAQ_02_H1":"Com es compara Stremio amb Kodi i Plex?","FAQ_02_P1":"Ens inspiren aquests dos programes. Però tenim objectius diferents - Stremio s\'orienta específicament cap al entreteniment en vídeo i s\'esforça per convertir-se en la solució principal per ser molt fàcil d\'utilitzar.","FAQ_02_P2":"Stremio mai serà tan personalitzable i ric en funcions com Kodi i Plex, però és molt més fàcil d\'utilitzar. Només ${1} proveu-lo i veureu ${2} :)","FAQ_03_H1":"Com es compara Stremio amb Netflix?","FAQ_03_P1":"Una vegada més, Netflix és una de les nostres inspiracions. Ens esforcem per aconseguir l\'experiència d\'usuari de Netflix, a més d\'un munt de coses addicionals. Però el més important és que us oferim la llibertat de gestionar la vostra pròpia biblioteca i afegir noves fonts de contingut amb el nostre sistema de complements.","FAQ_03_P2":"Això fa que Stremio sigui infinitament extensible, de manera que quan feu servir Stremio mai no es limita al contingut que Netflix decideix llicenciar. Per exemple, mitjançant Stremio podeu veure contingut de ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} i fins i tot el mateix ${9}Netflix${10}!","FAQ_04_H1":"Com es compara Stremio amb Flipboard?","FAQ_04_P1":"Aquesta pregunta no ens arriba tan sovint, excepte quan parlem amb emprenedors :)","FAQ_04_P2":"Stremio és per disseny d\'un agregador de continguts, que bàsicament el converteix en Flipboard per a vídeo. Això és molt evident a la nostra secció de Tauler, que us proporciona catàlegs i notificacions de episodis/vídeos nous del que seguiu, igual que Flipboard.","FAQ_05_H1":"Com es compara Stremio amb Popcorn Time?","FAQ_05_P1":"Stremio i Popcorn Time són similars a la interfície d\'usuari, perquè no hi ha moltes maneres de fer els catàlegs d\'entreteniment de vídeo correctament :)","FAQ_05_P2":"Però, mentre que Popcorn Time se centra en la transmissió de torrents de fonts específiques, Stremio no té restriccions i és només un agregador de continguts - no està bloquejat en una font de contingut específica.","FAQ_05_P3":"A més, no proporcionem cap complement de torrent per defecte, de manera que Stremio no cobreix el cas d\'ús Popcorn Time amb la funcionalitat oficial.","FAQ_05_P4":"Una altra diferència notable és que Popcorn Time és completament de codi obert, mentre que Stremio és ${1} parcialment de codi obert${2}.","FAQ_06_H1":"Afegireu aquesta pel·lícula/sèrie?","FAQ_06_P1":"No, ho sento :(","FAQ_06_P2":"Com s\'esmenta a la majoria de les altres preguntes, Stremio no proporciona cap contingut per si mateix - tot s\'afegeix a través del sistema de complements. En cas que tingueu una sol·licitud de contingut, podeu fer servir el botó “Informa” del reproductor, que enviarà un correu electrònic a l\'autor del complement que esteu utilitzant actualment.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Creeu un complement per a X?","FAQ_08_P1":"És del tot possible.","FAQ_08_P2":"Si teniu una idea per a un complement, envieu-nos una línia a ${1}office@stremio.com${2}, però assegureu-vos que la vostra idea de complement no infringeixi cap copyright ni les condicions d\'ús.","FAQ_08_P3":"De moment, les següents coses del nostre full de ruta són complements per a FandangoNOW, el vídeo a la carta de Filmon.tv i Crunchyroll.","FAQ_09_H1":"Stremio utilitza BitTorrent?","FAQ_09_P1":"Sí, Stremio admet BitTorrent com a protocol de transmissió. Podeu fer-ho amb un complement de torrent, arrossegant i deixant anar un fitxer .torrent a Stremio o enganxant un enllaç magnètic a la barra de cerca.","FAQ_09_P2":"Tingueu en compte que l\'únic complement oficial que utilitza BitTorrent és ${1}Vodo${2}, que proporciona contingut independent, tot el que es pot distribuir amb BitTorrent.","FAQ_09_P3":"No admetem l\'ús de complements de tercers que puguin permetre la infracció dels drets d\'autor.","FAQ_10_H1":"Què puc veure a Stremio amb els complements oficials?","FAQ_10_P1":"Per defecte, podeu veure el contingut de Filmon.tv, YouTube i Vodo dins del mateix Stremio, amb el reproductor incrustat. A més, tenim un complement per a Twitch.tv i alguns altres.","FAQ_10_P2":"Aquesta combinació proporciona una selecció de:","FAQ_10_L1":"Canals de televisió populars, proporcionats per Filmon.tv - per exemple E4, BBC, Bollyworld TV","FAQ_10_L2":"Tot des de YouTube - per exemple BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Pel·lícules independents amb Vodo","FAQ_10_L4":"Emissions de jocs en línia amb Twitch.tv","FAQ_10_P3":"A més, hi ha moltes fonts de contingut que es proporcionen amb Guidebox i els complements Netflix, que no es reprodueixen completament dins Stremio, però que redirigiran al servei indicat. Per exemple, el complement Guidebox us proporcionarà una selecció de pel·lícules que podeu reproduir gratuïtament als Estats Units, des de serveis com TubiTV i Crackle.","FAQ_11_H1":"Stremio no s\'instal·la, què he de fer?","FAQ_11_P1":"Si utilitzeu Windows, proveu ${1}aquest instal·lador alternatiu${2}.","FAQ_11_P2":"Si utilitzeu Mac OS X, tingueu en compte que no admetem res més antic que OS X Mavericks (10.9).","FAQ_11_P3":"Si utilitzeu Linux, tingueu en compte que en aquest moment només admetem Linux de 64 bit (x64).","FAQ_11_P4":"Si encara no podeu resoldre el vostre problema, escriviu-nos al nostre ${1}grup de Facebook${2}.","FAQ_12_H1":"Per què es queixa del meu antivirus? És segur Stremio?","FAQ_12_P1":"Us assegurem que Stremio és ${1}100% net${2}.","FAQ_12_P2":"El vostre antivirus es queixa perquè incloem publicitat al nostre instal·lador, que alguns programes antivirus reconeixen com a ad-ware.","FAQ_12_P3":"Si encara no esteu segur, podeu provar el nostre ${1}instal·lador alternatiu${2}.","FAQ_13_H1":"Com puc fer un complement?","FAQ_13_P1":"Per començar, us recomanem que consulteu el nostre ${1}mòdul del sistema de complements${2} a GitHub.","FAQ_13_P2":"Després, podeu seguir el ${1}tutorial Hola Món${2}.","FAQ_13_P3":"Si no teniu cap habilitat de programació, publiqueu la vostra idea a ${1}la comunitat Reddit${2} i poseu-vos en contacte amb nosaltres amb la vostra idea de complement a ${3}office@stremio.com${4}.","FAQ_14_H1":"Com es publiquen els complements?","FAQ_14_P1":"Quan creeu un complement i un host, i col·loqueu un camp endpoint al manifest, que apunti a una adreça de complement funcional, el complement es publicarà automàticament al nostre ${1}catàleg de complements${2}.","FAQ_14_P2":"Això passa perquè la part del servidor del mòdul stremio-addons fa una crida automàticament a la nostra API per anunciar-lo. Quan la nostra API validi el vostre endpoint com a complement vàlid, començarà a aparèixer al catàleg.","FAQ_15_H1":"Puc executar Stremio al meu navegador?","FAQ_15_P1":"De moment no, però s\'acosta!","FAQ_15_P2":"Si teniu curiositat per veure un Alpha, el podeu veure aquí: ${1}alpha4.strem.io${2}. Recordeu que la transmissió està desactivada en aquest alfa. Admetem Chrome, Firefox, Opera i Edge.","FAQ_16_H1":"Emetre a la televisió no funciona / els subtítols no funcionen","FAQ_16_P1":"La transmissió a TV utilitza la tecnologia DLNA, que és molt inconsistent entre les diferents marques i models de televisors. Per aquest motiu, no tenim la capacitat de provar-ho en tots els casos, de manera que no és ni molt menys perfecte. Tot i això, estem treballant per millorar-lo constantment, però no podem proporcionar-vos una estimació de temps sobre quan DLNA començarà a funcionar correctament amb el vostre televisor.","FAQ_16_P2":"Si ni tan sols veieu el televisor al menú d\'emissió, proveu de desactivar la connexió de xarxa i tornar-la a activar (a Windows, feu clic amb el botó dret a la xarxa i utilitzeu Activa/Desactiva), així com reiniciar el router, el televisor i l\'ordinador.","FAQ_16_P3":"Si encara teniu problemes, podeu ajudar-nos enviant la informació de la vostra marca i model de televisió a ${1}office@stremio.com${2}.","FAQ_16_P4":"Mentrestant, recomanem Chromecast, que funciona molt bé, o simplement connecteu el televisor al PC amb un cable HDMI.","FAQ_17_H1":"Stremio es congela o es bloqueja, què puc fer?","FAQ_17_P1":"En primer lloc, si utilitzeu Windows 7 amb antivirus AVG: tenim aquesta problemàtica. El problema es troba en la pròpia AVG i no hi ha cap manera raonable de resoldre-ho per nosaltres mateixos. Malauradament, les excepcions o la desactivació de l\'antivirus no funcionaran. L\'única solució és substituir AVG per un altre.","FAQ_17_P2":"Si aquest no és el problema, però encara esteu utilitzant Windows, actualitzeu-lo a la versió més recent i actualitzeu/reinstal·leu els controladors de la GPU, llavors torneu-ho a provar.","FAQ_17_P3":"Si el problema encara no s\'ha resolt o si utilitzeu un Mac o Linux, escriviu-nos informant dels detalls exactes del problema al ${1}grup de Facebook${2}.","FAQ_18_H1":"Com puc fer un complement?","FAQ_18_P1":"Per començar, us recomanem que consulteu el nostre ${1}mòdul del sistema de complements${2} a GitHub.","FAQ_18_P2":"Després, podeu seguir el ${1}tutorial Hola Món${2}.","FAQ_18_P3":"Si no teniu cap habilitat de programació, publiqueu la vostra idea a ${1}la comunitat Reddit${2} i poseu-vos en contacte amb nosaltres amb la vostra idea de complement a ${3}office@stremio.com${4}.","FAQ_19_H1":"Per què Stremio ocupa espai al disc?","FAQ_19_P1":"Stremio té una memòria cau local per conservar temporalment els fitxers de vídeo que transmets.","FAQ_19_P2":"Això té dos avantatges: en primer lloc, permet a Stremio pre-emmagatzemar el vídeo per garantir una transmissió més fluida. En segon lloc, manté els vídeos a la memòria cau local perquè pugueu continuar veient-los fora de línia.","FAQ_19_P3":"La quantitat que guarda Stremio depèn del paràmetre Memòria cau del tauler de configuració. És possible que Stremio mantingui la quantitat establerta (ex: 2GB) al disc, tret que el vídeo que es reprodueixi actualment sigui més gran que aquest. En aquest cas ha d\'assignar prou emmagatzematge per conservar-lo mentre que l\'estiguis reproduint.","FAQ_20_H1":"On és la carpeta de memòria cau?","FAQ_20_P1":"A Windows, és stremio-cache a la unitat que heu seleccionat a Configuració (per exemple \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"A MacOS, és \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"A Linux, és \\"~/.stremio/stremio-cache\\" o \\"~/stremio-cache\\"","FAQ_21_H1":"Tinc l\'error \\"El servidor de transmissió no s\'ha trobat\\" què puc fer?","FAQ_21_P1":"Si obteniu aquest error, significa alguna d\'aquestes coses:","FAQ_21_P2":"1) Esteu provant d\'utilitzar un complement compatible amb la font de YouTube/BitTorrent a través de la nostra ${1}versió web${2}. En aquest cas, hauríeu d\'instal·lar la nostra versió d\'escriptori des del ${3}nostre lloc web${4}.","FAQ_21_P3":"2) Hi ha un problema amb la instal·lació d\'Stremio. En aquest cas, proveu de tornar a instal·lar la nostra versió d\'escriptori més recent des del ${1}lloc web${2}. Si això no ajuda, proveu de desactivar els programes antivirus i els tallafocs, reinicieu el PC i torneu-ho a provar. Si això també no funciona, escriviu-nos al nostre ${3}grup de Facebook${4}.","FAQ_22_H1":"No puc veure/utilitzar la majoria dels complements a iOS","FAQ_22_P1":"A causa de les restriccions dels termes i condicions de l\'App Store d\'Apple, hem restringit l\'aplicació iOS només a un conjunt concret de complements.","FAQ_22_P2":"Però tingueu la seguretat: hi haurà més complements per a iOS en el futur, i també podem afegir una integració que us permetrà utilitzar tots els complements Stremio gràcies a la connexió de l\'aplicació iOS al servidor de transmissió Stremio."}')},2840:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Seriály","TYPE_tv":"Televizní kanál","TYPE_channel":"Kanál","TYPE_other":"Ostatní","TYPE_movie_PL":"Filmy","TYPE_series_PL":"Seriály","TYPE_tv_PL":"Televizní kanály","TYPE_channel_PL":"Kanály","TYPE_other_PL":"Ostatní","TYPE_ALL":"All","VIDEO":"Video","BACK":"Dozadu","MORE":"Více","DONE":"Hotovo","COPY":"Kopírovat","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Discover","Board":"Rozdání","Library":"Knihovna","My Library":"Moje knihovna","Calendar":"Kalendář","NOTIFICATION_ONLINE":"Nyní jste online","NOTIFICATION_OFFLINE":"V současné době jste offline","INTERNET_CONNECTION":"Připojení k síti","STORAGE_FULL_TITLE":"Varování: Úložiště je plné!","STORAGE_FULL_TEXT":"Stremio nebude moci uložit vaše nastavení, preference ani přihlašovací údaje. Zvažte opětovné spuštění nebo přeinstalování aplikace Stremio.","SEARCH":"hledat","SEARCH_NO_RESULTS":"Nebyly nalezeny žádné výsledky","SEARCH_EXPLANATION_CONTENT":"Vyhledávání filmů, seriálů, YouTube a televizních kanálů","SEARCH_EXPLANATION_PEOPLE":"Hledání herců, režisérů a scénáristů","SEARCH_PASTE_LINKS":"Vkládání odkazů HTTP a Magnet","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Přidat do knihovny","REMOVE_FROM_LIB":"Odebrat z knihovny","ADDED_TO_LIB":"Přidáno do knihovny","REMOVED_FROM_LIB":"Odstraněno z knihovny","TRAILER":"Přívěs","WATCH_TRAILER":"Sledovat trailer","WATCH_NOW":"Sledujte nyní","SHOW":"Zobrazit","SHOW_MOVIE":"Zobrazit film","WATCH_RANDOM":"Sledovat náhodné","IMDB_RATING":"IMDb hodnocení","YEAR":"Rok","DIRECTOR":"Režie","WRITER":"Spisovatel/ka","LEAD_ACTORS":"Hlavní herci","CAST":"Herec","CREW":"Posádka","SHOW_MORE_CAST":"Zobrazit více »","AIRED":"Vysíláno na","SEASONS":"Série","GENRE":"Žánr","CATALOG":"Katalog","SUMMARY":"Shrnutí","SHOW_MORE":"Zobrazit více","SIMILAR":"Podobné stránky","UPCOMING":"Nadcházející","ENDED":"Skončilo","DURATION":"Délka","FEATURED":"Doporučené","METADATA":"Metadata","CATEGORY":"kategorie","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"vyhledávání videí","SEARCH_PLACEHOLDER":"vyhledat nebo vložit adresu URL","ADDON":"doplněk","ADDONS":"Doplňky","OFFICIAL":"oficiální","ADDONS_OFFICIAL":"Oficiální doplňky Stremio","ADDONS_POPULAR":"Oblíbené ve vaší oblasti","ADDON_FREE":"zdarma","ADDON_PEERED":"nahlédl na","ADDON_SUBSCRIPTION":"předplatné","ADDON_STREAM_GEORESTRICTED":"není ve vaší oblasti k dispozici","ADDON_STREAM_OFFLINECACHE":"Offline mezipaměť","ADDON_STREAM_LOCALFILE":"Místní soubor","SHARE_ADDON":"Sdílet doplněk","AVAILABLE_STREAMS":"Dostupné proudy","NO_STREAM":"Nebyly nalezeny žádné toky","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Chcete-li získat více streamů, nainstalujte si další doplňky","STREAM_NOT_SUPPORTED":"Vybraný stream není na této platformě podporován.","ADDON_CATALOGUE":"Zobrazit všechny doplňky \\"","ADDON_CATALOGUE_MORE":"Instalace doplňků","REPO_ADDED":"Přidáno úložiště","ADDON_REPO_EXIST_ERR":"Tato kolekce doplňků již existuje","ADDON_REPO_ERR":"Při přidávání kolekce došlo k chybě","ADDON_ADD_ERR":"Při přidávání doplňku došlo k chybě","ERR_ADDON_PROTECTED":"Nelze odinstalovat doplněk, je chráněn","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Něco se pokazilo - možná selhalo ověřování","ERR_NOT_COLLECTION_URL":"Nejedná se o adresu URL sbírky","ERR_NOT_ADDON_URL":"Není platná adresa URL doplňku","ERR_DETECTFROMURL":"Nelze najít doplněk/sbírku z této adresy URL","ADDON_DUPLICATE_WARNING":"Varování: duplicitní addon","ADDON_COLLECTION_SET_FAILED":"Synchronizace nainstalovaných doplňků s vaším účtem se nezdařila","SETTINGS_DATA_EXPORT":"Export uživatelských dat","ADDON_PULL_FAILED":"Synchronizace nainstalovaných doplňků z vašeho účtu se nezdařila","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Film stále v kinech","WATCH_IN_CINEMA":"Podívejte se na něj v místním kině","IN_THEATER":"V kině","GET_TICKETS":"Získat vstupenky","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Tento kanál ještě není seškrábán.
Vraťte se prosím za několik minut.
","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Přidejte si ji do své knihovny, abyste byli informováni, jakmile bude k dispozici.","GET_NOTIFIED_WHEN_AVAILABLE":"Jakmile bude k dispozici, budete o tom informováni.","WARNING_STREAMING_SERVER":"Varování: místní streamovací server nebyl nalezen. Streamování z místních souborů, YouTube a BitTorrent nebude k dispozici.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Varování: toto video nemusí být podporováno vaším hardwarem. Mějte na paměti, že přehrávání může být pomalé.","PLAYER_ERROR":"Oops, chyba hráče","PLAYER_ERROR_LOOKSLIKE":"Vypadá to, že","PLAYER_ORIENTATION":"Orientace hráče","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Uzamčeno","PLAYER_ORIENTATION_SENSOR_SHORT":"Senzor","PLAYER_ORIENTATION_LANDSCAPE":"Orientace přehrávače uzamčená na šířku","PLAYER_ORIENTATION_SENSOR":"Automatická orientace hráče (senzor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Chyba přehrávání, zkuste to prosím znovu","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Neznámá chyba","PLAYER_PLAYBACK_ERROR_DEFAULT":"Je nám líto, ale toto video nelze přehrát pomocí {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Příště v pořadu","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Skrýt","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Sledovat nyní","STREAMING_FROM":"streamování z","CASTING_TO":"Obsazení do","NETWORK_STATUS":"Stav sítě","STREAM_SPEED":"Rychlost proudu:","STREAM_BUFFERED":"Vyrovnávací paměť:","PEERS_INFO":"Informace o vrstevnících","PEERS_ACTIVE":"Používáno:","PEERS_CONNECTED":"Připojeno:","PEERS_WAITING":"Čekání:","TRANSCODING_WARNING":"Varování: překódování videa.","STREAM_LOADING":"načítám...","PLAYING_LOCAL":"přehrávání z místního souboru","PLAYING_CACHE":"přehrávání z mezipaměti","WRONG_SUBS":"Špatné titulky?","ERR_SUBS_LOADING_TITLE":"Chyba při načítání titulků","ERR_SUBS_LOADING":"Neúspěšné načítání titulků: může se jednat o problém s používaným doplňkem nebo se síťovým připojením","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Následující doplňky titulků selhaly","ERR_CASTING_UPDATE_TITLE":"Nelze aktualizovat informace o zařízení pro odlévání: streamovací server může být offline","CHOOSE_DEVICE":"Výběr zařízení, na kterém chcete sledovat","NO_CAST_DEVICES":"Žádné odlévací zařízení není k dispozici.","NO_SETTINGS":"Žádné nastavení není k dispozici.","PHONE_TABLET":"Telefon / tablet","SUBTITLES":"Titulky","SUBTITLES_CHANGE":"Změna titulků pro","SUBTITLES_CHANGE_NONE":"Pro tento jazyk nejsou k dispozici žádné další titulky, omlouváme se.","SUBTITLES_CHANGE_ACIVE":"Aktuálně jsou aktivovány titulky #{{subtitlesDialog.activeIdx + 1}}. Kliknutím na \\"Pokračovat\\" aktivujete titulky #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Případně,","SUBTITLES_ADJUST_DELAY":"Nastavení zpoždění titulků:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Nebo můžete při přehrávání použít klávesy G / H pro nastavení.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: při hraní můžete použít klávesy G / H pro nastavení.","SUBTITLES_DELAY":"Zpoždění titulků:","SUBTITLES_LOADING":"Načítání titulků...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Vypnuto","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Období","EPISODE":"Epizody","SPECIAL":"Special","SORT":"řazení","SORT_BY":"Seřadit podle","FILTER":"filtr","SORT_TRENDING":"trendy","SORT_RECENT":"nedávné","SORT_ALPHABET":"a-z","SORT_RATING":"hodnocení","SORT_WATCHED":"sledoval","SORT_YEAR":"rok","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Novinky pro vás","New Episodes":"Nové epizody","New Videos":"Nové články a videa","Recommendations":"Doporučení","LIBRARY_RESUME":"Pokračovat","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detaily","LIBRARY_RESUME_DISMISS":"Skrýt","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Doporučené","DISCOVER_TOP":"Nahoře","DISCOVER_OSCAR":"Vítězové Oscara","DISCOVER_WARNING_TITLE":"Jejda!","DISCOVER_EMPTY_CATALOG":"Tento doplněk vrátil prázdný obsah.","DISCOVER_ADULT_WARNING":"Obsah je viditelný pouze pro dospělé. Jste starší 18 let?","DISCOVER_NOADDON_WARNING":"Varování: pro tento typ není aktivní žádný doplněk Stremio. Zobrazuje uložené položky, nic se zde neaktualizuje.","DISCOVER_LOAD_ERR":"Obsah se nenačetl, došlo k chybě.","DISCOVER_ADDON_UNINSTALLED":"Tento obsah již není k dispozici, možná jste doplněk odinstalovali.","UNINSTALL_THIS_ADDON":"Odinstalování tohoto doplňku","ERR_ADDON_NOT_INSTALLED":"Tento doplněk není nainstalován. Nainstalovat nyní?","DETAIL_RECEIVE_NOTIF_SERIES":"Přijímání oznámení o nových epizodách","DETAIL_RECEIVE_NOTIF_VIDEOS":"Přijímání upozornění na nová videa","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Opětovné spuštění nyní!","UPGRADE":"Nová verze je k dispozici! Upgrade na nejnovější verzi Stremio","RELOAD_UI":"Opětovné načtení uživatelského rozhraní","MANUAL_UPDATE_TITLE":"Aktualizace verze aplikace Stremio","MANUAL_UPDATE_LINE1":"Používáte zastaralou verzi aplikace Stremio, která se nedoporučuje.","MANUAL_UPDATE_LINE2":"Prosíme o co nejrychlejší aktualizaci.","BUTTON_UPDATE_LATTER":"Nyní ne","BUTTON_UPDATE_NOW":"Aktualizovat","ANONYMOUS_USER":"Anonymní uživatel","DONT_HAVE_ACC":"Nemáte účet?","HAVE_ACC":"Již máte účet?","PASSWORD":"Heslo","PASSWORD_CONFIRM":"Potvrďte heslo","EMAIL":"E-mail","FB_LOGIN":"Pokračovat na Facebooku","FB_NOTHINGSHARED":"Nic není sdíleno bez vašeho souhlasu","FB_NOPOST":"Vaším jménem nic nezveřejníme","OR":"nebo","I_ACCEPT":"Přijímám","I_ACCEPT_BY_CLICKING":"Kliknutím na výše uvedené tlačítko stvrzuji, že souhlasím s tím, že","TOS":"Obchodní podmínky","MUST_ACCEPT_TERMS":"Musíte přijmout podmínky","PASSWORDS_NOMATCH":"Heslo se neshodují","SIGN_UP":"Registrovat se","SIGN_UP_EMAIL":"Zaregistrujte se pomocí e-mailu","CLICK_TO_SIGN_UP":"Klikněte zde a zaregistrujte se.","LOG_IN":"Přihlásit","LOG_OUT":"Odhlásit se","EXIT_FULLSCREEN":"Ukončení celoobrazovkového režimu","ENTER_FULLSCREEN":"Vstup do celoobrazovkového režimu","PLAY_URL_MAGNET_LINK":"Přehrát adresu URL / odkaz na magnet","HELP_FEEDBACK":"Nápověda a zpětná vazba","TERMS_OF_SERVICE":"Podmínky služby","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"O Stremio","USER_PANEL":"Uživatelský panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Přihlášení hosta","GUEST_LOGIN_NOTICE":"Přihlášení hosta se nedoporučuje. Použití běžného přihlášení umožňuje službě Stremio synchronizovat vaši knihovnu a přijímat oznámení o oblíbených seriálech/kanálech. Jste si jisti, že chcete pokračovat?","GUEST_LOGIN_NOTICE_2":"Přihlášení hosta se nedoporučuje - nebudete mít synchronizované oznámení o knihovně a nástěnce, což jsou důležité funkce aplikace Stremio. Jste si jisti, že chcete pokračovat?","CLICK_HERE":"klikněte sem","WRONG_PASSWORD":"Špatný e-mail nebo heslo. V případě, že jste zapomněli heslo,","SET_A_PASS":"nastavit heslo","RESET_PASSWORD":"Obnovit heslo","FORGOT_PASSWORD":"Zapomenuté heslo?","EMAIL_USED_WITH_FB":"Tento e-mail byl použit s přihlášením na Facebook.","INVALID_EMAIL":"Zadejte prosím platnou emailovou adresu","INVALID_PASSWORD":"Zadejte prosím platné heslo","CONN_ERR":"Chyba připojení - zkuste to prosím později.\\n\\nPokud přetrvává, vypněte firewall/antivirový software (zejména Bitdefender).","IMPORT_FROM_GUEST":"Import knihovny z účtu hosta","RECEIVE_UPDATES_EMAIL":"Přijímání aktualizací do e-mailu od Stremio","LOGIN_FAILED":"Přihlášení se nezdařilo.","SIGNUP_FAILED":"Registrace se nezdařila.","SEARCH_FAILED":"Vyhledávání se nezdařilo","EMAIL_USED":"E-mail je už používán.","WAITING_FB_LOGIN":"Přihlášení pomocí Facebooku...","EXTERNAL_PLAYER_TITLE":"Přehrávání v externím přehrávači","EXTERNAL_REMEMBER_PLAYER":"Chcete si svou volbu zapamatovat","EXTERNAL_ALWAYS_PLAY":"Ano","EXTERNAL_ONLY_ONCE":"Ne","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Řekněte nám, co se vám líbí","INTRO_TASTE_LONG":"Řekněte nám, co byste chtěli sledovat","INTRO_TASTE_PICK":"Vyberte {{interestsRemaining}} zájmy","INTRO_TASTE_PICK_MORE":"Vyberte {{interestsRemaining}} dalších zájmů","INTRO_TASTE_HELP_US":"Pomozte nám dozvědět se o vás více.","INTRO_TASTE_CHOOSE_THESE":"Vyberte si některé z nich:","INTRO_TASTE_CHOOSE_MIN":"Vyberte alespoň 3 kategorie","INTRO_TASTE_CHOOSE_MIN_ERR":"Musíte vybrat alespoň 3 kategorie!","INTRO_TASTE_LIFESTYLE":"Životní styl","INTRO_TASTE_SPORTS":"Sporty","INTRO_TASTE_FOOD_HEALTH":"Potraviny a zdraví","INTRO_TASTE_BEAUTY_FASHION":"Krása a móda","INTRO_TASTE_NEWS":"Novinky","INTRO_TASTE_GAMING":"Hry","INTRO_TASTE_SCIENCE_EDU":"Věda a vzdělávání","INTRO_TASTE_MUSIC":"Hudba","INTRO_TASTE_TRAVEL":"Cestovní kancelář","INTRO_TASTE_LATE_NIGHT":"Pozdní noční show","INTRO_TASTE_REALITY":"Realita","INTRO_TASTE_COMEDY":"Komedie","INTRO_TASTE_DIY":"Jak na kutilství","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Kino","ADDON_NOT_SUPPORTED":"Vybraný doplněk není na této platformě podporován.","ADDON_DISCLAIMER":"Používání doplňků třetích stran vždy podléhá vaší odpovědnosti a právním předpisům jurisdikce, ve které se nacházíte.","ADDON_ACTIVATE":"Aktivovat tento doplněk?","ADDON_REPO_ADD":"Adresa URL sbírky doplňků","ADDON_ADD":"Přidat","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Co je nového","BUTTON_CONTINUE":"Pokračovat","BUTTON_ACTIVATE":"Aktivovat","BUTTON_ACTIVATED":"Aktivovaný","BUTTON_CANCEL":"Zrušit","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Odmítnout vše","BUTTON_VIEW_ALL":"zobrazit vše","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Vaše knihovna vypadá prázdná. Zjistěte, jak je užitečná :)","HOW_START":"Zde je návod, jak začít:","LIB_EMPTY_CAL":"V kalendáři se zobrazují série ve vaší knihovně.","HOW_START_CAL":"Zde je návod, jak můžete přidávat série:","LIB_EMPTY_BOARD":"Tabule zobrazuje oznámení & doporučení týkající se vaší knihovny.","HOW_START_BOARD_WAIT":"Prosím, přidejte do své knihovny několik seriálů nebo kanálů a dejte nám pár minut na zpracování :)","HOW_START_BOARD":"Zde je návod, jak do něj můžete přidat seriály & filmy:","IMPORT_FB":"Import věcí, které se vám líbí, ze služby Facebook","IMPORT_TRAKT":"Import knihovny médií ze služby Trakt","IMPORT_DISCOVER":"Najděte zajímavé věci ze služby Discover","IMPORT_DISK":"Importovat filmy nebo pořady, které máte na místním disku","PLEASE_CREATE_ACC":" Vytvořte si účet, abyste mohli synchronizovat knihovnu a tabuli.","IMPORT_DISCOVER_SIGNUP":"Zaregistrujte se a najděte zajímavé věci z Discover","IMPORT_DISK_SIGNUP":"Zaregistrujte se a importujte filmy nebo pořady, které máte na místním disku","LIB_EMPTY_CLOUD":"Cloudová knihovna","LIB_EMPTY_CLOUD_DESC":"Osobní cloudová knihovna synchronizovaná na všech zařízeních","LIB_EMPTY_EARLY":"Brzy","LIB_EMPTY_EARLY_DESC":"Přijímání oznámení o nových epizodách","LIB_EMPTY_PERSONAL":"Osobní","LIB_EMPTY_PERSONAL_DESC":"Získejte osobní doporučení","LIB_EMPTY_CALENDAR_DESC":"Naplánujte si osobní kalendář sledování","LIB_EMPTY_ALL":"Zaregistrujte se a získejte je všechny:","LIB_EMPTY_BEST":"Zaregistrujte se a získejte to nejlepší ze Stremio","LIB_EMPTY_OTHER":"Zaregistrujte se a povolte Kalendář a další skvělé funkce","CALENDAR_ADDED":"Kalendář Stremio byl přidán do vašeho výchozího kalendáře na ploše.","CALENDAR_ADDED_MSG":"Pokud to nefunguje, přidejte tuto adresu URL do aplikace kalendáře ručně","TRAKT_EXPIRED":"Platnost ověření Traktu vypršela, přejděte prosím do Nastavení a znovu se ověřte","TRAKT_REQUIRES_LOGIN":"Chyba traktu","TRAKT_REQUIRES_LOGIN_MSG":"Musíte se přihlásit","SETTINGS_LABEL":"Nastavení","SETTINGS_NAV_GENERAL":"Obecné","SETTINGS_NAV_PLAYER":"Hráci","SETTINGS_NAV_STREAMING":"Streamování","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Spuštění při spuštění","SETTINGS_VLC_DEFAULT":"Přehrávání pomocí VLC","SETTINGS_UI_LANGUAGE":"Jazyk uživatelského rozhraní","SETTINGS_FULLSCREEN_EXIT":"Klávesa Escape ukončí celou obrazovku","SETTINGS_GAMEPAD":"Povolení podpory gamepadu","SETTINGS_CLOSE_WINDOW":"Zavření aplikace při zavření okna","SETTINGS_SUBTITLES_LANGUAGE":"Výchozí jazyk titulků","SETTINGS_SUBTITLES_SIZE":"Výchozí velikost titulků","SETTINGS_SUBTITLES_BACKGROUND":"Pozadí titulků","SETTINGS_SUBTITLES_COLOR":"Barva titulků","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Barva obrysu titulků","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Barva pozadí titulků","SETTINGS_SEEK_KEY":"Klávesy se šipkami hledají čas","SETTINGS_SEEK_KEY_SHIFT":"Klávesy se šipkami hledají čas při podržení klávesy Shift","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Automatické přehrávání další epizody","SETTINGS_NEXT_VIDEO":"Upozornění na spuštění další epizody","SETTINGS_NEXT_VIDEO_TRIGGER":"Zobrazit upozornění na další epizodu:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Automatická změna velikosti okna před přehráváním","SETTINGS_OVERRIDE_SERVER":"Přepsání adresy URL streamovacího serveru (pro pokročilé)","SETTINGS_SERVER_URL":"Adresa URL streamovacího serveru","SETTINGS_SERVER_AVAILABLE":"Streamovací server je k dispozici.","SETTINGS_SERVER_UNAVAILABLE":"Streamovací server není k dispozici.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Koncový bod HTTPS pro streamování","SETTINGS_USE_BETA":"Vždy používejte nejnovější betaverzi","SETTINGS_IMPORT_FB":"Import ze služby Facebook","SETTINGS_IMPORT_DISK":"Import z místního disku","SETTINGS_IMPORT_TRAKT":"Import ze služby Trakt","SETTINGS_PAUSE_MINIMIZED":"Pozastavení přehrávání při minimalizaci","SETTINGS_HWDEC":"Hardwarově akcelerované dekódování","SETTINGS_BACKGROUND":"Přehrávání na pozadí","SETTINGS_SUBSCRIBE_CALENDAR":"Přihlásit se k odběru kalendáře","SETTINGS_REQ_EXPORT":"Žádost o export dat","SETTINGS_ACC_DELETE":"Žádost o odstranění účtu","SETTINGS_CHANGE_PASSWORD":"Změnit heslo","SETTINGS_TOS":"Podmínky služby","SETTINGS_SUPPORT":"Kontaktovat podporu","SETTING_LANGUAGE":"Jazyk","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Odhlášení z Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Naskenujte QR kód pro otevření dálkového ovládání","SETTINGS_DESKTOP_NOTIFICATIONS":"Oznámení na ploše","SETTINGS_DATA_SAVER":"Spořič dat","SETTINGS_LANGUAGE_INTERFACE":"rozhraní","SETTINGS_LANGUAGE_SUBS":"výchozí titulky","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"účet","SETTINGS_VERSION":"verze","SETTINGS_MPV_WINDOW":"Spuštění přehrávače v samostatném okně (pokročilé)","SETTINGS_PLAY_IN_EXTERNAL":"Vždy spustit video v externím přehrávači","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Odejít","CONNECTED":"Připojeno","AUTHENTICATE":"Ověřit","CACHING":"Mezipaměť","SETTINGS_CACHING_DRIVE":"Jednotka mezipaměti","ENABLE_LOCAL_FILES_ADDON":"Povolení doplňku pro místní soubory (vyžaduje restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Povolení vzdálených připojení HTTPS","TORRENT_PROFILE":"Profil Torrent","DATA_CACHING":"Ukládání dat do mezipaměti","MAGNET_PARSING":"Rozbor odkazu magnetu","January":"Leden","February":"Únor","March":"Březen","April":"Duben","May":"Květen","June":"Červen","July":"Červenec","August":"Srpen","September":"Září","October":"Říjen","November":"Listopad","December":"Prosinec","Monday":"Pondělí","Tuesday":"Úterý","Wednesday":"Středa","Thursday":"Čtvrtek","Friday":"Pátek","Saturday":"Sobota","Sunday":"Neděle","Action":"Akce","Comedy":"Komedie","War":"Válka","Family":"Rodina","Animation":"Animace","Adventure":"Dobroudružná hra","Fantasy":"Fantasy","Crime":"Zločin","Mystery":"Záhada","Romance":"Romantické","Drama":"Drama","Horror":"Horory","Thriller":"Thriller","Sci-Fi":"Sci-fi","Music":"Hudba","Biography":"Životopis","Documentary":"Dokumentární film","Sport":"Sport","Musical":"Hudební","Western":"Západní","Film-Noir":"Film-noir","News":"Novinky","History":"Historie","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film a zábava","Gaming":"Hry","From TV":"Z televize","Lifestyle":"Životní styl","Science & Education":"Věda a vzdělávání","Cooking & Health":"Vaření a zdraví","Beauty & Fashion":"Krása a móda","Sports":"Sporty","News & Politics":"Zprávy a politika","How-to & DIY":"Jak na to & Udělej si sám","Tech":"Tech","Automotive":"Automobilový průmysl","Causes & Non-Profits":"Kauzy a neziskové organizace","Movies":"Filmy","Uk Live Tv":"Spojené království Živá televize","Fashion":"Móda","Business News Radio":"Business News Radio","Business Tv":"Obchodní televize","Cars & Auto":"Automobily a auta","Comedy Radio":"Komediální rádio","Lifestyle Radio":"Rádio životního stylu","News Tv":"Zpravodajská televize","Food And Wine":"Jídlo a víno","Latino Tv":"Latinskoamerická televize","Shopping Tv":"Nákupní televize","Religion":"Náboženství","Kids":"Děti","Body & Soul":"Tělo a duše","Education":"Vzdělání","Indian Tv":"Indická televize","Extreme Sports":"Extrémní sporty","Middle Eastern Tv":"Blízkovýchodní televize","Celebrity Tv":"Celebrity Tv","Science Tv":"Vědecká televize","Bikini babe":"Kočka v bikinách","Outdoors":"Venku","German Tv":"Německá televize","French Tv":"Francouzská televize","Italian Tv":"Italská televize","Gamer Tv":"Gamer Tv","Travel":"Cestovní kancelář","Asian Tv":"Asijská televize","Entertainment":"Zábava","News Radio":"Zpravodajské rádio","Music Radio":"Hudební rádio","Language Learning":"Výuka jazyků","Science Radio":"Vědecké rádio","Tech Radio":"Tech Radio","Science & Technology Vod":"Věda a technika Vod","new video":"nové video","new episode":"nová epizoda","new movie":"nový film","recommended":"doporučené","we recommend":"doporučujeme","offer of the day":"nabídka dne","news":"novinky","music video":"hudební video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Odmítnutí oznámení","CTX_DISMISS_ALL":"Odmítnout všechny","CTX_SHARE":"Sdílet","CTX_COPY_SHARE_LINK":"Kopírovat odkaz na sdílení","CTX_COPY_MAGNET_LINK":"Kopírovat odkaz na magnet","CTX_COPY_STREAM_LINK":"Kopírovat odkaz na stream","CTX_DOWNLOAD_VIDEO":"Stáhněte si toto video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Zobrazit","CTX_PLAY":"Přehrát","CTX_PLAY_IN":"Přehrát v","CTX_PLAY_ON":"Přehrát na","CTX_WATCH_ON":"Sledujte na","CTX_WATCH":"Sledovat","CTX_WATCHED":"Sledováno","CTX_WATCH_BEGINNING":"Sledujte od začátku","CTX_WATCH_MOBILE":"Sledování na mobilním zařízení","CTX_REWIND":"Přetočení na začátek","CTX_MARK_WATCHED":"Označit jako sledované","CTX_MARK_NON_WATCHED":"Označit jako nesledované","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Zbytek označte jako sledovaný","CTX_UNMARK_REST":"Zbytek označte jako nesledovaný","CTX_RECEIVE_NEW_NOTIF":"Přijímání nových oznámení","CTX_REMOVE_CACHE":"Odstranění z mezipaměti","CTX_REMOVE_CACHE_EP":"Odstranění epizody z mezipaměti","CTX_OPEN_CONTAINING":"Otevřít složku obsahující","CTX_REMOVE":"Odebrat z knihovny","CTX_AVAILABLE_OFFLINE":"Dostupné offline","CTX_PAUSED":"Pozastaveno","CTX_ALWAYS_ON_TOP":"Vždy na vrcholu","CTX_FULLSCREEN":"Celá obrazovka","CTX_WRONG_SUBS":"Špatné titulky?","CTX_REPORT_ISSUES":"Nahlásit problém","CTX_COPY":"Kopírovat","CTX_PASTE":"Vložit","CTX_CLEAR":"Vymazat","CTX_CLEAR_RECENT_SEARCHES":"Vymazat poslední vyhledávání","HELLO_THERE":"Dobrý den","HOPE_YOU_ENJOY":"Doufáme, že se vám Stremio bude líbit a že se stane jednou z vašich oblíbených aplikací!","WHO_ARE_WE":"Kdo jsme? Jsme tým, který za tím stojí - dva kluci, kteří už tři roky každý den tvrdě pracují na tom, aby byl tento produkt stále lepší a lepší.","SUPPORT_US":"Pokud se vám Stremio líbí, pokud je pro vás Stremio přínosné - šiřte tuto informaci dál!","SPREAD_THE_WORD":"Sdílejte se svými přáteli, rozšiřte informace o Stremiu","MORE_PEOPLE":"Čím více lidí bude Stremio používat, tím lepší bude!","SEND_A_LINK":"Nebo pošlete odkaz na naše webové stránky","TIP_LOCALFILES":"Tip: do aplikace Stremio můžete přetáhnout místní video soubory","ADDON_MY":"Moje doplňky","ADDON_COMMUNITY":"Doplňky komunity","ADDON_OFFICIAL":"Oficiální doplňky","ADDON_REPOS":"Sbírky doplňků","ADDON_SEARCH":"Vyhledávání doplňků","ADDON_INSTALL":"Instalovat","ADDON_CONFIGURE":"Konfigurovat","ADDON_UNINSTALL":"Odinstalovat","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Nainstalováno","ADDON_INSTALLED_MSG":"Addon nainstalován!","ADDON_UPGRADED_MSG":"Addon upgradován!","ADDON_UNKNOWN":"Neznámý","ADDON_ERR":"Chyba při instalaci doplňku!","ADDON_DISCONNECTED":"Odpojeno","ADDON_APP_MISSING":"aplikace pro tento zdroj není nainstalována. Chcete ji nyní nainstalovat?","ADDON_APP_INSTALL":"Nainstalovat nyní","ADDON_PAGE":"Stránka doplňku","ADDON_TOP_CONTENT":"To nejlepší z tohoto doplňku","ADDON_PROVIDES":"Tento doplněk vám poskytne:","ADDON_WATCH":"Sledujte #{types} nyní!","ADDON_WATCH_FREE":"Sledujte #{types} nyní ZDARMA!","ADDON_ADDON":"Doplněk","ADDON_SUPPORTED_TYPES":"Podporované typy","ADDON_SUPPORTED_CATALOGS":"Podporované katalogy","ADDON_PROVIDES_DISCOVER":"Další #{types} v aplikaci Discover","ADDON_PROVIDES_STREAMS":"Sledujte #{types}","ADDON_PROVIDES_STREAMS_FREE":"Sledujte #{types} ZDARMA","ADDON_PROVIDES_SUBTITLES":"Titulky pro #{types}","ADDON_CANTDETECT":"Nepodařilo se nám zjistit spuštěné Stremio, takže jsme nemohli zjistit, jaké máte nainstalované doplňky.","ERR_NO_META":"O tomto nebyly nalezeny žádné informace","ERR_GETTING_META":"Chyba při načítání informací o tomto.","ERR_CANT_PARSE_MAGNET":"Nelze analyzovat magnet","ERR_NO_MAGNET_INFOHASH":"Žádný platný informační hash pro magnet","ERR_NO_FILE_PATH":"Nelze odeslat požadavek bez cesty k souboru","ERR_NO_TORRENT":"Žádný torrent se nevrátil","ERR_NO_SUPPORTERD_FILES":"Nebyly nalezeny žádné podporované soubory","ERR_OPENING_FILES":"Nelze otevřít externí soubory","ERR_INVALID_LINK":"Neplatný odkaz","ERR_REGISTERED_ONLY":"Tato možnost je k dispozici pouze pro registrované uživatele.","ERR_CLIPBOARD":"Nelze přehrávat ze schránky","ERR_CLIPBOARD_READ":"Na této platformě nelze číst schránku","ERR_CLIPBOARD_GENERIC":"Ve schránce nebyla nalezena žádná přehrávatelná adresa URL. Zkopírujte prosím adresu URL (např. odkaz na magnet) na video.","BOARD_CONTINUE_WATCHING":"Pokračovat ve sledování","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmy vybrané speciálně pro vás.
Tento film je ukázkovým doporučením.","BOARD_EXPLANATION_EPISODES":"Zde se objevují nové epizody vašich oblíbených seriálů.
Přidejte si sledované seriály do své knihovny.","BOARD_EXPLANATION_VIDEOS":"Zde se objevují nové epizody vašich oblíbených kanálů.
Přidejte si sledované kanály YouTube do své knihovny.","WEBSITE_SLOGAN_WATCH":"Sledujte okamžitě","WEBSITE_SLOGAN_ALL":"Veškerý videoobsah, který si užíváte, na jednom místě","WEBSITE_SLOGAN_NEW":"Vše, co můžete sledovat","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Sledujte od","WEBSITE_DOWNLOAD":"Stáhnout nyní","WEBSITE_DOWNLOAD_FOR":"Stáhnout nyní pro","WEBSITE_IS_DESKTOP":"Stremio je aplikace pro stolní počítače, otevřete tuto stránku v počítači a stáhněte si ji","WEBSITE_DESKTOP_DEMO_VID":"Demonstrační verze pro stolní počítače","WEBSITE_PAGE_HOME":"Domů","WEBSITE_PAGE_FEATURES":"Vlastnosti","WEBSITE_PAGE_ADDONS":"Doplňky","WEBSITE_PAGE_TECH":"Technologie","WEBSITE_PAGE_CREATE_ADDON":"Vytvořit doplněk","WEBSITE_PAGE_CONTACTS":"Kontakty","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmy","WEBSITE_TYPE_series_PL":"Seriály","WEBSITE_TYPE_tv":"Živý televizní přenos","WEBSITE_TYPE_channel":"Kanály","WEBSITE_STREMIO_WHAT_IS":"Stremio je aplikace, která vám pomůže uspořádat a okamžitě sledovat vaše oblíbená videa, filmy, seriály a televizní kanály.","WEBSITE_FEATURES_WATCH":"Sledujte okamžitě v HD","WEBSITE_FEATURES_WATCH_DETAIL":"Klikněte a přehrávejte své oblíbené filmy, televizní pořady, videa a televizní kanály.","WEBSITE_FEATURES_SUBS":"Automatické titulky","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automaticky vybere synchronizované titulky pro váš jazyk.","WEBSITE_FEATURES_SUBS_LABEL":"Váš tah, šéfe.","WEBSITE_FEATURES_CAST":"Přehrávání na televizoru a mobilních zařízeních","WEBSITE_FEATURES_CAST_DETAIL":"Cast na AppleTV, Chromecast, Smart TV (DLNA/UPnP) a mobilní zařízení.","WEBSITE_LIB":"Užívejte si svou osobní knihovnu synchronizovanou na všech zařízeních","WEBSITE_LIB_COLLECT":"Sbírat od Stremio","WEBSITE_LIB_IMPORT":"Import ze služby Facebook","WEBSITE_LIB_LOCAL":"Přidání z místní jednotky","WEBSITE_BOARD":"Rada - Vaše jediné místo pro oznámení a doporučení","WEBSITE_BOARD_RECOMMEND":"Doporučený televizní pořad","WEBSITE_BOARD_TRENDING":"Trendy film","WEBSITE_BOARD_NEW":"Nové video","WEBSITE_BOARD_EPISODE":"Nová epizoda","WEBSITE_BOARD_1":"Hledáte něco zajímavého ke sledování? Získejte doporučení podle svého vkusu!","WEBSITE_BOARD_2":"Nechte se upozornit na nový díl svého oblíbeného televizního pořadu nebo kanálu YouTube!","WEBSITE_BOARD_YOUTUBE":"Nová videa kanálů YouTube","WEBSITE_BOARD_EPISODES":"Nové epizody seriálů, které sledujete","WEBSITE_ADDONS":"Doplňky obsahu","WEBSITE_TECH_DETAIL":"Milujeme technologie, milujeme šílenou vědu!\\nStremio používá následující open source technologie:","WEBSITE_TECH_WCJS":"WebChimera.js umožňuje službě Stremio přehrávat jakýkoli formát videa s dobrým výkonem.","WEBSITE_TECH_WCJS_EXTRA":"Jsme hlavními přispěvateli projektu","WEBSITE_TECH_ELECTRON":"Electron poskytuje inovativní platformu, na které lze vytvořit Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Jsme přispěvatelé projektu","WEBSITE_TECH_LINVODB":"Databázová technologie, která zajišťuje, že vaše data jsou uspořádaná a dostupná kdekoli, kde se přihlásíte.","WEBSITE_TECH_LINVODB_EXTRA":"Vlastní technologie","WEBSITE_CREATE_ADDON":"Vytvoření doplňku","WEBSITE_CREATE_ADDON_DETAIL":"Máte službu poskytující videoobsah? Pomůžeme vám využít funkce Stremio vytvořením vašeho doplňku.","WEBSITE_CREATE_ADDON_BENEFITS":"Výhody vytvoření doplňku pro Stremio","WEBSITE_P2P_BEAUTY":"Krása peer-to-peer streamování","WEBSITE_P2P_1":"Spolehlivé a cenově dostupné video v rozlišení Full HD / 4K na vyžádání nebo živé vysílání","WEBSITE_P2P_2":"Distribuční platforma poskytující skvělý uživatelský zážitek","WEBSITE_P2P_3":"Vytvoříme doplněk, který bude přesně odpovídat vašim potřebám","WEBSITE_P2P_CONTACT":"Máte zájem? Můžete nás kontaktovat.","WEBSITE_P2P_CONTACT_EXTRA":"Rádi vám pomůžeme s integrací vašeho obsahu do služby Stremio!","WEBSITE_P2P":"Jednou za čas se objeví technologie, která změní název hry. Investovali jsme spoustu času a úsilí do vytvoření našeho enginu pro streamování videa P2P (Peer-to-Peer), který poskytuje skvělý výkon a všestrannost, aby se přizpůsobil jakémukoli případu použití.\\nKontaktujte nás pro P2P video na vyžádání nebo živé streamování s podporou DRM.","WEBSITE_THOUGHTS":"Myšlenky, které sdílíme:","WEBSITE_SPREAD":"Šíření informací o Stremio:","WEBSITE_CONTACT":"Kontaktujte nás, budeme rádi, když se nám ozvete!","WEBSITE_OPENSOURCE":"Naše projekty s otevřeným zdrojovým kódem naleznete na adrese","WEBSITE_BITCOIN":"Darujte bitcoin:","WEBSITE_FAQ":"Nejčastější dotazy","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Otázky","WEBSITE_TOS":"Podmínky použití","WEBSITE_LEGAL":"Právo","WEBSITE_PAGE_ABOUT":"O nás","WEBSITE_PAGE_BECOME_PARTNER":"Staňte se partnerem","WEBSITE_ALL_YOU_CAN_WATCH":"Svoboda sledování\\nVše, co chcete.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Co je stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio je komplexní centrum pro agregaci video obsahu. Objevujte, organizujte a sledujte videa ze všech zdrojů na jakémkoli zařízení, které vlastníte.","WEBSITE_WHAT_IS_STREMIO_P2":"Filmy, televizní pořady, seriály, živé televizní vysílání nebo webové kanály jako YouTube a Twitch.tv - to vše najdete na Stremiu.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio je moderní multimediální centrum, které představuje komplexní řešení pro vaši videozábavu. Objevujete, sledujete a organizujete videoobsah ze snadno instalovatelných doplňků.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmy, televizní pořady, živé vysílání nebo webové kanály - to vše najdete na Stremiu.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Užívejte si na všech svých multimediálních zařízeních","WEBSITE_DEVICES_COLLECT":"Sbírat od Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import z facebooku","WEBSITE_DEVICES_LOCAL":"Přidání z místní jednotky","WEBSITE_JOIN_THE_PARTY_NOW":"Připojte se k večírku nyní","WEBSITE_DEVICES_ALL":"Snadné použití na všech zařízeních;","WEBSITE_EXTENDABLE_CATALOG":"Nekonečně rozšiřitelný katalog videa;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Skvělé funkce pro organizaci médií;","WEBSITE_AS_SEEN_ON":"Neviděno","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"O nás","WEBSITE_LINK_TECHNOLOGY":"Technologie","WEBSITE_LINK_APPS":"Aplikace","WEBSITE_LINK_DOWNLOADS":"Stahování","WEBSITE_MORE":"Více","WEBSITE_LINK_ADDONS":"Doplňky","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Делать вклад","WEBSITE_LINK_COMMUNITY":"Komunita","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"Dnes již máte procvičeno. Buď přidejte více karet, nebo začněte znovu zítra.","WEBSITE_LINK_HELP":"Centrum nápovědy","WEBSITE_LINK_CONTACTS":"Obchodní dotazy","WEBSITE_LINK_TOS":"Podmínky a pravidla","WEBSITE_LINK_PRAVACY":"Zásady ochrany osobních údajů","WEBSITE_SUBSCRIBE":"Odebírat","WEBSITE_NEWSLETTER":"Připojte se k našemu zpravodaji pro úžasné věci","WEBSITE_PLACEHOLDER_EMAIL":"Váš e-mail","WEBSITE_COMMUNITY":"Komunita","WEBSITE_LINK_PRAVACY_LEGAL":"Ochrana soukromí a právní předpisy","WEBSITE_WHY":"Proč to děláme","WEBSITE_WHY_P1":"Ve Stremio chodíme každý den do práce, protože chceme vyřešit důležitý problém pro odvětví videa na vyžádání. Každou minutu je zveřejněno tolik nového obsahu, že je prakticky nemožné se v něm zorientovat.","WEBSITE_WHY_P2":"Pomáháme lidem orientovat se v obrovském světě video zábavy a objevovat nový obsah. Naše aplikace sdružují filmy, seriály, živé televizní vysílání, webové kanály a další. Snažíme se uživatelům neuvěřitelně usnadnit vyhledávání oblíbených titulů a televizních stanic.","WEBSITE_WHY_P3":"Naši službu můžete používat na jakémkoli zařízení a kdykoli, takže Stremio je jediné centrum video zábavy, které kdy budete potřebovat.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"Tým Stremio je malý, ale výkonný: deset z nás programuje v X jazycích a sdílíme odborné znalosti v oblasti vývoje softwaru, designu uživatelského rozhraní a UX, marketingu a reklamy a podnikání a startupů.","WEBSITE_FEATURES":"Vlastnosti","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Snadné objevování nového obsahu","WEBSITE_FEATURES_DISCOVER_P":"Snadno objevujte nové filmy, televizní pořady, seriály a kanály ke sledování. Procházejte podle kategorie, žánru, hodnocení, oblíbenosti atd. nebo jednoduše zadejte název a vyhledejte. Se službou Stremio je vyhledávání nového videoobsahu hračka.","WEBSITE_FEATURES_ALL_CONTENT":"Veškerý video obsah na jedné obrazovce","WEBSITE_FEATURES_ALL_CONTENT_P1":"Podívejte se, které filmy, seriály nebo videa jste nedokoukali, a pokračujte v jejich sledování, nechte si posílat upozornění na nové epizody a novinky a procházejte doporučení, která dostanete na základě svých diváckých návyků.","WEBSITE_FEATURES_LIBRARY":"Uspořádejte svou knihovnu videí","WEBSITE_FEATURES_LIBRARY_P1":"Jedním kliknutím přidáte do knihovny Stremio libovolný titul a můžete se orientovat v obsahu, který je přehledně uspořádán podle typu, aktuálnosti nebo abecedního pořadí.","WEBSITE_FEATURES_CALENDAR":"Sledujte vše, co sledujete","WEBSITE_FEATURES_CALENDAR_P1":"Získejte vizualizaci všech filmů a seriálů, které přidáte do své knihovny, v kalendáři. Exportujte svůj kalendář Stremio a synchronizujte jej, abyste vždy věděli, kdy se má objevit nová epizoda nebo premiéra.","WEBSITE_FEATURES_BIG_SCREEN":"Vychutnejte si video obsah na větší obrazovce","WEBSITE_FEATURES_BIG_SCREEN_P1":"Jediným kliknutím můžete přehrát cokoli, co sledujete, do jiného zařízení - telefonu, tabletu nebo televizoru.","WEBSITE_FEATURES_SOURCES":"Sledování videí z mnoha různých zdrojů","WEBSITE_FEATURES_SOURCES_P":"Nainstalujte si oficiální a komunitní doplňky, abyste si mohli vychutnat videa od mnoha různých poskytovatelů - to vše v jedné elegantní a snadno použitelné aplikaci.","WEBSITE_CREATE_AN_ADDON":"Vytvoření doplňku","WEBSITE_FEATURES_SYNC":"Synchronizace knihovny mezi různými zařízeními a obnovení přehrávání","WEBSITE_FEATURES_SYNC_P1":"Přihlaste se pomocí svého účtu do všech zařízení a užívejte si synchronizovanou knihovnu, doplňky, přehrávání a kalendář.","WEBSITE_FEATURES_EXTENDABLE":"Rozšiřitelný katalog videí pomocí doplňků","WEBSITE_FEATURES_EXTENDABLE_P1":"Katalog doplňků Stremio nabízí řadu doplňků, které si můžete nainstalovat a sledovat z nich nejrůznější videoobsah. Patří sem filmy, seriály, živé televizní vysílání, sport, zprávy, podcasty, webové kanály, videohry a další.","WEBSITE_FEATURES_AUTO_SUBS":"Automatické titulky","WEBSITE_FEATURES_AUTO_SUBS_P1":"S našimi doplňky titulků získáte automaticky vybrané možnosti pro preferovaný jazyk.","WEBSITE_FEATURES_CHROMECAST":"Casting do Chromecastu","WEBSITE_FEATURES_CHROMECAST_P1":"Vychutnejte si videoobsah na větší obrazovce nebo jen přenášejte sledované video do jiného zařízení.","WEBSITE_FEATURES_KEEP_TRACK":"Sledování oblíbených televizních pořadů a webových kanálů","WEBSITE_FEATURES_KEEP_TRACK_P1":"Získejte vizualizaci kalendáře a upozornění na nové epizody oblíbených seriálů a webových kanálů.","WEBSITE_FEATURES_POWER_USER":"Funkce pro výkonné uživatele","WEBSITE_FEATURES_POWER_USER_P1":"Přehrávání v externím přehrávači","WEBSITE_FEATURES_POWER_USER_P2":"Přehrávání ze souboru torrent nebo odkazu magnet","WEBSITE_FEATURES_POWER_USER_P3":"Import do knihovny ze služby Facebook likes nebo z místního disku","WEBSITE_ADD_ONS":"Doplňky","WEBSITE_ADD_ONS_P1":"Veškerý videoobsah, který Stremio poskytuje, je získáván prostřednictvím systému doplňků - aplikace neobsahuje žádný obsah ani poskytovatele obsahu.","WEBSITE_ADD_ONS_P2":"K dispozici jsou dvě skupiny doplňků: oficiální a komunitní.","WEBSITE_ADD_ONS_P3":"Oficiální doplňky vyvíjí a hostuje Stremio, zatímco komunitní doplňky vytvářejí členové naší komunity, kteří je také hostují.","WEBSITE_ADDONS_OFFICIAL":"Oficiální doplňky","WEBSITE_ADDONS_WATCHUB":"Streamujte své oblíbené filmy, seriály a pořady od poskytovatelů, jako jsou iTunes, Hulu, Amazon a další britské/americké služby.","WEBSITE_ADDONS_YOUTUBE":"Sledujte své oblíbené kanály YouTube bez reklam a dostávejte upozornění na nové příspěvky od autorů, které sledujete.","WEBSITE_ADDONS_FILMON":"Sledujte živé televizní vysílání, filmy a sociální televizi zdarma. 600 televizních kanálů, 45 000 bezplatných filmů, dokumentů a další.","WEBSITE_ADDONS_OPENSUBTITLES":"Filmové a televizní titulky ve více jazycích, tisíce přeložených titulků nahraných každý den.","WEBSITE_ADDONS_COMMUNITY":"Doplňky komunity","WEBSITE_ADDONS_FILMON_VOD":"Sledujte video na vyžádání z Filmon.tv","WEBSITE_ADDONS_TWICH":"Sledujte živé přenosy z Twitch.tv - platformy pro streamování videa z e-sportů.","WEBSITE_ADDONS_VODO":"Sledujte nezávislé filmy zcela zdarma.","WEBSITE_ADDONS_NETFLIX":"Sledování filmů a webových seriálů Netflix.","WEBSITE_ADDONS_CREATE":"Vytvoření doplňku","WEBSITE_ADDONS_CREATE_P1":"Pokud chcete, můžete si vytvořit vlastní doplněk. Tímto způsobem můžete sobě i naší komunitě poskytnout přístup k novému videoobsahu a oslovit nové, cílené publikum milionů uživatelů po celém světě.","WEBSITE_ADDONS_START_CREATE":"Chcete-li začít, navštivte stránku Stremio Addon SDK:","WEBSITE_DOWNLOADS":"Stahování","WEBSITE_DOWNLOADS_P1":"Pro optimální výkon doporučujeme používat nejnovější dostupnou verzi aplikací Stremio. Pokud však z nějakého důvodu chcete používat starší verzi, můžete si ji stáhnout zde.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio pro Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio pro macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio pro Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio pro Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio pro iOS (omezená verze)","WEBSITE_CONTRIBUTE":"Делать вклад","WEBSITE_CONTRIBUTE_P1":"Platforma Stremio má otevřený zdrojový kód a můžete snadno vytvořit doplněk pro obsah, který v současné době nemá zdrojový kód.","WEBSITE_CONTRIBUTE_WHY":"Proč byste si měli vytvořit doplněk?","WEBSITE_CONTRIBUTE_WHY_P1":"Oslovte nové publikum pro svůj video obsah","WEBSITE_CONTRIBUTE_WHY_P2":"Uživatelská základna Stremio rychle roste - během prvního roku od spuštění získalo Stremio 1 milion uživatelů po celém světě a ve druhém roce existence platformy se jejich počet zvýšil na 2,5 milionu.","WEBSITE_CONTRIBUTE_WHY_P3":"S vaším doplňkem můžete toto publikum snadno oslovit a distribuovat mu svůj videoobsah.","WEBSITE_CONTRIBUTE_ALL":"Sledujte své oblíbené filmy, videa, seriály a kanály na jednom místě.","WEBSITE_CONTRIBUTE_ALL_P1":"Jste fanouškem určitého typu obsahu, který zatím není na Stremiu k dispozici? Vytvořte si pro něj doplněk a užijte si sledování oblíbených videí v jednom z největších a nejsnadněji použitelných zábavních center na trhu.","WEBSITE_CONTRIBUTE_ALL_P2":"Kromě toho získáte nekonečnou vděčnost dalších podobně smýšlejících členů komunity Stremio.","WEBSITE_CONTRIBUTE_MONETIZE":"Zpeněžujte svůj doplněk a vydělávejte peníze s jeho pomocí","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Jakmile vyvinete nový doplněk pro Stremio, můžete jej snadno zpeněžit několika různými způsoby. Pokud o tom uvažujete, neváhejte nás kontaktovat na adrese","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - rádi s vámi zkonzultujeme možnosti zpeněžení doplňků a poradíme vám.","WEBSITE_CONTRIBUTE_TRANSLATE":"Staňte se dobrovolným překladatelem","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Pokud chcete využívat aplikace Stremio v různých jazycích, můžete se připojit k naší komunitě dobrovolných překladatelů. Ti nám pomáhají přidávat verze aplikace Stremio v mnoha různých jazycích.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Máte chuť začít?","WEBSITE_TRANSALTE_STREMIO":"Přeložit Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Oficiální komunity","WEBSITE_COMMUNITY_OFFICIALS_P1":"Staňte se součástí rostoucí komunity Stremio. Sledujte nás na sociálních sítích a nestyďte se nás pozdravit - rádi se ozýváme našim fanouškům!","WEBSITE_COMMUNITY_UNOFFICIALS":"Neoficiální komunity","STREMIO_COMMUNITY_NL":"Stremio Nizozemsko","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Německo","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgie","STREMIO_COMMUNITY_FRANCE":"Stremio Francie","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugalsko","STREMIO_COMMUNITY_ITALY":"Stremio Itálie","STREMIO_COMMUNITY_UK":"Stremio Česká republika","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexiko","STREMIO_COMMUNITY_ADDONS":"Doplňky Stremio","STREMIO_COMMUNITY_AWESOME":"Úžasné Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partneři a podporovatelé","WEBSITE_COMMUNITY_GOODIES":"Stremio dobroty","WEBSITE_COMMUNITY_WALLPAPERS":"Tapety na plochu","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Kontaktujte nás","WEBSITE_CONTACT_US_P1":"Máte-li jakékoli dotazy, připomínky nebo návrhy, neváhejte nás kontaktovat prostřednictvím níže uvedeného kontaktního formuláře.","WEBSITE_CONTACT_US_P2":"Mějte na paměti, že se nacházíme v Bulharsku, takže může dojít ke zpoždění při řešení vašeho dotazu kvůli rozdílům v časových pásmech.","WEBSITE_CONTACT_US_SUCCESS":"Vaše zpráva byla odeslána. Ozveme se vám v nejbližším možném termínu.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Zadejte prosím platný e-mail!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Čeho se vaše otázka týká?","WEBSITE_CONTACT_US_Q_OS":"Jaký je váš operační systém?","WEBSITE_CONTACT_US_PH_EMAIL":"Váš e-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Zpráva","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ODESLAT","WEBSITE_CONTACT_US_Q_1":"Jak nainstalovat?","WEBSITE_CONTACT_US_Q_2":"Jak odinstalovat?","WEBSITE_CONTACT_US_Q_3":"(HTML) Jak připravit lasagne?","WEBSITE_CONTACT_US_Q_4":"Doplňky","WEBSITE_CONTACT_US_OS_1":"Umístěním databáze na síťovou jednotku je ve Windows zakázáno, aby se předešlo poškození dat. Mnemosyne bude nyní uzavřeno.","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technologie","WEBSITE_TECHNOLOGY_P1":"
Milujeme technologie a bláznivou vědu.
Tady je to, co pohání Stremio (vše je open-source).","WEBSITE_TECHNOLOGY_P_QT":"Vývoj softwaru napříč platformami v té nejlepší podobě.","WEBSITE_TECHNOLOGY_P_MPV":"Bezplatný multiplatformní přehrávač médií s otevřeným zdrojovým kódem.","WEBSITE_TECHNOLOGY_P_RN":"React Native umožňuje vytvářet mobilní aplikace pouze pomocí JavaScriptu.","WEBSITE_TECHNOLOGY_P_VLC":"Mediální rámec vložený do aplikace pro získání multimédií.","WEBSITE_TECHNOLOGY_P_REALM":"Realm je mobilní platforma a náhrada SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js je open-source, multiplatformní běhové prostředí jazyka JavaScript.","WEBSITE_TECHNOLOGY_P_RUST":"Rust je multiparadigmatický systémový programovací jazyk zaměřený na bezpečnost, zejména na bezpečnou souběžnost.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Přispět k projektu","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Existují dva způsoby, jak můžete přispět na Stremio a pomoci nám produkt ještě vylepšit.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Své cenné jazykové znalosti můžete věnovat překladu platformy...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"nebo","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... můžete využít své programátorské dovednosti při vytváření komunitních doplňků","WEBSITE_TRANSLATE_STREMIO":"Přeložit Stremio","WEBSITE_404_OH_NO":"Uh-oh! Hledaná stránka se zde nenachází...","WEBSITE_GO_HOME":"Jít domů","WEBSITE_LINK_OTHER_DOWNLOADS":"Ostatní soubory ke stažení","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Podpora","WEBSITE_DOWNLOAD_4_0_BETA":"Stáhněte si Stremio 4 beta nyní","WEBSITE_GET_FOR_DESKTOP":"Získat pro stolní počítače","WEBSITE_LINK_ADDON_COMPETITION":"Soutěž o doplněk","WEBSITE_LINK_ART_CONTEST":"Výtvarná soutěž","WEBSITE_MY_ACCOUNT":"Můj účet","WEBSITE_MAINPAGE_FAQ_001_H1":"Co je Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio je moderní multimediální centrum, které vám dává svobodu sledovat vše, co chcete.","WEBSITE_MAINPAGE_FAQ_002_H1":"Jak to funguje?","WEBSITE_MAINPAGE_FAQ_002_P1":"Po instalaci aplikace Stremio do zařízení a vytvoření účtu stačí navštívit katalog doplňků, nainstalovat libovolný doplněk a můžete začít!","WEBSITE_MAINPAGE_FAQ_002_P2":"Poté můžete přejít do sekce Objevovat nebo Nástěnka a začít zkoumat obsah.","WEBSITE_MAINPAGE_FAQ_003_H1":"Co zde mohu sledovat?","WEBSITE_MAINPAGE_FAQ_003_P1":"Hodně: Filmy, televizní pořady, webové kanály, sport, televizní kanály, poslech podcastů a další. Díky našemu systému doplňků máte přístup k nejrůznějšímu obsahu.","WEBSITE_MAINPAGE_FAQ_004_H1":"Je Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Ano, můžete se podívat na následující odkazy: ${1}desktopová aplikace${2} a ${3}Organizace GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Je Stremio bezpečné?","WEBSITE_MAINPAGE_FAQ_005_P1":"Ano: protože se jedná o software s otevřeným zdrojovým kódem, kód je veřejně kontrolovatelný a můžete si ho sami zkontrolovat.","WEBSITE_MAINPAGE_FAQ_006_H1":"A co moje soukromí?","WEBSITE_MAINPAGE_FAQ_006_P1":"Respektujeme soukromí uživatelů a neshromažďujeme žádné osobní údaje kromě nezbytného minima pro vytvoření a synchronizaci vašeho účtu.","WEBSITE_MAINPAGE_FAQ_006_P2":"Při registraci je k dispozici také režim ${1}Guest${2}, který nevyžaduje žádná data: v tomto režimu se nevolá na náš backend. Je to však na úkor užitečných funkcí, jako je možnost synchronizovat knihovnu napříč zařízeními.","WEBSITE_MAINPAGE_FAQ_007_H1":"Mohu vysílat na televizoru?","WEBSITE_MAINPAGE_FAQ_007_P1":"Ano, podporujeme Chromecast a můžete vysílat jak z počítače, tak z mobilních aplikací (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Kolik má Stremio doplňků?","WEBSITE_MAINPAGE_FAQ_008_P1":"Od konce roku 2019 je jich více než 50 - více informací najdete v našem katalogu doplňků.","WEBSITE_MAINPAGE_FAQ_009_H1":"Lze Stremio rozšířit nad rámec toho, co je v katalogu doplňků?","WEBSITE_MAINPAGE_FAQ_009_P1":"Ano, měli byste je zkontrolovat: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, atd.","WEBSITE_MAINPAGE_FAQ_010_H1":"Jaká zařízení Stremio podporuje?","WEBSITE_MAINPAGE_FAQ_010_P1":"Máme desktopové aplikace pro Windows, Mac a Linux. Pro mobilní zařízení podporujeme Android a iOS, i když mějte na paměti, že iOS má omezené funkce (nepodporuje většinu doplňků).","WEBSITE_MAINPAGE_FAQ_010_P2":"Existuje mnoho zařízení se systémem Android, na kterých můžete spustit Stremio, například NVIDIA Shield a Amazon Fire Stick, ale oficiálně je nepodporujeme.","WEBSITE_MAINPAGE_FAQ_011_H1":"Můžete do služby Stremio přidat určitý obsah?","WEBSITE_MAINPAGE_FAQ_011_P1":"Omlouváme se, ale sami neposkytujeme žádný obsah, ale čím více doplňků Stremio máte nainstalováno, tím více obsahu budete moci najít.","WEBSITE_MAINPAGE_FAQ_012_H1":"Umí Stremio přehrávat magnetické odkazy?","WEBSITE_MAINPAGE_FAQ_012_P1":"Ano, a umí také přehrávat běžné odkazy HTTP a soubory torrent (přetažením).","WEBSITE_MAINPAGE_FAQ_013_H1":"Mohu si video stáhnout a sledovat ho offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Funkce dostupná offline je připravovaná, ale pokud povolíte, aby Stremio ukládalo videa do mezipaměti ve vašem zařízení (na panelu nastavení), můžete je později sledovat bez připojení.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nic nefunguje, pomozte mi!","WEBSITE_MAINPAGE_FAQ_014_P1":"Jste si jisti, že máte nainstalované doplňky? Pokud ano, obraťte se na naše ${1}pomocné centrum${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Jak Stremio udržuje své vývojové operace?","WEBSITE_MAINPAGE_FAQ_015_P1":"Nevtíravé reklamy provozujeme prostřednictvím společnosti ${1}AdEx${2}, což je společnost stejného zakladatelského týmu, která se zaměřuje na transparentní reklamy chránící soukromí.","WEBSITE_MAINPAGE_FAQ_015_P2":"Další dotazy naleznete v našem ${1}pomocném centru${2}.","HELP_LEARN_MORE":"Pomozte nám dozvědět se o vás více.","LIFESTYLE":"Životní styl","SPORTS":"Sporty","FOOD_HEALTH":"Potraviny a zdraví","BEAUTY_FASHION":"Krása a móda","NEWS":"Novinky","GAMING":"Hry","SCIENCE_EDUCATION":"Věda & vzdělávání","MUSIC":"Hudba","TRAVEL":"Cestovní kancelář","LATE_NIGHT":"Pozdní noc","REALITY":"Realita","COMEDY":"Komedie","DIY":"Jak na kutilství","TECH":"Tech","CINEMA":"Kino","CONTINUE":"Pokračovat","SLOW_LOADING":"POMALÉ NAČÍTÁNÍ?","I_GIVE_UP":"VZDÁVÁM SE","LEARN_MORE":"Zjistit více","POOR_SOURCE":"Tento zdroj je špatně dostupný nebo vaše internetové připojení není dostatečně rychlé","PICK_CATEGORIES_ERR":"Musíte vybrat alespoň 3 kategorie","ADJUST_TIMING":"Nastavte časování pomocí","ADJUST_SIZE":"Upravte velikost pomocí","SEARCH_ANYTHING":"Můžete vyhledávat cokoli...","ALL_CATEGORIES":"Vše","SEARCH_CATEGORIES":"Filmy, seriály, YouTube a TV","SEARCH_PERSONS":"Herci, režiséři a scénáristé","SEARCH_PROTOCOLS":"HTTP & Magnet Odkazy","SEARCH_TYPES":"Odkazy na IMDB / TVDB","WATCHED":"Sledováno","SHOW_LESS":"Zobrazit méně","LAST_SEARCHES":"Poslední vyhledávání","CLEAR_HISTORY":"Vymazat historii","CHOOSE_SOME":"VYBERTE SI NĚCO Z TOHO:","NO_WEB_REMOTE":"Web Remote nelze načíst","STREMIO_OFFLINE":"Stremio je offline","STREMIO_EXPENSIVE_CONNECTION":"Zjistili jsme, že používáte mobilní datové připojení, chcete pokračovat?","USE_DATA":"Použití dat","WARNING":"Varování","MORE_INFO":"Více informací ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Načítám...","STREMIO_TV_BACK_TO_LANGUAGES":"Zpět na jazyky","STREMIO_TV_REMOTE":"Vzdálený","STREMIO_TV_GO_TO":"Přejít na:","STREMIO_TV_OR_SCAN":"nebo skenování:","STREMIO_TV_ADDON_INSTRUCTIONS":"Při instalaci preferovaných doplňků postupujte podle pokynů.","STREMIO_TV_LIVE_TV":"Živý televizní přenos","STREMIO_TV_RESUME_WATCHING":"Sledování životopisu","STREMIO_TV_LOADING_BACKGROUND":"Načítání pozadí","STREMIO_TV_CHECKING_AUTHENTICATION":"Kontrola ověřování","STREMIO_TV_LOADING_BOARD":"Nakládací deska","STREMIO_TV_LOGIN_HEADER_LINE_1":"Chceme, aby naši uživatelé měli s naším softwarem co nejlepší personalizované zkušenosti.","STREMIO_TV_LOGIN_HEADER_LINE_2":"Z tohoto důvodu vás žádáme, abyste si vytvořili a/nebo se přihlásili ke svému účtu.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Děkujeme za pochopení,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Tým Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Chcete-li používat webový ovladač pomocí chytrého telefonu / tabletu / stolního počítače:","STREMIO_TV_WIFI_SETUP":"Nastavení Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Aplikace Stremio Circle nezjistila připojení k internetu.","STREMIO_TV_WIFI_DETAILS_1":"Připojte se k:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Použijte heslo:","STREMIO_TV_WIFI_DETAILS_4":"stremiokruh","STREMIO_TV_WIFI_DETAILS_5":"Otevřete webový prohlížeč s odkazem:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Přepínací zařízení","REMOTE_VIDEOS":"Videa","REMOTE_ADJUST_TIMING":"Nastavení časování","REMOTE_ADJUST_SIZE":"Nastavení velikosti","REMOTE_COULD_NOT_BE_LOADED":"Web Remote nelze načíst","REMOTE_RETRY":"Zkusit znovu","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Co je Stremio?","FAQ_001_P1":"Stremio je software mediálního centra navržený pro video zábavu s ohledem na snadné používání. Stremio vám umožňuje organizovat & sledovat vlastní sbírku filmů, seriálů, kanálů a živého televizního vysílání.","FAQ_001_P2":"Stremio shromažďuje obsah, který vám zobrazuje, z vašeho místního disku a z našeho systému doplňků.","FAQ_001_P3":"Upozorní vás také na nové epizody/videa/filmy, které vás zajímají, a doporučí vám filmy.","FAQ_02_H1":"Jak si Stremio vede ve srovnání s Kodi a Plexem?","FAQ_02_P1":"Inspirovali jsme se těmito dvěma softwary. Máme však odlišné cíle - Stremio je zaměřeno speciálně na video pro zábavu a snaží se stát hlavním řešením pro tuto oblast, protože se velmi snadno používá.","FAQ_02_P2":"Stremio nikdy nebude tak přizpůsobitelné a funkčně bohaté jako Kodi a Plex, ale jeho používání je podstatně jednodušší. Stačí ${1} si ho pořídit a uvidíte ${2} :)","FAQ_03_H1":"Jak si Stremio vede ve srovnání s Netflixem?","FAQ_03_P1":"Jednou z našich inspirací je opět Netflix. Snažíme se dosáhnout uživatelského zážitku Netflixu a navíc přidat spoustu dalších vychytávek. Co je však nejdůležitější, dáváme vám svobodu spravovat vlastní knihovnu a přidávat nové zdroje obsahu pomocí našeho systému doplňků.","FAQ_03_P2":"Díky tomu je Stremio nekonečně rozšiřitelné, takže při používání Stremio nejste nikdy omezeni obsahem, který se Netflix rozhodne licencovat. Prostřednictvím služby Stremio můžete například sledovat obsah z ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} a dokonce i ${9}Netflix${10} samotný!","FAQ_04_H1":"Jak si Stremio vede ve srovnání s Flipboardem?","FAQ_04_P1":"Tuto otázku nedostáváme tak často, kromě rozhovorů se začínajícími podnikateli :)","FAQ_04_P2":"Stremio je svým založením agregátor obsahu, což z něj v podstatě dělá Flipboard pro video. To je velmi patrné v sekci Nástěnka, která vám stejně jako Flipboard nabízí katalogy a upozornění na nové epizody/nová videa, která sledujete.","FAQ_05_H1":"Jak si Stremio vede ve srovnání s Popcorn Time?","FAQ_05_P1":"Stremio a Popcorn Time jsou si podobné uživatelským rozhraním, protože není mnoho způsobů, jak udělat katalogy video zábavy správně :)","FAQ_05_P2":"Zatímco Popcorn Time se zaměřuje na streamování torrentů z konkrétních zdrojů, Stremio je bez omezení a je pouze agregátorem obsahu - není vázáno na konkrétní zdroj obsahu.","FAQ_05_P3":"Kromě toho ve výchozím nastavení neposkytujeme žádné doplňky torrentů, takže Stremio nepokrývá případ použití Popcorn Time oficiálními funkcemi.","FAQ_05_P4":"Dalším významným rozdílem je, že Popcorn Time je zcela open source, zatímco Stremio je ${1} částečně open source${2}.","FAQ_06_H1":"Přidáte tento film/seriál?","FAQ_06_P1":"Ne, je mi líto :(","FAQ_06_P2":"Jak je uvedeno ve většině ostatních otázek, Stremio samo o sobě neposkytuje žádný obsah - vše se přidává prostřednictvím systému doplňků. V případě, že máte požadavek na obsah, můžete použít tlačítko \\"Nahlásit\\" v přehrávači, které odešle e-mail autorovi doplňku, který právě používáte.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Vytvoříte doplněk pro X?","FAQ_08_P1":"Je to docela možné.","FAQ_08_P2":"Pokud máte nápad na doplněk, napište nám na ${1}office@stremio.com${2}, ale ujistěte se, že váš nápad na doplněk neporušuje autorská práva ani podmínky používání.","FAQ_08_P3":"V současné době jsou na našem plánu doplňky pro FandangoNOW, Filmon.tv video on demand a Crunchyroll.","FAQ_09_H1":"Používá Stremio BitTorrent?","FAQ_09_P1":"Ano, Stremio podporuje BitTorrent jako streamovací protokol. Ten můžete použít buď pomocí doplňku torrent, nebo přetažením souboru .torrent do aplikace Stremio, případně vložením odkazu na magnet do vyhledávacího panelu.","FAQ_09_P2":"Vezměte prosím na vědomí, že jediným oficiálním doplňkem využívajícím BitTorrent je ${1}Vodo${2}, který poskytuje nezávislý obsah povolený k distribuci pomocí BitTorrentu.","FAQ_09_P3":"Nepodporujeme používání doplňků třetích stran, které by mohly umožnit porušování autorských práv.","FAQ_10_H1":"Co mohu sledovat v aplikaci Stremio s oficiálními doplňky?","FAQ_10_P1":"Ve výchozím nastavení můžete sledovat obsah serverů Filmon.tv, YouTube a Vodo přímo v aplikaci Stremio pomocí vloženého přehrávače. Kromě toho máme doplněk pro Twitch.tv a několik dalších.","FAQ_10_P2":"Tato kombinace nabízí výběr:","FAQ_10_L1":"Oblíbené televizní kanály, které poskytuje Filmon.tv - například E4, BBC, Bollyworld TV","FAQ_10_L2":"Vše z YouTube - například BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Nezávislé filmy s Vodo","FAQ_10_L4":"Online vysílání her pomocí Twitch.tv","FAQ_10_P3":"Kromě toho existuje mnoho zdrojů obsahu poskytovaných pomocí služby Guidebox a doplňků Netflix, které se nepřehrávají zcela uvnitř služby Stremio, ale přesměrovávají se na danou službu. Například doplněk Guidebox by vám poskytl výběr filmů, které můžete v USA streamovat zdarma, ze služeb jako TubiTV a Crackle.","FAQ_11_H1":"Stremio se nechce nainstalovat, co mám dělat?","FAQ_11_P1":"Pokud používáte Windows, zkuste ${1}tento alternativní instalátor${2}.","FAQ_11_P2":"Pokud používáte systém Mac OS X, upozorňujeme, že nepodporujeme nic staršího než OS X Mavericks (10.9).","FAQ_11_P3":"Pokud používáte Linux, vězte, že v současné době podporujeme pouze 64bitový (x64) Linux.","FAQ_11_P4":"Pokud se vám stále nedaří vyřešit váš problém, napište nám na naši ${1}Facebookovou skupinu${2}.","FAQ_12_H1":"Proč si můj antivirový program stěžuje? Je Stremio bezpečné?","FAQ_12_P1":"Ujišťujeme vás, že Stremio je ${1}100% cčistý ${2}.","FAQ_12_P2":"Váš antivirový program si stěžuje, protože v našem instalačním programu je reklama, kterou některé antivirové programy rozpoznávají jako ad-ware.","FAQ_12_P3":"Pokud si stále nejste jisti, můžete vyzkoušet náš ${1}alternativní instalátor${2}.","FAQ_13_H1":"Jak mohu vytvořit doplněk?","FAQ_13_P1":"Pro začátek doporučujeme zkontrolovat náš systémový modul ${1}addons${2} na GitHubu.","FAQ_13_P2":"Poté můžete postupovat podle výukového programu ${1}Hello World${2}.","FAQ_13_P3":"Pokud nemáte žádné programátorské dovednosti, napište svůj nápad na ${1}komunitu Reddit${2} a kontaktujte nás s nápadem na doplněk na ${3}office@stremio.com${4}.","FAQ_14_H1":"Jak se publikují doplňky?","FAQ_14_P1":"Když vytvoříte doplněk a hostitele a do manifestu vložíte pole koncového bodu, které ukazuje na adresu funkčního doplňku, doplněk se automaticky zveřejní v našem katalogu ${1}Addon catalogue${2}.","FAQ_14_P2":"K tomu dochází proto, že serverová část modulu stremio-addons automaticky volá naše rozhraní API a oznamuje doplněk. Jakmile naše rozhraní API potvrdí váš koncový bod jako platný doplněk, začne se zobrazovat v katalogu.","FAQ_15_H1":"Mohu spustit Stremio v prohlížeči?","FAQ_15_P1":"Momentálně ne, ale už se to blíží!","FAQ_15_P2":"Pokud jste zvědaví na verzi Alpha, můžete si ji prohlédnout zde: ${1}alpha4.strem.io${2}. Mějte na paměti, že streamování je v této alfě vypnuté. Podporujeme prohlížeče Chrome, Firefox, Opera a Edge.","FAQ_16_H1":"Casting do TV nefunguje / titulky nefungují","FAQ_16_P1":"Odesílání do televizoru využívá technologii DLNA, která je u různých značek a modelů televizorů velmi nejednotná. Z tohoto důvodu nemáme možnost testovat ji ve všech případech, takže zdaleka není dokonalá. Přesto na jejím vylepšování neustále pracujeme, ale nemůžeme vám poskytnout časový odhad, kdy DLNA začne s vaším televizorem správně fungovat.","FAQ_16_P2":"Pokud se televizor nezobrazuje ani v nabídce obsazení, zkuste zakázat síťové připojení a znovu jej povolit (v systému Windows klikněte pravým tlačítkem myši na položku Síť a použijte příkaz Povolit/Zakázat) a restartujte směrovač, televizor a počítač.","FAQ_16_P3":"Pokud se stále potýkáte s problémy, můžete nám pomoci zasláním informací o značce a modelu televizoru na adresu ${1}office@stremio.com${2}.","FAQ_16_P4":"Do té doby doporučujeme Chromecast, který velmi dobře podporujeme, nebo jednoduše připojit televizor k počítači pomocí kabelu HDMI.","FAQ_17_H1":"Co mám dělat, když Stremio zamrzne a/nebo spadne?","FAQ_17_P1":"Pokud používáte systém Windows 7 s antivirovým programem AVG, máme s touto kombinací problém. Problém je v samotném AVG a na naší straně neexistuje žádný rozumný způsob, jak jej vyřešit. Výjimky ani vypnutí antiviru bohužel nepomohou. Jediným řešením je nahradit AVG něčím jiným.","FAQ_17_P2":"Pokud to není problém, ale stále používáte systém Windows, aktualizujte jej na nejnovější servisní balíček a aktualizujte/přeinstalujte ovladače grafického procesoru a pak to zkuste znovu.","FAQ_17_P3":"Pokud problém stále není vyřešen nebo používáte Mac či Linux, napište nám přesné informace o problému na ${1}naší skupinu na Facebooku${2}.","FAQ_18_H1":"Jak mohu vytvořit doplněk?","FAQ_18_P1":"Pro začátek doporučujeme zkontrolovat náš systémový modul ${1}addons${2} na GitHubu.","FAQ_18_P2":"Poté můžete postupovat podle výukového programu ${1}Hello World${2}.","FAQ_18_P3":"Pokud nemáte žádné programátorské dovednosti, napište svůj nápad na ${1}komunitu Reddit${2} a kontaktujte nás s nápadem na doplněk na ${3}office@stremio.com${4}.","FAQ_19_H1":"Proč Stremio zabírá místo na disku?","FAQ_19_P1":"Stremio má místní mezipaměť pro dočasné uchovávání streamovaných video souborů.","FAQ_19_P2":"To má dvě výhody: zaprvé umožňuje Stremio předem vyrovnat video do vyrovnávací paměti, aby bylo zajištěno plynulejší streamování. Zadruhé uchovává videa v místní mezipaměti, takže je můžete dále sledovat offline.","FAQ_19_P3":"Množství, které Stremio uchovává, závisí na nastavení vyrovnávací paměti na panelu Nastavení. Stremio může na vašem disku uchovávat až nastavené množství (např. 2 GB), pokud není aktuálně streamované video větší než toto množství, v takovém případě musí vyčlenit dostatek úložného prostoru, aby jej uchoval až do doby, kdy jej budete streamovat.","FAQ_20_H1":"Kde se nachází složka mezipaměti?","FAQ_20_P1":"V systému Windows je to stremio-cache v jednotce, kterou jste vybrali v Nastavení (např. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"V systému MacOS je to \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"V systému Linux je to \\"~/.stremio/stremio-cache\\" nebo \\"~/stremio-cache\\"","FAQ_21_H1":"Zobrazí se mi chyba \\"Streaming server nebyl nalezen\\", co mám dělat?","FAQ_21_P1":"Pokud se vám tato chyba zobrazí, znamená to jednu z několika možností:","FAQ_21_P2":"1) Snažíte se použít doplněk podporovaný zdrojem YouTube/BitTorrent prostřednictvím naší verze ${1}web${2}. V takovém případě byste si měli nainstalovat naši verzi pro stolní počítače z ${3}našich webových stránek${4}.","FAQ_21_P3":"2) Něco je špatně s vaší instalací Stremio. V takovém případě zkuste znovu nainstalovat naši nejnovější verzi pro stolní počítače z ${1}webové stránky${2}. Pokud to nepomůže, zkuste vypnout antivirové programy a brány firewall, restartovat počítač a zkusit to znovu. Pokud ani to nepomůže, napište nám do naší ${3}skupiny na Facebooku${4}.","FAQ_22_H1":"Většinu doplňků v systému iOS nevidím/používám","FAQ_22_P1":"Vzhledem k omezením v podmínkách obchodu Apple App Store jsme aplikaci pro iOS omezili pouze na určitou sadu doplňků.","FAQ_22_P2":"Ale buďte si jisti - v budoucnu se objeví další doplňky pro iOS a možná přidáme také integraci, která vám umožní používat všechny doplňky Stremio díky připojení aplikace iOS ke Stremio Streaming Serveru."}')},4806:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"Kanal","TYPE_channel":"Kanal","TYPE_other":"Andet","TYPE_movie_PL":"Film","TYPE_series_PL":"Serier","TYPE_tv_PL":"TV","TYPE_channel_PL":"YouTube","TYPE_other_PL":"Andrer","TYPE_ALL":"All","VIDEO":"Video","BACK":"Tilbage","MORE":"Mere","DONE":"Færdig","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Opdag","Board":"Væg","Library":"Bibliotek","My Library":"Mit Bibliotek","Calendar":"Kalender","NOTIFICATION_ONLINE":"Du er nu online","NOTIFICATION_OFFLINE":"Du er nu offline","INTERNET_CONNECTION":"Netværk forbindelse","STORAGE_FULL_TITLE":"OBS: Ikke mere ledig plads","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"Søg efter","SEARCH_NO_RESULTS":"Ingen resultater fundet","SEARCH_EXPLANATION_CONTENT":"Søg efter film, serier, YouTube og TV kanaler","SEARCH_EXPLANATION_PEOPLE":"Søg efter skuespiller, direktører og forfatterer","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Tilføj til Bibliotek","REMOVE_FROM_LIB":"Fjern fra Bibliotek","ADDED_TO_LIB":"Tilføjet til Bibliotek","REMOVED_FROM_LIB":"Fjernet fra Bibliotek","TRAILER":"Trailer","WATCH_TRAILER":"Se Trailer","WATCH_NOW":"Afspil","SHOW":"Vis","SHOW_MOVIE":"Vis film","WATCH_RANDOM":"Se tilfældig","IMDB_RATING":"IMDb Bedømmelse","YEAR":"År","DIRECTOR":"Instruktør","WRITER":"Skrevet af","LEAD_ACTORS":"Hovedroller","CAST":"Medvirkende","CREW":"Filmhold","SHOW_MORE_CAST":"Se flere »","AIRED":"Sendt","SEASONS":"Sæsoner","GENRE":"Genre","CATALOG":"Katalog","SUMMARY":"Opsummering","SHOW_MORE":"Show More","SIMILAR":"Lignende","UPCOMING":"Kommende","ENDED":"Sluttet","DURATION":"Længde","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"Kategori","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Søg videoer","SEARCH_PLACEHOLDER":"Søg eller indsæt magnet link","ADDON":"Tilføjelse","ADDONS":"Tilføjelser","OFFICIAL":"Officielle","ADDONS_OFFICIAL":"Officielle Stremio tilføjelser","ADDONS_POPULAR":"Populære nær dig","ADDON_FREE":"Gratis","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abonnement","ADDON_STREAM_GEORESTRICTED":"Ikke tilgængeligt i dit område","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Lokal Fil","SHARE_ADDON":"Del tilføjelse","AVAILABLE_STREAMS":"Tilgængelige Streams","NO_STREAM":"Ingen tilgængelige streams","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For flere streams, vær venlig at installere flere tilføjelser","STREAM_NOT_SUPPORTED":"Den valgte stream er ikke understøttet på denne platform.","ADDON_CATALOGUE":"Vis alle tilføjelser »","ADDON_CATALOGUE_MORE":"Flere tilføjelser »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Der opstod fejl under tilføjelse af repository","ADDON_ADD_ERR":"Der skete en fejl under tilføjelse af tilføjelsen","ERR_ADDON_PROTECTED":"Beskyttet tilføjelse","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Noget gik galt - authentificering slog måske fejl","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Film stadig i biografen","WATCH_IN_CINEMA":"se den i din lokale biograf","IN_THEATER":"I biografen","GET_TICKETS":"Køb biletter","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Denne kanal er ikke indekseret endnu.
Kom tilbage om et par minutter.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Tilføj til dit bibliotek og bliv notificeret når den er tilgængelig","GET_NOTIFIED_WHEN_AVAILABLE":"Du vil blive notificeret når den er tilgængelig","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"streamer fra","CASTING_TO":"Afspiller på","NETWORK_STATUS":"Netværksstatus","STREAM_SPEED":"Hastighed:","STREAM_BUFFERED":"Downloadet:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Aktive:","PEERS_CONNECTED":"Forbundet:","PEERS_WAITING":"Venter:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"Henter..","PLAYING_LOCAL":"afspiller fra lokal fil","PLAYING_CACHE":"afspiller fra cache","WRONG_SUBS":"Forkert tekst?","ERR_SUBS_LOADING_TITLE":"Fejl under indlæsning af undertekster","ERR_SUBS_LOADING":"Kunne ikke indlæse undertekster: det kunne være et problem med tilføjelsen du bruger eller med din netværk forbindelse","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Følgende underteksts tilføjelse fejlede","ERR_CASTING_UPDATE_TITLE":"Kunne ikke opdatere casting enheds info: streaming serveren er måske offline","CHOOSE_DEVICE":"Vælg enhed at afspille på","NO_CAST_DEVICES":"Ingen casting enheder tilgængelige.","NO_SETTINGS":"Ingen instillinger tilgængelige.","PHONE_TABLET":"Telefon / Tablet","SUBTITLES":"Undertekster","SUBTITLES_CHANGE":"Ændre undertekster","SUBTITLES_CHANGE_NONE":"Der er ikke flere undertekster til dette sprog, desværre.","SUBTITLES_CHANGE_ACIVE":"Undertekst #{{subtitlesDialog.activeIdx + 1}} er aktiveret. Klik \\"Forsæt\\" for at aktivere #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativt,","SUBTITLES_ADJUST_DELAY":"Juster undertekst forsinkelse:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Eller brug G / H taster under afspilning for at justere.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: du kan bruge G / H taster under afspilning for at justere.","SUBTITLES_DELAY":"Undertekst forsinkelse:","SUBTITLES_LOADING":"Indlæser undertekster...","SUBTITLES_UNAVAILABLE":"Ingen eksterne undertekster tilgængelige","SUBTITLES_DISABLED":"Slået fra","AUDIO":"Lyd","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sæson","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"tendens","SORT_RECENT":"seneste","SORT_ALPHABET":"alfabetisk","SORT_RATING":"bedømmelser","SORT_WATCHED":"set","SORT_YEAR":"år","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nyt til dig","New Episodes":"Nye episoder","New Videos":"Nye Videoer","Recommendations":"Anbefalinger","LIBRARY_RESUME":"Genoptag","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detaljer","LIBRARY_RESUME_DISMISS":"Afvis","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Indhold","DISCOVER_TOP":"Populære","DISCOVER_OSCAR":"Oscar Vindere","DISCOVER_WARNING_TITLE":"Ups!","DISCOVER_EMPTY_CATALOG":"Tilføjelsen returnerede tomt indhold.","DISCOVER_ADULT_WARNING":"Inholdet er kun synligt for voksne. Er du 18+?","DISCOVER_NOADDON_WARNING":"Advarsel: intet Stremio tilføjelse aktiveret for denne type. Viser gemte ting, intet vil blive opdateret.","DISCOVER_LOAD_ERR":"Indholdet kunne ikke indlæses, fejl opstået.","DISCOVER_ADDON_UNINSTALLED":"Indholdet er ikke længere tilgængeligt, måske har du afinstalleret tilføjelsen.","UNINSTALL_THIS_ADDON":"Afinstaler tilføjelsen","ERR_ADDON_NOT_INSTALLED":"Tilføjelsen er ikke instaleret. Instaler nu?","DETAIL_RECEIVE_NOTIF_SERIES":"Modtag notifikationer for nye episoder","DETAIL_RECEIVE_NOTIF_VIDEOS":"Modtag notificationer for nye videoer","SIDEBAR_SHOW_STREAMS":"Vis streams","RELAUNCH":"Genindlæs nu!","UPGRADE":"Opdater til seneste Stremio version","RELOAD_UI":"Genindlæs brugerflade","MANUAL_UPDATE_TITLE":"Opdater din Stremio version","MANUAL_UPDATE_LINE1":"Du kører en gammel version af Stremio hvilket ikke er anbefalet.","MANUAL_UPDATE_LINE2":"Opdater venligst så hurtigt som muligt.","BUTTON_UPDATE_LATTER":"Ikke nu","BUTTON_UPDATE_NOW":"Opdater","ANONYMOUS_USER":"Anonym bruger","DONT_HAVE_ACC":"Har du ikke en konto?","HAVE_ACC":"Har du allerede en konto?","PASSWORD":"Adgangskode","PASSWORD_CONFIRM":"Bekræft adgangskode","EMAIL":"E-mail","FB_LOGIN":"Login med Facebook","FB_NOTHINGSHARED":"Intet bliver delt uden din tilladelse","FB_NOPOST":"Vi slår aldrig noget op på dine vegne","OR":"eller","I_ACCEPT":"Jeg accepterer","I_ACCEPT_BY_CLICKING":"Ved at klikke overstående knap bekræfter jeg at jeg accepterer ","TOS":"Betingelser","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Kodeord ikke korrekt","SIGN_UP":"Opret","SIGN_UP_EMAIL":"Tilmeld med email","CLICK_TO_SIGN_UP":"Klik her for at tilmelde dig.","LOG_IN":"Log ind","LOG_OUT":"Log ud","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Hjælp & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"Om Stremio","USER_PANEL":"Bruger Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gæste log ind","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"Klik her","WRONG_PASSWORD":"Forkert kodeord. Har du glemt dit kodeord, ","SET_A_PASS":"Vælg kodeord","RESET_PASSWORD":"Reset kodeord","FORGOT_PASSWORD":"Glemt kodeord?","EMAIL_USED_WITH_FB":"Denne email er brugt til Facebook log ind.","INVALID_EMAIL":"Venligst intast en gyldig email addresse","INVALID_PASSWORD":"Venligst indtast et gyldigt kodeord","CONN_ERR":"Forbindelse fejl - Prøv igen senere.\\n\\nHvis fejl forsætter, deaktiver firewalls/anti-virus software (specielt Bitdefender).","IMPORT_FROM_GUEST":"Importer bibliotek fra din gæstekonto","RECEIVE_UPDATES_EMAIL":"Modtag opdateringer til din email fra Stremio","LOGIN_FAILED":"Login fejlede.","SIGNUP_FAILED":"Tilmelding fejlede.","SEARCH_FAILED":"Søgning fejlede","EMAIL_USED":"Denne email er allerede i brug.","WAITING_FB_LOGIN":"Logger ind med Facebook...","EXTERNAL_PLAYER_TITLE":"Afspil i extern afspiller","EXTERNAL_REMEMBER_PLAYER":"Husk valg?","EXTERNAL_ALWAYS_PLAY":"Ja","EXTERNAL_ONLY_ONCE":"Nej","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Fortæl os hvad du godt kan lide","INTRO_TASTE_LONG":"Fortæl os om hvad du gerne vil se","INTRO_TASTE_PICK":"Vælg {{interestsRemaining}} interesser","INTRO_TASTE_PICK_MORE":"Vælg {{interestsRemaining}} flere interesser","INTRO_TASTE_HELP_US":"Hjælp os med at lære mere om dig.","INTRO_TASTE_CHOOSE_THESE":"Vælg nogle af disse:","INTRO_TASTE_CHOOSE_MIN":"Vælg mindst 3 kategorier","INTRO_TASTE_CHOOSE_MIN_ERR":"Du skal vælge mindst 3 kategorier!","INTRO_TASTE_LIFESTYLE":"Livsstil","INTRO_TASTE_SPORTS":"Sport","INTRO_TASTE_FOOD_HEALTH":"Mad & Sunhed","INTRO_TASTE_BEAUTY_FASHION":"Skønhed & Mode","INTRO_TASTE_NEWS":"Nyheder","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Videnskab & Uddannelse","INTRO_TASTE_MUSIC":"Musik","INTRO_TASTE_TRAVEL":"Rejse","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Komedie","INTRO_TASTE_DIY":"Gør det selv","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Biograf","ADDON_NOT_SUPPORTED":"Den valgte tilføjelse er ikke understøttet på denne platform.","ADDON_DISCLAIMER":"Brug af tredjeparts tilføjelser vil altid være dit eget ansvar og love og regler kan være forskellige fra land til land.","ADDON_ACTIVATE":"Aktiver denne tilføjelse?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Hvad er nyt","BUTTON_CONTINUE":"Fortsæt","BUTTON_ACTIVATE":"Aktiver","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Annuller","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Dit bibliotek er tomt. Find ud af hvor brugbart det er :) ","HOW_START":"Tilføj indhold til dit bibliotek","LIB_EMPTY_CAL":"Din kalender viser serier fra dit bibliotek.","HOW_START_CAL":"Tilføj indhold til dit bibliotek","LIB_EMPTY_BOARD":"Din væg viser notifikationer & anbefalinger relateret til dit bibliotek.","HOW_START_BOARD_WAIT":"Tilføj indhold til dit bibliotek og vent et par minutter til indholdet er opdateret :)","HOW_START_BOARD":"Sådan tilføjer du indhold","IMPORT_FB":"Importer ting du kan lide fra Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interessante ting fra Opdag","IMPORT_DISK":"Importer film og serier fra din computer","PLEASE_CREATE_ACC":"Venligst opret en konto for at aktivere Bibliotek & Væg.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Kør ved opstart","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Importer fra Facebook","SETTINGS_IMPORT_DISK":"Importer fra computer","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Abonner på kalender","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Ændre kodeord","SETTINGS_TOS":"Servicevilkår","SETTINGS_SUPPORT":"Kontakt support","SETTING_LANGUAGE":"Sprog","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Afslut","CONNECTED":"Connected","AUTHENTICATE":"Godkend","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Vælg caching drev","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januar","February":"Februar","March":"Marts","April":"April","May":"Maj","June":"Juni","July":"Juli","August":"August","September":"September","October":"Oktober","November":"November","December":"December","Monday":"Mandag","Tuesday":"Tirsdag","Wednesday":"Onsdag","Thursday":"Torsdag","Friday":"Fredag","Saturday":"Lørdag","Sunday":"Søndag","Action":"Action","Comedy":"Komedie","War":"Krig","Family":"Familie","Animation":"Animation","Adventure":"Eventyr","Fantasy":"Fantasy","Crime":"Krimi","Mystery":"Mystik","Romance":"Romantik","Drama":"Drama","Horror":"Gyser","Thriller":"Spænding","Sci-Fi":"Sci-Fi","Music":"Musik","Biography":"Biografi","Documentary":"Dokumentar","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Nyheder","History":"Historie","Game-Show":"Gameshow","Reality-TV":"Reality TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Underholdning","Gaming":"Gaming","From TV":"Fra TV","Lifestyle":"Livsstil","Science & Education":"Videnskab & Uddannelse","Cooking & Health":"Madlavning & Helbred","Beauty & Fashion":"Skønhed & Mode","Sports":"Sport","News & Politics":"Nyheder & Politik","How-to & DIY":"Gør det selv","Tech":"Teknologi","Automotive":"Biler","Causes & Non-Profits":"Sager & Non-profit","Movies":"Film","Uk Live Tv":"UK Direkte TV","Fashion":"Mode","Business News Radio":"Business Nyheds Radio","Business Tv":"Business TV","Cars & Auto":"Biler & Auto","Comedy Radio":"Komedie Radio","Lifestyle Radio":"Livsstils Radio","News Tv":"Nyheds TV","Food And Wine":"Mad & Vin","Latino Tv":"Latino TV","Shopping Tv":"Shopping TV","Religion":"Religion","Kids":"Børn","Body & Soul":"Krop & Sjæl","Education":"Uddannelse","Indian Tv":"Indisk TV","Extreme Sports":"Ekstremsport","Middle Eastern Tv":"TV fra Mellemøsten","Celebrity Tv":"Kendis TV","Science Tv":"Videnskabs TV","Bikini babe":"Bikini Piger","Outdoors":"udendørs","German Tv":"Tysk TV","French Tv":"Fransk TV","Italian Tv":"Italiensk TV","Gamer Tv":"Spil TV","Travel":"Rejse TV","Asian Tv":"Asiatisk TV","Entertainment":"Underholdning","News Radio":"Nyheds Radio","Music Radio":"Musik Radio","Language Learning":"Sprog & Læring","Science Radio":"Videnskabs Radio","Tech Radio":"Teknologi Radio","Science & Technology Vod":"Videnskab & Teknologi VOD","new video":"ny video","new episode":"ny episode","new movie":"ny film","recommended":"anbefalet","we recommend":"vi anbefaler","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Afvis notifikationer","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Del","CTX_COPY_SHARE_LINK":"Kopier dele link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Vis","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Se på","CTX_WATCH":"Se","CTX_WATCHED":"Set","CTX_WATCH_BEGINNING":"Se fra begyndelsen","CTX_WATCH_MOBILE":"Se på en mobil enhed","CTX_REWIND":"Tilbage til begyndelsen","CTX_MARK_WATCHED":"Marker som set","CTX_MARK_NON_WATCHED":"Marker som ikke set","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Modtag nye notifikationer","CTX_REMOVE_CACHE":"Fjern cache","CTX_REMOVE_CACHE_EP":"Fjern episode fra cache","CTX_OPEN_CONTAINING":"Åben mappe","CTX_REMOVE":"Fjern fra bibliotek","CTX_AVAILABLE_OFFLINE":"Tilgængelig Offline","CTX_PAUSED":"Pause","CTX_ALWAYS_ON_TOP":"Altid øverst","CTX_FULLSCREEN":"Fuldskærm","CTX_WRONG_SUBS":"Forkerte undetekster?","CTX_REPORT_ISSUES":"Rapporter problem","CTX_COPY":"Kopier","CTX_PASTE":"Indsæt","CTX_CLEAR":"Ryd","CTX_CLEAR_RECENT_SEARCHES":"Ryd seneste søgninger","HELLO_THERE":"Hej","HOPE_YOU_ENJOY":"Vi håber du nyder Stremio og at det er et af dine favorit programmer allerede!","WHO_ARE_WE":"Hvem er vi? Vi er holded bag - to gutter som har arbejdet hårdt de sidste 3 år, med et samlet mål - at gøre dette produkt bedre og bedre.","SUPPORT_US":"Hvis du kan lide Stremio, hvis Stremio er værdifuldt for dig - støt os!","SPREAD_THE_WORD":"Del med dine venner nu, spred ordet omkring Stremio","MORE_PEOPLE":"Nu flere folk der bruger Stremio, nu bedre vil det blive!","SEND_A_LINK":"Eller send et link til vores hjemmeside","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},1145:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"Fernsehkanal","TYPE_channel":"Kanal","TYPE_other":"Andere","TYPE_movie_PL":"Filme","TYPE_series_PL":"Serien","TYPE_tv_PL":"Fernsehkanäle","TYPE_channel_PL":"Kanäle","TYPE_other_PL":"Andere","TYPE_ALL":"All","VIDEO":"Video","BACK":"Zurück","MORE":"Mehr","DONE":"Erledigt","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Entdecken","Board":"Tafel","Library":"Bibliothek","My Library":"Meine Bibliothek","Calendar":"Kalender","NOTIFICATION_ONLINE":"Sie sind jetzt online","NOTIFICATION_OFFLINE":"Sie sind gerade offline.","INTERNET_CONNECTION":"Netzwerkverbindung","STORAGE_FULL_TITLE":"Warnung: Speicher voll!","STORAGE_FULL_TEXT":"Stremio kann Ihre Einstellungen, Präferenzen oder Anmeldeinformationen nicht speichern. Erwägen Sie, Stremio neu zu starten oder zu installieren.","SEARCH":"Suche","SEARCH_NO_RESULTS":"Es wurden keine Ergebnisse gefunden","SEARCH_EXPLANATION_CONTENT":"Suche nach Filmen, Serien, YouTube- und Fernsehkanälen","SEARCH_EXPLANATION_PEOPLE":"Suche nach Schauspielern, Regisseuren und Autoren","SEARCH_PASTE_LINKS":"HTTP- und Magnet-Links einfügen","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Zur Bibliothek hinzufügen","REMOVE_FROM_LIB":"Aus Bibliothek entfernen","ADDED_TO_LIB":"Zur Bibliothek hinzugefügt","REMOVED_FROM_LIB":"Aus der Bibliothek entfernt","TRAILER":"Filmvorschau","WATCH_TRAILER":"Filmvorschau ansehen","WATCH_NOW":"Jetzt ansehen","SHOW":"Anzeigen","SHOW_MOVIE":"Zeige Film","WATCH_RANDOM":"Zufälliges ansehen","IMDB_RATING":"IMDb-Bewertung","YEAR":"Jahr","DIRECTOR":"Regisseur","WRITER":"Autor","LEAD_ACTORS":"Hauptdarsteller","CAST":"Besetzung","CREW":"Crew","SHOW_MORE_CAST":"Mehr anzeigen »","AIRED":"Ausgestrahlt","SEASONS":"Staffeln","GENRE":"Genre","CATALOG":"Katalog","SUMMARY":"Zusammenfassung","SHOW_MORE":"Zeige mehr","SIMILAR":"Ähnlich","UPCOMING":"Bevorstehend","ENDED":"Beendet","DURATION":"Dauer","FEATURED":"Vorgestellt","METADATA":"Metadaten","CATEGORY":"Kategorie","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Videos suchen","SEARCH_PLACEHOLDER":"Magnet-Link suchen oder einfügen","ADDON":"Addon","ADDONS":"Addons","OFFICIAL":"Offiziell","ADDONS_OFFICIAL":"Offizielle Stremio-Addons","ADDONS_POPULAR":"In Ihrer Gegend beliebt","ADDON_FREE":"frei","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abonnement","ADDON_STREAM_GEORESTRICTED":"In Ihrer Gegend nicht verfügbar","ADDON_STREAM_OFFLINECACHE":"Offline-Zwischenspeicher","ADDON_STREAM_LOCALFILE":"Lokale Datei","SHARE_ADDON":"Addon teilen","AVAILABLE_STREAMS":"Verfügbare Streams","NO_STREAM":"Keine Streams verfügbar","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Um mehr Streams bitte weitere Addons installieren","STREAM_NOT_SUPPORTED":"Ausgewählter Stream wird auf dieser Plattform nicht unterstützt.","ADDON_CATALOGUE":"Alle Addons anzeigen »","ADDON_CATALOGUE_MORE":"Mehr Addons »","REPO_ADDED":"Repositorium hinzugeügt","ADDON_REPO_EXIST_ERR":"Dieses Addons-Repositorium existiert bereits","ADDON_REPO_ERR":"Beim Hinzufügen des Repositoriums ist ein Fehler aufgetreten","ADDON_ADD_ERR":"Beim Hinzufügen des Addons ist ein Fehler aufgetreten","ERR_ADDON_PROTECTED":"Geschütztes Addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Etwas ist schief gelaufen - die Authentifizierung ist möglicherweise fehlgeschlagen","ERR_NOT_COLLECTION_URL":"Keine Sammlungs-URL","ERR_NOT_ADDON_URL":"Keine Addon-URL","ERR_DETECTFROMURL":"Kann nicht aus der URL erkannt werden","ADDON_DUPLICATE_WARNING":"Warnung: dupliziertes Addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Daten exportieren","ADDON_PULL_FAILED":"Herunterladen des Addons fehlgeschlagen","REFRESH_ON_CLICK":"Hier klicken, um es erneut zu versuchen","STILL_IN_THEATER":"Film immer noch im Kino","WATCH_IN_CINEMA":"Sehen Sie ihn in Ihrem lokalen Kino an","IN_THEATER":"Im Kino","GET_TICKETS":"Karten besorgen","UPCOMING_EPISODE":"Bevorstehende Folge","UPCOMING_EPISODE_MESSAGE":"Diese Folge wird ausgestrahlt am","MISSING_DATE_EPISODE":"Für diese Folge gibt es noch kein Datum","MISSING_DATE_EPISODE_MESSAGE":"Diese Folge wurde möglicherweise noch nicht ausgestrahlt","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Fügen Sie es zu Ihrer Bibliothek hinzu, um benachrichtigt zu werden, sobald es verfügbar ist.","GET_NOTIFIED_WHEN_AVAILABLE":"Sie werden benachrichtigt, sobald es verfügbar ist.","WARNING_STREAMING_SERVER":"Warnung: lokaler Streaming-Server nicht gefunden. Streaming von lokalen Dateien, YouTube und BitTorrent wird nicht verfügbar sein.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warnung: Dieses Video wird von Ihrer Hardware möglicherweise nicht unterstützt. Denken Sie daran, dass die Wiedergabe langsam sein könnte.","PLAYER_ERROR":"Hoppla, Abspielerfehler","PLAYER_ERROR_LOOKSLIKE":"Es sieht aus wie","PLAYER_ORIENTATION":"Abspielerausrichtung","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Gesperrt","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Abspielerausrichtung im Querformat fixiert","PLAYER_ORIENTATION_SENSOR":"Abspielerausrichtung automatisch (Sensor)","PLAYER_PLAYBACK_SPEED":"Wiedergabegeschwindigkeit","PLAYER_PLAYBACK_ERROR":"Wiedergabefehler, bitte versuchen Sie es erneut","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unbekannter Fehlerr","PLAYER_PLAYBACK_ERROR_DEFAULT":"Entschuldigung, dieses Video kann nicht von {{productName}} abgespielt werden.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Als Nächstes im Programm","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Ablehnen","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Jetzt ansehen","STREAMING_FROM":"streamt von","CASTING_TO":"Casting nach","NETWORK_STATUS":"Netzwerkstatus","STREAM_SPEED":"Stream-Geschwindigkeit:","STREAM_BUFFERED":"Gepuffert:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Aktiv:","PEERS_CONNECTED":"Verbunden:","PEERS_WAITING":"Warten:","TRANSCODING_WARNING":"Warnung: Video wird transkodiert.","STREAM_LOADING":"Ladevorgang...","PLAYING_LOCAL":"Wiedergabe aus lokaler Datei","PLAYING_CACHE":"Wiedergabe aus Zwischenspeicher","WRONG_SUBS":"Falsche Untertitel?","ERR_SUBS_LOADING_TITLE":"Fehler beim Laden der Untertitel","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Die folgenden Untertitel-Addons sind fehlgeschlagen","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Wählen Sie ein Gerät aus, auf dem Sie zuschauen möchten","NO_CAST_DEVICES":"Keine Casting-Geräte vorhanden.","NO_SETTINGS":"Keine Einstellungen verfügbar","PHONE_TABLET":"Telefon / Tablet","SUBTITLES":"Untertitel","SUBTITLES_CHANGE":"Untertitel ändern für ","SUBTITLES_CHANGE_NONE":"Es gibt keine anderen Untertitel für diese Sprache, Entschuldigung.","SUBTITLES_CHANGE_ACIVE":"Derzeit sind Untertitel #{{subtitlesDialog.activeIdx + 1}} aktiviert. Klicken Sie auf \\"Fortsetzen\\", um Untertitel #{{subtitlesDialog.pickedIdx + 1}}. zu aktivieren","SUBTITLES_OR":"Alternativ,","SUBTITLES_ADJUST_DELAY":"Untertitelverzögerung anpassen:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Oder verwenden Sie die Tasten G / H zum Anpassen während der Wiedergabe.","SUBTITLES_ADJUST_DELAY_TIP":"TIPP: Sie können die Tasten G / H zum Anpassen während der Wiedergabe verwenden.","SUBTITLES_DELAY":"Untertitelverzögerung:","SUBTITLES_LOADING":"Untertitel werden geladen...","SUBTITLES_UNAVAILABLE":"Keine externen Untertitel verfügbar","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Standard-Sprache","DEFAULT_SECONDARY_LANGUAGE":"Standard-Sekundärsprache","SEASON":"Staffel","EPISODE":"Episode","SPECIAL":"Special","SORT":"sortieren","SORT_BY":"Sortieren nach","FILTER":"filtern","SORT_TRENDING":"im Trend","SORT_RECENT":"kürzlich","SORT_ALPHABET":"a-z","SORT_RATING":"Bewertung","SORT_WATCHED":"gesehen","SORT_YEAR":"Jahr","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Neu für Sie","New Episodes":"Neue Episoden","New Videos":"Neue Videos","Recommendations":"Empfehlungen","LIBRARY_RESUME":"Fortsetzen","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"Ablehnen","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Ausgewählt","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oscar-Gewinner","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Dieses Addon liefert leeren Inhalt.","DISCOVER_ADULT_WARNING":"Diese Inhalte sind nur für Erwachsene sichtbar. Sind Sie über 18?","DISCOVER_NOADDON_WARNING":"Warnung: Für diesen Typ ist kein Stremio-Addon aktiv. Gespeicherte Elemente werden angezeigt, nichts wird hier aktualisiert.","DISCOVER_LOAD_ERR":"Diese Inhalte konnten nicht geladen werden, da ein Fehler vorlag.","DISCOVER_ADDON_UNINSTALLED":"Diese Inhalte sind nicht mehr verfügbar. Möglicherweise wurde das Addon deinstalliert.","UNINSTALL_THIS_ADDON":"Dieses Addon deinstallieren","ERR_ADDON_NOT_INSTALLED":"Dieses Addon ist nicht installiert. Jetzt installieren?","DETAIL_RECEIVE_NOTIF_SERIES":"Benachrichtigungen über neue Episoden erhalten","DETAIL_RECEIVE_NOTIF_VIDEOS":"Benachrichtigungen über neue Videos erhalten","SIDEBAR_SHOW_STREAMS":"Streams zeigen","RELAUNCH":"Jetzt neu starten!","UPGRADE":"Neue Version ist verfügbar! Aktualisieren Sie auf die neueste Stremio-Version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Aktualisieren Sie Ihre Stremio-Version","MANUAL_UPDATE_LINE1":"Sie nutzen eine veraltete Version von Stremio, was nicht empfohlen wird.","MANUAL_UPDATE_LINE2":"Bitte aktualisieren Sie schnellstmöglich.","BUTTON_UPDATE_LATTER":"Nicht jetzt","BUTTON_UPDATE_NOW":"Aktualisieren","ANONYMOUS_USER":"Anonymer Benutzer","DONT_HAVE_ACC":"Sie haben kein Konto?","HAVE_ACC":"Sie haben bereits ein Konto?","PASSWORD":"Passwort","PASSWORD_CONFIRM":"Passwort bestätigen","EMAIL":"E-Mail","FB_LOGIN":"Mit Facebook anmelden","FB_NOTHINGSHARED":"Ohne Ihre Berechtigung wird nichts geteilt","FB_NOPOST":"Wir werden nichts in Ihrem Namen posten","OR":"oder","I_ACCEPT":"Ich akzeptiere die","I_ACCEPT_BY_CLICKING":"Wenn Sie auf die obige Schaltfläche klicken, bestätigen Sie, dass Sie die ","TOS":"Geschäftsbedingungen annehmen","MUST_ACCEPT_TERMS":"Sie müssen die Bedingungen annehmen","PASSWORDS_NOMATCH":"Passwörter stimmen nicht überein","SIGN_UP":"Registrieren","SIGN_UP_EMAIL":"Mit E-Mail registrieren","CLICK_TO_SIGN_UP":"Klicken Sie hier, um sich zu registrieren.","LOG_IN":"Anmelden","LOG_OUT":"Abmelden","EXIT_FULLSCREEN":"Vollbildmodus verlassen","ENTER_FULLSCREEN":"Vollbildmodus aktivieren","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Hilfe und Feedback","TERMS_OF_SERVICE":"Geschäftsbedingungen","PRIVACY_POLICY":"Datenschutzbestimmungen","ABOUT_STREMIO":"Über Stremio","USER_PANEL":"Nutzerpanel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gast-Anmeldung","GUEST_LOGIN_NOTICE":"Gast-Anmeldung wird nicht empfohlen. Mit einer regelmäßigen Anmeldung kann Stremio Ihre Bibliothek synchronisieren und Sie können Benachrichtigungen für Ihre Lieblingserien/-kanäle erhalten. Sind Sie sicher, dass Sie fortfahren möchten?","GUEST_LOGIN_NOTICE_2":"Gast-Anmeldung wird nicht empfohlen - Sie werden keine Bibliotheks- und Tafelbenachrichtigungen synchronisiert haben, die wichtige Stremio-Funktionen sind. Sind Sie sicher, dass Sie fortfahren möchten?","CLICK_HERE":"Klicken Sie hier","WRONG_PASSWORD":"Falsche E-Mail-Adresse oder Passwort. Falls Sie Ihr Passwort vergessen haben, ","SET_A_PASS":"Passwort festlegen","RESET_PASSWORD":"Passwort zurücksetzen","FORGOT_PASSWORD":"Passwort vergessen?","EMAIL_USED_WITH_FB":"Diese E-Mail-Adresse wurde mit einer Facebook-Anmeldung verwendet.","INVALID_EMAIL":"Bitte geben Sie eine gültige E-Mail-Adresse ein","INVALID_PASSWORD":"Bitte geben Sie ein gültiges Passwort ein","CONN_ERR":"Verbindungsfehler - bitte versuchen Sie es später noch einmal.\\n\\nWenn dies weiterhin besteht, deaktivieren Sie Firewalls/Antivirus-Software (vor allem Bitdefender).","IMPORT_FROM_GUEST":"Bibliothek von Ihrem Gastkonto importieren","RECEIVE_UPDATES_EMAIL":"Aktualisierungen in Ihrer E-Mail von Stremio erhalten","LOGIN_FAILED":"Anmeldung fehlgeschlagen.","SIGNUP_FAILED":"Registrierung fehlgeschlagen.","SEARCH_FAILED":"Suche fehlgeschlagen","EMAIL_USED":"Diese E-Mail-Adresse wird bereits verwendet","WAITING_FB_LOGIN":"Anmeldung mit Facebook...","EXTERNAL_PLAYER_TITLE":"Wiedergabe im externen Player","EXTERNAL_REMEMBER_PLAYER":"Möchten Sie Ihre Auswahl in Erinnerung behalten?","EXTERNAL_ALWAYS_PLAY":"Ja","EXTERNAL_ONLY_ONCE":"Nein","BEST_FIT":"Best Fit","FIT_SCREEN":"in Bildschirm einpassen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Erzählen Sie uns, was Sie mögen","INTRO_TASTE_LONG":"Erzählen Sie uns, was Sie gerne sehen möchten","INTRO_TASTE_PICK":"Wählen Sie {{interestsRemaining}} Interessen aus","INTRO_TASTE_PICK_MORE":"Wählen Sie {{interestsRemaining}} weitere Interessen aus","INTRO_TASTE_HELP_US":"Helfen Sie uns, mehr über Sie zu erfahren.","INTRO_TASTE_CHOOSE_THESE":"Wählen Sie einige davon:","INTRO_TASTE_CHOOSE_MIN":"Wählen Sie mindestens 3 Kategorien aus","INTRO_TASTE_CHOOSE_MIN_ERR":"Sie müssen mindestens 3 Kategorien auswählen!","INTRO_TASTE_LIFESTYLE":"Lebensstil","INTRO_TASTE_SPORTS":"Sport","INTRO_TASTE_FOOD_HEALTH":"Essen & Gesundheit","INTRO_TASTE_BEAUTY_FASHION":"Schönheit & Mode","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Spielen","INTRO_TASTE_SCIENCE_EDU":"Wissenschaft & Bildung","INTRO_TASTE_MUSIC":"Musik","INTRO_TASTE_TRAVEL":"Reise","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Kino","ADDON_NOT_SUPPORTED":"Ausgewähltes Addon wird auf dieser Plattform nicht unterstützt.","ADDON_DISCLAIMER":"Die Verwendung von Drittanbieter-Addons unterliegt immer Ihrer Verantwortung und dem Recht der Gerichtsbarkeit, in der Sie sich befinden.","ADDON_ACTIVATE":"Dieses Addon aktivieren?","ADDON_REPO_ADD":"Addon-Repositoriums-URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Was gibt\'s Neues","BUTTON_CONTINUE":"Fortsetzen","BUTTON_ACTIVATE":"Aktivieren","BUTTON_ACTIVATED":"Aktiviert","BUTTON_CANCEL":"Abbrechen","BUTTON_SUBMIT":"Senden","BUTTON_DISMISS_ALL":"Alle ablehnen","BUTTON_VIEW_ALL":"Alle ansehen","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Ihre Bibliothek sieht leer aus. Finden Sie heraus, wie nützlich sie ist :) ","HOW_START":"So können Sie anfangen:","LIB_EMPTY_CAL":"Ihr Kalender zeigt die Serien in Ihrer Bibliothek an.","HOW_START_CAL":"So können Sie Serien hinzufügen:","LIB_EMPTY_BOARD":"Tafel zeigt Benachrichtigungen & Empfehlungen zu Ihrer Bibliothek an.","HOW_START_BOARD_WAIT":"Bitte fügen Sie ein paar Serien oder Kanäle zu Ihrer Bibliothek hinzu und geben uns ein paar Minuten zum Verarbeiten :)","HOW_START_BOARD":"So können Sie Serien & Filme zu ihr hinzufügen:","IMPORT_FB":"Importieren Sie Dinge von Facebook, die Sie mögen","IMPORT_TRAKT":"Importieren Sie Ihre Medienbibliothek von Trakt","IMPORT_DISCOVER":"Finden Sie interessante Sachen von Entdecken","IMPORT_DISK":"Importieren Sie Filme oder Shows, die Sie auf Ihrer lokalen Festplatte haben","PLEASE_CREATE_ACC":"Bitte erstellen Sie ein Konto, um das Synchronisieren der Bibliothek & Tafel zu ermöglichen.","IMPORT_DISCOVER_SIGNUP":"Registrieren Sie sich und finden Sie interessante Sachen von Entdecken","IMPORT_DISK_SIGNUP":"Registrieren Sie sich und importieren Sie Filme oder Shows, die Sie auf Ihrer lokalen Festplatte haben","LIB_EMPTY_CLOUD":"Cloud-Bibliothek","LIB_EMPTY_CLOUD_DESC":"Persönliche Cloud-Bibliothek auf allen Geräten synchronisiert","LIB_EMPTY_EARLY":"Früher Vogel","LIB_EMPTY_EARLY_DESC":"Erhalten Sie Benachrichtigungen für neue Episoden","LIB_EMPTY_PERSONAL":"Persönlich","LIB_EMPTY_PERSONAL_DESC":"Holen Sie sich persönliche Empfehlungen","LIB_EMPTY_CALENDAR_DESC":"Planen Sie Ihren persönlichen Anschau-Kalender","LIB_EMPTY_ALL":"Registrieren Sie sich, um all dies zu bekommen:","LIB_EMPTY_BEST":"Registrieren Sie sich, um das Beste von Stremio zu bekommen","LIB_EMPTY_OTHER":"Registrieren Sie sich, um Kalender & andere tolle Funktionen zu aktivieren","CALENDAR_ADDED":"Der Stremio-Kalender wurde zu Ihrem Standard-Desktop-Kalender hinzugefügt.","CALENDAR_ADDED_MSG":"Wenn dies nicht funktioniert, fügen Sie diese URL bitte manuell zu Ihrer Kalenderanwendung hinzu","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt-Fehler","TRAKT_REQUIRES_LOGIN_MSG":"Sie müssen sich anmelden","SETTINGS_LABEL":"Einstellungen","SETTINGS_NAV_GENERAL":"Algemein","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Verknüpfungen","SETTINGS_SHORTCUT_RELOAD_APP":"App neu laden","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Lautstärke erhöhen","SETTINGS_SHORTCUT_VOLUME_DOWN":"Lautstärke verringern","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Seitenleiste umschalten","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Beim Start ausführen","SETTINGS_VLC_DEFAULT":"Mit VLC wiedergeben","SETTINGS_UI_LANGUAGE":"Sprache des UI","SETTINGS_FULLSCREEN_EXIT":"Esc-Taste beendet den Vollbildmodus","SETTINGS_GAMEPAD":"Gamepad-Unterstützung aktivieren","SETTINGS_CLOSE_WINDOW":"Anwendungen beenden, wenn das Fenster geschlossen wird","SETTINGS_SUBTITLES_LANGUAGE":"Standardauswahl für die Untertitelsprache","SETTINGS_SUBTITLES_SIZE":"Standardgröße der Untertitel","SETTINGS_SUBTITLES_BACKGROUND":"Hintergrund der Untertitel","SETTINGS_SUBTITLES_COLOR":"Farbe der Untertitel","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Umrandungsfarbe der Untertitel","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Hintergrundfarbe der Untertitel","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Nächste Episode automatisch wiedergeben","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Größe des Fensters vor der Wiedergabe automatisch ändern","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming-Server ist verfügbar.","SETTINGS_SERVER_UNAVAILABLE":"Streaming-Server ist nichtverfügbar.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Immer neueste Beta verwenden","SETTINGS_IMPORT_FB":"Von Facebook importieren","SETTINGS_IMPORT_DISK":"Von lokaler Festplatte importieren","SETTINGS_IMPORT_TRAKT":"Von Trakt importieren","SETTINGS_PAUSE_MINIMIZED":"Wiedergabe pausieren, wenn die Anwendung minimiert wird","SETTINGS_HWDEC":"Hardwarebeschleunigte Dekodierung","SETTINGS_BACKGROUND":"Hintergrund-Wiedergabe","SETTINGS_SUBSCRIBE_CALENDAR":"Kalender abonnieren","SETTINGS_REQ_EXPORT":"Datenexport anfordern","SETTINGS_ACC_DELETE":"Kontolöschung anfordern","SETTINGS_CHANGE_PASSWORD":"Passwort ändern","SETTINGS_TOS":"Nutzungsbedingungen","SETTINGS_SUPPORT":"Kundendienst kontaktieren","SETTING_LANGUAGE":"Sprache","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Von Trakt.tv abmelden","SETTINGS_SCAN_FOR_REMOTE":"QR-Code zum Öffnen der Fernbedienung scannen","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop-Benachrichtigungen","SETTINGS_DATA_SAVER":"Datenretter","SETTINGS_LANGUAGE_INTERFACE":"Oberfläche","SETTINGS_LANGUAGE_SUBS":"Standarduntertitel","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"Konto","SETTINGS_VERSION":"Version","SETTINGS_MPV_WINDOW":"Abspieler in einem separaten Fenster starten (erweitert)","SETTINGS_PLAY_IN_EXTERNAL":"Video immer im externen Player starten","SETTINGS_STORAGE_BUTTON":"Lokalen Speicher leeren","SETTINGS_STORAGE_MODAL_TITLE":"Sind Sie sicher?","SETTINGS_STORAGE_MODAL_MESSAGE":"Dies wird den lokalen Speicher leeren und Sie auslogggen.","SETTINGS_HWDEC_PICKER":"Einstellung für hardwarebeschleunigte Dekodierung wählen","SETTINGS_HW_AUTOMATIC":"Automatik","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Dekodier-Beschleunigung","SETTINGS_HW_FULL":"Vollständige Beschleunigung","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Schwarze Hintergrundfarbe verwenden","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Eingebettete Untertitel","MOBILE_PRIVACY_POLICY":"Datenschutzbestimmungen","MOBILE_CRASH_REPORTING":"Absturzbericht","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Wiedergabegeschwindigkeit wählen","MOBILE_EMPTY_LIBRARY":"Ihre Bibliothek ist leer","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"Ich bin damit einverstanden, von Stremio Marketingmitteilungen zu erhalten","QUIT":"Beenden","CONNECTED":"Verbunden","AUTHENTICATE":"Authentifizieren","CACHING":"Zwischenspeicherung","SETTINGS_CACHING_DRIVE":"Zwischenspeicherungslaufwerk","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Datenzwischenspeicherung","MAGNET_PARSING":"Magnet-Link wird geparst","January":"Januar","February":"Februar","March":"März","April":"April","May":"Mai","June":"Juni","July":"Juli","August":"August","September":"September","October":"Oktober","November":"November","December":"Dezember","Monday":"Montag","Tuesday":"Dienstag","Wednesday":"Mittwoch","Thursday":"Donnerstag","Friday":"Freitag","Saturday":"Samstag","Sunday":"Sonntag","Action":"Action","Comedy":"Comedy","War":"Krieg","Family":"Familie","Animation":"Animation","Adventure":"Abenteuer","Fantasy":"Fantasy","Crime":"Krimi","Mystery":"Mystery","Romance":"Romantik","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Musik","Biography":"Biografie","Documentary":"Dokumentation","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Nachrichten","History":"Geschichte","Game-Show":"Spielshow","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Unterhaltung","Gaming":"Spielen","From TV":"Vom Fernsehen","Lifestyle":"Lebensstil","Science & Education":"Wissenschaft & Bildung","Cooking & Health":"Kochen & Gesundheit","Beauty & Fashion":"Schönheit & Mode","Sports":"Sport","News & Politics":"News & Politik","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automobil","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Filme","Uk Live Tv":"Uk Live Tv","Fashion":"Mode","Business News Radio":"Business News Radio","Business Tv":"Geschäftsfernsehen","Cars & Auto":"Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lebensstilradio","News Tv":"News Tv","Food And Wine":"Essen und Wein","Latino Tv":"Latino Tv","Shopping Tv":"Verkaufsfernsehen","Religion":"Religion","Kids":"Kinder","Body & Soul":"Körper & Seele","Education":"Bildung","Indian Tv":"Indian Tv","Extreme Sports":"Extremsport","Middle Eastern Tv":"Fernsehen des Mittleren Ostens","Celebrity Tv":"Promifernsehen","Science Tv":"Wissenschaftsfernsehen","Bikini babe":"Bikinischönheit","Outdoors":"Outdoors","German Tv":"Deutsches Fernsehen","French Tv":"Französisches Fernsehen","Italian Tv":"Italienisches Fernsehen","Gamer Tv":"Spielerfernsehen","Travel":"Reise","Asian Tv":"Asiatisches Fernsehen","Entertainment":"Unterhaltung","News Radio":"Nachrichtenradio","Music Radio":"Musikradio","Language Learning":"Sprachen lernen","Science Radio":"Wissenschaftsradio","Tech Radio":"Tech Radio","Science & Technology Vod":"Abrufvideo Wissenschaft & Technologie","new video":"neues Video","new episode":"neue Episode","new movie":"neuer Film","recommended":"empfohlen","we recommend":"wir empfehlen","offer of the day":"Angebot des Tages","news":"Nachrichten","music video":"Musikvideo","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Benachrichtigungen ablehnen","CTX_DISMISS_ALL":"Alles ablehnen","CTX_SHARE":"Teilen","CTX_COPY_SHARE_LINK":"Freigabelink kopieren","CTX_COPY_MAGNET_LINK":"Magnet-Link kopieren","CTX_COPY_STREAM_LINK":"Stream-Link kopieren","CTX_DOWNLOAD_VIDEO":"Dieses Video herunterladen","CTX_DOWNLOAD_SUBS":"Untertitel herunterladen","CTX_VIEW_ON_YOUTUBE":"Auf YouTube ansehen","CTX_SHOW":"Anzeigen","CTX_PLAY":"Wiedergabe","CTX_PLAY_IN":"Wiedergabe in","CTX_PLAY_ON":"Wiedergabe auf","CTX_WATCH_ON":"Angesehen am","CTX_WATCH":"Ansehen","CTX_WATCHED":"Angesehen","CTX_WATCH_BEGINNING":"Von Anfang an ansehen","CTX_WATCH_MOBILE":"Auf einem mobilen Gerät ansehen","CTX_REWIND":"Zurückspulen zum Anfang","CTX_MARK_WATCHED":"Als angesehen markieren","CTX_MARK_NON_WATCHED":"Als nicht angesehen markieren","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Rest als angesehen markieren","CTX_UNMARK_REST":"Rest als nicht angesehen markieren","CTX_RECEIVE_NEW_NOTIF":"Neue Benachrichtigungen erhalten","CTX_REMOVE_CACHE":"Aus Zwischenspeicher entfernen","CTX_REMOVE_CACHE_EP":"Episode aus Zwischenspeicher entfernen","CTX_OPEN_CONTAINING":"Enthaltenden Ordner öffnen","CTX_REMOVE":"Aus Bibliothek entfernen","CTX_AVAILABLE_OFFLINE":"Offline verfügbar","CTX_PAUSED":"Pausiert","CTX_ALWAYS_ON_TOP":"Immer oben","CTX_FULLSCREEN":"Vollbild","CTX_WRONG_SUBS":"Falsche Untertitel?","CTX_REPORT_ISSUES":"Problem melden","CTX_COPY":"Kopieren","CTX_PASTE":"Einfügen","CTX_CLEAR":"Löschen","CTX_CLEAR_RECENT_SEARCHES":"Kürzliche Suchanfragen löschen","HELLO_THERE":"Hallöchen","HOPE_YOU_ENJOY":"Wir hoffen, dass Sie Stremio genießen und es schon eine Ihrer Lieblings-Apps ist!","WHO_ARE_WE":"Wer sind wir? Wir sind das Team dahinter - zwei Jungs, die jeden Tag seit den letzten 3 Jahren hart arbeiten, um dieses Produkt besser und besser zu machen.","SUPPORT_US":"Wenn Sie Stremio gerne verwenden, wenn Stremio für Sie wertvoll ist - sagen Sie es weiter!","SPREAD_THE_WORD":"Teilen Sie es jetzt mit Ihren Freunden, erzählen Sie Stremio weiter","MORE_PEOPLE":"Je mehr Menschen Stremio benutzen, desto besser wird es!","SEND_A_LINK":"Oder senden Sie einen Link zu unserer Website","TIP_LOCALFILES":"Tipp: Sie können lokale Videodateien per Drag & Drop in Stremio verschieben","ADDON_MY":"Meine Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Offizielle Addons","ADDON_REPOS":"Addon-Repositorien","ADDON_SEARCH":"Addons suchen","ADDON_INSTALL":"Installieren","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Deinstallieren","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installiert","ADDON_INSTALLED_MSG":"Addon installiert!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unbekannt","ADDON_ERR":"Addon-Installationsfehler!","ADDON_DISCONNECTED":"Getrennt","ADDON_APP_MISSING":"die App für diese Quelle ist nicht installiert. Möchten Sie sie jetzt installieren?","ADDON_APP_INSTALL":"Jetzt installieren","ADDON_PAGE":"Addon-Seite","ADDON_TOP_CONTENT":"Bestes aus diesem Addon","ADDON_PROVIDES":"Dieses Addon gibt Ihnen:","ADDON_WATCH":"#{types} jetzt ansehen!","ADDON_WATCH_FREE":"#{types} jetzt KOSTENLOS ansehen!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Mehr #{types} in Entdecken","ADDON_PROVIDES_STREAMS":"#{types} ansehen","ADDON_PROVIDES_STREAMS_FREE":"#{types} KOSTENLOS ansehen","ADDON_PROVIDES_SUBTITLES":"Untertitel für #{types}","ADDON_CANTDETECT":"Wir konnten kein laufendes Stremio erkennen, deshalb konnten wir nicht erkennen, welche Addons Sie installiert haben.","ERR_NO_META":"Keine Informationen dazu gefunden ","ERR_GETTING_META":"Fehler beim Abrufen von Informationen darüber.","ERR_CANT_PARSE_MAGNET":"Kann Magnet nicht parsen","ERR_NO_MAGNET_INFOHASH":"Kein gültiger Info-Hash für Magnet","ERR_NO_FILE_PATH":"Kann keine Anfrage ohne Pfad zur Datei senden","ERR_NO_TORRENT":"Kein Torrent zurückgegeben","ERR_NO_SUPPORTERD_FILES":"Keine unterstützten Dateien gefunden","ERR_OPENING_FILES":"Externe Dateien konnten nicht geöffnet werden","ERR_INVALID_LINK":"Ungültiger Link","ERR_REGISTERED_ONLY":"Diese Option ist nur für registrierte Benutzer verfügbar.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Weiter ansehen","BOARD_EXPLANATION_RECOMMENDATIONS":"Filme, die speziell für Sie ausgewählt wurden.
Dieser Film ist eine Beispielempfehlung.","BOARD_EXPLANATION_EPISODES":"Neue Episoden Ihrer Lieblingsserie kommen hierher.
Fügen Sie Serien, denen Sie folgen, zu Ihrer Bibliothek hinzu.","BOARD_EXPLANATION_VIDEOS":"Neue Episoden Ihrer Lieblingskanäle kommen hierher.
Fügen Sie YouTube-Kanäle, denen Sie folgen, zu Ihrer Bibliothek hinzu.","WEBSITE_SLOGAN_WATCH":"Sofort ansehen","WEBSITE_SLOGAN_ALL":"Alle Videoinhalte, die Sie an einem Ort genießen","WEBSITE_SLOGAN_NEW":"Alles, was Sie sehen können","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Ansehen von","WEBSITE_DOWNLOAD":"Jetzt herunterladen","WEBSITE_DOWNLOAD_FOR":"Jetzt herunterladen für","WEBSITE_IS_DESKTOP":"Stremio ist eine Desktop-Anwendung, öffnen Sie diese Seite auf Ihrem PC und laden Sie sie herunter","WEBSITE_DESKTOP_DEMO_VID":"Desktop-Demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Funktionen","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technologie","WEBSITE_PAGE_CREATE_ADDON":"Addon erstellen","WEBSITE_PAGE_CONTACTS":"Kontakte","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filme","WEBSITE_TYPE_series_PL":"Serien","WEBSITE_TYPE_tv":"Live-Fernsehen","WEBSITE_TYPE_channel":"Kanäle","WEBSITE_STREMIO_WHAT_IS":"Stremio ist eine App, die Ihnen hilft, Ihre Lieblingsvideos, Filme, Fernsehserien und Fernsehkanäle zu organisieren und sofort anzusehen.","WEBSITE_FEATURES_WATCH":"Sofort in HD ansehen","WEBSITE_FEATURES_WATCH_DETAIL":"Klicken und geben Sie Ihre Lieblingsfilme, Fernsehshows, Videos und Fernsehkanäle wieder.","WEBSITE_FEATURES_SUBS":"Automatische Untertitel","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio holt automatisch synchronisierte Untertitel für Ihre Sprache.","WEBSITE_FEATURES_SUBS_LABEL":"Sie sind dran, Chef.","WEBSITE_FEATURES_CAST":"Auf Fernseher & mobilen Geräten wiedergeben","WEBSITE_FEATURES_CAST_DETAIL":"An AppleTV, Chromecast, Smart TV (DLNA/UPnP) und mobile Geräte übertragen.","WEBSITE_LIB":"Genießen Sie Ihre persönliche synchronisierte Bibliothek auf all Ihren Geräten","WEBSITE_LIB_COLLECT":"Von Stremio sammeln","WEBSITE_LIB_IMPORT":"Von Facebook importieren","WEBSITE_LIB_LOCAL":"Von Ihrer lokaler Festplatte hinzufügen","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Empfohlene Fernsehshow","WEBSITE_BOARD_TRENDING":"Film im Trend","WEBSITE_BOARD_NEW":"Neues Video","WEBSITE_BOARD_EPISODE":"Neue Episode","WEBSITE_BOARD_1":"Suchen Sie etwas Interessantes zum Anschauen? Holen Sie sich Empfehlungen nach Ihrem Geschmack!","WEBSITE_BOARD_2":"Lassen Sie sich benachrichtigen, wenn eine neue Episode Ihrer Lieblingssendung oder Ihres Lieblingskanals auf YouTube veröffentlicht wurde!","WEBSITE_BOARD_YOUTUBE":"Neue Videos von YouTube-Kanälen","WEBSITE_BOARD_EPISODES":"Neue Episoden von Serien, denen Sie folgen","WEBSITE_ADDONS":"Inhalts-Addons","WEBSITE_TECH_DETAIL":"Wir lieben Technologie, wir lieben verrückte Wissenschaft!\\nStremio verwendet die folgenden Open-Source-Technologien:","WEBSITE_TECH_WCJS":"WebChimera.js erlaubt Stremio die Wiedergabe jedes Videoformats mit guter Leistung.","WEBSITE_TECH_WCJS_EXTRA":"Wir sind Kern-Projektbeitragende","WEBSITE_TECH_ELECTRON":"Electron bietet eine innovative Plattform, um Stremio damit zu bauen.","WEBSITE_TECH_ELECTRON_EXTRA":"Wir sind Projektbeitragende","WEBSITE_TECH_LINVODB":"Eine Datenbank-Technologie, die sicherstellt, dass Ihre Daten organisiert und überall verfügbar sind, wo Sie sich anmelden.","WEBSITE_TECH_LINVODB_EXTRA":"Hauseigene Technologie","WEBSITE_CREATE_ADDON":"Erstellen Sie Ihr Addon","WEBSITE_CREATE_ADDON_DETAIL":"Haben Sie einen Dienst, der Videoinhalte anbietet? Wir helfen Ihnen, von den Funktionen von Stremio zu profitieren, indem wir Ihr Addon erstellen.","WEBSITE_CREATE_ADDON_BENEFITS":"Vorteile vom Erstellen eines Addons für Stremio","WEBSITE_P2P_BEAUTY":"Die Schönheit von Peer-to-Peer-Streaming","WEBSITE_P2P_1":"Zuverlässige und erschwingliche Full HD / 4K Video on Demand oder Live-Streaming","WEBSITE_P2P_2":"Verteilungsplattform für großartige Benutzererfahrung","WEBSITE_P2P_3":"Wir erstellen ein Addon, das Ihre genauen Bedürfnisse erfüllt","WEBSITE_P2P_CONTACT":"Interessiert? Sie sind herzlich eingeladen, uns zu kontaktieren.","WEBSITE_P2P_CONTACT_EXTRA":"Wir helfen Ihnen gerne bei der Integration Ihrer Inhalte mit Stremio!","WEBSITE_P2P":"Gelegentlich kommt eine Technologie, die den Namen des Spiels ändert. Wir haben viel Zeit und Mühe investiert, unsere Peer-to-Peer (P2P) Video-Streaming-Engine zu bauen, die eine hervorragende Leistung und Vielseitigkeit bietet, um sich jedem Anwendungsfall anzupassen.\\nKontaktieren Sie uns für DRM-fähiges P2P-Abrufvideo oder Live-Streaming.","WEBSITE_THOUGHTS":"Gedanken, die wir teilen:","WEBSITE_SPREAD":"Erzählen Sie über Stremio:","WEBSITE_CONTACT":"Kontaktieren Sie uns, wir freuen uns von Ihnen zu hören!","WEBSITE_OPENSOURCE":"Für unsere Open-Source-Projekte, gehen Sie zu unserem","WEBSITE_BITCOIN":"Bitcoin spenden:","WEBSITE_FAQ":"Häufig gestellte Fragen","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Fragen","WEBSITE_TOS":"Nutzungsbedingungen","WEBSITE_LEGAL":"Rechtlich","WEBSITE_PAGE_ABOUT":"Über","WEBSITE_PAGE_BECOME_PARTNER":"Werden Sie Partner","WEBSITE_ALL_YOU_CAN_WATCH":"Alles, was Sie ansehen können","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Was ist Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Genießen Sie es auf all Ihren Mediengeräten.","WEBSITE_DEVICES_COLLECT":"Von Stremio abholen","WEBSITE_DEVICES_IMPORT_FB":"Von Facebook importieren","WEBSITE_DEVICES_LOCAL":"Von lokalem Laufwerk hinzufügen","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"Wie gesehen am","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Über uns","WEBSITE_LINK_TECHNOLOGY":"Technologie","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"Mehr","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Beitragen","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & Mehr","WEBSITE_LINK_HELP":"Hilfezentrum","WEBSITE_LINK_CONTACTS":"Kontaktieren Sie uns","WEBSITE_LINK_TOS":"Geschäftsbedingungen","WEBSITE_LINK_PRAVACY":"Datenschutzerklärung","WEBSITE_SUBSCRIBE":"Abonnieren","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Ihre E-Mail","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Datenschutz & Rechtliches","WEBSITE_WHY":"Warum wir es tun","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Merkmale","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio für Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio für macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio für Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio für Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio für iOS","WEBSITE_CONTRIBUTE":"Beitragen","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Stremio übersetzen","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Inoffiziell","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Kontaktieren Sie uns","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Bitte geben Sie eine gültige E-Mail-Adresse ein!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Worauf bezieht sich Ihre Frage?","WEBSITE_CONTACT_US_Q_OS":"Was ist Ihr Betriebssystem?","WEBSITE_CONTACT_US_PH_EMAIL":"Ihre E-Mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Nachricht","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SENDEN","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technologie","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"oder","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Stremio übersetzen","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Helfen Sie uns, mehr über Sie zu erfahren.","LIFESTYLE":"Lebensstil","SPORTS":"Sport","FOOD_HEALTH":"Essen & Gesundheit","BEAUTY_FASHION":"Schönheit & Mode","NEWS":"Nachrichten","GAMING":"Spielen","SCIENCE_EDUCATION":"Wissenschaft & Bildung","MUSIC":"Musik","TRAVEL":"Reise","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Kino","CONTINUE":"Fortsetzen","SLOW_LOADING":"LANGSAMES LADEN?","I_GIVE_UP":"ICH GEBE AUF","LEARN_MORE":"Erfahren Sie mehr","POOR_SOURCE":"Diese Quelle ist schlecht verfügbar oder Ihre Internetverbindung ist nicht schnell genug","PICK_CATEGORIES_ERR":"Sie müssen mindestens 3 Kategorien auswählen","ADJUST_TIMING":"zeitliche Abstimmung anpassen mit ","ADJUST_SIZE":"Größe anpassen mit ","SEARCH_ANYTHING":"Sie können alles suchen...","ALL_CATEGORIES":"Alle","SEARCH_CATEGORIES":"Filme, Serien, YouTube & Fernsehen","SEARCH_PERSONS":"Schauspieler, Regisseure und Autoren","SEARCH_PROTOCOLS":"HTTP- & Magnet-Links","SEARCH_TYPES":"IMDB- / TVDB-Links","WATCHED":"Angesehen","SHOW_LESS":"Weniger anzeigen","LAST_SEARCHES":"Letzte Suchanfragen","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"WÄHLEN SIE VON DIESEN AUS:","NO_WEB_REMOTE":"Web-Fernbedienung konnte nicht geladen werden","STREMIO_OFFLINE":"Stremio ist offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warnung","MORE_INFO":"Weitere Informationen ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Wird geladen ...","STREMIO_TV_BACK_TO_LANGUAGES":"Zurück zu den Sprachen","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Das Stremio-Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi-Einrichtung","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Verbinden mit:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Passwort verwenden:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Größe anpassen","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Wiederholen","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Was ist Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},5158:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Ταινία","TYPE_series":"Σειρά","TYPE_tv":"Τηλ. κανάλι","TYPE_channel":"Κανάλι","TYPE_other":"Άλλο","TYPE_movie_PL":"Ταινίες","TYPE_series_PL":"Σειρές","TYPE_tv_PL":"Τηλ. κανάλια","TYPE_channel_PL":"Κανάλια","TYPE_other_PL":"Άλλα","TYPE_ALL":"All","VIDEO":"Βίντεο","BACK":"Πίσω","MORE":"Περισσότερα","DONE":"Τέλος","COPY":"Αντιγραφή","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Ανακάλυψη","Board":"Πίνακας","Library":"Περιήγηση","My Library":"Η βιβλιοθήκη μου","Calendar":"Ημερολόγιο","NOTIFICATION_ONLINE":"Είστε σε σύνδεση","NOTIFICATION_OFFLINE":"Είστε εκτός σύνδεσης","INTERNET_CONNECTION":"Σύνδεση δικτύου","STORAGE_FULL_TITLE":"Προειδοποίηση: Πλήρης αποθηκευτικός χώρος!","STORAGE_FULL_TEXT":"Το Stremio δεν θα μπορεί να αποθηκεύει τις ρυθμίσεις, τις προτιμήσεις ή τα στοιχεία σύνδεσής σας. Δοκιμάστε να κάνετε εκ νέου εκκίνηση ή εγκατάσταση του Stremio.","SEARCH":"Αναζήτηση","SEARCH_NO_RESULTS":"Δεν βρέθηκαν αποτελέσματα","SEARCH_EXPLANATION_CONTENT":"Αναζήτηση ταινιών, σειρών, καναλιών τηλεόρασης και YouTube","SEARCH_EXPLANATION_PEOPLE":"Αναζήτηση ηθοποιών, σκηνοθετών και σεναριογράφων","SEARCH_PASTE_LINKS":"Επικόλληση συνδέσμων HTTP και magnet","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Εισαγωγή στη βιβλιοθήκη","REMOVE_FROM_LIB":"Αφαίρεση από τη βιβλιοθήκη","ADDED_TO_LIB":"Προστέθηκε στη βιβλιοθήκη","REMOVED_FROM_LIB":"Αφαιρέθηκε από τη βιβλιοθήκη","TRAILER":"Τρέιλερ","WATCH_TRAILER":"Προβολή τρέιλερ","WATCH_NOW":"Προβολή τώρα","SHOW":"Εμφάνιση","SHOW_MOVIE":"Εμφάνιση ταινίας","WATCH_RANDOM":"Τυχαία προβολή","IMDB_RATING":"Στο IMDb","YEAR":"Έτος","DIRECTOR":"Σκηνοθεσία","WRITER":"Σενάριο","LEAD_ACTORS":"Πρωταγωνιστές","CAST":"Ηθοποιοί","CREW":"Συντελεστές","SHOW_MORE_CAST":"Περισσότερα »","AIRED":"Μετάδοση","SEASONS":"Κύκλοι","GENRE":"Είδος","CATALOG":"Κατάλογος","SUMMARY":"Περίληψη","SHOW_MORE":"Περισσότερα","SIMILAR":"Παρόμοια","UPCOMING":"Επερχόμενα","ENDED":"Τέλος","DURATION":"Διάρκεια","FEATURED":"Προτεινόμενα","METADATA":"Μεταδεδομένα","CATEGORY":"Κατηγορία","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Αναζήτηση βίντεο","SEARCH_PLACEHOLDER":"Αναζήτηση ή επικόλληση URL","ADDON":"Πρόσθετο","ADDONS":"Πρόσθετα","OFFICIAL":"Επίσημο","ADDONS_OFFICIAL":"Επίσημα πρόσθετα του Stremio","ADDONS_POPULAR":"Δημοφιλή στην περιοχή σας","ADDON_FREE":"Δωρεάν","ADDON_PEERED":"Σε peers","ADDON_SUBSCRIPTION":"Συνδρομή","ADDON_STREAM_GEORESTRICTED":"Δεν διατίθεται στην περιοχή σας","ADDON_STREAM_OFFLINECACHE":"Προσωρινή μνήμη εκτός σύνδεσης","ADDON_STREAM_LOCALFILE":"Τοπικό αρχείο","SHARE_ADDON":"Κοινοποίηση προσθέτου","AVAILABLE_STREAMS":"Διαθέσιμες ροές","NO_STREAM":"Δεν βρέθηκαν ροές","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Για περισσότερες ροές, παρακαλώ εγκαταστήστε περισσότερα πρόσθετα","STREAM_NOT_SUPPORTED":"Η επιλεγμένη ροή δεν υποστηρίζεται σε αυτήν την πλατφόρμα.","ADDON_CATALOGUE":"Εμφάνιση όλων των προσθέτων »","ADDON_CATALOGUE_MORE":"Εγκατάσταση προσθέτων","REPO_ADDED":"Το αποθετήριο προστέθηκε","ADDON_REPO_EXIST_ERR":"Αυτή η συλλογή προσθέτων υπάρχει ήδη","ADDON_REPO_ERR":"Προέκυψε σφάλμα κατά την προσθήκη της συλλογής","ADDON_ADD_ERR":"Προέκυψε σφάλμα κατά την προσθήκη του προσθέτου","ERR_ADDON_PROTECTED":"Δεν είναι δυνατή η αφαίρεση του προσθέτου, είναι προστατευόμενο","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Κάτι πήγε στραβά - η ταυτοποίηση ενδέχεται να απέτυχε","ERR_NOT_COLLECTION_URL":"Δεν είναι URL συλλογής","ERR_NOT_ADDON_URL":"Δεν είναι έγκυρο URL προσθέτου","ERR_DETECTFROMURL":"Δεν είναι δυνατή η εύρεση του προσθέτου/συλλογής από αυτό το URL","ADDON_DUPLICATE_WARNING":"Προειδοποίηση: Διπλότυπο πρόσθετο","ADDON_COLLECTION_SET_FAILED":"Αποτυχία συγχρονισμού εγκατεστημένων προσθέτων στον λογαριασμό σας","SETTINGS_DATA_EXPORT":"Εξαγωγή δεδομένων χρήστη","ADDON_PULL_FAILED":"Αποτυχία συγχρονισμού εγκατεστημένων προσθέτων από τον λογαριασμό σας","REFRESH_ON_CLICK":"Κάντε κλικ για επανάληψη","STILL_IN_THEATER":"Ακόμη στις αίθουσες","WATCH_IN_CINEMA":"Δείτε το στον τοπικό σας κινηματογράφο","IN_THEATER":"Στις αίθουσες","GET_TICKETS":"Εισιτήρια","UPCOMING_EPISODE":"Επερχόμενο επεισόδιο","UPCOMING_EPISODE_MESSAGE":"Αυτό το επεισόδιο θα προβληθεί σε","MISSING_DATE_EPISODE":"Απουσία ημερομηνίας","MISSING_DATE_EPISODE_MESSAGE":"Αυτό το επεισόδιο ενδέχεται να μην έχει προβληθεί ακόμα","CHANNEL_NOT_SCRAPED":"Δεν έχει γίνει ακόμα συλλογή δεδομένων για αυτό το κανάλι.
Παρακαλώ επιστρέψτε σε λίγα λεπτά.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Προσθέστε το στη βιβλιοθήκη σας για να ειδοποιηθείτε μόλις γίνει διαθέσιμο.","GET_NOTIFIED_WHEN_AVAILABLE":"Θα ειδοποιηθείτε μόλις γίνει διαθέσιμο.","WARNING_STREAMING_SERVER":"Προειδοποίηση: Δεν βρέθηκε τοπική υπηρεσία ροής. Η ροή από τοπικά αρχεία, YouTube και BitTorrent δεν θα είναι διαθέσιμη.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Προειδοποίηση: Αυτό το βίντεο ενδέχεται να μην υποστηρίζεται από το υλικό σας. Λάβετε υπόψη ότι η αναπαραγωγή μπορεί να είναι αργή.","PLAYER_ERROR":"Ωχ, σφάλμα αναπαραγωγής","PLAYER_ERROR_LOOKSLIKE":"Φαίνεται ότι","PLAYER_ORIENTATION":"Προσανατολισμός αναπαραγωγής","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Κλειδωμένος","PLAYER_ORIENTATION_SENSOR_SHORT":"Αισθητήρας","PLAYER_ORIENTATION_LANDSCAPE":"Ο προσανατολισμός αναπαραγωγής κλείδωσε στην οριζόντια θέση","PLAYER_ORIENTATION_SENSOR":"Αυτόματος προσανατολισμός αναπαραγωγής (αισθητήρας)","PLAYER_PLAYBACK_SPEED":"Ταχύτητα αναπαραγωγής","PLAYER_PLAYBACK_ERROR":"Σφάλμα αναπαραγωγής, παρακαλώ δοκιμάστε ξανά","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Άγνωστο σφάλμα","PLAYER_PLAYBACK_ERROR_DEFAULT":"Δυστυχώς, αυτό το βίντεο δεν μπορεί να αναπαραχθεί από το {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Ζωντανά","PLAYER_NEXT_VIDEO_TITLE":"Επόμενο βίντεο","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Απόρριψη","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Προβολή τώρα","STREAMING_FROM":"Ροή από","CASTING_TO":"Μετάδοση σε","NETWORK_STATUS":"Κατάσταση δικτύου","STREAM_SPEED":"Ταχύτητα ροής:","STREAM_BUFFERED":"Ενδιάμεση μνήμη:","PEERS_INFO":"Πληροφορίες peers","PEERS_ACTIVE":"Ενεργοί:","PEERS_CONNECTED":"Σε σύνδεση:","PEERS_WAITING":"Αναμονή:","TRANSCODING_WARNING":"Προειδοποίηση: Αλλαγή κωδικοποίησης βίντεο.","STREAM_LOADING":"Φόρτωση...","PLAYING_LOCAL":"Αναπαραγωγή από τοπικό αρχείο","PLAYING_CACHE":"Αναπαραγωγή από προσωρινή μνήμη","WRONG_SUBS":"Εσφαλμένοι υπότιτλοι;","ERR_SUBS_LOADING_TITLE":"Σφάλμα φόρτωσης υποτίτλων","ERR_SUBS_LOADING":"Αποτυχία φόρτωσης υποτίτλων: ενδέχεται να υπάρχει πρόβλημα με το πρόσθετό σας ή τη σύνδεση δικτύου σας","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Τα ακόλουθα πρόσθετα υποτίτλων απέτυχαν","ERR_CASTING_UPDATE_TITLE":"Δεν ήταν δυνατή η ενημέρωση των πληροφοριών της συσκευής μετάδοσης: ο διακομιστής ροής ενδέχεται να είναι εκτός σύνδεσης","CHOOSE_DEVICE":"Επιλέξτε συσκευή για παρακολούθηση","NO_CAST_DEVICES":"Δεν διατίθενται συσκευές μετάδοσης.","NO_SETTINGS":"Καμία διαθέσιμη ρύθμιση.","PHONE_TABLET":"Τηλέφωνο/Tablet","SUBTITLES":"Υπότιτλοι","SUBTITLES_CHANGE":"Αλλαγή υποτίτλων για ","SUBTITLES_CHANGE_NONE":"Δυστυχώς, δεν υπάρχουν άλλοι υπότιτλοι για αυτήν τη γλώσσα.","SUBTITLES_CHANGE_ACIVE":"Αυτήν τη στιγμή, είναι ενεργοί οι υπότιτλοι #{{subtitlesDialog.activeIdx + 1}}. Κάντε κλικ στο «Συνέχεια» για να ενεργοποιήσετε τους υπότιτλους #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Εναλλακτικά,","SUBTITLES_ADJUST_DELAY":"Προσαρμογή καθυστέρησης υποτίτλων:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Ή χρησιμοποιήστε τα πλήκτρα G / H κατά την αναπαραγωγή.","SUBTITLES_ADJUST_DELAY_TIP":"ΣΥΜΒΟΥΛΗ: Μπορείτε να χρησιμοποιήσετε τα πλήκτρα G / H κατά την αναπαραγωγή.","SUBTITLES_DELAY":"Καθυστέρηση υποτίτλων:","SUBTITLES_LOADING":"Φόρτωση υποτίτλων...","SUBTITLES_UNAVAILABLE":"Δεν διατίθενται εξωτερικοί υπότιτλοι","SUBTITLES_DISABLED":"Ανενεργοί","AUDIO":"Ήχος","DEFAULT_LANGUAGE":"Προεπιλεγμένη γλώσσα","DEFAULT_SECONDARY_LANGUAGE":"Δευτερεύουσα προεπιλεγμένη γλώσσα","SEASON":"Κύκλος","EPISODE":"Επεισόδιο","SPECIAL":"Σπέσιαλ","SORT":"Ταξινόμηση","SORT_BY":"Ταξινόμηση κατά","FILTER":"Φιλτράρισμα","SORT_TRENDING":"Τάσεις","SORT_RECENT":"Πρόσφατα","SORT_ALPHABET":"Α-Ω","SORT_RATING":"Βαθμολογία","SORT_WATCHED":"Ποβολή","SORT_YEAR":"Έτος","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Νέα για εσάς","New Episodes":"Νέα επεισόδια","New Videos":"Νέα βίντεο","Recommendations":"Προτάσεις","LIBRARY_RESUME":"Συνέχιση","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Λεπτομέρειες","LIBRARY_RESUME_DISMISS":"Απόρριψη","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Προτεινόμενα","DISCOVER_TOP":"Κορυφαία","DISCOVER_OSCAR":"Νικητές Όσκαρ","DISCOVER_WARNING_TITLE":"Ωχ!","DISCOVER_EMPTY_CATALOG":"Αυτό το πρόσθετο επέστρεψε κενό περιεχόμενο.","DISCOVER_ADULT_WARNING":"Το περιεχόμενο είναι ορατό μόνο για ενήλικες. Είστε 18+;","DISCOVER_NOADDON_WARNING":"Προειδοποίηση: Δεν υπάρχει ενεργό πρόσθετο στο Stremio για αυτόν τον τύπο. Εμφανίζονται αποθηκευμένα στοιχεία, δεν θα ενημερωθεί τίποτα εδώ.","DISCOVER_LOAD_ERR":"Το περιεχόμενο δεν φορτώθηκε, προέκυψε σφάλμα.","DISCOVER_ADDON_UNINSTALLED":"Αυτό το περιεχόμενο δεν είναι πλέον διαθέσιμο, ενδέχεται να έχετε αφαιρέσει το πρόσθετο.","UNINSTALL_THIS_ADDON":"Αφαίρεση προσθέτου","ERR_ADDON_NOT_INSTALLED":"Αυτό το πρόσθετο δεν έχει εγκατασταθεί. Να γίνει εγκατάσταση;","DETAIL_RECEIVE_NOTIF_SERIES":"Λήψη ειδοποιήσεων για νέα επεισόδια","DETAIL_RECEIVE_NOTIF_VIDEOS":"Λήψη ειδοποιήσεων για νέα βίντεο","SIDEBAR_SHOW_STREAMS":"Εμφάνιση ροών","RELAUNCH":"Κάντε επανεκκίνηση τώρα!","UPGRADE":"Υπάρχει νέα διαθέσιμη έκδοση! Αναβαθμίστε στην πιο πρόσφατη έκδοση του Stremio","RELOAD_UI":"Ανανεώστε το περιβάλλον χρήστη","MANUAL_UPDATE_TITLE":"Ενημερώστε την έκδοση του Stremio σας","MANUAL_UPDATE_LINE1":"Χρησιμοποιείτε μια παρωχημένη έκδοση του Stremio, κάτι που δεν προτείνεται.","MANUAL_UPDATE_LINE2":"Παρακαλώ κάντε ενημέρωση το συντομότερο δυνατόν.","BUTTON_UPDATE_LATTER":"Όχι τώρα","BUTTON_UPDATE_NOW":"Ενημέρωση","ANONYMOUS_USER":"Ανώνυμος χρήστης","DONT_HAVE_ACC":"Δεν έχετε λογαριασμό;","HAVE_ACC":"Έχετε ήδη λογαριασμό;","PASSWORD":"Κωδικός πρόσβασης","PASSWORD_CONFIRM":"Επιβεβαίωση κωδικού πρόσβασης","EMAIL":"Email","FB_LOGIN":"Συνέχεια με Facebook","FB_NOTHINGSHARED":"Δεν κοινοποιούμε τίποτα χωρίς την άδειά σας","FB_NOPOST":"Δεν θα δημοσιεύσουμε τίποτα εκ μέρους σας","OR":"ή","I_ACCEPT":"Αποδοχή","I_ACCEPT_BY_CLICKING":"Κάνοντας κλικ στο παραπάνω κουμπί, δηλώνω την αποδοχή ","TOS":"Όροι και Προϋποθέσεις","MUST_ACCEPT_TERMS":"Πρέπει να αποδεχθείτε τους όρους","PASSWORDS_NOMATCH":"Οι κωδικοί πρόσβασης δεν ταιριάζουν","SIGN_UP":"Εγγραφή","SIGN_UP_EMAIL":"Εγγραφή με email","CLICK_TO_SIGN_UP":"Κάντε κλικ εδώ για να εγγραφείτε.","LOG_IN":"Σύνδεση","LOG_OUT":"Αποσύνδεση","EXIT_FULLSCREEN":"Έξοδος από πλήρη οθόνη","ENTER_FULLSCREEN":"Είσοδος σε πλήρη οθόνη","PLAY_URL_MAGNET_LINK":"Αναπαραγωγή URL/συνδέσμου magnet","HELP_FEEDBACK":"Βοήθεια & σχόλια","TERMS_OF_SERVICE":"Όροι υπηρεσίας","PRIVACY_POLICY":"Πολιτική Απορρήτου","ABOUT_STREMIO":"Σχετικά με το Stremio","USER_PANEL":"Πίνακας χρήστη","LOGIN_LABEL":"Σύνδεση","GUEST_LOGIN":"Σύνδεση επισκέπτη","GUEST_LOGIN_NOTICE":"Δεν προτείνεται η σύνδεση επισκέπτη. Η κανονική σύνδεση επιτρέπει στο Stremio να συγχρονίζει τη βιβλιοθήκη σας και να σας στέλνει ειδοποιήσεις για αγαπημένες σειρές/κανάλια. Θέλετε σίγουρα να συνεχίσετε;","GUEST_LOGIN_NOTICE_2":"Δεν προτείνεται η σύνδεση επισκέπτη - δεν θα συγχρονίζεται η βιβλιοθήκη και οι ειδοποιήσεις πίνακα, που είναι βασικές λειτουργίες του Stremio. Θέλετε σίγουρα να συνεχίσετε;","CLICK_HERE":"Κάντε κλικ εδώ","WRONG_PASSWORD":"Εσφαλμένο email ή κωδικός πρόσβασης. Σε περίπτωση που έχετε ξεχάσει τον κωδικό πρόσβασής σας, ","SET_A_PASS":"Ορισμός κωδικού πρόσβασης","RESET_PASSWORD":"Επαναφορά κωδικού πρόσβασης","FORGOT_PASSWORD":"Ξεχάσατε τον κωδικό πρόσβασής σας;","EMAIL_USED_WITH_FB":"Αυτό το email χρησιμοποιήθηκε με σύνδεση Facebook.","INVALID_EMAIL":"Παρακαλώ εισαγάγετε μια έγκυρη διεύθυνση email","INVALID_PASSWORD":"Παρακαλώ εισαγάγετε έναν έγκυρο κωδικό πρόσβασης","CONN_ERR":"Σφάλμα σύνδεσης - παρακαλώ δοκιμάστε ξανά αργότερα.\\n\\nΑν επιμένει, απενεργοποιήστε το λογισμικό προστασίας από ιούς ή το τείχος προστασίας (ειδικά το Bitdefender).","IMPORT_FROM_GUEST":"Εισαγωγή βιβλιοθήκης από λογαριασμό επισκέπτη","RECEIVE_UPDATES_EMAIL":"Λήψη ενημερώσεων από το Stremio στο email σας","LOGIN_FAILED":"Αποτυχία σύνδεσης.","SIGNUP_FAILED":"Αποτυχία εγγραφής.","SEARCH_FAILED":"Αποτυχία αναζήτησης","EMAIL_USED":"Αυτό το email χρησιμοποιείται ήδη.","WAITING_FB_LOGIN":"Σύνδεση μέσω Facebook...","EXTERNAL_PLAYER_TITLE":"Αναπαραγωγή σε εξωτερικό πρόγραμμα","EXTERNAL_REMEMBER_PLAYER":"Θέλετε να αποθηκεύσετε την επιλογή σας;","EXTERNAL_ALWAYS_PLAY":"Ναι","EXTERNAL_ONLY_ONCE":"Όχι","BEST_FIT":"Βέλτιστη προσαρμογή","FIT_SCREEN":"Προσαρμογή στην οθόνη","FILL":"Γέμισμα","16:9":"16:9","4:3":"4:3","Original":"Αρχικό","INTRO_TASTE":"Πείτε μας τι σας αρέσει","INTRO_TASTE_LONG":"Πείτε μας τι θα θέλατε να δείτε","INTRO_TASTE_PICK":"Επιλέξτε {{interestsRemaining}} ενδιαφέροντα","INTRO_TASTE_PICK_MORE":"Επιλέξτε {{interestsRemaining}} κι άλλα ενδιαφέροντα","INTRO_TASTE_HELP_US":"Βοηθήστε μας να μάθουμε περισσότερα για εσάς.","INTRO_TASTE_CHOOSE_THESE":"Επιλέξτε κάποια από αυτά:","INTRO_TASTE_CHOOSE_MIN":"Επιλέξτε τουλάχιστον 3 κατηγορίες","INTRO_TASTE_CHOOSE_MIN_ERR":"Πρέπει να επιλέξετε τουλάχιστον 3 κατηγορίες!","INTRO_TASTE_LIFESTYLE":"Τρόπος ζωής","INTRO_TASTE_SPORTS":"Αθλήματα","INTRO_TASTE_FOOD_HEALTH":"Φαγητό & υγεία","INTRO_TASTE_BEAUTY_FASHION":"Ομορφιά & μόδα","INTRO_TASTE_NEWS":"Ειδήσεις","INTRO_TASTE_GAMING":"Παιχνίδια","INTRO_TASTE_SCIENCE_EDU":"Επιστήμη & εκπαίδευση","INTRO_TASTE_MUSIC":"Μουσική","INTRO_TASTE_TRAVEL":"Ταξίδια","INTRO_TASTE_LATE_NIGHT":"Βραδινό","INTRO_TASTE_REALITY":"Ριάλιτι","INTRO_TASTE_COMEDY":"Κωμωδία","INTRO_TASTE_DIY":"Κατασκευές","INTRO_TASTE_TECH":"Τεχνολογία","INTRO_TASTE_CINEMA":"Κινηματογράφος","ADDON_NOT_SUPPORTED":"Το επιλεγμένο πρόσθετο δεν υποστηρίζεται σε αυτήν την πλατφόρμα.","ADDON_DISCLAIMER":"Η χρήση τρίτων προσθέτων θα υπόκειται πάντα στη δική σας ευθύνη και την ισχύουσα νομοθεσία της χώρας σας.","ADDON_ACTIVATE":"Ενεργοποίηση προσθέτου;","ADDON_REPO_ADD":"URL συλλογής προσθέτων","ADDON_ADD":"Προσθήκη","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Τι νέο υπάρχει","BUTTON_CONTINUE":"Συνέχεια","BUTTON_ACTIVATE":"Ενεργοποίηση","BUTTON_ACTIVATED":"Ενεργό","BUTTON_CANCEL":"Ακύρωση","BUTTON_SUBMIT":"Υποβολή","BUTTON_DISMISS_ALL":"Απόρριψη όλων","BUTTON_VIEW_ALL":"Προβολή όλων","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Η βιβλιοθήκη σας είναι κενή. Ανακαλύψτε πόσο χρήσιμη είναι :) ","HOW_START":"Δείτε από πού μπορείτε να ξεκινήσετε:","LIB_EMPTY_CAL":"Το ημερολόγιό σας εμφανίζει σειρές στη βιβλιοθήκη σας.","HOW_START_CAL":"Δείτε πώς μπορείτε να προσθέσετε σειρές:","LIB_EMPTY_BOARD":"Ο πίνακας εμφανίζει ειδοποιήσεις & προτάσεις σχετικές με τη βιβλιοθήκη σας.","HOW_START_BOARD_WAIT":"Παρακαλούμε προσθέστε μερικές σειρές ή κανάλια στη βιβλιοθήκη σας και δώστε μας λίγα λεπτά για να τα επεξεργαστούμε :)","HOW_START_BOARD":"Δείτε πώς μπορείτε να προσθέσετε σειρές & ταινίες:","IMPORT_FB":"Εισαγωγή αγαπημένων από το Facebook","IMPORT_TRAKT":"Εισαγωγή βιβλιοθήκης πολυμέσων από το Trakt","IMPORT_DISCOVER":"Εύρεση ενδιαφέροντος περιεχομένου από την Ανακάλυψη","IMPORT_DISK":"Εισαγωγή ταινιών ή εκπομπών από τον τοπικό σας δίσκο","PLEASE_CREATE_ACC":"Παρακαλώ δημιουργήστε έναν λογαριασμό για να ενεργοποιήσετε τον συγχρονισμό βιβλιοθήκης & πίνακα.","IMPORT_DISCOVER_SIGNUP":"Εγγραφείτε και βρείτε ενδιαφέρον περιεχόμενο από την Ανακάλυψη","IMPORT_DISK_SIGNUP":"Εγγραφείτε και εισαγάγετε ταινίες ή εκπομπές από τον τοπικό σας δίσκο","LIB_EMPTY_CLOUD":"Συγχρονισμός","LIB_EMPTY_CLOUD_DESC":"Συγχρονισμός προσωπικής βιβλιοθήκης cloud σε κάθε συσκευή","LIB_EMPTY_EARLY":"Πρόωρη άφιξη","LIB_EMPTY_EARLY_DESC":"Λήψη ειδοποιήσεων για νέα επεισόδια","LIB_EMPTY_PERSONAL":"Εξατομίκευση","LIB_EMPTY_PERSONAL_DESC":"Λήψη εξατομικευμένων προτάσεων","LIB_EMPTY_CALENDAR_DESC":"Διαχειριστείτε το προσωπικό σας ημερολόγιο παρακολούθησης","LIB_EMPTY_ALL":"Εγγραφείτε για να έχετε όλα τα ακόλουθα:","LIB_EMPTY_BEST":"Εγγραφείτε για να αξιοποιήσετε το Stremio στο έπακρο","LIB_EMPTY_OTHER":"Εγγραφείτε για να ενεργοποιήσετε το Ημερολόγιο και άλλες λειτουργίες","CALENDAR_ADDED":"Το ημερολόγιο του Stremio έχει προστεθεί στο προεπιλεγμένο ημερολόγιο του υπολογιστή σας.","CALENDAR_ADDED_MSG":"Αν δεν λειτουργήσει αυτό, παρακαλώ προσθέστε χειροκίνητα αυτό το URL της εφαρμογής ημερολογίου σας","TRAKT_EXPIRED":"Η ταυτοποίηση στο Trakt έληξε, παρακαλώ μεταβείτε στις Ρυθμίσεις και κάντε ξανά έλεγχο ταυτότητας","TRAKT_REQUIRES_LOGIN":"Σφάλμα Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Πρέπει να κάνετε σύνδεση","SETTINGS_LABEL":"Ρυθμίσεις","SETTINGS_NAV_GENERAL":"Γενικά","SETTINGS_NAV_PLAYER":"Αναπαραγωγή","SETTINGS_NAV_STREAMING":"Ροή","SETTINGS_NAV_SHORTCUTS":"Συντομεύσεις","SETTINGS_SHORTCUT_RELOAD_APP":"Επαναφόρτωση εφαρμογής","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Άνοιγμα ρυθμίσεων","SETTINGS_SHORTCUT_SWITCH_TABS":"Αλλαγή σελίδας","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Εναλλαγή καρτελών προς τα εμπρός","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Εναλλαγή καρτελών προς τα πίσω","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Έξοδος / Πίσω","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Λειτουργεία πλήρους οθόνης","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Εμφάνιση στοιχείων ελέγχου","SETTINGS_SHORTCUT_PLAY_PAUSE":"Αναπαραγωγή / Παύση","SETTINGS_SHORTCUT_VOLUME_UP":"Ανοίξτε τη φωνή","SETTINGS_SHORTCUT_VOLUME_DOWN":"Κλεσίτε τη φωνή","SETTINGS_SHORTCUT_SEEK_NEXT":"Πηγαίντε στο επόμενο επεισόδιο","SETTINGS_SHORTCUT_SEEK_PREV":"Πηγαίντε στο προηγούμενο επεισόδιο","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Επόμενο","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Αυξήστε το μέγεθος των υποτίτλων","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Μειώστε το μέγεθος των υποτίτλων","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Αυξήστε την καθυστέρηση των υποτίτλων","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Μειώστε την καθυστέρηση των υποτίτλων","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Αλλαγή θέσης πλευρικής γραμμής","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Άνοιγμα κατά την εκκίνηση","SETTINGS_VLC_DEFAULT":"Αναπαραγωγή με VLC","SETTINGS_UI_LANGUAGE":"Γλώσσα εφαρμογής","SETTINGS_FULLSCREEN_EXIT":"Έξοδος από πλήρη οθόνη με το πλήκτρο Escape","SETTINGS_GAMEPAD":"Ενεργοποίηση υποστήριξης για gamepad","SETTINGS_CLOSE_WINDOW":"Κλείσιμο εφαρμογής όταν κλείνει το παράθυρο","SETTINGS_SUBTITLES_LANGUAGE":"Προεπιλεγμένη γλώσσα υποτίτλων","SETTINGS_SUBTITLES_SIZE":"Προεπιλεγμένο μέγεθος υποτίτλων","SETTINGS_SUBTITLES_BACKGROUND":"Φόντο υποτίτλων","SETTINGS_SUBTITLES_COLOR":"Χρώμα υποτίτλων","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Χρώμα περιγράμματος υποτίτλων","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Χρώμα φόντου υποτίτλων","SETTINGS_SEEK_KEY":"Χρονική μετατόπιση με πλήκτρα-βέλη","SETTINGS_SEEK_KEY_SHIFT":"Χρονική μετατόπιση με πλήκτρα-βέλη όταν είναι πατημένο το πλήκτρο Shift","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Αυτόματη αναπαραγωγή επόμενου επεισοδίου","SETTINGS_NEXT_VIDEO":"Εμφάνιση ειδοποίησης για έναρξη επόμενου επεισοδίου","SETTINGS_NEXT_VIDEO_TRIGGER":"Εμφάνιση ειδοποίησης επόμενου επεισοδίου για:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Αυτόματη προσαρμογή παραθύρου πριν από την αναπαραγωγή","SETTINGS_OVERRIDE_SERVER":"Παράκαμψη URL διακομιστή ροής (σύνθετο)","SETTINGS_SERVER_URL":"URL διακομιστή ροής: ","SETTINGS_SERVER_AVAILABLE":"Ο διακομιστής ροής είναι διαθέσιμος.","SETTINGS_SERVER_UNAVAILABLE":"Ο διακομιστής ροής δεν είναι διαθέσιμος.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Ακροσημείο HTTPS ροής: ","SETTINGS_USE_BETA":"Πάντα χρήση της πιο πρόσφατης έκδοσης beta","SETTINGS_IMPORT_FB":"Εισαγωγή από Facebook","SETTINGS_IMPORT_DISK":"Εισαγωγή από τοπικό δίσκο","SETTINGS_IMPORT_TRAKT":"Εισαγωγή από Trakt","SETTINGS_PAUSE_MINIMIZED":"Παύση αναπαραγωγής κατά την ελαχιστοποίηση","SETTINGS_HWDEC":"Αποκωδικοποίηση με επιτάχυνση υλικού","SETTINGS_BACKGROUND":"Αναπαραγωγή στο παρασκήνιο","SETTINGS_SUBSCRIBE_CALENDAR":"Εγγραφή σε ημερολόγιο","SETTINGS_REQ_EXPORT":"Αίτημα εξαγωγής δεδομένων","SETTINGS_ACC_DELETE":"Αίτημα διαγραφής λογαριασμού","SETTINGS_CHANGE_PASSWORD":"Αλλαγή κωδικού πρόσβασης","SETTINGS_TOS":"Όροι υπηρεσίας","SETTINGS_SUPPORT":"Επικοινωνία με την υποστήριξη","SETTING_LANGUAGE":"Γλώσσα","SETTINGS_TRAKT":"Αυτόματη παρακολούθηση Trakt","SETTINGS_TRAKT_LOGOUT":"Αποσύνδεση από Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Σαρώστε τον κωδικό QR για να ανοίξετε το τηλεχειριστήριο","SETTINGS_DESKTOP_NOTIFICATIONS":"Ειδοποιήσεις υπολογιστή","SETTINGS_DATA_SAVER":"Εξοικονόμηση δεδομένων","SETTINGS_LANGUAGE_INTERFACE":"Περιβάλλον χρήστη","SETTINGS_LANGUAGE_SUBS":"Προεπιλεγμένοι υπότιτλοι","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Αυτόματη επιλογή κομματιού ήχου","SETTINGS_DEFAULT_AUDIO_TRACK":"Προεπιλεγμένο κομμάτι ήχου","SETTINGS_ACCOUNT":"Λογαριασμός","SETTINGS_VERSION":"Έκδοση","SETTINGS_MPV_WINDOW":"Εκκίνηση αναπαραγωγής σε ξεχωριστό παράθυρο (σύνθετο)","SETTINGS_PLAY_IN_EXTERNAL":"Πάντα εκκίνηση του βίντεο σε εξωτερικό πρόγραμμα","SETTINGS_STORAGE_BUTTON":"Απαλοιφή τοπικής αποθήκευσης","SETTINGS_STORAGE_MODAL_TITLE":"Σίγουρα;","SETTINGS_STORAGE_MODAL_MESSAGE":"Αυτό θα εκκαθαρίσει τον τοπικό χώρο αποθήκευσης και θα σας αποσυνδέσει.","SETTINGS_HWDEC_PICKER":"Επιλέξτε ρύθμιση αποκωδικοποίησης με επιτάχυνση υλικού","SETTINGS_HW_AUTOMATIC":"Αυτόματη","SETTINGS_HW_DISABLED":"Ανενεργή","SETTINGS_HW_ACCELERATED":"Επιτάχυνση αποκωδικοποίησης","SETTINGS_HW_FULL":"Πλήρης επιτάχυνση","SETTINGS_HW_LEGACY":"Παλαιού τύπου","SUBSPICKER_AUDIO":"Ήχος","SUBSPICKER_SUBTITLES":"Πρόσθετα Υποτίτλων","SUBSPICKER_BLACK_BACKGROUND":"Χρήση μαύρου φόντου","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Μέγεθος","SUBSPICKER_DELAY":"Καθυστέρηση","SUBSPICKER_EMBEDDED_SUBS":"Ενσωματωμένοι Υπότιτλοι","MOBILE_PRIVACY_POLICY":"Πολιτική Απορρήτου","MOBILE_CRASH_REPORTING":"Αναφορά σφάλματος","MOBILE_ZOOM_TO_FILL":"Ζουμ για πλήρη οθόνη","MOBILE_PASSTHROUGH":"Ψηφιακή έξοδος ήχου (passthrough)","MOBILE_RUN_LOW_BATTERY":"Λειτουργία με χαμηλή μπαταρία","MOBILE_RUN_FOREGROUND":"Εκτέλεση ως υπηρεσία προσκηνίου","MOBILE_PERFORMANCE":"Απόδοση & Σταθερότητα","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"Ο κωδικός QR λήει σε","MOBILE_LOG_INTO":"Συνδεθείτε στον λογαριασμό σας","MOBILE_SCAN_QR":"Σκανάρετε το κωδικό QR η πηγαίντε","MOBILE_LINK_ACCOUNT":"Σύνδεση λογαριασμού","MOBILE_SPEEDPICKER_CANCEL":"Ακύρωση","MOBILE_SPEEDPICKER_LABEL":"Ταχύτητα Αναπαραγωγής","MOBILE_EMPTY_LIBRARY":"Η βιβλιοθήκη σας είναι άδεια","MOBILE_NO_ADDON_ACTIVE":"Κανένα πρόσθετο δε μπορεί να εκτελέσει αυτή τη λειτουργία.","MOBILE_ORGANIZER_WARNING":"Η εφαρμογή Stremio Organizer παρέχει περιορισμένη λειτουργικότητα. Για μια λίστα με ροές με δυνατότητα αναπαραγωγής και την πλήρη εμπειρία του Stremio, χρησιμοποιήστε το Stremio στον υπολογιστή.","MOBILE_ADDON_LOADING":"Φορτώνει","MOBILE_ADDONS_LOADING":"Τα πρόσθετα φορτώνουν","MOBILE_ADDON":"Πρόσθετο","MOBILE_CONFIGURE_ADDON":"Διαμορφώστε το πρόσθετο","MOBILE_CONFIGURE_ADDON_LABEL":"Διαμορφώστε το πρόσθετο","MOBILE_ORGANIZER_ADDONS_WARNING":"Η εφαρμογή Stremio Organizer παρέχει περιορισμένα πρόσθετα. Για την πλήρη εμπειρία του Stremio, χρησιμοποιήστε το Stremio στον υπολογιστή.","MOBILE_DISCONNECT":"Αποσύνδεση","MOBILE_LOOKING_FOR_DEVICES":"Αναζήτηση συσκευών...","MOBILE_CAST_TO":"Μετάδοση σε","NAVIGATION_ON":"Ανοιχτό","NAVIGATION_OFF":"Κλειστό","MARKETING_AGREE":"Συμφωνώ να λαμβάνω ενημερωτικά e-mail από το Stremio","QUIT":"Έξοδος","CONNECTED":"Σε σύνδεση","AUTHENTICATE":"Ταυτοποίηση","CACHING":"Προσωρινή αποθήκευση","SETTINGS_CACHING_DRIVE":"Δίσκος προσωρινής μνήμης","ENABLE_LOCAL_FILES_ADDON":"Ενεργοποίηση προσθέτου τοπικών αρχείων (απαιτεί επανεκκίνηση)","LOCAL_ADDON_NOT_ENABLED":"Το τοπικό πρόσθετο δεν είναι ενεργοποιημένο. Κάντε κλικ εδώ για να μεταβείτε στις ρυθμίσεις και να το ενεργοποιήσετε","ENABLE_REMOTE_HTTPS_CONN":"Ενεργοποίηση απομακρυσμένων συνδέσεων HTTPS","TORRENT_PROFILE":"Προφίλ torrent","DATA_CACHING":"Προσωρινή αποθήκευση δεδομένων","MAGNET_PARSING":"Ανάλυση συνδέσμου magnet","January":"Ιανουάριος","February":"Φεβρουάριος","March":"Μάρτιος","April":"Απρίλιος","May":"Μάιος","June":"Ιούνιος","July":"Ιούλιος","August":"Αύγουστος","September":"Σεπτέμβριος","October":"Οκτώβριος","November":"Νοέμβριος","December":"Δεκέμβριος","Monday":"Δευτέρα","Tuesday":"Τρίτη","Wednesday":"Τετάρτη","Thursday":"Πέμπτη","Friday":"Παρασκευή","Saturday":"Σάββατο","Sunday":"Κυριακή","Action":"Δράση","Comedy":"Κωμωδία","War":"Πόλεμος","Family":"Οικογενειακές","Animation":"Κινούμενα σχέδια","Adventure":"Περιπέτεια","Fantasy":"Φαντασία","Crime":"Έγκλημα","Mystery":"Μυστήριο","Romance":"Ρομαντικές","Drama":"Δράμα","Horror":"Τρόμος","Thriller":"Θρίλερ","Sci-Fi":"Επιστημονική φαντασία","Music":"Μουσική","Biography":"Βιογραφία","Documentary":"Ντοκιμαντέρ","Sport":"Αθλήματα","Musical":"Μιούζικαλ","Western":"Γουέστερν","Film-Noir":"Φιλμ νουάρ","News":"Ειδήσεις","History":"Ιστορία","Game-Show":"Τηλεπαιχνίδι","Reality-TV":"Ριάλιτι","Talk-Show":"Τοκ σόου","Film & Entertainment":"Σινεμά & ψυχαγωγία","Gaming":"Παιχνίδια","From TV":"Από την τηλεόραση","Lifestyle":"Τρόπος ζωής","Science & Education":"Επιστήμη & εκπαίδευση","Cooking & Health":"Μαγειρική & υγεία","Beauty & Fashion":"Ομορφιά & μόδα","Sports":"Αθλήματα","News & Politics":"Ειδήσεις & πολιτική","How-to & DIY":"Κατασκευές","Tech":"Τεχνολογία","Automotive":"Αυτοκίνηση","Causes & Non-Profits":"Φιλανθρωπία","Movies":"Ταινίες","Uk Live Tv":"Ηνωμένο Βασίλειο","Fashion":"Μόδα","Business News Radio":"Επιχειρήσεις - Ράδιο","Business Tv":"Επιχειρήσεις","Cars & Auto":"Αυτοκίνητα","Comedy Radio":"Κωμωδία - Ράδιο","Lifestyle Radio":"Τρόπος ζωής - Ράδιο","News Tv":"Ειδήσεις","Food And Wine":"Φαγητό & ποτά","Latino Tv":"Λατινική Αμερική","Shopping Tv":"Αγορές","Religion":"Θρησκεία","Kids":"Παιδικά","Body & Soul":"Σώμα & πνεύμα","Education":"Εκπαίδευση","Indian Tv":"Ινδία","Extreme Sports":"Εξτρίμ σπορ","Middle Eastern Tv":"Μέση Ανατολή","Celebrity Tv":"Διάσημοι","Science Tv":"Επιστήμη","Bikini babe":"Bikini babe","Outdoors":"Εξοχή","German Tv":"Γερμανία","French Tv":"Γαλλία","Italian Tv":"Ιταλία","Gamer Tv":"Παιχνίδια","Travel":"Ταξίδια","Asian Tv":"Ασία","Entertainment":"Ψυχαγωγία","News Radio":"Ειδήσεις - Ράδιο","Music Radio":"Μουσική - Ράδιο","Language Learning":"Εκμάθηση γλωσσών","Science Radio":"Επιστήμη - Ράδιο","Tech Radio":"Τεχνολογία - Ράδιο","Science & Technology Vod":"Επιστήμη & τεχνολογία","new video":"Νέο βίντεο","new episode":"Νέο επεισόδιο","new movie":"Νέα ταινία","recommended":"Προτάσεις","we recommend":"Προτείνουμε","offer of the day":"Προσφορά ημέρας","news":"Ειδήσεις","music video":"Μουσικό βίντεο","CTX_SHOW_HOTKEYS":"Εμφάνιση πλήκτρων συντομεύσεων","CTX_DISMISS_NOTIF":"Απόρριψη ειδοποιήσεων","CTX_DISMISS_ALL":"Απόρριψη όλων","CTX_SHARE":"Κοινοποίηση","CTX_COPY_SHARE_LINK":"Αντιγραφή συνδέσμου κοινής χρήσης","CTX_COPY_MAGNET_LINK":"Αντιγραφή συνδέσμου magnet","CTX_COPY_STREAM_LINK":"Αντιγραφή συνδέσμου ροής","CTX_DOWNLOAD_VIDEO":"Λήψη βίντεο","CTX_DOWNLOAD_SUBS":"Λήψη υποτίτλων","CTX_VIEW_ON_YOUTUBE":"Προβολή στο YouTube","CTX_SHOW":"Εμφάνιση","CTX_PLAY":"Αναπαραγωγή","CTX_PLAY_IN":"Αναπαραγωγή σε","CTX_PLAY_ON":"Αναπαραγωγή σε","CTX_WATCH_ON":"Παρακολούθηση σε","CTX_WATCH":"Προβολή","CTX_WATCHED":"Προβλήθηκε","CTX_WATCH_BEGINNING":"Προβολή από την αρχή","CTX_WATCH_MOBILE":"Προβολή σε κινητή συσκευή","CTX_REWIND":"Επιστροφή στην αρχή","CTX_MARK_WATCHED":"Σήμανση ως προβεβλημένο","CTX_MARK_NON_WATCHED":"Σήμανση ως μη προβεβλημένο","CTX_MARK_UNWATCHED":"Σήμανση ως μη προβεβλημένο","CTX_MARK_REST":"Σήμανση υπολοίπων ως προβεβλημένων","CTX_UNMARK_REST":"Σήμανση υπολοίπων ως μη προβεβλημένων","CTX_RECEIVE_NEW_NOTIF":"Λήψη νέων ειδοποιήσεων","CTX_REMOVE_CACHE":"Αφαίρεση από προσωρινή μνήμη","CTX_REMOVE_CACHE_EP":"Αφαίρεση επεισοδίου από προσωρινή μνήμη","CTX_OPEN_CONTAINING":"Άνοιγμα φακέλου αποθήκευσης","CTX_REMOVE":"Αφαίρεση από βιβλιοθήκη","CTX_AVAILABLE_OFFLINE":"Διαθέσιμο εκτός σύνδεσης","CTX_PAUSED":"Σε παύση","CTX_ALWAYS_ON_TOP":"Πάντα στο προσκήνιο","CTX_FULLSCREEN":"Πλήρης οθόνη","CTX_WRONG_SUBS":"Εσφαλμένοι υπότιτλοι;","CTX_REPORT_ISSUES":"Αναφορά ζητήματος","CTX_COPY":"Αντιγραφή","CTX_PASTE":"Επικόλληση","CTX_CLEAR":"Απαλοιφή","CTX_CLEAR_RECENT_SEARCHES":"Απαλοιφή πρόσφατων αναζητήσεων","HELLO_THERE":"Γεια σας","HOPE_YOU_ENJOY":"Ελπίζουμε να απολαμβάνετε το Stremio και να έχει γίνει ήδη μία από τις αγαπημένες σας εφαρμογές!","WHO_ARE_WE":"Ποιοι είμαστε; Είμαστε η ομάδα που το αναπτύσσει - δύο τύποι που εργάζονται σκληρά κάθε μέρα για τα τελευταία 3 έτη, προκειμένου να κάνουν αυτό το προϊόν όλο και καλύτερο.","SUPPORT_US":"Αν απολαμβάνετε το Stremio, αν το Stremio είναι ανεκτίμητο για εσάς - μοιραστείτε το με όλους!","SPREAD_THE_WORD":"Μοιραστείτε το με τους φίλους σας, μιλήστε σε όλους για το Stremio","MORE_PEOPLE":"Όσο περισσότερα άτομα χρησιμοποιούν το Stremio, τόσο καλύτερο θα γίνεται!","SEND_A_LINK":"Ή στείλτε έναν σύνδεσμο για τον ιστότοπό μας","TIP_LOCALFILES":"Συμβουλή: Μπορείτε να σύρετε και να εναποθέσετε τοπικά αρχεία βίντεο στο Stremio","ADDON_MY":"Τα πρόσθετά μου","ADDON_COMMUNITY":"Πρόσθετα κοινότητας","ADDON_OFFICIAL":"Επίσημα πρόσθετα","ADDON_REPOS":"Συλλογές προσθέτων","ADDON_SEARCH":"Αναζήτηση προσθέτων","ADDON_INSTALL":"Εγκατάσταση","ADDON_CONFIGURE":"Ρύθμιση","ADDON_UNINSTALL":"Αφαίρεση","ADDON_UPGRADE":"Αναβάθμιση","ADDON_INSTALLED":"Εγκατεστημένο","ADDON_INSTALLED_MSG":"Το πρόσθετο εγκαταστάθηκε!","ADDON_UPGRADED_MSG":"Το πρόσθετο αναβαθμίστηκε!","ADDON_UNKNOWN":"Άγνωστο","ADDON_ERR":"Σφάλμα εγκατάστασης προσθέτου!","ADDON_DISCONNECTED":"Αποσυνδέθηκε","ADDON_APP_MISSING":"Η εφαρμογή για αυτήν την πηγή δεν έχει εγκατασταθεί. Θέλετε να την εγκαταστήσετε τώρα;","ADDON_APP_INSTALL":"Εγκατάσταση","ADDON_PAGE":"Σελίδα προσθέτου","ADDON_TOP_CONTENT":"Τα καλύτερα από αυτό το πρόσθετο","ADDON_PROVIDES":"Αυτό το πρόσθετο προσφέρει:","ADDON_WATCH":"Παρακολούθηση «#{types}»!","ADDON_WATCH_FREE":"Δωρεάν παρακολούθηση «#{types}»!","ADDON_ADDON":"Πρόσθετο","ADDON_SUPPORTED_TYPES":"Υποστηριζόμενοι τύποι","ADDON_SUPPORTED_CATALOGS":"Υποστηριζόμενοι κατάλογοι","ADDON_PROVIDES_DISCOVER":"Περισσότερα «#{types}» στην Ανακάλυψη","ADDON_PROVIDES_STREAMS":"Παρακολούθηση «#{types}»","ADDON_PROVIDES_STREAMS_FREE":"Δωρεάν παρακολούθηση «#{types}»","ADDON_PROVIDES_SUBTITLES":"Υπότιτλοι για «#{types}»","ADDON_CANTDETECT":"Δεν μπορέσαμε να εντοπίσουμε κάποια εκτέλεση του Stremio, επομένως δεν μπορέσαμε να προσδιορίσουμε τα εγκατεστημένα σας πρόσθετα.","ERR_NO_META":"Δεν βρέθηκε καμία πληροφορία σχετικά με αυτό ","ERR_GETTING_META":"Σφάλμα ανάκτηση σχετικών πληροφοριών.","ERR_CANT_PARSE_MAGNET":"Δεν ήταν δυνατή η ανάλυση του magnet","ERR_NO_MAGNET_INFOHASH":"Κανένα έγκυρο hash πληροφοριών για το magnet","ERR_NO_FILE_PATH":"Δεν είναι δυνατή η αποστολή αιτήματος χωρίς διαδρομή σε αρχείο","ERR_NO_TORRENT":"Δεν επιστράφηκε κανένα torrent","ERR_NO_SUPPORTERD_FILES":"Δεν βρέθηκαν υποστηριζόμενα αρχεία","ERR_OPENING_FILES":"Δεν ήταν δυνατό το άνοιγμα εξωτερικών αρχείων","ERR_INVALID_LINK":"Μη έγκυρος σύνδεσμος","ERR_REGISTERED_ONLY":"Αυτή η επιλογή είναι διαθέσιμη μόνο για εγγεγραμμένους χρήστες.","ERR_CLIPBOARD":"Δεν είναι δυνατή η αναπαραγωγή από το πρόχειρο","ERR_CLIPBOARD_READ":"Δεν είναι δυνατή η ανάγνωση από το πρόχειρο σε αυτήν την πλατφόρμα","ERR_CLIPBOARD_GENERIC":"Δεν βρέθηκε κατάλληλο URL στο πρόχειρο. Παρακαλώ αντιγράψτε ένα URL βίντεο (π.χ. σύνδεσμος magnet).","BOARD_CONTINUE_WATCHING":"Συνέχεια παρακολούθησης","BOARD_EXPLANATION_RECOMMENDATIONS":"Ταινίες ειδικά επιλεγμένες για εσάς.
Αυτή η ταινία αποτελεί δείγμα πρότασης.","BOARD_EXPLANATION_EPISODES":"Τα νέα επεισόδια των αγαπημένων σας σειρών έρχονται εδώ.
Προσθέστε στη βιβλιοθήκη σας τις σειρές που ακολουθείτε.","BOARD_EXPLANATION_VIDEOS":"Τα νέα επεισόδια των αγαπημένων σας καναλιών έρχονται εδώ.
Προσθέστε στη βιβλιοθήκη σας τα κανάλια που ακολουθείτε.","WEBSITE_SLOGAN_WATCH":"Άμεση παρακολούθηση","WEBSITE_SLOGAN_ALL":"Όλο το περιεχόμενό σας, σε ένα μέρος","WEBSITE_SLOGAN_NEW":"Απεριόριστη παρακολούθηση","WEBSITE_SLOGAN_NEW_NEW":"Ελευθερία στο streaming","WEBSITE_WATCH_FROM":"Προβολή από","WEBSITE_DOWNLOAD":"Λήψη τώρα","WEBSITE_DOWNLOAD_FOR":"Λήψη τώρα για","WEBSITE_IS_DESKTOP":"Το Stremio είναι εφαρμογή για υπολογιστές, ανοίξτε αυτήν τη σελίδα στον υπολογιστή για να κάντε λήψη","WEBSITE_DESKTOP_DEMO_VID":"Επίδειξη σε υπολογιστή","WEBSITE_PAGE_HOME":"Αρχική","WEBSITE_PAGE_FEATURES":"Λειτουργίες","WEBSITE_PAGE_ADDONS":"Πρόσθετα","WEBSITE_PAGE_TECH":"Τεχνολογία","WEBSITE_PAGE_CREATE_ADDON":"Δημιουργία προσθέτου","WEBSITE_PAGE_CONTACTS":"Επαφές","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Ταινίες","WEBSITE_TYPE_series_PL":"Σειρές","WEBSITE_TYPE_tv":"Ζωντανή τηλεόραση","WEBSITE_TYPE_channel":"Κανάλια","WEBSITE_STREMIO_WHAT_IS":"Το Stremio είναι μια εφαρμογή που σας βοηθά να οργανώσετε και να παρακολουθήσετε άμεσα τα αγαπημένα σας βίντεο, ταινίες, σειρές και τηλεοπτικά κανάλια.","WEBSITE_FEATURES_WATCH":"Άμεση παρακολούθηση σε HD","WEBSITE_FEATURES_WATCH_DETAIL":"Κάντε κλικ και δείτε τις αγαπημένες σας ταινίες, εκπομπές, βίντεο και κανάλια.","WEBSITE_FEATURES_SUBS":"Αυτόματοι υπότιτλοι","WEBSITE_FEATURES_SUBS_DETAIL":"Το Stremio επιλέγει αυτόματα συγχρονισμένους υπότιτλους στη γλώσσα σας.","WEBSITE_FEATURES_SUBS_LABEL":"Εσύ αποφασίζεις.","WEBSITE_FEATURES_CAST":"Αναπαραγωγή σε τηλεόραση & κινητές συσκευές","WEBSITE_FEATURES_CAST_DETAIL":"Μετάδοση σε AppleTV, Chromecast, Smart TV (DLNA/UPnP) και κινητές συσκευές.","WEBSITE_LIB":"Η προσωπική σας βιβλιοθήκη σε όλες τις συσκευές σας","WEBSITE_LIB_COLLECT":"Συλλογή από Stremio","WEBSITE_LIB_IMPORT":"Εισαγωγή από Facebook","WEBSITE_LIB_LOCAL":"Προσθήκη από τοπικό δίσκο","WEBSITE_BOARD":"Ο πίνακας - Ένα ενιαίο μέρος για ειδοποιήσεις και προτάσεις","WEBSITE_BOARD_RECOMMEND":"Προτεινόμενη εκπομπή","WEBSITE_BOARD_TRENDING":"Δημοφιλής ταινία","WEBSITE_BOARD_NEW":"Νέο βίντεο","WEBSITE_BOARD_EPISODE":"Νέο επεισόδιο","WEBSITE_BOARD_1":"Ψάχνετε να παρακολουθήσετε κάτι ενδιαφέρον; Λάβετε προτάσεις βάσει των προτιμήσεών σας!","WEBSITE_BOARD_2":"Ειδοποιηθείτε όταν κυκλοφορήσει ένα νέο επεισόδιο της αγαπημένης σας εκπομπής ή καναλιού YouTube!","WEBSITE_BOARD_YOUTUBE":"Νέα βίντεο καναλιών YouTube","WEBSITE_BOARD_EPISODES":"Νέα επεισόδια των σειρών που ακολουθείτε","WEBSITE_ADDONS":"Πρόσθετα περιεχομένου","WEBSITE_TECH_DETAIL":"Αγαπούμε την τεχνολογία και την επιστήμη!\\nΤο Stremio χρησιμοποιεί τις εξής τεχνολογίες ανοικτού κώδικα:","WEBSITE_TECH_WCJS":"Το WebChimera.js επιτρέπει στο Stremio την αναπαραγωγή οποιασδήποτε μορφής βίντεο με καλές επιδόσεις.","WEBSITE_TECH_WCJS_EXTRA":"Είμαστε οι βασικοί συντελεστές του έργου","WEBSITE_TECH_ELECTRON":"Το Electron αποτελεί μια καινοτόμα πλατφόρμα για την ανάπτυξη του Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Είμαστε συντελεστές του έργου","WEBSITE_TECH_LINVODB":"Μια τεχνολογία βάσης δεδομένων που εξασφαλίζει ότι τα δεδομένα σας είναι οργανωμένα και διαθέσιμα απ\' όπου κάνετε σύνδεση.","WEBSITE_TECH_LINVODB_EXTRA":"Τεχνολογία από εμάς","WEBSITE_CREATE_ADDON":"Δημιουργήστε το πρόσθετό σας","WEBSITE_CREATE_ADDON_DETAIL":"Διαθέτετε κάποια υπηρεσία παροχής περιεχομένου βίντεο; Θα σας βοηθήσουμε να επωφεληθείτε από τις δυνατότητες του Stremio δημιουργώντας το πρόσθετό σας.","WEBSITE_CREATE_ADDON_BENEFITS":"Οφέλη της δημιουργίας ενός προσθέτου για το Stremio","WEBSITE_P2P_BEAUTY":"Η ομορφιά της ροής peer-to-peer","WEBSITE_P2P_1":"Αξιόπιστη και προσιτή προβολή Full HD/4K βίντεο on demand ή σε ζωντανή ροή","WEBSITE_P2P_2":"Πλατφόρμα διανομής με εξαιρετική εμπειρία χρήσης","WEBSITE_P2P_3":"Θα δημιουργήσουμε ένα πρόσθετο που θα καλύπτει απόλυτα τις ανάγκες σας","WEBSITE_P2P_CONTACT":"Σας ενδιαφέρει; Μπορείτε πάντα να επικοινωνήσετε μαζί μας.","WEBSITE_P2P_CONTACT_EXTRA":"Θα χαρούμε να σας βοηθήσουμε στην ενσωμάτωση του περιεχομένου σας στο Stremio!","WEBSITE_P2P":"Κατά καιρούς, εμφανίζεται μια τεχνολογία που αλλάζει το τοπίο. Επενδύσαμε πολύ χρόνο και προσπάθεια στην ανάπτυξη της δικής μας μηχανής ροής βίντεο Peer-to-Peer (P2P) που παρέχει εξαιρετικές επιδόσεις και ανταποκρίνεται σε κάθε είδους χρήση.\\nΕπικοινωνήστε μαζί μας για P2P βίντεο με DRM, on demand ή σε ζωντανή ροή.","WEBSITE_THOUGHTS":"Οι σκέψεις μας:","WEBSITE_SPREAD":"Μιλήστε σε άλλους για το Stremio:","WEBSITE_CONTACT":"Επικοινωνήστε μαζί μας, θα χαρούμε να σας ακούσουμε!","WEBSITE_OPENSOURCE":"Για τα έργα μας με ανοικτό κώδικα, μεταβείτε στο","WEBSITE_BITCOIN":"Δωρεά bitcoin:","WEBSITE_FAQ":"Συχνές ερωτήσεις","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Ερωτήσεις","WEBSITE_TOS":"Όροι χρήσης","WEBSITE_LEGAL":"Νομικά","WEBSITE_PAGE_ABOUT":"Πληροφορίες","WEBSITE_PAGE_BECOME_PARTNER":"Γίνετε συνεργάτης","WEBSITE_ALL_YOU_CAN_WATCH":"Δείτε ό,τι θέλετε, ελεύθερα.","WEBSITE_FREEDOM_TO_STREAM":"Ελευθερία στο streaming","WEBSITE_WHAT_IS_STREMIO":"Τι είναι το Stremio;","WEBSITE_WHAT_IS_STREMIO_P1":"Το Stremio αποτελεί ένα ενιαίο κέντρο για περιεχόμενο βίντεο. Ανακαλύψτε, οργανώστε και παρακολουθήστε βίντεο από όλα τα είδη πηγών σε οποιαδήποτε συσκευή σας.","WEBSITE_WHAT_IS_STREMIO_P2":"Ταινίες, εκπομπές, σειρές, ζωντανή τηλεόραση ή διαδικτυακά κανάλια, όπως το YouTube και το Twitch.tv - μπορείτε να τα βρείτε όλα στο Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Το Stremio είναι ένα σύγχρονο κέντρο πολυμέσων για όλο σας το ψυχαγωγικό περιεχόμενο βίντεο. Ανακαλύψτε, παρακολουθήστε και οργανώστε το περιεχόμενο βίντεο με εύχρηστα πρόσθετα.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Ταινίες, εκπομπές, ζωντανή τηλεόραση ή διαδικτυακά κανάλια - βρείτε τα όλα στο Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Απολαύστε σε όλες τις συσκευές πολυμέσων σας","WEBSITE_DEVICES_COLLECT":"Συλλογή από Stremio","WEBSITE_DEVICES_IMPORT_FB":"Εισαγωγή από Facebook","WEBSITE_DEVICES_LOCAL":"Προσθήκη από τοπικό δίσκο","WEBSITE_JOIN_THE_PARTY_NOW":"Ελάτε κι εσείς στο πάρτι","WEBSITE_DEVICES_ALL":"Εύκολο στη χρήση σε όλες σας τις συσκευές·","WEBSITE_EXTENDABLE_CATALOG":"Απεριόριστα επεκτάσιμος κατάλογος βίντεο·","WEBSITE_ORGANIZE_YOUR_MEDIA":"Εξαιρετικές δυνατότητες οργάνωσης πολυμέσων·","WEBSITE_AS_SEEN_ON":"Γνώμες από τον τύπο","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Σχετικά με εμάς","WEBSITE_LINK_TECHNOLOGY":"Τεχνολογία","WEBSITE_LINK_APPS":"Εφαρμογές","WEBSITE_LINK_DOWNLOADS":"Λήψεις","WEBSITE_MORE":"Περισσότερα","WEBSITE_LINK_ADDONS":"Πρόσθετα","WEBSITE_LINK_ADDON_SDK":"SDK προσθέτων","WEBSITE_LINK_CONTRIBUTE":"Συνεισφορά","WEBSITE_LINK_COMMUNITY":"Κοινότητα","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & ακόμα πιο πολλά","WEBSITE_LINK_HELP":"Κέντρο βοήθειας","WEBSITE_LINK_CONTACTS":"Επαγγελματικές ερωτήσεις","WEBSITE_LINK_TOS":"Όροι & προϋποθέσεις","WEBSITE_LINK_PRAVACY":"Πολιτική απορρήτου","WEBSITE_SUBSCRIBE":"Συνδρομή","WEBSITE_NEWSLETTER":"Εγγραφείτε στο ενημερωτικό μας δελτίο για απίθανα πράγματα","WEBSITE_PLACEHOLDER_EMAIL":"Το email σας","WEBSITE_COMMUNITY":"Κοινότητα","WEBSITE_LINK_PRAVACY_LEGAL":"Απόρρητο & νομικά","WEBSITE_WHY":"Γιατι το κανουμε","WEBSITE_WHY_P1":"Στο Stremio, εργαζόμαστε καθημερινά επειδή θέλουμε να επιλύσουμε ένα σημαντικό πρόβλημα της βιομηχανίας βίντεο on demand. Υπάρχει τόσο πολύ νέο περιεχόμενο που δημοσιεύεται κάθε λεπτό, που είναι σχεδόν αδύνατο να το διαχειριστείτε.","WEBSITE_WHY_P2":"Βοηθούμε τους ανθρώπους να πλοηγηθούν σε αυτόν τον τεράστιο κόσμο βίντεο ψυχαγωγίας και να ανακαλύψουν νέο περιεχόμενο. Οι εφαρμογές μας συνδυάζουν ταινίες, σειρές, ζωντανή τηλεόραση, διαδικτυακά κανάλια και πολλά άλλα. Έχουμε αφοσιωθεί στο να κάνουμε την εύρεση τίτλων εξαιρετική εύκολη για τους χρήστες μας.","WEBSITE_WHY_P3":"Μπορείτε να χρησιμοποιήσετε την υπηρεσία μας σε οποιαδήποτε συσκευή και ανά πάσα στιγμή, καθιστώντας το Stremio το μοναδικό κέντρο ψυχαγωγίας βίντεο που θα χρειαστείτε.","WEBSITE_TEAM":"Ομάδα","WEBSITE_TEAM_P":"Η ομάδα του Stremio είναι μικρή αλλά ισχυρή: τα δέκα μέλη της γράφουν κώδικα σε X γλώσσες και μοιράζονται εμπειρία στην ανάπτυξη λογισμικού, στον σχεδιασμό UI και UX, στο μάρκετινγκ και στη διαφήμιση, καθώς και στις επιχειρήσεις.","WEBSITE_FEATURES":"Λειτουργίες","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Εύκολη ανακάλυψη νέου περιεχομένου","WEBSITE_FEATURES_DISCOVER_P":"Ανακαλύψτε εύκολα νέες ταινίες, εκπομπές, σειρές και κανάλια. Περιηγηθείτε κατά κατηγορία, είδος, βαθμολογία, πρόσφατη προβολή κ.λπ. ή απλά πληκτρολογήστε ένα όνομα. Το Stremio κάνει πανεύκολη την εύρεση νέου περιεχομένου.","WEBSITE_FEATURES_ALL_CONTENT":"Όλο σας το περιεχόμενο σε μία οθόνη","WEBSITE_FEATURES_ALL_CONTENT_P1":"Δείτε ποιες ταινίες, σειρές ή βίντεο δεν τελειώσατε και συνεχίστε την παρακολούθηση τους· λάβετε ειδοποιήσεις για νέα επεισόδια και κυκλοφορίες· περιηγηθείτε στις προτάσεις που θα λάβετε βάσει των συνηθειών παρακολούθησής σας.","WEBSITE_FEATURES_LIBRARY":"Οργάνωση βιβλιοθήκης βίντεο","WEBSITE_FEATURES_LIBRARY_P1":"Προσθέστε οποιονδήποτε τίτλο στη βιβλιοθήκη του Stremio σας με ένα μόνο κλικ και πλοηγηθείτε στο περιεχόμενό σας, οργανωμένο κατά τύπο, πρόσφατη προβολή ή αλφαβητική σειρά.","WEBSITE_FEATURES_CALENDAR":"Εποπτεία όλων όσων παρακολουθείτε","WEBSITE_FEATURES_CALENDAR_P1":"Δείτε ένα ημερολόγιο με όλες τις ταινίες και σειρές που προσθέτετε στη βιβλιοθήκη σας. Εξαγάγετε και συγχρονίστε το ημερολόγιο σας, ώστε να γνωρίζετε πάντα πότε θα κυκλοφορήσει ένα νέο επεισόδιο ή μια νέα σειρά.","WEBSITE_FEATURES_BIG_SCREEN":"Απολαύστε το περιεχόμενό σας σε μεγαλύτερη οθόνη","WEBSITE_FEATURES_BIG_SCREEN_P1":"Μεταδώστε ό,τι παρακολουθείτε σε μια άλλη συσκευή - σε τηλέφωνο, tablet ή τηλεόραση TV με ένα μόνο κλικ.","WEBSITE_FEATURES_SOURCES":"Προβολή βίντεο από πολλές διαφορετικές πηγές","WEBSITE_FEATURES_SOURCES_P":"Εγκαταστήστε επίσημα πρόσθετα και πρόσθετα κοινότητας για να απολαμβάνετε βίντεο από πολλούς διαφορετικούς παρόχους - όλα σε μία κομψή, εύχρηστη εφαρμογή.","WEBSITE_CREATE_AN_ADDON":"Δημιουργία προσθέτου","WEBSITE_FEATURES_SYNC":"Συγχρονίστε τη βιβλιοθήκη σας σε πολλαπλές συσκευές και συνεχίστε την αναπαραγωγή","WEBSITE_FEATURES_SYNC_P1":"Συνδεθείτε με τον λογαριασμό σας σε όλες τις συσκευές σας και απολαύστε τον συγχρονισμό της βιβλιοθήκης, των προσθέτων, της αναπαραγωγής και του ημερολογίου σας.","WEBSITE_FEATURES_EXTENDABLE":"Επεκτάσιμος κατάλογος βίντεο με τα πρόσθετα","WEBSITE_FEATURES_EXTENDABLE_P1":"Ο κατάλογος προσθέτων του Stremio παρέχει πολυάριθμα πρόσθετα για την παρακολούθηση ποικίλου περιεχομένου βίντεο. Δείτε ταινίες, εκπομπές, ζωντανή τηλεόραση, αθλήματα, ειδήσεις, podcast, διαδικτυακά κανάλια, βιντεοπαιχνίδια και πολλά άλλα.","WEBSITE_FEATURES_AUTO_SUBS":"Αυτόματοι υπότιτλοι","WEBSITE_FEATURES_AUTO_SUBS_P1":"Με τα πρόσθετα υποτίτλων μας, καθορίζονται αυτόματα οι επιλογές για την προτιμώμενη γλώσσα σας.","WEBSITE_FEATURES_CHROMECAST":"Μετάδοση σε Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Απολαύστε το περιεχόμενό σας σε μια μεγαλύτερη οθόνη ή μεταδώστε ό,τι βλέπετε σε μια άλλη συσκευή.","WEBSITE_FEATURES_KEEP_TRACK":"Εποπτεία των αγαπημένων σειρών και καναλιών σας","WEBSITE_FEATURES_KEEP_TRACK_P1":"Δείτε ένα ημερολόγιο και λάβετε ειδοποιήσεις για νέα επεισόδια των αγαπημένων σας σειρών και καναλιών.","WEBSITE_FEATURES_POWER_USER":"Λειτουργίες για έμπειρους χρήστες","WEBSITE_FEATURES_POWER_USER_P1":"Αναπαραγωγή σε εξωτερικό πρόγραμμα","WEBSITE_FEATURES_POWER_USER_P2":"Αναπαραγωγή από αρχείο torrent ή σύνδεσμο magnet","WEBSITE_FEATURES_POWER_USER_P3":"Εισαγωγή στη βιβλιοθήκη από αγαπημένα στο Facebook ή τον τοπικό δίσκο","WEBSITE_ADD_ONS":"Πρόσθετα","WEBSITE_ADD_ONS_P1":"Όλο το περιεχόμενο που παρέχει το Stremio προέρχεται από ένα σύστημα προσθέτων - δεν ενσωματώνεται καθόλου περιεχόμενο και κανένας πάροχος στην εφαρμογή.","WEBSITE_ADD_ONS_P2":"Υπάρχουν δύο ομάδες διαθέσιμων προσθέτων: επίσημα πρόσθετα και πρόσθετα κοινότητας.","WEBSITE_ADD_ONS_P3":"Τα επίσημα αναπτύσσονται και φιλοξενούνται από το Stremio, ενώ τα πρόσθετα κοινότητας δημιουργούνται και φιλοξενούνται από τα μέλη της κοινότητάς μας.","WEBSITE_ADDONS_OFFICIAL":"Επίσημα πρόσθετα","WEBSITE_ADDONS_WATCHUB":"Δείτε τις αγαπημένες σας ταινίες, σειρές και εκπομπές από παρόχους, όπως το iTunes, το Hulu, το Amazon και άλλες υπηρεσίες των ΗΠΑ/ΗΒ.","WEBSITE_ADDONS_YOUTUBE":"Παρακολουθήστε τα αγαπημένα σας κανάλια YouTube χωρίς διαφημίσεις και λάβετε ειδοποιήσεις για νέες μεταφορτώσεις από τους δημιουργούς που ακολουθείτε.","WEBSITE_ADDONS_FILMON":"Παρακολουθήστε ζωντανή τηλεόραση, ταινίες και εκπομπές δωρεάν. 600 τηλεοπτικά κανάλια, 45.000 δωρεάν ταινίες, ντοκιμαντέρ και πολλά άλλα.","WEBSITE_ADDONS_OPENSUBTITLES":"Υπότιτλοι ταινιών και σειρών σε πολλαπλές γλώσσες, μεταφορτώνονται χιλιάδες μεταφρασμένοι υπότιτλοι καθημερινά.","WEBSITE_ADDONS_COMMUNITY":"Πρόσθετα κοινότητας","WEBSITE_ADDONS_FILMON_VOD":"Παρακολουθήστε βίντεο on demand από το Filmon.tv","WEBSITE_ADDONS_TWICH":"Παρακολουθήστε ζωντανές ροές από το Twitch.tv - μια πλατφόρμα ροής βίντεο για τη βιομηχανία των e-sports.","WEBSITE_ADDONS_VODO":"Παρακολουθήστε ανεξάρτητες ταινίες εντελώς δωρεάν.","WEBSITE_ADDONS_NETFLIX":"Παρακολουθήστε ταινίες και σειρές του Netflix.","WEBSITE_ADDONS_CREATE":"Δημιουργία προσθέτου","WEBSITE_ADDONS_CREATE_P1":"Εάν το επιθυμείτε, μπορείτε να αναπτύξετε το δικό σας πρόσθετο. Με αυτόν τον τρόπο, μπορείτε να παραχωρήσετε στον εαυτό σας και στην κοινότητά μας πρόσβαση σε νέο περιεχόμενο βίντεο και να προσεγγίσετε ένα νέο κοινό εκατομμυρίων χρηστών παγκοσμίως.","WEBSITE_ADDONS_START_CREATE":"Για να ξεκινήσετε, επισκεφθείτε τη σελίδα του SDK προσθέτων του Stremio:","WEBSITE_DOWNLOADS":"Λήψεις","WEBSITE_DOWNLOADS_P1":"Για βέλτιστες επιδόσεις, προτείνουμε τη χρήση της πιο πρόσφατης έκδοσης των εφαρμογών Stremio. Αν όμως, για κάποιο λόγο, θέλετε να χρησιμοποιήσετε μια παλαιότερη έκδοση, μπορείτε να τη βρείτε εδώ.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio για Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio για macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio για Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio για Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio για Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio για φορητή συσκευή Android","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio για το Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio για iOS (περιορισμένη έκδοση)","WEBSITE_CONTRIBUTE":"Συνεισφορά","WEBSITE_CONTRIBUTE_P1":"Η πλατφόρμα του Stremio είναι ανοικτού κώδικα και μπορείτε εύκολα να δημιουργήσετε ένα πρόσθετο για περιεχόμενο που δεν παρέχεται αυτήν τη στιγμή.","WEBSITE_CONTRIBUTE_WHY":"Γιατί να δημιουργήσετε ένα πρόσθετο;","WEBSITE_CONTRIBUTE_WHY_P1":"Βρείτε νέο κοινό για τα βίντεό σας","WEBSITE_CONTRIBUTE_WHY_P2":"Η βάση χρηστών του Stremio αυξάνεται ταχύτατα - μέσα στο πρώτο έτος κυκλοφορίας, το Stremio απέκτησε 1 εκατομμύριο χρήστες σε όλο τον κόσμο, ενώ το δεύτερο έτος της ύπαρξης της πλατφόρμας ο αριθμός αυτός έφτασε τα 2,5 εκατομμύρια.","WEBSITE_CONTRIBUTE_WHY_P3":"Με το πρόσθετό σας, μπορείτε εύκολα να προσεγγίσετε και να διανείμετε το περιεχόμενο σε αυτό το κοινό.","WEBSITE_CONTRIBUTE_ALL":"Παρακολουθήστε τις αγαπημένες σας ταινίες, σειρές, βίντεο και κανάλια σε ένα ενιαίο μέρος.","WEBSITE_CONTRIBUTE_ALL_P1":"Είστε λάτρης ενός συγκεκριμένου τύπου περιεχομένου που δεν διατίθεται ακόμα στο Stremio; Δημιουργήστε ένα πρόσθετο για αυτόν και απολαύστε τα αγαπημένα σας βίντεο σε ένα από τα μεγαλύτερα και πιο εύχρηστα κέντρα ψυχαγωγίας της αγοράς.","WEBSITE_CONTRIBUTE_ALL_P2":"Επιπλέον, θα έχετε την απεριόριστη ευγνωμοσύνη των υπόλοιπων μελών της κοινότητας του Stremio.","WEBSITE_CONTRIBUTE_MONETIZE":"Δημιουργήστε έσοδα με το πρόσθετό σας","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Μόλις αναπτύξετε ένα νέο πρόσθετο για το Stremio, μπορείτε εύκολα να δημιουργήσετε έσοδα μέσω πολλαπλών μεθόδων. Αν σκέφτεστε αυτήν την προοπτική, μπορείτε να επικοινωνήσετε μαζί μας στο ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - θα χαρούμε να ανταλλάξουμε συμβουλές μαζί σας σχετικά με τις επιλογές δημιουργίας εσόδων από τα πρόσθετα.","WEBSITE_CONTRIBUTE_TRANSLATE":"Γίνετε εθελοντής μεταφραστής","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Αν θέλετε να απολαύσετε τις εφαρμογές Stremio σε διαφορετικές γλώσσες, μπορείτε να συμμετάσχετε στην κοινότητα των εθελοντών μεταφραστών μας, οι οποίοι μας βοηθούν να προσθέσουμε εκδόσεις του Stremio σε πολλές διαφορετικές γλώσσες.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Θέλετε να ξεκινήσετε;","WEBSITE_TRANSALTE_STREMIO":"Μετάφραση του Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Επίσημες κοινότητες","WEBSITE_COMMUNITY_OFFICIALS_P1":"Γίνετε μέλος της αναπτυσσόμενης κοινότητας του Stremio. Ακολουθήστε μας στα κοινωνικά δίκτυα και μην ντραπείτε να πείτε ένα «γεια» - λατρεύουμε να γνωρίζουμε τους υποστηρικτές μας! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Ανεπίσημες κοινότητες","STREMIO_COMMUNITY_NL":"Stremio Ολλανδίας","STREMIO_COMMUNITY_BRASIL":"Stremio Βραζιλίας","STREMIO_COMMUNITY_GERMANY":"Stremio Γερμανίας","STREMIO_COMMUNITY_BELGIUM":"Stremio Βελγίου","STREMIO_COMMUNITY_FRANCE":"Stremio Γαλλίας","STREMIO_COMMUNITY_PORTUGAL":"Stremio Πορτογαλίας","STREMIO_COMMUNITY_ITALY":"Stremio Ιταλίας","STREMIO_COMMUNITY_UK":"Stremio ΗΒ","STREMIO_COMMUNITY_USA":"Stremio ΗΠΑ","STREMIO_COMMUNITY_MEXICO":"Stremio Μεξικού","STREMIO_COMMUNITY_ADDONS":"Πρόσθετα Stremio","STREMIO_COMMUNITY_AWESOME":"Το απίθανο Stremio","WEBSITE_COMMUNITY_PARTNERS":"Συνεργάτες και υποστηρικτές","WEBSITE_COMMUNITY_GOODIES":"Καλούδια Stremio","WEBSITE_COMMUNITY_WALLPAPERS":"Ταπετσαρίες","WEBSITE_COMMUNITY_ART":"Συλλογή κοινότητας","WEBSITE_LINK_ART":"Συλλογή κοινότητας","WEBSITE_CONTACT_US":"Επικοινωνία","WEBSITE_CONTACT_US_P1":"Αν έχετε τυχόν απορίες, σχόλια ή προτάσεις, μπορείτε να επικοινωνήσετε μαζί μας μέσω της παρακάτω φόρμας επικοινωνίας.","WEBSITE_CONTACT_US_P2":"Σημειώστε ότι εδρεύουμε στη Βουλγαρία, επομένως ενδέχεται να υπάρξει καθυστέρηση στην απάντησή σας λόγω διαφορών στις ζώνες ώρας.","WEBSITE_CONTACT_US_SUCCESS":"Το μήνυμά σας έχει αποσταλεί. Θα σας απαντήσουμε το συντομότερο δυνατόν.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Παρακαλούμε εισαγάγετε ένα έγκυρο email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Ποιο θέμα αφορά η ερώτησή σας;","WEBSITE_CONTACT_US_Q_OS":"Ποιο είναι το λειτουργικό σας σύστημα;","WEBSITE_CONTACT_US_PH_EMAIL":"Το email σας","WEBSITE_CONTACT_US_PH_MESSAGE":"Μήνυμα","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"Αποστολή","WEBSITE_CONTACT_US_Q_1":"Πώς κάνω εγκατάσταση;","WEBSITE_CONTACT_US_Q_2":"Πώς κάνω κατάργηση εγκατάστασης;","WEBSITE_CONTACT_US_Q_3":"(HTML) Πώς φτιάχνω λαζάνια;","WEBSITE_CONTACT_US_Q_4":"Πρόσθετα","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Τεχνολογία","WEBSITE_TECHNOLOGY_P1":"Αγαπούμε την τεχνολογία και την επιστήμη.
Δείτε τι κρύβεται πίσω από το Stremio (είναι όλα ανοικτού κώδικα).","WEBSITE_TECHNOLOGY_P_QT":"Η ανάπτυξη λογισμικού για πολλαπλές πλατφόρμες, στα καλύτερά της.","WEBSITE_TECHNOLOGY_P_MPV":"Ένα δωρεάν, ανοικτού κώδικα, πρόγραμμα αναπαραγωγής πολυμέσων για πολλαπλές πλατφόρμες.","WEBSITE_TECHNOLOGY_P_RN":"Το React Native σάς επιτρέπει να αναπτύσσετε εφαρμογές για κινητές συσκευές, μόνο με τη χρήση JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Ενσωματωμένο πλαίσιο πολυμέσων στην εφαρμογή για τη λήψη πολυμέσων.","WEBSITE_TECHNOLOGY_P_REALM":"Το Realm είναι μια πλατφόρμα για κινητές συσκευές και αντικαθιστά τα SQLite και Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Το Node.js είναι ένα ανοικτού κώδικα περιβάλλον εκτέλεσης JavaScript για όλες τις πλατφόρμες.","WEBSITE_TECHNOLOGY_P_RUST":"Η Rust είναι μια γλώσσα πολλαπλών προγραμματιστικών παραδειγμάτων, η οποία εστιάζει στην ασφάλεια και ειδικά στον ασφαλή ταυτοχρονισμό.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Συνεισφορά στο έργο","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Υπάρχουν δύο τρόποι συνεισφοράς στο Stremio για την περαιτέρω βελτίωση του προϊόντος.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Μπορείτε να δωρίσετε τις πολύτιμες γλωσσικές ικανότητές σας μεταφράζοντας την πλατφόρμα...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"ή","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... μπορείτε να αξιοποιήσετε τις ικανότητές σας στον προγραμματισμό για τη δημιουργία προσθέτων κοινότητας. ","WEBSITE_TRANSLATE_STREMIO":"Μετάφραση του Stremio","WEBSITE_404_OH_NO":"Ωχ όχι! Η σελίδα που ψάχνετε δεν είναι εδώ...","WEBSITE_GO_HOME":"Αρχική","WEBSITE_LINK_OTHER_DOWNLOADS":"Άλλες λήψεις","WEBSITE_FAQ_ABR":"Συχνές ερωτήσεις","WEBSITE_SUPPORT":"Υποστήριξη","WEBSITE_DOWNLOAD_4_0_BETA":"Λήψη του Stremio 4 Beta","WEBSITE_GET_FOR_DESKTOP":"Λήψη για υπολογιστή","WEBSITE_LINK_ADDON_COMPETITION":"Διαγωνισμός προσθέτων","WEBSITE_LINK_ART_CONTEST":"Καλλιτεχνικός διαγωνισμός","WEBSITE_MY_ACCOUNT":"Ο λογαριασμός μου","WEBSITE_MAINPAGE_FAQ_001_H1":"Τι είναι το Stremio;","WEBSITE_MAINPAGE_FAQ_001_P1":"Το Stremio είναι ένα σύγχρονο κέντρο πολυμέσων που σας επιτρέπει να παρακολουθήσετε τα πάντα.","WEBSITE_MAINPAGE_FAQ_002_H1":"Πώς λειτουργεί;","WEBSITE_MAINPAGE_FAQ_002_P1":"Μόλις εγκαταστήσετε το Stremio στη συσκευή σας και δημιουργήσετε έναν λογαριασμό, το μόνο που χρειάζεται να κάνετε είναι να επισκεφθείτε τον κατάλογο προσθέτων και να εγκαταστήσετε όποιο πρόσθετο επιθυμείτε. Αυτό ήταν!","WEBSITE_MAINPAGE_FAQ_002_P2":"Έπειτα, μπορείτε να μεταβείτε στις ενότητες «Ανακάλυψη» ή «Πίνακας» για να ξεκινήσετε την εξερεύνηση περιεχομένου.","WEBSITE_MAINPAGE_FAQ_003_H1":"Τι μπορώ να παρακολουθήσω εδώ;","WEBSITE_MAINPAGE_FAQ_003_P1":"Πολλά: Ταινίες, εκπομπές, διαδικτυακά κανάλια, αθλήματα, τηλεοπτικά κανάλια, podcasts και πολλά άλλα. Χάρη στο σύστημα προσθέτων μας, μπορείτε να προσπελάσετε μια ευρεία γκάμα περιεχομένου.","WEBSITE_MAINPAGE_FAQ_004_H1":"Είναι το Stremio λογισμικό ανοικτού κώδικα;","WEBSITE_MAINPAGE_FAQ_004_P1":"Ναι, μπορείτε να δείτε τους εξής συνδέσμους: ${1}εφαρμογή για υπολογιστές${2} και ${3}οργανισμός GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Είναι το Stremio ασφαλές;","WEBSITE_MAINPAGE_FAQ_005_P1":"Ναι. Επειδή είναι λογισμικό ανοικτού κώδικα, ο κώδικάς του είναι δημόσια διαθέσιμος και μπορείτε να τον ελέγξετε και εσείς.","WEBSITE_MAINPAGE_FAQ_006_H1":"Τι γίνεται με το απόρρητό μου;","WEBSITE_MAINPAGE_FAQ_006_P1":"Σεβόμαστε το απόρρητο των χρηστών και δεν συλλέγουμε κανένα προσωπικό δεδομένο, εκτός από τα απολύτως απαραίτητα στοιχεία για τη δημιουργία και τον συγχρονισμό του λογαριασμού σας.","WEBSITE_MAINPAGE_FAQ_006_P2":"Υπάρχει επίσης η ${1}λειτουργία επισκέπτη${2} κατά την εγγραφή, η οποία δεν απαιτεί καθόλου δεδομένα: σε αυτήν τη λειτουργία, δεν γίνεται καμία κλήση στο παρασκηνιακό μας σύστημα. Ωστόσο, δεν περιέχει ορισμένες χρήσιμες λειτουργίες, όπως η δυνατότητα συγχρονισμού βιβλιοθήκης με άλλες συσκευές.","WEBSITE_MAINPAGE_FAQ_007_H1":"Μπορώ να κάνω μετάδοση στην τηλεόρασή μου;","WEBSITE_MAINPAGE_FAQ_007_P1":"Ναι, υποστηρίζουμε Chromecast και μπορείτε να κάνετε μετάδοση τόσο από τον υπολογιστή, όσο και από την κινητή σας συσκευή (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Πόσα πρόσθετα διαθέτει το Stremio;","WEBSITE_MAINPAGE_FAQ_008_P1":"Από τα τέλη του 2019, πάνω από 50 - για περισσότερες πληροφορίες, δείτε τον κατάλογο των προσθέτων μας.","WEBSITE_MAINPAGE_FAQ_009_H1":"Μπορώ να επεκτείνω τον κατάλογο προσθέτων του Stremio;","WEBSITE_MAINPAGE_FAQ_009_P1":"Ναι, ανατρέξετε στα εξής: ${1}PimpMyStremio${2}, ${3}κοινότητες Reddit${4}, ${5}Stremio Downloader${6}, κ.λπ.","WEBSITE_MAINPAGE_FAQ_010_H1":"Ποιες συσκευές υποστηρίζει το Stremio;","WEBSITE_MAINPAGE_FAQ_010_P1":"Διαθέτουμε εφαρμογές για Windows, Mac και Linux. Για τις κινητές συσκευές, υποστηρίζουμε Android και iOS, ωστόσο λάβετε υπόψη ότι η έκδοση για iOS διαθέτει περιορισμένη λειτουργικότητα (δεν υποστηρίζει τα περισσότερα πρόσθετα).","WEBSITE_MAINPAGE_FAQ_010_P2":"Υπάρχουν πολλές συσκευές που βασίζονται στο Android και μπορούν να εκτελέσουν το Stremio, όπως το NVIDIA Shield και το Amazon Fire Stick, αλλά δεν τις υποστηρίζουμε επίσημα.","WEBSITE_MAINPAGE_FAQ_011_H1":"Μπορείτε να προσθέσετε συγκεκριμένο περιεχόμενο στο Stremio;","WEBSITE_MAINPAGE_FAQ_011_P1":"Δυστυχώς, δεν παρέχουμε εμείς το περιεχόμενο, αλλά όσα περισσότερα πρόσθετε έχετε εγκαταστήσει στο Stremio, τόσο περισσότερο περιεχόμενο θα μπορέσετε να βρείτε.","WEBSITE_MAINPAGE_FAQ_012_H1":"Μπορεί το Stremio να κάνει αναπαραγωγή συνδέσμων magnet;","WEBSITE_MAINPAGE_FAQ_012_P1":"Ναι και μπορεί επίσης να κάνει αναπαραγωγή κανονικών συνδέσμων HTTP και αρχείων torrent (μεταφορά και εναπόθεση).","WEBSITE_MAINPAGE_FAQ_013_H1":"Μπορώ να κάνω λήψη ενός βίντεο για προβολή εκτός σύνδεσης;","WEBSITE_MAINPAGE_FAQ_013_P1":"Η διαθεσιμότητα εκτός σύνδεσης αποτελεί επερχόμενη λειτουργία, αλλά εάν επιτρέψετε στο Stremio την προσωρινή αποθήκευση στη συσκευή σας (από τον πίνακα ρυθμίσεων), μπορείτε να παρακολουθήσετε τα βίντεο αργότερα, χωρίς σύνδεση στο διαδίκτυο.","WEBSITE_MAINPAGE_FAQ_014_H1":"Δεν λειτουργεί τίποτα, βοήθεια!","WEBSITE_MAINPAGE_FAQ_014_P1":"Έχετε σίγουρα εγκαταστήσει πρόσθετα; Εάν ναι, δείτε το ${1}κέντρο βοήθειάς${2} μας.","WEBSITE_MAINPAGE_FAQ_015_H1":"Πώς υποστηρίζει το Stremio την ανάπτυξή του;","WEBSITE_MAINPAGE_FAQ_015_P1":"Χρησιμοποιούμε μη παρεμβατικές διαφημίσεις από το ${1}AdEx${2}, μια εταιρεία από την ίδια ιδρυτική ομάδα, που εστιάζει στη διατήρηση του απορρήτου και τις ειλικρινείς διαφημίσεις.","WEBSITE_MAINPAGE_FAQ_015_P2":"Για περισσότερες ερωτήσεις, μεταβείτε στο ${1}κέντρο βοήθειάς${2} μας.","HELP_LEARN_MORE":"Βοηθήστε μας να μάθουμε περισσότερα για εσάς.","LIFESTYLE":"Τρόπος ζωής","SPORTS":"Αθλήματα","FOOD_HEALTH":"Φαγητό & υγεία","BEAUTY_FASHION":"Ομορφιά & μόδα","NEWS":"Ειδήσεις","GAMING":"Παιχνίδια","SCIENCE_EDUCATION":"Επιστήμη & εκπαίδευση","MUSIC":"Μουσική","TRAVEL":"Ταξίδια","LATE_NIGHT":"Βραδινό","REALITY":"Ριάλιτι","COMEDY":"Κωμωδία","DIY":"Κατασκευές","TECH":"Τεχνολογία","CINEMA":"Κινηματογράφος","CONTINUE":"Συνέχεια","SLOW_LOADING":"Αργή Φόρτωση;","I_GIVE_UP":"Ακύρωση","LEARN_MORE":"Μάθετε περισσότερα","POOR_SOURCE":"Αυτή η πηγή δεν είναι επαρκώς διαθέσιμη ή η σύνδεση σας στο διαδίκτυο δεν είναι αρκετά γρήγορη","PICK_CATEGORIES_ERR":"Πρέπει να επιλέξετε τουλάχιστον 3 κατηγορίες","ADJUST_TIMING":"Προσαρμογή χρονισμού με ","ADJUST_SIZE":"Προσαρμογή μεγέθους με ","SEARCH_ANYTHING":"Μπορείτε να αναζητήσετε οτιδήποτε...","ALL_CATEGORIES":"Όλα","SEARCH_CATEGORIES":"Ταινίες, σειρές, YouTube & τηλεόραση","SEARCH_PERSONS":"Ηθοποιοί, σκηνοθέτες & σεναριογράφοι","SEARCH_PROTOCOLS":"Σύνδεσμοι HTTP & Magnet","SEARCH_TYPES":"Σύνδεσμοι IMDB/TVDB","WATCHED":"Προβλήθηκε","SHOW_LESS":"Λιγότερα","LAST_SEARCHES":"Πρόσφατες αναζητήσεις","CLEAR_HISTORY":"Απαλοιφή ιστορικού","CHOOSE_SOME":"ΕΠΙΛΕΞΤΕ ΚΑΠΟΙΑ ΑΠΟ ΑΥΤΑ:","NO_WEB_REMOTE":"Δεν ήταν δυνατή η φόρτωση του Web Remote","STREMIO_OFFLINE":"Το Stremio είναι εκτός σύνδεσης","STREMIO_EXPENSIVE_CONNECTION":"Εντοπίσαμε ότι χρησιμοποιείτε σύνδεση δεδομένων κινητής, θέλετε να συνεχίσετε;","USE_DATA":"Χρήση δεδομένων","WARNING":"Προειδοποίηση","MORE_INFO":"Περισσότερες πληροφορίες...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Φόρτωση...","STREMIO_TV_BACK_TO_LANGUAGES":"Πίσω στις γλώσσες","STREMIO_TV_REMOTE":"Τηλεχειριστήριο","STREMIO_TV_GO_TO":"Μεταβείτε στο:","STREMIO_TV_OR_SCAN":"ή σαρώστε το:","STREMIO_TV_ADDON_INSTRUCTIONS":"Παρακαλούμε ακολουθήστε τις οδηγίες για να εγκαταστήσετε τα προτιμώμενα πρόσθετά σας.","STREMIO_TV_LIVE_TV":"Ζωντανή TV","STREMIO_TV_RESUME_WATCHING":"Συνέχιση παρακολούθησης","STREMIO_TV_LOADING_BACKGROUND":"Φόρτωση παρασκηνίου","STREMIO_TV_CHECKING_AUTHENTICATION":"Έλεγχος ταυτοποίησης","STREMIO_TV_LOADING_BOARD":"Φόρτωση πίνακα","STREMIO_TV_LOGIN_HEADER_LINE_1":"Θέλουμε οι χρήστες μας να έχουν την καλύτερη δυνατή, εξατομικευμένη εμπειρία με το λογισμικό μας.","STREMIO_TV_LOGIN_HEADER_LINE_2":"Αυτός είναι ο λόγος που σας ζητούμε να δημιουργήσετε ή/και να συνδεθείτε στον λογαριασμό σας.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Σας ευχαριστούμε για την κατανόηση,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Η ομάδα του Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Για να χρησιμοποιήσετε το Web Remote με το smartphone/tablet/υπολογιστή σας:","STREMIO_TV_WIFI_SETUP":"Ρύθμιση Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Το Stremio Circle δεν εντόπισε σύνδεση στο διαδίκτυο.","STREMIO_TV_WIFI_DETAILS_1":"Συνδεθείτε στο:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Χρησιμοποιήστε τον κωδικό πρόσβασης:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Ανοίξτε ένα πρόγραμμα περιήγησης με τον σύνδεσμο:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Προεπιλεγμένο","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Από την τελευταία παρακολούθηση","STREMIO_TV_LIBRARY_SORT_NAME":"Από το όνομα","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Από τις φορές που παρακολουθήσατε","STREMIO_TV_DETAILS_SEASON_NUMBER":"Κύκλος ${1}","STREMIO_TV_STREAMS_LOADING":"Φορτωμένα ${1} / ${2} πρόσθετα...","STREMIO_TV_STREAMS_STILL_LOADING":"Το ${1} ακόμα φορτώνει ...","STREMIO_TV_PLAYER_SETTINGS":"Ρυθμίσεις προγράμματος αναπαραγωγής","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Καθυστέρηση υποτίτλων","STREMIO_TV_PLAYER_AUDIO_DELAY":"Καθυστέρηση ήχου","STREMIO_TV_PLAYER_VIDEO_SCALING":"Κλιμάκωση βίντεο","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Μη υποστηριζόμενη πηγή ροής","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Αποτυχία ανοίγματος εξωτερικού συνδέσμου","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Αναπαραγωγή με τον ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Αναπαραγωγή με τον libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Αλλαγή στον libVLC player λόγω σφάλματος αναπαραγωγής","STREMIO_TV_ADDONS_TITLE":"Χρησιμοποιήστε το Stremio στο τηλέφωνο ή τον υπολογιστή σας για να εγκαταστήσετε ή να διαμορφώσετε πρόσθετα και πατήστε \\"Συγχρονισμός πρόσθετων\\"","STREMIO_TV_ADDONS_SUBTITLE":"Σημείωση: βεβαιωθείτε ότι χρησιμοποιείτε τον ίδιο λογαριασμό Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Συγχρονισμός πρόσθετων","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Επιτυχής συγχρονισμός πρόσθετων","STREMIO_TV_ADDONS_SYNC_FAILED":"Αποτυχία συγχρονισμού πρόσθετων","STREMIO_TV_META_LINK_FAILED":"Αποτυχία ανοίγματος μετα-συνδέσμου","STREMIO_TV_CATALOG_LOADING":"Ο κατάλογος φορτώνει...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Η γλώσσα της εφαρμογής ενημερώθηκε","STREMIO_TV_SETTINGS_THEME_UPDATED":"Το θέμα ενημερώθηκε","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Προτιμητέα γλώσσα","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Εναλλακτική Γλώσσα","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Πιθανά προβλήματα αναπαραγωγής σε ορισμένες συσκευές","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Ορισμένες μορφές βίντεο ενδέχεται να μην λειτουργούν","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Αυτόματη αντιστοίχιση ρυθμού καρέ","STREMIO_TV_SETTINGS_NO_CACHING":"Χωρίς προσωρινή αποθήκευση","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Προεπιλεγμένη","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Ήπιο","STREMIO_TV_SETTINGS_PROFILE_FAST":"Γρήγορο","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Πολύ γρήγορο","STREMIO_TV_SETTINGS_SERVER_URL":"URL διακομιστή ροής","STREMIO_TV_SETTINGS_SERVER_VERSION":"Έκδοση διακομιστή","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Άγνωστη","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Έκδοση του Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Επεξεργασία διεύθυνσης URL διακομιστή","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Εισαγάγετε μια διεύθυνση url διακομιστή ροής","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Για να διαβάσετε την Πολιτική Απορρήτου του Stremio, επισκεφτείτε:","STREMIO_TV_SETTINGS_TOS_TEXT":"Για να διαβάσετε τους Όρους και τις Προϋποθέσεις του Stremio, επισκεφτείτε:","STREMIO_TV_NAV_SEARCH":"Αναζήτηση","STREMIO_TV_NAV_HOME":"Αρχική","STREMIO_TV_NAV_DISCOVER":"Περιήγηση","STREMIO_TV_NAV_LIBRARY":"Βιβλιοθήκη","STREMIO_TV_NAV_MOVIES":"Ταινίες","STREMIO_TV_NAV_SERIES":"Σειρές","STREMIO_TV_NAV_CHANNELS":"Κανάλια","STREMIO_TV_NAV_TV":"Ζωντανά","STREMIO_TV_NAV_SETTINGS":"Ρυθμίσεις","STREMIO_TV_NAV_ADDONS":"Πρόσθετα","STREMIO_TV_LOGIN_TITLE":"Σύνδεση λογαριασμού","STREMIO_TV_LOGIN_EXPIRES_IN":"Λήγει σε","STREMIO_TV_LOGIN_STEP_ONE":"Σαρώστε τον κωδικό QR παραπάνω ή μεταβείτε στο","STREMIO_TV_LOGIN_STEP_TWO":"Συνδεθείτε στον λογαριασμό σας στο Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Νέος σύνδεσμος","STREMIO_TV_LOGIN_LINK_REFRESHED":"Ο κωδικός σύνδεσης ανανεώθηκε","STREMIO_TV_SEARCH_PLACEHOLDER":"Πληκτρολόγησε κάτι","STREMIO_TV_SEARCH_NO_ADDONS":"Δεν ζητήθηκαν πρόσθετα για καταλόγους!","STREMIO_TV_SEARCH_BUTTON":"Αναζήτηση","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Κενό","STREMIO_TV_SEARCH_KEY_CLEAR":"Σβήσιμο","STREMIO_TV_SEARCH_HISTORY_TITLE":"Ιστορικό αναζήτησης","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Μπορείτε να αναζητήσετε Τίτλους, Ηθοποιούς, Κανάλια και άλλα...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Διαγράψτε το ιστορικό αναζήτησης","STREMIO_TV_FILTERS_DESCRIPTION":"Επιλέξτε ένα από τα παρακάτω φίλτρα","FILTERS":"Φίλτρα","SETTINGS":"Ρυθμίσεις","ACCOUNT":"Λογαριασμός","LOGOUT":"Αποσύνδεση","THEMES":"Θέματα","PLAYBACK":"Αναπαραγωγή","PLAYBACK_SPEED":"Ταχύτητα Αναπαραγωγής","AUDIO_TRACKS":"Κομμάτια ήχου","VIDEOS":"Βίντεο","SERVER":"Διακομιστής","LINKS":"Σύνδεσμοι","ABOUT":"Πληροφορίες","INTERFACE":"Εμφάνιση","ANIMATIONS":"Οπτικά εφέ","STATUS":"Κατάσταση","LANGUAGE":"Γλώσσα","SIZE":"Μέγεθος","DELAY":"Καθυστέρηση","BOLD":"Έντονα γράμματα","TEXT_COLOR":"Χρώμα κειμένου","OUTLINE_COLOR":"Χρώμα περιγράμματος","BACKGROUND_COLOR":"Χρώμα φόντου","BACKGROUND_BLUR":"Θάμπωμα φόντου","SEEK_TIME_DURATION":"Διάρκεια χρόνου παράλειψης","AUTO_PLAY":"Αυτόματη αναπαραγωγή επόμενου επεισοδίου","PLAY_NOW":"Αναπαραγωγή τώρα","MARK_AS_WATCHED":"Επισήμανση ως προβεβλημένο","MARK_AS_UNWATCHED":"Επισήμανση ως μη προβεβλημένο","REWIND_TO_BEGINNING":"Προβολή από την αρχή","CONTINUE_WATCHING":"Συνεχίστε να βλέπετε","ALL":"Όλα","SECONDS":"Δευτερόλπετα","ON":"Ανοιχτοί","OFF":"Κλειστοί","RELOAD":"Επανάληψη φόρτωσης","EDIT_URL":"Επεξεργασία συνδέσμου URL","NONE":"Κανένα","EMBEDDED":"Ενσωματωμένοι","REMOTE_SWITCH_DEVICES":"Εναλλαγή συσκευών","REMOTE_VIDEOS":"Βίντεο","REMOTE_ADJUST_TIMING":"Προσαρμογή χρονισμού","REMOTE_ADJUST_SIZE":"Προσαρμογή μεγέθους","REMOTE_COULD_NOT_BE_LOADED":"Δεν ήταν δυνατή η φόρτωση του Web Remote","REMOTE_RETRY":"Επανάληψη","TORRENT_PROFILE_DEFAULT":"Προεπιλεγμένο","TORRENT_PROFILE_SOFT":"Ήπιο","TORRENT_PROFILE_FAST":"Γρήγορο","TORRENT_PROFILE_ULTRA_FAST":"Πολύ γρήγορο","FAQ_001_H1":"Τι είναι το Stremio;","FAQ_001_P1":"Το Stremio είναι ένα λογισμικό κέντρου πολυμέσων που έχει σχεδιαστεί για εύκολη πρόσβαση σε ψυχαγωγικά βίντεο. Σας επιτρέπει να οργανώσετε και να παρακολουθείτε την προσωπική σας συλλογή ταινιών, σειρών, καναλιών και ζωντανής τηλεόρασης.","FAQ_001_P2":"Το Stremio συλλέγει το περιεχόμενο, που προβάλλει σε εσάς, από τον τοπικό σας δίσκο και το σύστημα προσθέτων μας.","FAQ_001_P3":"Θα σας ειδοποιήσει επίσης όταν κυκλοφορήσουν νέα επεισόδια/βίντεο/ταινίες που σας ενδιαφέρουν και θα σας προσφέρει προτάσεις ταινιών.","FAQ_02_H1":"Πόσο μοιάζει το Stremio με το Kodi και το Plex;","FAQ_02_P1":"Έχουμε εμπνευστεί από αυτά τα δύο λογισμικά. Όμως έχουν διαφορετικούς στόχους - το Stremio αφορά αποκλειστικά τα ψυχαγωγικά βίντεο και προσπαθεί να γίνει η πιο γνωστή και εύχρηστη λύση.","FAQ_02_P2":"Το Stremio δεν θα προσφέρει ποτέ τόσες λειτουργίες και δυνατότητες προσαρμογής, όσες το Kodi και το Plex, αλλά είναι σημαντικά πιο απλό στη χρήση. ${1} Δοκιμάστε το κι εσείς ${2} :)","FAQ_03_H1":"Πόσο μοιάζει το Stremio με το Netflix;","FAQ_03_P1":"Το Netflix αποτελεί μία από τις εμπνεύσεις μας. Προσπαθούμε να επιτύχουμε την εμπειρία χρήσης του Netflix, σε συνδυασμό με πολλά άλλα «καλούδια». Το πιο σημαντικό όμως είναι ότι σας παρέχουμε την ελευθερία να διαχειρίζεστε τη δική σας βιβλιοθήκη και να προσθέτετε νέες πηγές περιεχομένου με το σύστημα προσθέτων μας.","FAQ_03_P2":"Αυτό καθιστά το Stremio απεριόριστα επεκτάσιμο, ώστε να μην περιορίζεστε ποτέ στο περιεχόμενο που αποφασίζει να προσθέσει το Netflix. Για παράδειγμα, μέσω του Stremio μπορείτε να παρακολουθήσετε περιεχόμενο από το ${1} Filmon.tv ${2}, το ${3} Twitch.tv${4}, το ${5}YouTube${6}, το ${7}Vodo${8}, ακόμα και από το ίδιο το ${9}Netflix${10}!","FAQ_04_H1":"Πόσο μοιάζει το Stremio με το Flipboard;","FAQ_04_P1":"Δεν λαμβάνουμε τόσο συχνά αυτήν την ερώτηση, εκτός αν μιλάμε με άτομα από νεοφυείς εταιρείες :)","FAQ_04_P2":"Το Stremio είναι εκ σχεδιασμού μια εφαρμογή συγκέντρωσης περιεχομένου, αποτελώντας πρακτικά ένα Flipboard για βίντεο. Αυτό είναι ιδιαίτερα προφανές στην ενότητα «Πίνακας», η οποία παρέχει καταλόγους και ειδοποιήσεις νέων επεισοδίων/βίντεο για όσα ακολουθείτε, όπως και το Flipboard.","FAQ_05_H1":"Πόσο μοιάζει το Stremio με το Popcorn Time;","FAQ_05_P1":"Το Stremio και το Popcorn Time μοιάζουν όσον αφορά το περιβάλλον χρήστη, επειδή δεν υπάρχουν και τόσοι πολλοί τρόποι για τη σωστή υλοποίηση ψυχαγωγικών καταλόγων βίντεο :)","FAQ_05_P2":"Ωστόσο, το Popcorn Time εστιάζει στη ροή torrent από συγκεκριμένες πηγές, ενώ το Stremio κάνει απλά συγκέντρωση περιεχομένου - δεν περιορίζεται σε μια συγκεκριμένη πηγή περιεχομένου.","FAQ_05_P3":"Επιπλέον, δεν παρέχουμε κανένα πρόσθετο για torrent από προεπιλογή, επομένως το Stremio δεν καλύπτει τις δυνατότητες του Popcorn Time με την επίσημη λειτουργικότητά του.","FAQ_05_P4":"Μια ακόμα αξιοσημείωτη διαφορά είναι ότι ο κώδικας του Popcorn Time είναι πλήρως ανοικτός, ενώ ο κώδικας του Stremio είναι ${1}μερικώς ανοικτός{2}.","FAQ_06_H1":"Θα προσθέσετε αυτήν την ταινία/σειρά;","FAQ_06_P1":"Δυστυχώς, όχι :(","FAQ_06_P2":"Όπως αναφέρουμε και σε πολλές άλλες απαντήσεις, το Stremio δεν παρέχει από μόνο του περιεχόμενο - όλα προστίθενται μέσω του συστήματος προσθέτων. Σε περίπτωση που έχετε κάποιο αίτημα περιεχομένου, μπορείτε να χρησιμοποιήσετε το κουμπί «Αναφορά» στο πρόγραμμα αναπαραγωγής, το οποίο θα στείλει ένα email στον δημιουργό του προσθέτου που χρησιμοποιείτε τη δεδομένη στιγμή.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Θα δημιουργήσετε πρόσθετο για το X;","FAQ_08_P1":"Είναι πολύ πιθανό.","FAQ_08_P2":"Αν έχετε κάποια ιδέα για ένα πρόσθετο, στείλτε μας ένα email στο ${1}office@stremio.com${2}, αλλά παρακαλούμε βεβαιωθείτε ότι η ιδέα σας δεν θα παραβιάσει κανένα πνευματικό δικαίωμα ή όρο χρήσης.","FAQ_08_P3":"Αυτήν τη στιγμή, τα επόμενά μας σχέδια περιλαμβάνουν πρόσθετα για το FandangoNOW, το Filmon.tv και το Crunchyroll.","FAQ_09_H1":"Το Stremio χρησιμοποιεί το BitTorrent;","FAQ_09_P1":"Ναι, το Stremio υποστηρίζει το BitTorrent ως πρωτόκολλο ροής. Μπορείτε να το χρησιμοποιήσετε με ένα πρόσθετο για torrent, με εναπόθεση ενός αρχείου .torrent στο Stremio ή με επικόλληση ενός συνδέσμου magnet στη γραμμή αναζήτησης.","FAQ_09_P2":"Παρακαλούμε σημειώστε ότι το μόνο επίσημο πρόσθετο που χρησιμοποιεί BitTorrent είναι το ${1}Vodo${2}, που παρέχει ανεξάρτητο περιεχόμενο για το οποίο επιτρέπεται η διανομή με BitTorrent.","FAQ_09_P3":"Δεν υποστηρίζουμε τη χρήση τρίτων προσθέτων που ενδέχεται να οδηγήσουν σε καταπάτηση πνευματικών δικαιωμάτων.","FAQ_10_H1":"Τι μπορώ να παρακολουθήσω στο Stremio με τα επίσημα πρόσθετα;","FAQ_10_P1":"Από προεπιλογή, μπορείτε να παρακολουθήσετε περιεχόμενο από το Filmon.tv, το YouTube και το Vodo στο Stremio, με το ενσωματωμένο πρόγραμμα αναπαραγωγής. Επιπροσθέτως, διαθέτουμε ένα πρόσθετο για το Twitch.tv και κάποιους άλλους παρόχους.","FAQ_10_P2":"Με όλα τα παραπάνω, παρέχεται μια συλλογή από:","FAQ_10_L1":"Δημοφιλή τηλεοπτικά κανάλια από το Filmon.tv - για παράδειγμα, το E4, το BBC, το Bollyworld TV","FAQ_10_L2":"Όλο το YouTube - για παράδειγμα, το BBC News, το Top Gear, το Vevo, τον PewDiePie","FAQ_10_L3":"Ανεξάρτητες ταινίες με το Vodo","FAQ_10_L4":"Διαδικτυακές μεταδόσεις παιχνιδιών με το Twitch.tv","FAQ_10_P3":"Επιπλέον, υπάρχουν πολλές πηγές περιεχομένου που παρέχονται από τα πρόσθετα Guidebox και Netflix, τα οποία δεν κάνουν αναπαραγωγή εξ ολοκλήρου εντός του Stremio, αλλά ανακατεύθυνση στην αντίστοιχη υπηρεσία. Για παράδειγμα, το πρόσθετο Guidebox σάς προσφέρει μια συλλογή από ταινίες που μπορείτε να παρακολουθήσετε δωρεάν στις ΗΠΑ, από υπηρεσίες όπως το TubiTV και το Crackle.","FAQ_11_H1":"Το Stremio δεν εγκαθίσταται, τι να κάνω;","FAQ_11_P1":"Εάν χρησιμοποιείτε Windows, δοκιμάστε ${1}αυτό το εναλλακτικό πρόγραμμα εγκατάστασης${2}.","FAQ_11_P2":"Εάν χρησιμοποιείτε Mac OS X, σημειώστε ότι δεν υποστηρίζουμε καμία έκδοση πριν από το OS X Mavericks (10.9).","FAQ_11_P3":"Εάν χρησιμοποιείτε Linux, σημειώστε ότι υποστηρίζουμε μόνο εκδόσεις 64-bit (x64) του Linux αυτήν τη στιγμή.","FAQ_11_P4":"Αν δεν μπορείτε ακόμα να λύσετε το πρόβλημά σας, παρακαλούμε στείλτε μας μήνυμα στην {1}ομάδα μας στο Facebook${2}.","FAQ_12_H1":"Γιατί με προειδοποιεί το πρόγραμμα προστασίας από ιούς; Είναι ασφαλές το Stremio;","FAQ_12_P1":"Σας διαβεβαιώνουμε ότι το Stremio είναι ${1}100% «καθαρό»${2}.","FAQ_12_P2":"Το λογισμικό σας, σάς προειδοποιεί επειδή το πρόγραμμα εγκατάστασής μας περιλαμβάνει διαφημίσεις, οι οποίες θεωρούνται ως ad-ware από ορισμένα προγράμματα προστασίας από ιούς.","FAQ_12_P3":"Αν ακόμα έχετε αμφιβολίες, μπορείτε να δοκιμάσετε το ${1}εναλλακτικό πρόγραμμα εγκατάστασής${2} μας.","FAQ_13_H1":"Πώς μπορώ να δημιουργήσω ένα πρόσθετο;","FAQ_13_P1":"Για αρχή, προτείνουμε να δείτε τη ${1}μονάδα του συστήματος προσθέτων${2} μας στο GitHub.","FAQ_13_P2":"Έπειτα, μπορείτε να ακολουθήσετε τον ${1}εισαγωγικό οδηγό${2} μας.","FAQ_13_P3":"Αν δεν διαθέτετε γνώσεις προγραμματισμού, παρακαλούμε αναφέρετε την ιδέα σας στην ${1}κοινότητα του Reddit${2} και επικοινωνήστε μαζί μας σχετικά με την ιδέα σας στο ${3}office@stremio.com${4}.","FAQ_14_H1":"Πώς δημοσιεύονται τα πρόσθετα;","FAQ_14_P1":"Όταν δημιουργήσετε ένα πρόσθετο και έναν κεντρικό υπολογιστή και προσθέσετε ένα πεδίο ακροσημείου (endpoint) στο αρχείο manifest σας, το οποίο δείχνει σε μια λειτουργική διεύθυνση προσθέτου, το πρόσθετο θα δημοσιευτεί αυτόματα στον ${1}κατάλογο προσθέτων${2} μας.","FAQ_14_P2":"Αυτό συμβαίνει επειδή το τμήμα διακομιστή της μονάδας stremio-addons κάνει αυτόματα κλήση στο API μας, προκειμένου να ανακοινώσει το πρόσθετο. Όταν το API μας επαληθεύσει το ακροσημείο (endpoint) σας ως έγκυρο πρόσθετο, τότε θα αρχίσει να εμφανίζεται στον κατάλογο.","FAQ_15_H1":"Μπορώ να εκτελέσω το Stremio στο πρόγραμμα περιήγησής μου;","FAQ_15_P1":"Προς το παρόν, όχι. Αλλά έρχεται σύντομα!","FAQ_15_P2":"Αν έχετε περιέργεια να δείτε μια πρώιμη έκδοση, μπορείτε να τη βρείτε εδώ: ${1}alpha4.strem.io${2}. Σημειώστε ότι η ροή είναι απενεργοποιημένη σε αυτήν την έκδοση. Υποστηρίζουμε τα Chrome, Firefox, Opera και Edge.","FAQ_16_H1":"Η μετάδοση σε τηλεόραση δεν λειτουργεί / οι υπότιτλοι δεν λειτουργούν","FAQ_16_P1":"Η μετάδοση σε τηλεόραση χρησιμοποιεί την τεχνολογία DLNA που δεν είναι κοινή για όλες τις μάρκες και τα μοντέλα τηλεοράσεων. Για τον λόγο αυτό, δεν μπορούμε να τη δοκιμάσουμε σε όλες τις περιπτώσεις, επομένως δεν είναι σε καμία περίπτωση τέλεια. Εργαζόμαστε για τη συνεχή βελτίωση της λειτουργίας, αλλά δεν μπορούμε να προσδιορίσουμε πότε θα αρχίσει να λειτουργεί κανονικά το DLNA στην τηλεόρασή σας.","FAQ_16_P2":"Αν δεν βλέπετε καν την τηλεόρασή σας στο μενού μετάδοσης, παρακαλούμε δοκιμάστε να απενεργοποιήσετε και να ενεργοποιήσετε εκ νέου τη σύνδεση δικτύου σας (στα Windows, κάντε δεξί κλικ στο «Δίκτυο» και επιλέξτε «Ενεργοποίηση/Απενεργοποίηση»). Επίσης, επανεκκινήστε το router, την τηλεόραση και τον υπολογιστή σας.","FAQ_16_P3":"Αν εξακολουθείτε να αντιμετωπίζετε ζητήματα, μπορείτε να μας βοηθήσετε στέλνοντας τη μάρκα και το μοντέλο της τηλεόρασής σας στο ${1}office@stremio.com${2}.","FAQ_16_P4":"Εν τω μεταξύ, προτείνουμε το Chromecast, το οποίο υποστηρίζουμε πολύ καλά ή μπορείτε απλά να συνδέσετε την τηλεόρασή σας στον υπολογιστή σας με ένα καλώδιο HDMI.","FAQ_17_H1":"Το Stremio «παγώνει» ή/και καταρρέει, τι μπορώ να κάνω;","FAQ_17_P1":"Πρώτα απ\' όλα, εάν χρησιμοποιείτε Windows 7 με το πρόγραμμα προστασίας AVG: υπάρχει πρόβλημα με αυτόν τον συνδυασμό. Το πρόβλημα έγκειται στο ίδιο το AVG και δεν υπάρχει κάποιος τρόπος να το επιλύσουμε από την πλευρά μας. Δυστυχώς, οι εξαιρέσεις ή η απενεργοποίηση του λογισμικού ασφαλείας δεν θα λειτουργήσει. Η μόνη λύση είναι να αντικαταστήσετε το AVG με κάποιο άλλο πρόγραμμα.","FAQ_17_P2":"Αν δεν είναι αυτό το πρόβλημα, αλλά χρησιμοποιείτε Windows, παρακαλούμε ενημερώστε στο πιο πρόσφατο Service Pack και ενημερώστε/εγκαταστήστε εκ νέου τα προγράμματα οδήγησης της GPU και έπειτα, δοκιμάστε ξανά.","FAQ_17_P3":"Αν δεν έχει επιλυθεί ακόμα το πρόβλημά σας ή χρησιμοποιείτε Mac ή Linux, παρακαλούμε στείλτε μας μια αναφορά με ακριβείς λεπτομέρειες για το πρόβλημα στην ${1}ομάδα μας στο Facebook${2}.","FAQ_18_H1":"Πώς μπορώ να δημιουργήσω ένα πρόσθετο;","FAQ_18_P1":"Για αρχή, προτείνουμε να δείτε τη ${1}μονάδα του συστήματος προσθέτων${2} μας στο GitHub.","FAQ_18_P2":"Έπειτα, μπορείτε να ακολουθήσετε τον ${1}εισαγωγικό οδηγό${2} μας.","FAQ_18_P3":"Αν δεν διαθέτετε γνώσεις προγραμματισμού, παρακαλούμε αναφέρετε την ιδέα σας στην ${1}κοινότητα του Reddit${2} και επικοινωνήστε μαζί μας σχετικά με την ιδέα σας στο ${3}office@stremio.com${4}.","FAQ_19_H1":"Γιατί το Stremio καταλαμβάνει χώρο στον δίσκο;","FAQ_19_P1":"Το Stremio διαθέτει τοπική προσωρινή μνήμη (cache) για την προσωρινή διατήρηση των αρχείων βίντεο που παρακολουθείτε.","FAQ_19_P2":"Αυτή έχει δύο πλεονεκτήματα: πρώτον, επιτρέπει στο Stremio να προφορτώσει το βίντεο για πιο ομαλή ροή. Δεύτερον, διατηρεί τα βίντεο στην τοπική προσωρινή μνήμη, ώστε να μπορείτε να τα παρακολουθείτε εκτός σύνδεσης.","FAQ_19_P3":"Μπορείτε να προσαρμόσετε το μέγεθος των αρχείων που επιτρέπεται να αποθηκεύει το Stremio με τη ρύθμιση Προσωρινή μνήμη του πίνακα ρυθμίσεων. Το Stremio μπορεί να διατηρήσει έως και το καθορισμένο μέγεθος (π.χ. 2GB) στον δίσκο σας, εκτός αν το τρέχον βίντεο ροής είναι μεγαλύτερο, στην οποία περίπτωση θα πρέπει το Stremio να δεσμεύσει επαρκή χώρο ώστε να διατηρήσει το βίντεο μέχρι να ολοκληρώσετε τη ροή του.","FAQ_20_H1":"Πού βρίσκεται ο φάκελος προσωρινής μνήμης;","FAQ_20_P1":"Στα Windows, είναι ο φάκελος «stremio-cache» στον δίσκο που επιλέξατε από τις Ρυθμίσεις (π.χ. «E:\\\\stremio-cache»)","FAQ_20_P2":"Στο MacOS, είναι στη διαδρομή «~/Library/Application Support/Stremio/stremio-cache»","FAQ_20_P3":"Στο Linux, είναι στη διαδρομή «~/.stremio/stremio-cache» ή «~/stremio-cache»","FAQ_21_H1":"Λαμβάνω το σφάλμα «Δεν βρέθηκε διακομιστής ροής», τι μπορώ να κάνω;","FAQ_21_P1":"Αν λάβετε αυτό το σφάλμα, υπάρχουν δύο πιθανές εξηγήσεις:","FAQ_21_P2":"1) Προσπαθείτε να χρησιμοποιήσετε ένα πρόσθετο με πηγή YouTube/BitTorrent, μέσω της ${1}διαδικτυακής έκδοσης${2}. Σε αυτήν την περίπτωση, θα πρέπει να εγκαταστήσετε την εφαρμογή μας για υπολογιστές από τον ${3}ιστότοπό${4} μας.","FAQ_21_P3":"2) Κάτι δεν πάει καλά με την εγκατάσταση του Stremio σας. Σε αυτήν την περίπτωση, δοκιμάστε να εγκαταστήσετε εκ νέου την πιο πρόσφατη έκδοση για υπολογιστές από τον ${1}ιστότοπό${2} μας. Αν αυτό δεν βοηθήσει, δοκιμάστε να απενεργοποιήσετε τα προγράμματα προστασίας από ιούς και τα τείχη προστασίας, επανεκκινήστε τον υπολογιστή σας και προσπαθήστε ξανά. Αν δεν λειτουργήσει ούτε αυτό, παρακαλούμε στείλτε μας μήνυμα στην ${3}ομάδα μας στο Facebook${4}.","FAQ_22_H1":"Δεν μπορώ να δω/χρησιμοποιήσω τα περισσότερα πρόσθετα στο iOS","FAQ_22_P1":"Λόγω των περιορισμών στους όρους και τις προϋποθέσεις του Apple App Store, διατίθεται μόνο ένα συγκεκριμένο σύνολο προσθέτων για την εφαρμογή του iOS.","FAQ_22_P2":"Αλλά μην ανησυχείτε - θα διατεθούν περισσότερα πρόσθετα για το iOS στο μέλλον και ίσως προστεθεί η δυνατότητα χρήσης όλων των προσθέτων του Stremio, χάρη στη σύνδεση της εφαρμογής για iOS με τον διακομιστή ροής του Stremio."}')},3865:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Movie","TYPE_series":"Series","TYPE_tv":"TV channel","TYPE_channel":"Channel","TYPE_other":"Other","TYPE_movie_PL":"Movies","TYPE_series_PL":"Series","TYPE_tv_PL":"TV channels","TYPE_channel_PL":"Channels","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Back","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Discover","Board":"Board","Library":"Library","My Library":"My Library","Calendar":"Calendar","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"search","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Add to Library","REMOVE_FROM_LIB":"Remove from Library","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Watch Trailer","WATCH_NOW":"Watch Now","SHOW":"Show","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb Rating","YEAR":"Year","DIRECTOR":"Director","WRITER":"Writer","LEAD_ACTORS":"Lead Actors","CAST":"Cast","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Aired","SEASONS":"Seasons","GENRE":"Genre","CATALOG":"Catalog","SUMMARY":"Summary","SHOW_MORE":"Show More","SIMILAR":"Similar","UPCOMING":"Upcoming","ENDED":"Ended","DURATION":"Duration","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"search videos","SEARCH_PLACEHOLDER":"search or paste URL","ADDON":"addon","ADDONS":"Addons","OFFICIAL":"official","ADDONS_OFFICIAL":"Official Stremio Addons","ADDONS_POPULAR":"Popular in your area","ADDON_FREE":"free","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"subscription","ADDON_STREAM_GEORESTRICTED":"not available in your area","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Available Streams","NO_STREAM":"No streams were found","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"Install addons","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons collection already exist","ADDON_REPO_ERR":"Error occurred while adding collection","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Cannot uninstall addon, it is protected","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection URL","ERR_NOT_ADDON_URL":"Not a valid addon URL","ERR_DETECTFROMURL":"Cannot find addon/collection from this URL","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Syncing installed addons to your account failed","SETTINGS_DATA_EXPORT":"Export user data","ADDON_PULL_FAILED":"Syncing installed addons from your account failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Movie still in theaters","WATCH_IN_CINEMA":"Watch it in your local cinema","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Add it to your library to get notified once it is available.","GET_NOTIFIED_WHEN_AVAILABLE":"You will get notified once it is available.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from local files, YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"streaming from","CASTING_TO":"Casting to","NETWORK_STATUS":"Network status","STREAM_SPEED":"Stream speed:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Active:","PEERS_CONNECTED":"Connected:","PEERS_WAITING":"Waiting:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"loading...","PLAYING_LOCAL":"playing from local file","PLAYING_CACHE":"playing from cache","WRONG_SUBS":"Wrong subtitles?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Choose a device to watch on","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Phone / Tablet","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Change subtitles for ","SUBTITLES_CHANGE_NONE":"There are no other subtitles for this language, sorry.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Season","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"rating","SORT_WATCHED":"watched","SORT_YEAR":"year","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"Resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"Dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oscar Winners","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Continue with Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"or","I_ACCEPT":"I accept the","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terms and Conditions","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passwords don\'t match","SIGN_UP":"Sign up","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Log in","LOG_OUT":"Log out","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Guest login","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"click here","WRONG_PASSWORD":"Wrong email or password. In case you have forgotten your password, ","SET_A_PASS":"set a password","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"This email was used with a Facebook login.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Activate this addon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"What\'s new","BUTTON_CONTINUE":"Continue","BUTTON_ACTIVATE":"Activate","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Cancel","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Change password","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Contact support","SETTING_LANGUAGE":"Language","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Quit","CONNECTED":"Connected","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"January","February":"February","March":"March","April":"April","May":"May","June":"June","July":"July","August":"August","September":"September","October":"October","November":"November","December":"December","Monday":"Monday","Tuesday":"Tuesday","Wednesday":"Wednesday","Thursday":"Thursday","Friday":"Friday","Saturday":"Saturday","Sunday":"Sunday","Action":"Action","Comedy":"Comedy","War":"War","Family":"Family","Animation":"Animation","Adventure":"Adventure","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romance","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon collections","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You Can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Stremio 4 beta Now","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can access a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},3989:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filmo","TYPE_series":"Serio","TYPE_tv":"Televida Kanalo","TYPE_channel":"Kanalo","TYPE_other":"Alia","TYPE_movie_PL":"Filmoj","TYPE_series_PL":"Serioj","TYPE_tv_PL":"Televidaj kanaloj","TYPE_channel_PL":"Kanaloj","TYPE_other_PL":"Aliaj","TYPE_ALL":"All","VIDEO":"Video","BACK":"Malantaŭen","MORE":"Pli","DONE":"Farite","COPY":"Kopii","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Esplori","Board":"Tabulo","Library":"Biblioteko","My Library":"Mia biblioteko","Calendar":"Kalendaro","NOTIFICATION_ONLINE":"Nun vi estas enreta","NOTIFICATION_OFFLINE":"Nune vi estas eksterreta","INTERNET_CONNECTION":"Reta Konekto","STORAGE_FULL_TITLE":"Atentu: Via datumstoro estas plena!","STORAGE_FULL_TEXT":"Stremio ne kapablos savi viajn agordojn, preferojn aŭ ensalut-informacion. Konsideru re-ŝalti aŭ re-instali Stremio-n.","SEARCH":"serĉi","SEARCH_NO_RESULTS":"Neniuj rezultoj trovitaj","SEARCH_EXPLANATION_CONTENT":"Serĉi filmojn, seriojn, Youtube kaj TV-kanalojn","SEARCH_EXPLANATION_PEOPLE":"Serĉi aktorojn, reĝisorojn kaj verkistojn","SEARCH_PASTE_LINKS":"Algui HTTP kaj Magnetajn ligilojn","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Aldoni al Biblioteko","REMOVE_FROM_LIB":"Forigi el Biblioteko","ADDED_TO_LIB":"Aldonite al via Biblioteko","REMOVED_FROM_LIB":"Forigita el via Biblioteko","TRAILER":"Film-anonco (trailer)","WATCH_TRAILER":"Spekti Film-anoncon","WATCH_NOW":"Spekti Nun","SHOW":"Vidi","SHOW_MOVIE":"Montri Filmon","WATCH_RANDOM":"Vidi hazarze","IMDB_RATING":"IMDb Poentaro","YEAR":"Jaro","DIRECTOR":"Reĝisoro","WRITER":"Verkisto","LEAD_ACTORS":"Ĉefaj geaktoroj","CAST":"Rolularo","CREW":"Crew","SHOW_MORE_CAST":"Montri pli »","AIRED":"Aerumita","SEASONS":"Sezonoj","GENRE":"Ĝenro","CATALOG":"Katalogo","SUMMARY":"Resumo","SHOW_MORE":"Montri pli","SIMILAR":"Simila","UPCOMING":"Venonta","ENDED":"Finiĝita","DURATION":"Daŭro","FEATURED":"Elstara","METADATA":"Metadatoj","CATEGORY":"Kategorio","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"serĉi videojn","SEARCH_PLACEHOLDER":"Serĉi aŭ algui ligilon","ADDON":"aldonaĵo","ADDONS":"Aldonaĵoj","OFFICIAL":"oficiala","ADDONS_OFFICIAL":"Oficialaj Stremio-aj Aldonaĵoj","ADDONS_POPULAR":"Populara ĉe via regiono","ADDON_FREE":"senpaga","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abono","ADDON_STREAM_GEORESTRICTED":"Ne disponebla ĉe via regiono","ADDON_STREAM_OFFLINECACHE":"Eksterreta Kaŝmemoro","ADDON_STREAM_LOCALFILE":"loka dosiero","SHARE_ADDON":"Konigi Aldonaĵon","AVAILABLE_STREAMS":"Disponeblaj elsendfluoj","NO_STREAM":"Neniu elsendfluo estis trovita","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Por trovi pli elsendfluojn, bonvolu instalu pli aldonaĵojn","STREAM_NOT_SUPPORTED":"La elektita elsendfluo ne estas suportata en ĉi plataformo.","ADDON_CATALOGUE":"Montri ĉiujn aldonaĵojn »","ADDON_CATALOGUE_MORE":"Instali aldonaĵojn","REPO_ADDED":"Deponejo aldonita","ADDON_REPO_EXIST_ERR":"Ĉi tiu aldonaĵa kolekto jam ekzistas","ADDON_REPO_ERR":"Eraro okazis dum aldonado de kolekto","ADDON_ADD_ERR":"Eraro okazis dum aldonado de aldonaĵo","ERR_ADDON_PROTECTED":"Oni ne povas malinstali la aldonaĵon, ĝi estas protektita","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Io misfunkciis - aŭtentikigo eble malsukcesis","ERR_NOT_COLLECTION_URL":"Ĉi tiu ne estas URL por kolekto ","ERR_NOT_ADDON_URL":"Ĉi tiu ne estas valida URL por aldonaĵo","ERR_DETECTFROMURL":"Oni ne povas trovi aldonaĵon/kolekton el ĉi tiu URL","ADDON_DUPLICATE_WARNING":"Atentu: duobligita aldonaĵo","ADDON_COLLECTION_SET_FAILED":"Sinkronigado de instalitaj aldonaĵoj al via konto malsukcesis","SETTINGS_DATA_EXPORT":"Eksportu uzantajn datumojn","ADDON_PULL_FAILED":"Sinkronigado de instalitaj aldonaĵoj el via konto malsukcesis","REFRESH_ON_CLICK":"Alklaku por reprovi","STILL_IN_THEATER":"Filmo ankoraŭ en kinejoj","WATCH_IN_CINEMA":"Spektu ĝin ĉe via loka kinejo","IN_THEATER":"Ĉe kinejo","GET_TICKETS":"Aĉeti boletojn","UPCOMING_EPISODE":"Venonta Epizodo","UPCOMING_EPISODE_MESSAGE":"Ĉi tiu epizodo estos elsendita","MISSING_DATE_EPISODE":"Dato de epizodo mankas","MISSING_DATE_EPISODE_MESSAGE":"Eble ĉi tiu epizodo ne elsendiĝis ankoraŭ","CHANNEL_NOT_SCRAPED":"Ĉi tiu kanalo ankoraŭ ne estis akirita.
Bonvolu reveni post kelkaj minutoj.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Aldonu ĝin al via biblioteko por ricevi sciigon kiam ĝi estos disponebla.","GET_NOTIFIED_WHEN_AVAILABLE":"Vi estos sciigita kiam ĝi estos disponebla.","WARNING_STREAMING_SERVER":"Atentu: loka elsendfluservilo ne estis trovita. Elsendfluado el lokaj dosieroj, Youtube kaj BitTorrent ne estos disponeblaj.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Atentu: ĉi tiu video eble ne estas subtenita de via aparataro (hardware). Sciu, ke la ludado povas esti malrapida.","PLAYER_ERROR":"Ho ve, ludila eraro!","PLAYER_ERROR_LOOKSLIKE":"Ŝajnas ke","PLAYER_ORIENTATION":"Orientiĝo de la ludilo","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Ŝlosita","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensilo","PLAYER_ORIENTATION_LANDSCAPE":"Orientiĝo de la ludilo ŝlosita kiel pejzaĝa reĝimo","PLAYER_ORIENTATION_SENSOR":"Aŭtomata orientiĝo de la ludilo (per sensilo)","PLAYER_PLAYBACK_SPEED":"Rapideco","PLAYER_PLAYBACK_ERROR":"Ludila eraro, bonvolu reprovi","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Nekonata eraro","PLAYER_PLAYBACK_ERROR_DEFAULT":"Pardonon! Ĉi tiu video ne povas esti ludita per {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Sekvos","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Forĵeti","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Spekti nun","STREAMING_FROM":"elsendado el","CASTING_TO":"Elsendante al","NETWORK_STATUS":"Reta stato","STREAM_SPEED":"Elsendada rapideco:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Active:","PEERS_CONNECTED":"Connected:","PEERS_WAITING":"Atendante:","TRANSCODING_WARNING":"Atentu: transcoding video.","STREAM_LOADING":"ŝargante...","PLAYING_LOCAL":"ludante el loka dosiero","PLAYING_CACHE":"ludante el kaŝmemoro","WRONG_SUBS":"Ĉu malĝustaj subtitoloj?","ERR_SUBS_LOADING_TITLE":"Eraro dum ŝarĝo de subtitoloj","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Elektu aparaton per kiun spekti","NO_CAST_DEVICES":"Ne disponeblas aparatoj por elsendi.","NO_SETTINGS":"Agordoj ne disponeblas.","PHONE_TABLET":"Phone / Tablet","SUBTITLES":"Subtitoloj","SUBTITLES_CHANGE":"Ŝangi subtitoloj por ","SUBTITLES_CHANGE_NONE":"Subtitloj por ĉi lingvo ne disponeblas, pardonon.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternative,","SUBTITLES_ADJUST_DELAY":"Sinkronigi subtitoloj:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Aŭ uzu G / H klavojn dum ludado por sinkronigi.","SUBTITLES_ADJUST_DELAY_TIP":"KONSILO: vi povas uzi G / H klavojn dum ludado por sinkronigi.","SUBTITLES_DELAY":"Subtitoloj sinkronado:","SUBTITLES_LOADING":"Ŝarĝante subtitoloj...","SUBTITLES_UNAVAILABLE":"Eksteraj subtitoloj ne disponeblas","SUBTITLES_DISABLED":"Malebligita","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sezono","EPISODE":"Episodo","SPECIAL":"Special","SORT":"ordigi","SORT_BY":"Ordigi laŭ ","FILTER":"filtri","SORT_TRENDING":"tendenca","SORT_RECENT":"lastatempa","SORT_ALPHABET":"a-z","SORT_RATING":"poentaro","SORT_WATCHED":"vidita","SORT_YEAR":"jaro","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nova por vi","New Episodes":"Novaj Epizodoj","New Videos":"Novaj Videoj","Recommendations":"Rekomendoj","LIBRARY_RESUME":"Daŭrigi","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detaloj","LIBRARY_RESUME_DISMISS":"Forĵeti","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oskar-premiitoj","DISCOVER_WARNING_TITLE":"Ho ve!","DISCOVER_EMPTY_CATALOG":"Ĉi tiu aldonaĵo resendas malplenan enhavon.","DISCOVER_ADULT_WARNING":"La enhavo estas videbla nur por plenkreskuloj. Ĉu vi estas +18-aĝa?","DISCOVER_NOADDON_WARNING":"Atentu: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"La enhavo ne ŝargis, eraro okazis.","DISCOVER_ADDON_UNINSTALLED":"Ĉi tiu enhavo ne plu disponeblas, vi eble malinstalis la aldonaĵon.","UNINSTALL_THIS_ADDON":"Malinstali ĉi tiun aldonaĵon","ERR_ADDON_NOT_INSTALLED":"Ĉi tiu aldonaĵo ne estas instalita. Instali nun?","DETAIL_RECEIVE_NOTIF_SERIES":"Ricevi sciigoj de novaj epizodoj Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Ricevi sciigoj de novaj videoj","SIDEBAR_SHOW_STREAMS":"Montri elsendojn","RELAUNCH":"Remalfermi nun!","UPGRADE":"Nova versio estas disponebla! Ĝisdatigu Stremio-n a la lasta versio!","RELOAD_UI":"Reŝargi la uzantan interfacon","MANUAL_UPDATE_TITLE":"Ĝisdatigu vian Stremio version","MANUAL_UPDATE_LINE1":"Vi estas uzante malĝisdatiga version de Stremio, kion tute ne estas rekomendita.","MANUAL_UPDATE_LINE2":"Bonvolu ĝisdatigi kiel eble plej baldaŭ.","BUTTON_UPDATE_LATTER":"Ne nun","BUTTON_UPDATE_NOW":"Ĝisdatigi","ANONYMOUS_USER":"Anonima uzanto","DONT_HAVE_ACC":"Ĉu vi ankoraŭ ne havas konton?","HAVE_ACC":"Ĉu vi jam havas konton?","PASSWORD":"Pasvorto","PASSWORD_CONFIRM":"Konfirmu pasvorton","EMAIL":"Retpoŝto","FB_LOGIN":"Daŭri per Facebook","FB_NOTHINGSHARED":"Nenio estas disdonita sen via permeso","FB_NOPOST":"Ni ne afiŝos nenion en via nomo","OR":"aŭ","I_ACCEPT":"Mi akceptas la","I_ACCEPT_BY_CLICKING":"Alklakante la supran butonon mi atestas, ke mi akceptas la ","TOS":"Uzkondiĉoj","MUST_ACCEPT_TERMS":"Vi devas akcepti la uzkondiĉojn","PASSWORDS_NOMATCH":"Pasvortoj ne koincidas","SIGN_UP":"Registriĝi","SIGN_UP_EMAIL":"Registriĝi per retpoŝto","CLICK_TO_SIGN_UP":"Klaku ĉi por ensaluti.","LOG_IN":"Ensaluti","LOG_OUT":"Elsaluti","EXIT_FULLSCREEN":"Malplenekranigi","ENTER_FULLSCREEN":"Plenekranigi","PLAY_URL_MAGNET_LINK":"Ludi URL/Magneta ligilon","HELP_FEEDBACK":"Helpo kaj sugestoj","TERMS_OF_SERVICE":"Serv-kondiĉoj","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"Pri Stremio","USER_PANEL":"Uzantaj agordoj","LOGIN_LABEL":"Login","GUEST_LOGIN":"Ensaluti kiel gasto","GUEST_LOGIN_NOTICE":"Gasta ensaluto ne estas rekomendita. Uzado de regula ensaluto permesas al Stremio sinkronigi vian Bibliotekon, ricevi sciigojn pri viaj plej ŝatataj serioj/kanaloj. Ĉu vi certas, ke vi volas daŭrigi?","GUEST_LOGIN_NOTICE_2":"Gasta ensaluto ne estas rekomendita - vi ne havos sinkronigitajn sciigojn de Biblioteko kaj Estraro, kiuj estas esencaj funkcioj de Stremio. Ĉu vi certas, ke vi volas daŭrigi?","CLICK_HERE":"klaku ĉi-tie","WRONG_PASSWORD":"Erara retpoŝtadreso aŭ pasvorto. Se vi forgesis vian pasvorton, ","SET_A_PASS":"defini pasvorton","RESET_PASSWORD":"Restarigi pasvorton","FORGOT_PASSWORD":"Ĉu vi forgesis vian pasvorton?","EMAIL_USED_WITH_FB":"Ĉi tiu retpoŝtadreso jam estis uzata kun Facebook-ensaluto.","INVALID_EMAIL":"Bonvolu entajpi validan retpoŝtadreson","INVALID_PASSWORD":"Bonvolu entajpi validan pasvorton","CONN_ERR":"Eraro de konekto - Bonvolu reprovi poste.\\n\\nSe ĉi tiu eraro daŭras, malŝaltu fajroŝirmilojn/kontraŭvirusajn programojn (precipe Bitdefender).","IMPORT_FROM_GUEST":"Importu Bibliotekon el via gasta konto","RECEIVE_UPDATES_EMAIL":"Ricevu ĝisdatigojn al via retpoŝto de Stremio","LOGIN_FAILED":"Ensaluto malsukcesis.","SIGNUP_FAILED":"Aliĝo malsukcesis.","SEARCH_FAILED":"Serĉo malsukcesis","EMAIL_USED":"Ĉi tiu retpoŝtadreso jam estas uzata.","WAITING_FB_LOGIN":"Ensaluto per Facebook...","EXTERNAL_PLAYER_TITLE":"Ludi per ekstera ludilo","EXTERNAL_REMEMBER_PLAYER":"Ĉu vi volas memori vian selekton","EXTERNAL_ALWAYS_PLAY":"Jes","EXTERNAL_ONLY_ONCE":"Ne","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Diru al ni pri tio, kion vi ŝatas","INTRO_TASTE_LONG":"Diru al ni pri tio, kion vi ŝatus spekti","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Helpu nin lerni pli pri vi.","INTRO_TASTE_CHOOSE_THESE":"Elektu kelkajn el ĉi tiuj:","INTRO_TASTE_CHOOSE_MIN":"Elektu almenaŭ 3 kategoriojn","INTRO_TASTE_CHOOSE_MIN_ERR":"Vi devas elekti almenaŭ 3 kategoriojn!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sportoj","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"Novaĵoj","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Scienco kaj Edukado","INTRO_TASTE_MUSIC":"Musiko","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Komedio","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selektita aldonaĵo ne estas subtenata por ĉi tiu platformo.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Ĉu aktivigi ĉi tiun aldonaĵon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Kio estas nova?","BUTTON_CONTINUE":"Continue","BUTTON_ACTIVATE":"Activate","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Cancel","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Forĵeti ĉion","BUTTON_VIEW_ALL":"vidi ĉion","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Importu filmojn aŭ spektaklojn kiujn vi havas ĉe via loka disko","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Agordoj","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Ludilo","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Malfermi per VLC","SETTINGS_UI_LANGUAGE":"Interfaca Lingvo","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Importi el Facebook","SETTINGS_IMPORT_DISK":"Importi el loka disko","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Peti forigon de konto","SETTINGS_CHANGE_PASSWORD":"Ŝangi pasvorton","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Kontaktu subtenon","SETTING_LANGUAGE":"Lingvo","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"versio","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Fini","CONNECTED":"Konektita","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januaro","February":"Februaro","March":"Marto","April":"Aprilo","May":"Majo","June":"Junio","July":"Julio","August":"Aŭgusto","September":"Septembro","October":"Oktobro","November":"Novembro","December":"Decembro","Monday":"Lundo","Tuesday":"Mardo","Wednesday":"Merkredo","Thursday":"Ĵaŭdo","Friday":"Vendredo","Saturday":"Sabato","Sunday":"Dimanĉo","Action":"Agadfilmo","Comedy":"Komedio","War":"Milito","Family":"Familia","Animation":"Animacio","Adventure":"Aventuroj","Fantasy":"Fantasto","Crime":"Krimo","Mystery":"Mistero","Romance":"Romance","Drama":"Dramo","Horror":"Horora Filmo","Thriller":"Suspenso","Sci-Fi":"Sciencfikcio","Music":"Music","Biography":"Biografio","Documentary":"Dokumentario","Sport":"Sport","Musical":"Musical","Western":"Vesterno","Film-Noir":"Film-Noir","News":"News","History":"Historio","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Vivstilo","Science & Education":"Scienco kaj Edukado","Cooking & Health":"Kuirado kaj Sano","Beauty & Fashion":"Beauty & Fashion","Sports":"Sportoj","News & Politics":"Novaĵoj kaj Politiko","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religio","Kids":"Infana","Body & Soul":"Body & Soul","Education":"Edukado","Indian Tv":"Hinda Televido","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Scienca Televido","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"nova video","new episode":"nova epizodo","new movie":"nova filmo","recommended":"rekomendita","we recommend":"ni rekomendas","offer of the day":"offer of the day","news":"novaĵoj","music video":"muzikvideo","CTX_SHOW_HOTKEYS":"Montri Agklavoj","CTX_DISMISS_NOTIF":"Forĵeti sciigojn","CTX_DISMISS_ALL":"Forĵeti ĉion","CTX_SHARE":"Konigi","CTX_COPY_SHARE_LINK":"Kopii ligilon por kunhavigi","CTX_COPY_MAGNET_LINK":"Kopii magnetan ligilon","CTX_COPY_STREAM_LINK":"Kopii elsendfluan ligilon","CTX_DOWNLOAD_VIDEO":"Elŝuti ĉi-tiun videon","CTX_DOWNLOAD_SUBS":"Elŝuti subtitolojn","CTX_VIEW_ON_YOUTUBE":"Spekti ĉe Youtube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Spekti","CTX_WATCHED":"Spektita","CTX_WATCH_BEGINNING":"Spekti ekde la komenco","CTX_WATCH_MOBILE":"Spekti per poŝtelefono","CTX_REWIND":"Rebobeni al komenco","CTX_MARK_WATCHED":"Marki kiel spektita","CTX_MARK_NON_WATCHED":"Marki kiel ne spektita","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Marki la ceterajn kiel rigarditajn","CTX_UNMARK_REST":"Marki la ceterajn kiel ne-spektitajn","CTX_RECEIVE_NEW_NOTIF":"Ricevi novajn sciigojn","CTX_REMOVE_CACHE":"Forigi el kaŝmemoro","CTX_REMOVE_CACHE_EP":"Forigi epizodon el kaŝmemoro","CTX_OPEN_CONTAINING":"Malfermu enhavantan dosierujon","CTX_REMOVE":"Forigi de la biblioteko","CTX_AVAILABLE_OFFLINE":"Disponebla eksterrete","CTX_PAUSED":"Paŭzo","CTX_ALWAYS_ON_TOP":"Ĉiam supre ĉio","CTX_FULLSCREEN":"Plenekrane","CTX_WRONG_SUBS":"Malĝustaj subtitoloj?","CTX_REPORT_ISSUES":"Raporti problemon","CTX_COPY":"Kopii","CTX_PASTE":"Algui","CTX_CLEAR":"Viŝi","CTX_CLEAR_RECENT_SEARCHES":"Viŝi freŝajn serĉojn","HELLO_THERE":"Saluton!","HOPE_YOU_ENJOY":"Ni esperas, ke vi ĝuos Stremio-n kaj ke ĝi jam estas unu el viaj plej ŝatataj aplikaĵoj!","WHO_ARE_WE":"Kiuj ni estas? Ni estas la teamo malantaŭ ĝi - du uloj kiuj intense laboras ĉiutage dum la lastaj 3 jaroj por fari ĉi tiun produkton pli kaj pli bona.","SUPPORT_US":"Se vi ŝatas uzi Stremio, se Stremio estas valora por vi - diskonigu ĝin!","SPREAD_THE_WORD":"Kunhavigu ĝin kun viaj amikoj nun, diskonigu pri Stremio","MORE_PEOPLE":"Ju pli da homoj uzas Stremio-n, des pli bone ĝi fariĝos!","SEND_A_LINK":"Aŭ sendu ligilon al nia retejo","TIP_LOCALFILES":"Konsilo: vi povas ŝovi kaj demeti lokaj videaj dosierojn en Stremio-n","ADDON_MY":"Miaj Aldonaĵoj","ADDON_COMMUNITY":"Komunumaj aldonaĵoj","ADDON_OFFICIAL":"Oficialaj Aldonaĵoj","ADDON_REPOS":"Aldonaĵa kolekto","ADDON_SEARCH":"Serĉi Aldonaĵoj","ADDON_INSTALL":"Instali","ADDON_CONFIGURE":"Agordi","ADDON_UNINSTALL":"Malinstali","ADDON_UPGRADE":"Ĝisdatigi","ADDON_INSTALLED":"Instalita","ADDON_INSTALLED_MSG":"Aldonaĵo instalita!","ADDON_UPGRADED_MSG":"Aldonaĵo ĝisdatita!","ADDON_UNKNOWN":"Nekonata","ADDON_ERR":"Aldonaĵ-instalado eraro!","ADDON_DISCONNECTED":"Malkonektita","ADDON_APP_MISSING":"la aplikaĵo por ĉi tiu fonto ne estas instalita. Ĉu vi volas instali ĝin nun?","ADDON_APP_INSTALL":"Instali nun","ADDON_PAGE":"Paĝo de la aldonaĵo","ADDON_TOP_CONTENT":"La plej bona de ĉi tiu aldonaĵo","ADDON_PROVIDES":"Ĉi tiu aldonaĵo donos al vi:","ADDON_WATCH":"Spekti #{types} nun!","ADDON_WATCH_FREE":"Spekti #{types} SENPAGE nun!","ADDON_ADDON":"Aldonaĵo","ADDON_SUPPORTED_TYPES":"Subtenataj tipoj","ADDON_SUPPORTED_CATALOGS":"Subtenataj katalogoj","ADDON_PROVIDES_DISCOVER":"Pli da #{types} en Discover","ADDON_PROVIDES_STREAMS":"Spekti #{types}","ADDON_PROVIDES_STREAMS_FREE":"Spekti #{types} SENPAGE","ADDON_PROVIDES_SUBTITLES":"Subtitoloj por #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"Neniu informo trovita pri tio ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Daŭre spekti","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmoj elektitaj speciale por vi.
Ĉi tiu filmo estas ekzempla rekomendo.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Spektu tuj!","WEBSITE_SLOGAN_ALL":"La tuta video-enhavo, kiun vi ĝuas en unu loko","WEBSITE_SLOGAN_NEW":"Ĉio, kion vi povas spekti","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Spekti el","WEBSITE_DOWNLOAD":"Elŝuti nun!","WEBSITE_DOWNLOAD_FOR":"Elŝutu Nun Por","WEBSITE_IS_DESKTOP":"Stremio estas komputila aplikaĵo, malfermu ĉi tiun paĝon je via komputilo kaj elŝutu ĝin","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Hejmo","WEBSITE_PAGE_FEATURES":"Funkcioj","WEBSITE_PAGE_ADDONS":"Aldonaĵoj","WEBSITE_PAGE_TECH":"Teknologio","WEBSITE_PAGE_CREATE_ADDON":"Kreu aldonaĵon","WEBSITE_PAGE_CONTACTS":"Kontaktoj","WEBSITE_PAGE_BLOG":"Blogo","WEBSITE_TYPE_movie":"Filmog","WEBSITE_TYPE_series_PL":"Filmoj","WEBSITE_TYPE_tv":"Viva televido","WEBSITE_TYPE_channel":"Kanaloj","WEBSITE_STREMIO_WHAT_IS":"Stremio estas aplikaĵo, kiu helpas vin organizi kaj tuj spekti viajn plej ŝatatajn videojn, filmojn, televidseriojn kaj televidkanalojn..","WEBSITE_FEATURES_WATCH":"Spektu tuj en HD","WEBSITE_FEATURES_WATCH_DETAIL":"Alklaku kaj ludu viajn plej ŝatatajn filmojn, televidajn programojn, filmetojn kaj televidajn kanalojn.","WEBSITE_FEATURES_SUBS":"Aŭtomataj Subtitoloj","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Importi el Facebook","WEBSITE_LIB_LOCAL":"Aldonu el via loka disko","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"Ni amas teknologion, ni amas frenezan sciencon!\\nStremio uzas la jenajn malfermitkodajn teknologiojn","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donaci Bitcoin:","WEBSITE_FAQ":"Plej Oftaj Demandoj","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Demandoj","WEBSITE_TOS":"Uzkondiĉoj","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"Pri","WEBSITE_PAGE_BECOME_PARTNER":"Iĝu partnero","WEBSITE_ALL_YOU_CAN_WATCH":"Libereco por Spekti\\nĈion Kion Vi Volas.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Kio estas Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio estas kompleta centro por videoenhava kolektado. Malkovru, organizu kaj spektu filmetojn el ĉiaj fontoj sur iu ajn aparato, kiun vi posedas.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio estas moderna aŭdvidaĵa centro, integrala solvo por via amuziĝo. Vi povas malkovri, spekti kaj organizi video-enhavon per facile instaleblaj aldonaĵoj.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmoj, televidaj programoj, viva televido aŭ retkanaloj - Stremio disponigas por vi ĉion ĉi.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importi el facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Aliĝu al la festo nun","WEBSITE_DEVICES_ALL":"Facile uzebla en ĉiuj viaj aparatoj;","WEBSITE_EXTENDABLE_CATALOG":"Senfine etendebla videokatalogo;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Mojosaj funkcioj por organizi viajn aŭdvidaĵojn;","WEBSITE_AS_SEEN_ON":"Kiel vi vidis ĝin en","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Pri ni","WEBSITE_LINK_TECHNOLOGY":"Teknologio","WEBSITE_LINK_APPS":"Aplikaĵoj","WEBSITE_LINK_DOWNLOADS":"Elŝutoj","WEBSITE_MORE":"Pli","WEBSITE_LINK_ADDONS":"Aldonaĵoj","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Kontribuu","WEBSITE_LINK_COMMUNITY":"Komunumo","WEBSITE_LINK_BLOG":"Blogo","WEBSITE_MORE_MORE":"... kaj pli","WEBSITE_LINK_HELP":"Helpcentro","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privatecaj politikoj","WEBSITE_SUBSCRIBE":"Aboni","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Via Retpoŝto","WEBSITE_COMMUNITY":"Komunumo","WEBSITE_LINK_PRAVACY_LEGAL":"Privateco kaj legalaĵo","WEBSITE_WHY":"Kial ni faras kion ni faras","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAMO","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Funkcioj","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Facile malkovru novan enhavon","WEBSITE_FEATURES_DISCOVER_P":"Facile esplori novaj filmoj, televidaj spektakloj, serioj kaj kanaloj por spekti. Serĉu laŭ kategorio, ĝenro, poentaro, lastatempeco, noveco, ktp. aŭ simple tajpu nomon por trovi. Stremio faciligas trovante novan videoenhavon tre facile.","WEBSITE_FEATURES_ALL_CONTENT":"Ĉiuj viaj videoenhavoj en unu ekrano","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organizu vian videobibliotekon","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Ĝuu vian videon enhavon sur granda ekrano","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Spektu videon el multaj diversaj fontoj","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Kreu aldonaĵon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Spektu Netflix-aj filmoj kaj ret-serioj.","WEBSITE_ADDONS_CREATE":"Kreu aldonaĵon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Elŝutoj","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Kontribuu","WEBSITE_CONTRIBUTE_P1":"La platformo Stremio estas liberafontkoda kaj vi povas facile krei aldonaĵo por enhavo kiu ne estas indeksita ankoraŭ.","WEBSITE_CONTRIBUTE_WHY":"Kial vi devus krei aldonaĵon?","WEBSITE_CONTRIBUTE_WHY_P1":"Atingu nova spektantaro por via videoenhavo","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Iĝu volontula tradukisto","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Ĉu vi avidas por komenci?","WEBSITE_TRANSALTE_STREMIO":"Traduku Stremio-n","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Komunuma Artgalerio","WEBSITE_LINK_ART":"Komunuma artgalerio","WEBSITE_CONTACT_US":"Kontaktu nin","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Bonvolu entajpi vian retpoŝton!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Pri kio temas via demando?","WEBSITE_CONTACT_US_Q_OS":"Kiu estas via Operaciumo?","WEBSITE_CONTACT_US_PH_EMAIL":"Via Retpoŝto","WEBSITE_CONTACT_US_PH_MESSAGE":"Mesaĝo","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SENDI","WEBSITE_CONTACT_US_Q_1":"Kiel instali","WEBSITE_CONTACT_US_Q_2":"Kiel malinstali?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Aldonaĵoj","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Teknologio","WEBSITE_TECHNOLOGY_P1":"Ni amas teknologion kaj frenezan sciencon.
Jen kio ebligas Stremio-n (ĉio estas malfermitkoda).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"Senpaga, malfermitfonta kaj plurplatforma plurmedia ludilo.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Kontribuu al la projekto","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Estas du manieroj per kiuj vi povas kontribui kun Stremio kaj helpi al ni plibonigi ĝin eĉ pli!.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Vi povas donaci viajn valorajn lingvokapablojn tradukante la platformon...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"aŭ","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... vi povas uzi viajn programadajn kapablojn por krei komunumajn aldonaĵojn. ","WEBSITE_TRANSLATE_STREMIO":"Traduku Stremio-n","WEBSITE_404_OH_NO":"Ho ve! La paĝo kiu vi serĉas ne estas ĉi tie...","WEBSITE_GO_HOME":"Iru hejmen","WEBSITE_LINK_OTHER_DOWNLOADS":"Aliaj elŝut-opcioj","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Subteni","WEBSITE_DOWNLOAD_4_0_BETA":"Elŝutu Stremio-n 4 beta nun!","WEBSITE_GET_FOR_DESKTOP":"Akiru ĝin por komputilo","WEBSITE_LINK_ADDON_COMPETITION":"Aldonaĵa konkurso","WEBSITE_LINK_ART_CONTEST":"Arta konkurso","WEBSITE_MY_ACCOUNT":"Mia konto","WEBSITE_MAINPAGE_FAQ_001_H1":"Kio estas Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio estas moderna plurmedia centro, kiu donas al vi la liberon spekti ĉion, kion vi volas.","WEBSITE_MAINPAGE_FAQ_002_H1":"Kiel ĝi funkcias?","WEBSITE_MAINPAGE_FAQ_002_P1":"Post kiam vi instalos Stremio sur via aparato kaj kreos konton, vi nur devas viziti la katalogon de aldonaĵoj kaj instali ajnan aldonaĵon, kiun vi volas, kaj vi estas bona por preta por ekkomenci!","WEBSITE_MAINPAGE_FAQ_002_P2":"Post tio, vi povas iri al la sekcioj Discover aŭ Board por komenci esplori enhavon.","WEBSITE_MAINPAGE_FAQ_003_H1":"Kion mi povas spekti ĉi tie?","WEBSITE_MAINPAGE_FAQ_003_P1":"Multaĵon: Filmoj, Televidaj Spektakloj, Retaj Kanaloj, Sporto, Televidaj kanaloj, aŭskulti Podkastojn kaj multe pli. Danke al nia aldonaĵa sistemo, vi povas akiri ĉiajn enhavojn.","WEBSITE_MAINPAGE_FAQ_004_H1":"Ĉu Stremio estas malfermitkoda?","WEBSITE_MAINPAGE_FAQ_004_P1":"Jes, vi povas viziti la jenajn ligilojn: ${1}desktop app${2} kaj ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Ĉu estas Stremio sekura?","WEBSITE_MAINPAGE_FAQ_005_P1":"Jes: ĉar ĝi estas libera programaro, la kodo estas publike alirebla kaj vi mem povas revizii ĝin.","WEBSITE_MAINPAGE_FAQ_006_H1":"Kio pri mia privateco?","WEBSITE_MAINPAGE_FAQ_006_P1":"Ni respektas la privateco de la uzantoj, tial ni ne kolektas nenian personalan datumon, krom la minimunon esencialan por krei kaj sinkronigi vian konton.","WEBSITE_MAINPAGE_FAQ_006_P2":"Ankaŭ ekzistas ${1}Gasta reĝimo${2} ĉe la aliĝo, kiu postulas neniujn datumojn: en ĉi tiu reĝimo, neniuj vokoj estas faritaj al nia servilo. Tamen, ĝi forĵetas utilajn funkciojn, kiel sinkronigi vian bibliotekon inter aparatoj.","WEBSITE_MAINPAGE_FAQ_007_H1":"Ĉu mi povas elsendi al mia televidilo?","WEBSITE_MAINPAGE_FAQ_007_P1":"Jes, ni subtenas Chromecast-on kaj vi povas elsendi el kaj labortablaj kaj el poŝtelefonaj aplikaĵoj (Android)..","WEBSITE_MAINPAGE_FAQ_008_H1":"Kiom da aldonaĵoj Stremio havas?","WEBSITE_MAINPAGE_FAQ_008_P1":"Je 2019, pli ol 50 - por plia informo, vidu nian aldonaĵan katalogon.","WEBSITE_MAINPAGE_FAQ_009_H1":"Ĉu Stremio povas esti etendita preter kio estas en la aldonaĵa katalogo?","WEBSITE_MAINPAGE_FAQ_009_P1":"jes, vi povas rigardi la jenajn: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, ktp.","WEBSITE_MAINPAGE_FAQ_010_H1":"Kiujn aparatojn Stremio subtenas?","WEBSITE_MAINPAGE_FAQ_010_P1":"Ni havas labortablaj aplikaĵoj por Vindozo, Mac kaj Linukso. Por poŝtelefono, ni subtenas Android kaj iOS, kvankam konsciu, ke iOS estas limigita en funkcioj (ne subtenas la plejmultajn aldonaĵojn).","WEBSITE_MAINPAGE_FAQ_010_P2":"Estas multaj Android-bazitaj aparatoj sur kiuj vi povas ruli Stremio-n, kiel NVIDIA Shield kaj Amazon Fire Stick, sed ni ne oficiale subtenas ilin.","WEBSITE_MAINPAGE_FAQ_011_H1":"Ĉu vi povas aldoni certan enhavon al Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Pardonu, ni mem provizas neniun enhavon, sed ju pli da Stremio-aldonaĵoj vi instalos, des pli da enhavo vi povos trovi.","WEBSITE_MAINPAGE_FAQ_012_H1":"Ĉu Stremio povas ludi magnetligojn","WEBSITE_MAINPAGE_FAQ_012_P1":"Jes, kaj ĝi ankaŭ povas ludi normalajn HTTP-ligilojn kaj torentajn dosierojn (ŝovi kaj demeti).","WEBSITE_MAINPAGE_FAQ_013_H1":"Ĉu mi povas elŝuti videon kaj spekti ĝin eksterrete?","WEBSITE_MAINPAGE_FAQ_013_P1":"Eksterreta disponebleco estas venonta funkcio, sed se vi permesas al Stremio konservi kaŝmemoron en via aparato (ĉe la agorda panelo) vi povas spekti la videojn senkonekte.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nenio funkcias, helpu min!","WEBSITE_MAINPAGE_FAQ_014_P1":"Ĉu vi certas, ke vi instalis aldonaĵojn? Se jes, iru al nia ${1}helpcentro${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Kiel Stremio subtenas ĝian programadon?","WEBSITE_MAINPAGE_FAQ_015_P1":"Ni ruligas netrudemajn reklamojn per ${1}AdEx${2}, kiu estas firmao de la sama fondteamo, kiu fokusiĝas en privateco-konservantaj travideblaj reklamoj.","WEBSITE_MAINPAGE_FAQ_015_P2":"Se vi havas pliaj demandoj, iru al nia ${1}helpcentro${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Montri malpli","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"Pli da informo ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Reprovi","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Kio estas Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"Kiel Stremio komparas al Kodi kaj al Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"Kiel Stremio komparas al Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"Kiel Stremio komparas al Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"Kiel Stremio komparas al Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Ĉu vi aldonos ĉi tiun filmon/serion?","FAQ_06_P1":"Ne, pardonon :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"Kiel mi povas krei aldonaĵon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Kie estas la kaŝmemora dosiero?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},9320:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Película","TYPE_series":"Series","TYPE_tv":"TV","TYPE_channel":"Youtube","TYPE_other":"Otros","TYPE_movie_PL":"Películas","TYPE_series_PL":"Series","TYPE_tv_PL":"TV","TYPE_channel_PL":"Youtube","TYPE_other_PL":"Otros","TYPE_ALL":"All","VIDEO":"Video","BACK":"Atrás","MORE":"Más","DONE":"Listo","COPY":"Copiar","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Descubrir","Board":"Panel","Library":"Biblioteca","My Library":"Mi Biblioteca","Calendar":"Calendario","NOTIFICATION_ONLINE":"Actualmente estás en línea","NOTIFICATION_OFFLINE":"Actualmente no estás conectado","INTERNET_CONNECTION":"Conexión de red","STORAGE_FULL_TITLE":"Advertencia: ¡Almacenamiento lleno!","STORAGE_FULL_TEXT":"Stremio no podrá guardar su configuración, preferencias o información de inicio de sesión. Considere reiniciar o reinstalar Stremio.","SEARCH":"Buscar","SEARCH_NO_RESULTS":"No se encontraron resultados","SEARCH_EXPLANATION_CONTENT":"Búsqueda de películas, series, Canales de Youtube y TV","SEARCH_EXPLANATION_PEOPLE":"Busca por actores, directores y escritores","SEARCH_PASTE_LINKS":"Pegar un enlace o enlace magnético","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Añadir a la biblioteca","REMOVE_FROM_LIB":"Eliminar de la biblioteca","ADDED_TO_LIB":"Añadido a la biblioteca","REMOVED_FROM_LIB":"Eliminado de la biblioteca","TRAILER":"Avance","WATCH_TRAILER":"Ver avance","WATCH_NOW":"Mirar ahora","SHOW":"Ver","SHOW_MOVIE":"Mostrar película","WATCH_RANDOM":"Mirar al azar","IMDB_RATING":"Calificación IMDb","YEAR":"Año","DIRECTOR":"Director","WRITER":"Escritor","LEAD_ACTORS":"Actores principales","CAST":"Reparto","CREW":"Equipo técnico","SHOW_MORE_CAST":"Mostrar más »","AIRED":"Salió al aire:","SEASONS":"Temporadas","GENRE":"Género","CATALOG":"Catálogo","SUMMARY":"Resumen","SHOW_MORE":"Mostrar más","SIMILAR":"Similar","UPCOMING":"Próximamente","ENDED":"Terminado","DURATION":"Duración","FEATURED":"Destacado","METADATA":"Metadatos","CATEGORY":"categoría","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Buscar videos","SEARCH_PLACEHOLDER":"Buscar o pegar enlace magnético","ADDON":"Complemento","ADDONS":"Complementos","OFFICIAL":"Oficial","ADDONS_OFFICIAL":"Complementos oficiales","ADDONS_POPULAR":"Popular en tu región","ADDON_FREE":"Gratis","ADDON_PEERED":"Compartido","ADDON_SUBSCRIPTION":"Suscripción","ADDON_STREAM_GEORESTRICTED":"No está disponible en su región","ADDON_STREAM_OFFLINECACHE":"Caché sin conexión","ADDON_STREAM_LOCALFILE":"Archivo Local","SHARE_ADDON":"Compartir extensión","AVAILABLE_STREAMS":"Transmisiones disponibles","NO_STREAM":"Transmisión no disponible","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Para más transmisiones, por favor instale más complementos","STREAM_NOT_SUPPORTED":"La transmisión seleccionada no es soportada en esta plataforma.","ADDON_CATALOGUE":"Mostrar todos los complementos »","ADDON_CATALOGUE_MORE":"Más complementos »","REPO_ADDED":"Repositorio agregado","ADDON_REPO_EXIST_ERR":"Este repositorio de complementos ya existe","ADDON_REPO_ERR":"Error ocurrido mientras agregaba repositorio","ADDON_ADD_ERR":"Error agregado mientras agregaba complemento","ERR_ADDON_PROTECTED":"Complemento protegido","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Algo ha salido mal - la autenticación pudo haber fallado","ERR_NOT_COLLECTION_URL":"No es una URL de colección","ERR_NOT_ADDON_URL":"No es una URL de complemento","ERR_DETECTFROMURL":"No se puede detectar desde la URL","ADDON_DUPLICATE_WARNING":"Advertencia: complemento duplicado","ADDON_COLLECTION_SET_FAILED":"Falló la recopilación de complementos","SETTINGS_DATA_EXPORT":"Exportar datos","ADDON_PULL_FAILED":"Error de extracción de complemento","REFRESH_ON_CLICK":"Hacer clic para intentarlo de nuevo","STILL_IN_THEATER":"Película aún en cines","WATCH_IN_CINEMA":"Véalo en su cine favorito","IN_THEATER":"En el cine","GET_TICKETS":"Conseguir entradas","UPCOMING_EPISODE":"Próximo episodio","UPCOMING_EPISODE_MESSAGE":"El próximo episodio se emitirá el","MISSING_DATE_EPISODE":"No existe la fecha de este episodio","MISSING_DATE_EPISODE_MESSAGE":"Es posible que este episodio no se haya emitido todavía","CHANNEL_NOT_SCRAPED":"Este canal aún no está habilitado.
Por favor, vuelve en unos minutos.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Añádelo a tu biblioteca para ser notificado una vez que esté disponible.","GET_NOTIFIED_WHEN_AVAILABLE":"Recibirá una notificación cuando esté disponible.","WARNING_STREAMING_SERVER":"Advertencia: Servidor de transmisión local no encontrado. La transmisión desde YouTube y BitTorrent no estará disponible.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Advertencia: este video podría no ser soportado en su hardware. Tenga en cuenta que la reproducción podría ser lenta.","PLAYER_ERROR":"Ups!, ha ocurrido un error en el reproductor","PLAYER_ERROR_LOOKSLIKE":"Parece que","PLAYER_ORIENTATION":"Orientación del reproductor","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Bloqueada","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Orientación del reproductor bloqueada en modo horizontal","PLAYER_ORIENTATION_SENSOR":"Orientación del reproductor automática (sensor)","PLAYER_PLAYBACK_SPEED":"Velocidad de reproducción","PLAYER_PLAYBACK_ERROR":"Error de reproducción, inténtelo de nuevo","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Error desconocido","PLAYER_PLAYBACK_ERROR_DEFAULT":"Lo sentimos, este video no puede ser reproducido por {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"En vivo","PLAYER_NEXT_VIDEO_TITLE":"A continuación en","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Descartar","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Ver vídeo","STREAMING_FROM":"Transmitiendo desde","CASTING_TO":"Transmitiendo a","NETWORK_STATUS":"Estado de la red","STREAM_SPEED":"Velocidad:","STREAM_BUFFERED":"Almacenado:","PEERS_INFO":"Información de pares","PEERS_ACTIVE":"Activos:","PEERS_CONNECTED":"Conectados:","PEERS_WAITING":"Esperando:","TRANSCODING_WARNING":"Alerta: transcodificando video.","STREAM_LOADING":"Cargando...","PLAYING_LOCAL":"Reproducción desde archivo local","PLAYING_CACHE":"Reproducción desde la memoria caché","WRONG_SUBS":"¿Subtítulos erróneos?","ERR_SUBS_LOADING_TITLE":"Error cargando subtítulos","ERR_SUBS_LOADING":"Fallo cargando subtítulos: esto podría ser un problema con la extensión que está usando o con su conexión de internet","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Los siguientes complementos de subtítulos fallaron","ERR_CASTING_UPDATE_TITLE":"No se pudo actualizar la información del dispositivo de transmisión: el servidor de transmisión puede estar fuera de línea","CHOOSE_DEVICE":"Elija un dispositivo para ver","NO_CAST_DEVICES":"No hay dispositivos de transmisión disponibles.","NO_SETTINGS":"No hay configuraciones disponibles.","PHONE_TABLET":"Móvil / Tableta","SUBTITLES":"Subtítulos","SUBTITLES_CHANGE":"Cambiar subtítulos para ","SUBTITLES_CHANGE_NONE":"No hay otros subtítulos para este idioma, lo siento.","SUBTITLES_CHANGE_ACIVE":"Actualmente los subtítulos #{{subtitlesDialog.activeIdx + 1}} están activados. Haga clic en \\"Continuar\\" para activar los subtítulos #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativamente,","SUBTITLES_ADJUST_DELAY":"Ajuste de retraso de subtítulos:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"O utilice las teclas G / H durante la reproducción para ajustar.","SUBTITLES_ADJUST_DELAY_TIP":"Nota: Puede usar las teclas G / H durante la reproducción para ajustar.","SUBTITLES_DELAY":"Retraso de subtítulos:","SUBTITLES_LOADING":"Cargando subtítulos...","SUBTITLES_UNAVAILABLE":"No hay subtítulos externos disponibles","SUBTITLES_DISABLED":"Desactivado","AUDIO":"Audio","DEFAULT_LANGUAGE":"Idioma Por Defecto","DEFAULT_SECONDARY_LANGUAGE":"Idioma Por Defecto Secundario","SEASON":"Temporada","EPISODE":"Episodio","SPECIAL":"Special","SORT":"Ordenar","SORT_BY":"Ordenar por","FILTER":"Filtrar","SORT_TRENDING":"Tendencias","SORT_RECENT":"Reciente","SORT_ALPHABET":"A-Z","SORT_RATING":"Calificación","SORT_WATCHED":"Visto","SORT_YEAR":"Año","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nuevo para ti","New Episodes":"Nuevos Episodios","New Videos":"Nuevos Videos","Recommendations":"Recomendaciones","LIBRARY_RESUME":"Reanudar","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detalles","LIBRARY_RESUME_DISMISS":"Descartar","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Destacado","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Ganadores del Oscar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Esta extensión no retornó contenido.","DISCOVER_ADULT_WARNING":"El contenido es visible solo para adultos. ¿Eres mayor de 18 años?","DISCOVER_NOADDON_WARNING":"Advertencia: Ningún complemento activo de este tipo. Mostrando artículos guardados, nada de aquí se actualizará.","DISCOVER_LOAD_ERR":"Descubrir: error al cargar el catálogo desde el complemento","DISCOVER_ADDON_UNINSTALLED":"Este contenido no está más disponible, puede que hayas desinstalado la extensión.","UNINSTALL_THIS_ADDON":"Desinstalar esta extensión","ERR_ADDON_NOT_INSTALLED":"Este complemento no está instalado. ¿Instalar ahora?","DETAIL_RECEIVE_NOTIF_SERIES":"Recibir notificaciones de nuevos episodios","DETAIL_RECEIVE_NOTIF_VIDEOS":"Recibir notificaciones de nuevos videos","SIDEBAR_SHOW_STREAMS":"Mostrar transmisiones","RELAUNCH":"¡Relanzar ahora!","UPGRADE":"¡Una nueva versión está disponible! Actualiza a la versión más reciente de Stremio","RELOAD_UI":"Volver a cargar la interfaz de usuario","MANUAL_UPDATE_TITLE":"Actualice su versión de Stremio","MANUAL_UPDATE_LINE1":"Está ejecutando una versión desactualizada de Stremio lo cual no se recomienda.","MANUAL_UPDATE_LINE2":"Actualice lo antes posible.","BUTTON_UPDATE_LATTER":"Ahora no","BUTTON_UPDATE_NOW":"Actualizar","ANONYMOUS_USER":"Usuario anónimo","DONT_HAVE_ACC":"¿No tienes una cuenta?","HAVE_ACC":"¿Ya tiene una cuenta?","PASSWORD":"Contraseña","PASSWORD_CONFIRM":"Confirme su contraseña","EMAIL":"Correo electrónico","FB_LOGIN":"Entrar con Facebook","FB_NOTHINGSHARED":"Nada será compartido sin su permiso","FB_NOPOST":"No publicaremos nada en su nombre","OR":"o","I_ACCEPT":"Yo acepto los","I_ACCEPT_BY_CLICKING":"Al hacer clic en el botón de arriba testifico que acepto los ","TOS":"Términos y Condiciones","MUST_ACCEPT_TERMS":"Debes aceptar los términos","PASSWORDS_NOMATCH":"Las contraseñas no coinciden","SIGN_UP":"Regístrate","SIGN_UP_EMAIL":"Ingrese con correo electrónico","CLICK_TO_SIGN_UP":"Clic aquí para ingresar","LOG_IN":"Iniciar sesión","LOG_OUT":"Cerrar sesión","EXIT_FULLSCREEN":"Salir de modo pantalla completa","ENTER_FULLSCREEN":"Entrar en modo pantalla completa","PLAY_URL_MAGNET_LINK":"Reproducir URL/enlace magnético","HELP_FEEDBACK":"Ayuda y retroalimentación","TERMS_OF_SERVICE":"Términos del servicio","PRIVACY_POLICY":"Política de privacidad","ABOUT_STREMIO":"Sobre Stremio","USER_PANEL":"Panel de usuario","LOGIN_LABEL":"Login","GUEST_LOGIN":"Acceso de usuario invitado","GUEST_LOGIN_NOTICE":"Acceder como invitado no es recomendable. Ingresar con tu cuenta le permite a Stremio sincronizar tu Biblioteca y recibir notificaciones para tus series/canales favoritos. ¿Estás seguro de que quieres continuar?","GUEST_LOGIN_NOTICE_2":"No se recomienda el inicio de sesión de invitado - no habrá sincronizado las notificaciones de la Biblioteca y del Panel, que son funciones vitales de Stremio. ¿Seguro que desea continuar?","CLICK_HERE":"Haga clic aquí","WRONG_PASSWORD":"Contraseña incorrecta. En caso de que haya olvidado su contraseña, ","SET_A_PASS":"Establecer una contraseña","RESET_PASSWORD":"Restablecer contraseña","FORGOT_PASSWORD":"¿Olvidaste tu contraseña?","EMAIL_USED_WITH_FB":"Este correo electrónico fue utilizado con un inicio de sesión de Facebook.","INVALID_EMAIL":"Por favor ingrese un correo electrónico válido","INVALID_PASSWORD":"Por favor ingrese una contraseña válida","CONN_ERR":"Error de conexión - por favor, inténtelo de nuevo más tarde.\\n\\nSi esto persiste, desactivar programas cortafuegos / antivirus (especialmente Bitdefender).","IMPORT_FROM_GUEST":"Importar biblioteca de su cuenta de invitado","RECEIVE_UPDATES_EMAIL":"Recibe novedades de Stremio en tu correo electrónico","LOGIN_FAILED":"Error en el inicio de sesión.","SIGNUP_FAILED":"Registro fallido.","SEARCH_FAILED":"Búsqueda fallida","EMAIL_USED":"Este correo electrónico ya está en uso.","WAITING_FB_LOGIN":"Iniciando sesión con Facebook...","EXTERNAL_PLAYER_TITLE":"Reproducir en reproductor externo","EXTERNAL_REMEMBER_PLAYER":"¿Quieres recordar tu elección?","EXTERNAL_ALWAYS_PLAY":"Si","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Melhor Ajuste","FIT_SCREEN":"Ajustar pantalla","FILL":"Rellenar","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Cuéntanos de tus gustos","INTRO_TASTE_LONG":"Cuéntanos que te gustaría ver","INTRO_TASTE_PICK":"Selecciona {{interestsRemaining}} intereses","INTRO_TASTE_PICK_MORE":"Selecciona {{interestsRemaining}} más intereses","INTRO_TASTE_HELP_US":"Ayúdanos a saber más de ti.","INTRO_TASTE_CHOOSE_THESE":"Escoge algunos de estos:","INTRO_TASTE_CHOOSE_MIN":"Escoge al menos 3 categorías","INTRO_TASTE_CHOOSE_MIN_ERR":"¡Tienes que seleccionar al menos 3 categorías!","INTRO_TASTE_LIFESTYLE":"Estilo de vida","INTRO_TASTE_SPORTS":"Deportes","INTRO_TASTE_FOOD_HEALTH":"Comida y Salud","INTRO_TASTE_BEAUTY_FASHION":"Belleza y Moda","INTRO_TASTE_NEWS":"Noticias","INTRO_TASTE_GAMING":"Juegos","INTRO_TASTE_SCIENCE_EDU":"Ciencia y Educación","INTRO_TASTE_MUSIC":"Música","INTRO_TASTE_TRAVEL":"Viajes","INTRO_TASTE_LATE_NIGHT":"Espectáculo nocturno","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedia","INTRO_TASTE_DIY":"Hazlo tú mismo","INTRO_TASTE_TECH":"Tecnología","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"El complemento seleccionado no es soportado en esta plataforma.","ADDON_DISCLAIMER":"El uso de complementos siempre estarán sujetos a su responsabilidad y la ley de gobierno de la jurisdicción en que te encuentres.","ADDON_ACTIVATE":"¿Activar este complemento?","ADDON_REPO_ADD":"URL del repositorio del complemento","ADDON_ADD":"Agregar","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Qué hay de nuevo","BUTTON_CONTINUE":"Continuar","BUTTON_ACTIVATE":"Activar","BUTTON_ACTIVATED":"Activado","BUTTON_CANCEL":"Cancelar","BUTTON_SUBMIT":"Enviar","BUTTON_DISMISS_ALL":"Descartar todo","BUTTON_VIEW_ALL":"ver todo","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Su biblioteca se ve vacía. Averigüe lo útil que es :) ","HOW_START":"Así es cómo puedes empezar:","LIB_EMPTY_CAL":"Su calendario muestra series en su Biblioteca.","HOW_START_CAL":"Así es como se puede agregar series:","LIB_EMPTY_BOARD":"El Panel muestra notificaciones y recomendaciones relacionadas con la Biblioteca.","HOW_START_BOARD_WAIT":"Por favor, añada algunas series o canales a su Biblioteca y denos unos minutos para procesar :)","HOW_START_BOARD":"Así es como se puede agregar series y películas a la misma:","IMPORT_FB":"Importar cosas que te gustan de Facebook","IMPORT_TRAKT":"Importar biblioteca de Trakt","IMPORT_DISCOVER":"Encontrar cosas interesantes de Descubrir","IMPORT_DISK":"Importar películas o mira las que tiene en su disco local","PLEASE_CREATE_ACC":"Por favor crea una cuenta para activar la sincronización con la Biblioteca y Panel.","IMPORT_DISCOVER_SIGNUP":"Regístrate y encuentra cosas interesantes en Descubrir","IMPORT_DISK_SIGNUP":"Regístrate e importa películas o shows desde tu disco local","LIB_EMPTY_CLOUD":"Biblioteca","LIB_EMPTY_CLOUD_DESC":"Biblioteca personal sincronizada con todos los dispositivos","LIB_EMPTY_EARLY":"Acceso temprano","LIB_EMPTY_EARLY_DESC":"Recibir notificaciones de nuevos episodios","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Obtener recomendaciones personalizadas","LIB_EMPTY_CALENDAR_DESC":"Agende su calendario personal de programas","LIB_EMPTY_ALL":"Regístrate para obtener todo esto:","LIB_EMPTY_BEST":"Regístrate para obtener lo mejor de Stremio","LIB_EMPTY_OTHER":"Regístrate para habilitar el Calendario y otras excelentes características","CALENDAR_ADDED":"El calendario de Stremio ha sido agregado a su calendario de escritorio por defecto.","CALENDAR_ADDED_MSG":"Si esto no funciona, por favor agregue esta URL manualmente a su aplicación de calendario","TRAKT_EXPIRED":"La autenticación de Trakt expiró, vaya a Configuración y vuelva a autenticar","TRAKT_REQUIRES_LOGIN":"Error de Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Necesitas iniciar sesión","SETTINGS_LABEL":"Configuración","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Reproductor","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Atajos","SETTINGS_SHORTCUT_RELOAD_APP":"Recargar Aplicación","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Abrir Configuración","SETTINGS_SHORTCUT_SWITCH_TABS":"Cambiar Pestañas","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Desplazarse por las Pestañas hacia Adelante","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Desplazarse por las Pestañas hacia Atrás","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Salir / Regresar","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Alternar Pantalla Completa","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Mostrar Controles","SETTINGS_SHORTCUT_PLAY_PAUSE":"Reproducir / Pausa","SETTINGS_SHORTCUT_VOLUME_UP":"Subir Volumen","SETTINGS_SHORTCUT_VOLUME_DOWN":"Bajar Volumen","SETTINGS_SHORTCUT_SEEK_NEXT":"Buscar Siguiente","SETTINGS_SHORTCUT_SEEK_PREV":"Buscar Previo","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Reproducir Siguiente","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Aumentar Tamaño del Subtítulo","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Reducir Tamaño del Subtítulo","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Aumentar Retraso del Subtítulo","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Reducir Retraso del Subtítulo","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Alternar Menu Lateral","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Abrir cuando arranque el equipo","SETTINGS_VLC_DEFAULT":"Reproducir en VLC","SETTINGS_UI_LANGUAGE":"Idioma de la interfaz de usuario","SETTINGS_FULLSCREEN_EXIT":"Tecla de escape para salir del modo pantalla completa","SETTINGS_GAMEPAD":"Habilitar soporte para mando","SETTINGS_CLOSE_WINDOW":"Cerrar la aplicación cuando se cierra la ventana","SETTINGS_SUBTITLES_LANGUAGE":"Idioma de subtítulos predeterminado","SETTINGS_SUBTITLES_SIZE":"Tamaño de subtítulos predeterminado","SETTINGS_SUBTITLES_BACKGROUND":"Fondo de subtítulos","SETTINGS_SUBTITLES_COLOR":"Color de subtítulos","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Color del contorno de los subtítulos","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Color de fondo de los subtítulos","SETTINGS_SEEK_KEY":"Tiempo de búsqueda de las teclas de flecha","SETTINGS_SEEK_KEY_SHIFT":"Tiempo de búsqueda de las teclas de flecha cuando se mantiene la tecla Shift","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Comenzar automáticamente el siguiente episodio","SETTINGS_NEXT_VIDEO":"Mostrar notificación para que comience el siguiente episodio","SETTINGS_NEXT_VIDEO_TRIGGER":"Mostrar la notificación de próximo episodio para:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Ajustar ventana automáticamente antes de reproducir","SETTINGS_OVERRIDE_SERVER":"Anular la URL del servidor de transmisión (avanzado)","SETTINGS_SERVER_URL":"URL del servidor de transmisión ","SETTINGS_SERVER_AVAILABLE":"El servidor de transmisión está disponible.","SETTINGS_SERVER_UNAVAILABLE":"El servidor de transmisión no está disponible.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Punto final HTTPS de transmisión: ","SETTINGS_USE_BETA":"Utilice siempre la última Beta","SETTINGS_IMPORT_FB":"Importar desde Facebook","SETTINGS_IMPORT_DISK":"Importar desde el disco local","SETTINGS_IMPORT_TRAKT":"Importar desde Trakt","SETTINGS_PAUSE_MINIMIZED":"Pausar la reproducción cuando se minimiza","SETTINGS_HWDEC":"Decodificación acelerada por hardware","SETTINGS_BACKGROUND":"Reproducción de fondo","SETTINGS_SUBSCRIBE_CALENDAR":"Suscribirse al calendario","SETTINGS_REQ_EXPORT":"Solicitar mis datos","SETTINGS_ACC_DELETE":"Eliminar mi cuenta","SETTINGS_CHANGE_PASSWORD":"Cambiar contraseña","SETTINGS_TOS":"Términos de servicio","SETTINGS_SUPPORT":"Soporte","SETTING_LANGUAGE":"Idioma","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Salir de Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Escanear código QR para abrir el control remoto","SETTINGS_DESKTOP_NOTIFICATIONS":"Notificaciones de escritorio","SETTINGS_DATA_SAVER":"Ahorrador de datos","SETTINGS_LANGUAGE_INTERFACE":"interfaz","SETTINGS_LANGUAGE_SUBS":"Subtítulos por defecto","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoseleccionar Pista de Audio","SETTINGS_DEFAULT_AUDIO_TRACK":"Pista de Audio por defecto","SETTINGS_ACCOUNT":"cuenta","SETTINGS_VERSION":"versión","SETTINGS_MPV_WINDOW":"Abrir reproductor en una ventana separada (avanzado)","SETTINGS_PLAY_IN_EXTERNAL":"Iniciar siempre el video en un reproductor externo","SETTINGS_STORAGE_BUTTON":"Borrar almacenamiento local","SETTINGS_STORAGE_MODAL_TITLE":"¿Está seguro?","SETTINGS_STORAGE_MODAL_MESSAGE":"Esta opción borrará el almacenamiento local y terminará su sesión.","SETTINGS_HWDEC_PICKER":"Selecciona la configuración de decodificación acelerada por hardware","SETTINGS_HW_AUTOMATIC":"Automático","SETTINGS_HW_DISABLED":"Deshabilitada","SETTINGS_HW_ACCELERATED":"Decodificación Acelerada","SETTINGS_HW_FULL":"Aceleración Completa","SETTINGS_HW_LEGACY":"Legado","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Subtítulos de complementos","SUBSPICKER_BLACK_BACKGROUND":"Usar color de fondo negro","SUBSPICKER_VERTICAL_OFFSET":"Desplazamiento Vertical","SUBSPICKER_SIZE":"Tamaño","SUBSPICKER_DELAY":"Retraso","SUBSPICKER_EMBEDDED_SUBS":"Subtítulos Embebidos","MOBILE_PRIVACY_POLICY":"Política de Privacidad","MOBILE_CRASH_REPORTING":"Reporte de Errores","MOBILE_ZOOM_TO_FILL":"Zoom para Rellenar la Pantalla","MOBILE_PASSTHROUGH":"Salida de Audio Digital (passthrough)","MOBILE_RUN_LOW_BATTERY":"Ejecutar con Batería Baja","MOBILE_RUN_FOREGROUND":"Ejecutar como Servicio en Primer Plano","MOBILE_PERFORMANCE":"Rendimiento y Estabilidad","MOBILE_SERVER_ONLINE":"En Linea","MOBILE_SERVER_OFFLINE":"Desconectado","MOBILE_QR_EXPIRES":"El Código QR expira en ","MOBILE_LOG_INTO":"Inicia sesión a tu cuenta Stremio ","MOBILE_SCAN_QR":"Escanea el Código QR de arriba o visita ","MOBILE_LINK_ACCOUNT":"Asociar Cuenta","MOBILE_SPEEDPICKER_CANCEL":"Cancelar","MOBILE_SPEEDPICKER_LABEL":"Seleccionar Velocidad de Reproducción","MOBILE_EMPTY_LIBRARY":"Tu Biblioteca está vacía","MOBILE_NO_ADDON_ACTIVE":"No hay complemento de Stremio activo para este tipo.","MOBILE_ORGANIZER_WARNING":"La aplicación Stremio Organizer proporciona una funcionalidad limitada. Para obtener una lista de transmisiones reproducibles y la experiencia completa de Stremio, use Stremio en el escritorio.","MOBILE_ADDON_LOADING":"todavía está cargando","MOBILE_ADDONS_LOADING":"los complementos aún se están cargando","MOBILE_ADDON":"Complementos","MOBILE_CONFIGURE_ADDON":"Configura tu complemento","MOBILE_CONFIGURE_ADDON_LABEL":"Configurar Complemento","MOBILE_ORGANIZER_ADDONS_WARNING":"La aplicación Stremio Organizer ofrece una selección limitada de complementos. Para disfrutar de la experiencia completa de Stremio, use Stremio en el escritorio.","MOBILE_DISCONNECT":"Desconectar","MOBILE_LOOKING_FOR_DEVICES":"Buscando dispositivos...","MOBILE_CAST_TO":"Emitir a","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"Acepto recibir comunicaciones de marketing de Stremio","QUIT":"Salir","CONNECTED":"Conectado","AUTHENTICATE":"Autenticar","CACHING":"Almacenamiento en caché","SETTINGS_CACHING_DRIVE":"Seleccione la unidad de almacenamiento en caché","ENABLE_LOCAL_FILES_ADDON":"Habilite el complemento de archivos locales (requiere reiniciar)","LOCAL_ADDON_NOT_ENABLED":"El complemento local no está habilitado. Haga clic aquí para ir a la configuración y habilitarlo","ENABLE_REMOTE_HTTPS_CONN":"Habilitar conexiones HTTPS remotas","TORRENT_PROFILE":"Perfil de Torrent","DATA_CACHING":"Caché almacenada","MAGNET_PARSING":"Analizando un enlace magnético","January":"Enero","February":"Febrero","March":"Marzo","April":"Abril","May":"Mayo","June":"Junio","July":"Julio","August":"Agosto","September":"Septiembre","October":"Octubre","November":"Noviembre","December":"Diciembre","Monday":"Lunes","Tuesday":"Martes","Wednesday":"Miércoles","Thursday":"Jueves","Friday":"Viernes","Saturday":"Sábado","Sunday":"Domingo","Action":"Acción","Comedy":"Comedia","War":"Guerra","Family":"Familia","Animation":"Animación","Adventure":"Aventura","Fantasy":"Fantasía","Crime":"Crimen","Mystery":"Misterio","Romance":"Romántico","Drama":"Drama","Horror":"Terror","Thriller":"Suspense","Sci-Fi":"Ciencia ficción","Music":"Música","Biography":"Biografía","Documentary":"Documental","Sport":"Deporte","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Noticias","History":"Historial","Game-Show":"Programa de juegos","Reality-TV":"Reality shows","Talk-Show":"Programa de entrevistas","Film & Entertainment":"Cine y Entretenimiento","Gaming":"Juegos","From TV":"De la televisión","Lifestyle":"Estilo de vida","Science & Education":"Ciencia y Educación","Cooking & Health":"Cocina y Salud","Beauty & Fashion":"Belleza y Moda","Sports":"Deportes","News & Politics":"Noticias y Política","How-to & DIY":"Cómo hacer y bricolaje","Tech":"Tecnología","Automotive":"Automotores","Causes & Non-Profits":"Causas y Fines de Lucro","Movies":"Películas","Uk Live Tv":"TV británica en vivo","Fashion":"Moda","Business News Radio":"Noticias de negocios - Radio","Business Tv":"Negocios TV","Cars & Auto":"Autos","Comedy Radio":"Comedia - Radio","Lifestyle Radio":"Estilo de vida - Radio","News Tv":"Noticias TV","Food And Wine":"Comida y Vino","Latino Tv":"Latino TV","Shopping Tv":"Compras TV","Religion":"Religión","Kids":"Niños","Body & Soul":"Cuerpo y Alma","Education":"Educación","Indian Tv":"India TV","Extreme Sports":"Deportes extremos","Middle Eastern Tv":"Medio oriente TV","Celebrity Tv":"Celebridades TV","Science Tv":"Ciencia TV","Bikini babe":"Bikini babe","Outdoors":"Al aire libre","German Tv":"TV alemana","French Tv":"TV francesa","Italian Tv":"TV italiana","Gamer Tv":"TV Videojuegos","Travel":"Viajes","Asian Tv":"TV asiática","Entertainment":"Entretenimiento","News Radio":"Noticias - Radio","Music Radio":"Música - Radio","Language Learning":"Aprendizaje de idiomas","Science Radio":"Ciencia - Radio","Tech Radio":"Tecnología - Radio","Science & Technology Vod":"Ciencia y Tecnología VBD","new video":"Nuevo video","new episode":"Nuevo episodio","new movie":"Nueva película","recommended":"Recomendado","we recommend":"Nosotros recomendamos","offer of the day":"Oferta del día","news":"Nuevo","music video":"Vídeo musical","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Descartar notificaciones","CTX_DISMISS_ALL":"Descartar todo","CTX_SHARE":"Compartir","CTX_COPY_SHARE_LINK":"Copiar enlace","CTX_COPY_MAGNET_LINK":"Copiar enlace magnético","CTX_COPY_STREAM_LINK":"Copiar enlace de la transmisión","CTX_DOWNLOAD_VIDEO":"Descargar este vídeo","CTX_DOWNLOAD_SUBS":"Descargar subtítulos","CTX_VIEW_ON_YOUTUBE":"Ver en YouTube","CTX_SHOW":"Mostrar","CTX_PLAY":"Reproducir","CTX_PLAY_IN":"Reproducir aquí","CTX_PLAY_ON":"Reproducir en","CTX_WATCH_ON":"Ver en","CTX_WATCH":"Ver","CTX_WATCHED":"Visto","CTX_WATCH_BEGINNING":"Mirar desde el principio","CTX_WATCH_MOBILE":"Ver en un dispositivo móvil","CTX_REWIND":"Retroceder al comienzo","CTX_MARK_WATCHED":"Marcar como visto","CTX_MARK_NON_WATCHED":"Marcar como no visto","CTX_MARK_UNWATCHED":"Marcar como no visto","CTX_MARK_REST":"Marcar el resto como visto","CTX_UNMARK_REST":"Marcar el resto como no visto","CTX_RECEIVE_NEW_NOTIF":"Recibir notificaciones nuevas","CTX_REMOVE_CACHE":"Eliminar de caché","CTX_REMOVE_CACHE_EP":"Eliminar el episodio de la memoria caché","CTX_OPEN_CONTAINING":"Abrir carpeta contenedora","CTX_REMOVE":"Eliminar de la Biblioteca","CTX_AVAILABLE_OFFLINE":"Disponible sin conexión","CTX_PAUSED":"En pausa","CTX_ALWAYS_ON_TOP":"Siempre en la parte superior","CTX_FULLSCREEN":"Pantalla completa","CTX_WRONG_SUBS":"¿Subtítulos erróneos?","CTX_REPORT_ISSUES":"Informar de un problema","CTX_COPY":"Copiar","CTX_PASTE":"Pegar","CTX_CLEAR":"Limpiar","CTX_CLEAR_RECENT_SEARCHES":"Borrar búsquedas recientes","HELLO_THERE":"Hola","HOPE_YOU_ENJOY":"¡Esperamos que disfrute de Stremio y sea una de sus aplicaciones favoritas!","WHO_ARE_WE":"¿Quiénes somos? Somos el equipo detrás de ella
dos chicos que trabajan duro todos los días durante los últimos 3 años, con un único objetivo
para hacer este producto cada vez mejor.","SUPPORT_US":"Si disfrutas usando Stremio, si Stremio es valioso para ti - apóyanos!","SPREAD_THE_WORD":"Comparte con tus amigos ahora, corre la voz sobre Stremio","MORE_PEOPLE":"Cuantas más personas usen Stremio, mejor será","SEND_A_LINK":"O envía un enlace de nuestro sitio web","TIP_LOCALFILES":"Consejo: puede arrastrar y soltar archivos de vídeo locales en Stremio","ADDON_MY":"Mis complementos","ADDON_COMMUNITY":"Complementos de la comunidad","ADDON_OFFICIAL":"Complementos Oficiales","ADDON_REPOS":"Repositorios de complementos","ADDON_SEARCH":"Buscar Complementos","ADDON_INSTALL":"Instalar","ADDON_CONFIGURE":"Configurar","ADDON_UNINSTALL":"Desinstalar","ADDON_UPGRADE":"Actualizar","ADDON_INSTALLED":"Instalado","ADDON_INSTALLED_MSG":"¡Complemento instalado!","ADDON_UPGRADED_MSG":"¡Complemento actualizado!","ADDON_UNKNOWN":"Desconocido","ADDON_ERR":"¡Error instalando complemento!","ADDON_DISCONNECTED":"Desconectado","ADDON_APP_MISSING":"la aplicación para este recurso no está instalada. ¿Quieres instalarla ahora?","ADDON_APP_INSTALL":"Instalar ahora","ADDON_PAGE":"Página del complemento","ADDON_TOP_CONTENT":"Lo mejor de este complemento","ADDON_PROVIDES":"Proporciona","ADDON_WATCH":"¡Ver #{types} ahora!","ADDON_WATCH_FREE":"¡Ver #{types} de forma GRATUITA ahora!","ADDON_ADDON":"Complemento","ADDON_SUPPORTED_TYPES":"Tipos compatibles","ADDON_SUPPORTED_CATALOGS":"Catálogos compatibles","ADDON_PROVIDES_DISCOVER":"Más #{types} en Descubrir","ADDON_PROVIDES_STREAMS":"Ver #{types}","ADDON_PROVIDES_STREAMS_FREE":"Ver #{types} de forma GRATUITA","ADDON_PROVIDES_SUBTITLES":"Subtítulos #{types}","ADDON_CANTDETECT":"No hemos podido detectar un Stremio en ejecución, así que no pudimos detectar qué complementos tiene instalado.","ERR_NO_META":"No se encontró información sobre esto ","ERR_GETTING_META":"Error obteniendo información de este.","ERR_CANT_PARSE_MAGNET":"Incapaz de analizar enlace magnético","ERR_NO_MAGNET_INFOHASH":"Código hash inválido para enlace magnético","ERR_NO_FILE_PATH":"Incapaz de enviar solicitud sin una ruta de archivo","ERR_NO_TORRENT":"No se devolvió torrent","ERR_NO_SUPPORTERD_FILES":"Archivo no soportado","ERR_OPENING_FILES":"No se pudieron abrir los archivos externos","ERR_INVALID_LINK":"Enlace inválido","ERR_REGISTERED_ONLY":"Esta opción está disponible solo para usuarios registrados.","ERR_CLIPBOARD":"No se puede reproducir desde el portapapeles","ERR_CLIPBOARD_READ":"Desde esta plataforma no se puede acceder al portapapeles","ERR_CLIPBOARD_GENERIC":"No se ha encontrado ningún URL reproducible en el portapapeles. Copie un URL (por ejemplo un enlace magnético) que lleve a un vídeo.","BOARD_CONTINUE_WATCHING":"Continuar viendo","BOARD_EXPLANATION_RECOMMENDATIONS":"Películas elegidas especialmente para ti.
Esta película es una muestra de recomendación.","BOARD_EXPLANATION_EPISODES":"Los nuevos episodios de tus series favoritas están aquí
Agrega las series que sigues en tu Biblioteca.","BOARD_EXPLANATION_VIDEOS":"Los nuevos videos de tus canales favoritos están aquí.
Agrega los canales de YouTube que sigues a tu Biblioteca.","WEBSITE_SLOGAN_WATCH":"Disfrute al instante","WEBSITE_SLOGAN_ALL":"de todo el contenido de vídeo en un solo lugar","WEBSITE_SLOGAN_NEW":"Todo lo que puedes ver","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Ver desde","WEBSITE_DOWNLOAD":"Descargar ahora","WEBSITE_DOWNLOAD_FOR":"Descargar para","WEBSITE_IS_DESKTOP":"Stremio es una aplicación de escritorio, abrí esta página en tu ordenador y descárgalo","WEBSITE_DESKTOP_DEMO_VID":"Demostración","WEBSITE_PAGE_HOME":"Inicio","WEBSITE_PAGE_FEATURES":"Características","WEBSITE_PAGE_ADDONS":"Complementos","WEBSITE_PAGE_TECH":"Tecnología","WEBSITE_PAGE_CREATE_ADDON":"Crear Complemento","WEBSITE_PAGE_CONTACTS":"Contactos","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Películas","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"TV en vivo","WEBSITE_TYPE_channel":"Canales de Youtube","WEBSITE_STREMIO_WHAT_IS":"Stremio es una aplicación que le ayuda a organizar y ver al instante sus canales de videos, películas, series de televisión y canales de televisión favoritos.","WEBSITE_FEATURES_WATCH":"Ver en HD al instante","WEBSITE_FEATURES_WATCH_DETAIL":"Haga clic y reproduzca sus películas favoritas, programas de televisión, videos y canales de televisión.","WEBSITE_FEATURES_SUBS":"Subtítulos automáticos","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio selecciona automáticamente los subtítulos sincronizados para su idioma.","WEBSITE_FEATURES_SUBS_LABEL":"Tu movimiento, jefe.","WEBSITE_FEATURES_CAST":"Reproduce en los dispositivos móviles y la televisión","WEBSITE_FEATURES_CAST_DETAIL":"Vea en AppleTV, Chromecast, Smart TV (DLNA/UPnP) y dispositivos móviles.","WEBSITE_LIB":"Disfrute de su biblioteca personal sincronizado en todos sus dispositivos","WEBSITE_LIB_COLLECT":"Recoger información de Stremio","WEBSITE_LIB_IMPORT":"Importar desde Facebook","WEBSITE_LIB_LOCAL":"Añadir de la unidad local","WEBSITE_BOARD":"El Panel - Su espacio para recibir Notificaciones y Recomendaciones","WEBSITE_BOARD_RECOMMEND":"Programa de televisión recomendado","WEBSITE_BOARD_TRENDING":"Tendencias en Películas","WEBSITE_BOARD_NEW":"Nuevo video","WEBSITE_BOARD_EPISODE":"Nuevo episodio","WEBSITE_BOARD_1":"¿Buscando algo interesante que ver?\\nObtén recomendaciones basadas en lo que te gusta!","WEBSITE_BOARD_2":"Sea notificado cuando un nuevo episodio de su programa favorito de televisión o canal de YouTube esté disponible!","WEBSITE_BOARD_YOUTUBE":"Nuevos videos de canales de YouTube","WEBSITE_BOARD_EPISODES":"Nuevos episodios de las series que sigues","WEBSITE_ADDONS":"Complementos","WEBSITE_TECH_DETAIL":"¡Nos encanta la tecnología, nos gusta la ciencia loca!\\nStremio utiliza las siguientes tecnologías de código abierto:","WEBSITE_TECH_WCJS":"WebChimera.js permite a Stremio reproducir cualquier formato de vídeo con un buen rendimiento.","WEBSITE_TECH_WCJS_EXTRA":"Somos contribuidores fundamentales del proyecto","WEBSITE_TECH_ELECTRON":"Electron proporciona una plataforma innovadora para construir Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Somos contribuidores del proyecto","WEBSITE_TECH_LINVODB":"Una tecnología de base de datos que asegura que sus datos se organicen y estén disponible en cualquier lugar que inicie sesión.","WEBSITE_TECH_LINVODB_EXTRA":"En la casa de la tecnología","WEBSITE_CREATE_ADDON":"Creé su complemento","WEBSITE_CREATE_ADDON_DETAIL":"¿Tiene un servicio para proporcionar contenido de vídeo?\\nVamos a ayudarle a beneficiarse de las características de Stremio creando su Complemento.","WEBSITE_CREATE_ADDON_BENEFITS":"Beneficios de crear un Complemento para Stremio","WEBSITE_P2P_BEAUTY":"La belleza de la transmisión Par a Par (P2P)","WEBSITE_P2P_1":"Vídeo o transmisión en vivo fiable y asequible en Full HD / 4K","WEBSITE_P2P_2":"La plataforma de distribución proporciona una gran experiencia de usuario","WEBSITE_P2P_3":"Vamos a crear un complemento para la satisfacción de sus necesidades exactas","WEBSITE_P2P_CONTACT":"¿Interesado? Eres bienvenido, Contáctenos.","WEBSITE_P2P_CONTACT_EXTRA":"¡Estaremos encantados de ayudarle a integrar su contenido con Stremio!","WEBSITE_P2P":"De vez en cuando, llega una tecnología que cambia el nombre del juego. Hemos invertido un montón de tiempo y esfuerzo en la construcción de nuestro motor de transmisión de Par A Par (P2P) de vídeo que proporciona un gran rendimiento y versatilidad para adaptarse a cualquier caso de uso.\\nContáctenos por DRM-enabled P2P video en demanda o transmisión en vivo.","WEBSITE_THOUGHTS":"Pensamientos que compartimos:","WEBSITE_SPREAD":"Difunde Stremio en tus redes sociales:","WEBSITE_CONTACT":"Contacta con nosotros, ¡Estamos deseando escucharte!","WEBSITE_OPENSOURCE":"Para nuestros proyectos de código abierto, vaya a","WEBSITE_BITCOIN":"Donar Bitcoin:","WEBSITE_FAQ":"Preguntas frecuentes","WEBSITE_FAQ_SHORT":"Preguntas frecuentes","WEBSITE_QUESTIONS":"Preguntas","WEBSITE_TOS":"Términos de Uso","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"Acerca de","WEBSITE_PAGE_BECOME_PARTNER":"Vuélvete un socio","WEBSITE_ALL_YOU_CAN_WATCH":"Libertad para ver\\nTodo lo que quieras.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"¿Qué es Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio es un centro unificado para agregación de contenido de vídeo. Descubre, organiza y ver videos de todo tipo de fuente en cualquier dispositivo que poseas.","WEBSITE_WHAT_IS_STREMIO_P2":"Películas, programas de televisión, series, televisión en vivo o canales web como YouTube y Twitch.tv: puedes encontrar todo esto en Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio es un media center moderno que le ofrece una solución integral de entretenimiento por vídeo. Puede descubrir, ver y organizar su contenido de vídeo desde complementos de fácil instalación.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Películas, programas de TV, TV en directo o canales web - Stremio pone todo esto a su disposición.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Disfruta en todos tus dispositivos","WEBSITE_DEVICES_COLLECT":"Recopilar desde Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importar desde Facebook","WEBSITE_DEVICES_LOCAL":"Agregar desde el disco local","WEBSITE_JOIN_THE_PARTY_NOW":"Únete a la fiesta ahora","WEBSITE_DEVICES_ALL":"Fácil de usar en todos tus dispositivos;","WEBSITE_EXTENDABLE_CATALOG":"Catálogo de videos extensible infinitamente;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Excelentes funcionalidades para organizar tu multimedia;","WEBSITE_AS_SEEN_ON":"Como se ve en","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Acerca de nosotros","WEBSITE_LINK_TECHNOLOGY":"Tecnología","WEBSITE_LINK_APPS":"Aplicaciones","WEBSITE_LINK_DOWNLOADS":"Descargas","WEBSITE_MORE":"Más","WEBSITE_LINK_ADDONS":"Complementos","WEBSITE_LINK_ADDON_SDK":"SDK para extensiones","WEBSITE_LINK_CONTRIBUTE":"Contribuye","WEBSITE_LINK_COMMUNITY":"Comunidad","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & Más","WEBSITE_LINK_HELP":"Centro de ayuda","WEBSITE_LINK_CONTACTS":"Contáctanos","WEBSITE_LINK_TOS":"Términos y condiciones","WEBSITE_LINK_PRAVACY":"Política de privacidad","WEBSITE_SUBSCRIBE":"Suscripción","WEBSITE_NEWSLETTER":"Únete a nuestro boletín de noticias para cosas increíbles","WEBSITE_PLACEHOLDER_EMAIL":"Su correo electrónico","WEBSITE_COMMUNITY":"Comunidad","WEBSITE_LINK_PRAVACY_LEGAL":"Privacidad y legal","WEBSITE_WHY":"¿Por qué hacemos esto?","WEBSITE_WHY_P1":"En Stremio, trabajamos cada día porque queremos solucionar un problema importante en la industria de vídeo bajo demanda. Hay tanto contenido nuevo publicado cada minuto que es virtualmente imposible de encontrar el camino a él.","WEBSITE_WHY_P2":"Ayudamos a las personas a navegar aquel enorme mundo del entretenimiento en vídeo y descubrir nuevo contenido para disfrutar. Nuestras aplicaciones traen juntas películas, series, televisión en vivo, canales web y más. Estamos dedicados a hacer esto increíblemente fácil para los usuarios buscar títulos y transmisiones que amarán.","WEBSITE_WHY_P3":"Puedes usar nuestro servicio en cualquier dispositivo y en cualquier momento, haciendo Stremio el único centro de entretenimiento de vídeo que necesitaras.","WEBSITE_TEAM":"EQUIPO","WEBSITE_TEAM_P":"El equipo Stremio es pequeño pero poderoso: entre diez de nosotros, programamos en X lenguajes y compartimos habilidades en desarrollo de software, diseño UI y UX, mercadeo y publicidad, y negocios y startups.","WEBSITE_FEATURES":"Características","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Descubre nuevo contenido con facilidad","WEBSITE_FEATURES_DISCOVER_P":"Descubre fácilmente nuevas películas, programas de televisión, series y canales para ver. Busca por categoría, género, calificación, año, etc. o simplemente escribe un nombre para buscar. Stremio hace fácil encontrar nuevo contenido de vídeo.","WEBSITE_FEATURES_ALL_CONTENT":"Todo tu contenido de vídeo en una pantalla","WEBSITE_FEATURES_ALL_CONTENT_P1":"Mira que películas, series o vídeos no has terminado y continua viendolos; obtén notificaciones de nuevos episodios y estrenos; y navega a través de recomendaciones que obtendrás basadas en tus hábitos.","WEBSITE_FEATURES_LIBRARY":"Organiza tus videos","WEBSITE_FEATURES_LIBRARY_P1":"Agrega cualquier título a tu biblioteca de Stremio con un solo clic y encuentra tu camino a través de tu contenido, perfectamente ordenado por tipo, año u orden alfabético.","WEBSITE_FEATURES_CALENDAR":"Mantiene seguimiento de todo lo que ves","WEBSITE_FEATURES_CALENDAR_P1":"Obtén un calendario de todas las películas y series que agregas a tu biblioteca. Exporta tu calendario Stremio y sincroniza este para que siempre sepas cuando hay un nuevo episodio o un estreno.","WEBSITE_FEATURES_BIG_SCREEN":"Disfruta tu contenido de video en una pantalla grande","WEBSITE_FEATURES_BIG_SCREEN_P1":"Transmite lo que sea que estés viendo a otro dispositivo - sea este un teléfono, tableta o un T.V. con un solo clic.","WEBSITE_FEATURES_SOURCES":"Ve videos de diferentes fuentes","WEBSITE_FEATURES_SOURCES_P":"Instala complementos oficiales y de la comunidad para disfrutar las fuentes de vídeo desde diferentes proveedores - todo en una aplicación elegante y fácil de usar.","WEBSITE_CREATE_AN_ADDON":"Crear un complemento","WEBSITE_FEATURES_SYNC":"Sincroniza tu biblioteca entre distintos dispositivos y continua la reproducción","WEBSITE_FEATURES_SYNC_P1":"Haz login en tu cuenta en todos los dispositivos y podrás disfrutar de tener tu biblioteca, complementos, lista de reproducción y calendario.","WEBSITE_FEATURES_EXTENDABLE":"Catálogo de videos ampliable a través de complementos","WEBSITE_FEATURES_EXTENDABLE_P1":"El complemento de catálogo de Stremio provee de una serie de complementos instalables que permiten ver contenido a través de ellos. Ésto incluye películas, series, televisión en directo, deportes, noticias, podcasts, suscripciones webs, video juego, etc.","WEBSITE_FEATURES_AUTO_SUBS":"Subtítulos automáticos","WEBSITE_FEATURES_AUTO_SUBS_P1":"Con nuestros complementos de subtítulos puedes obtener automáticamente una variedad de opciones en tu idioma.","WEBSITE_FEATURES_CHROMECAST":"Haciendo casting a Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Disfruta del video en una pantalla más grande o envía lo que estás viendo a otro dispositivo.","WEBSITE_FEATURES_KEEP_TRACK":"Haz el seguimiento de tus series o canales favoritos.","WEBSITE_FEATURES_KEEP_TRACK_P1":"Obtén un calendario con notificaciones cuando haya nuevos episodios de tu serie o canal favoritos.","WEBSITE_FEATURES_POWER_USER":"Características de usuario experto","WEBSITE_FEATURES_POWER_USER_P1":"Ver en un reproductor externo.","WEBSITE_FEATURES_POWER_USER_P2":"Reproducir desde un fichero torrent o unlace magnet","WEBSITE_FEATURES_POWER_USER_P3":"Importa en tu librería a través de los Me gusta de Facebook o desde tu disco duro local","WEBSITE_ADD_ONS":"Complementos","WEBSITE_ADD_ONS_P1":"Todo el contenido de vídeo que Stremio provee es obtenido a través de un sistema de complementos - no se ha incorporado ningún contenido o proveedor de contenido dentro de la aplicación.","WEBSITE_ADD_ONS_P2":"Hay dos grupos de complementos disponibles: oficiales y de la comunidad.","WEBSITE_ADD_ONS_P3":"Los complementos oficiales son desarrollados y alojados por Stremio, mientras que los complementos de la comunidad son creados por nuestros miembros de la comunidad, quienes también los alojan.","WEBSITE_ADDONS_OFFICIAL":"Complementos oficiales","WEBSITE_ADDONS_WATCHUB":"Reproduce tus películas, series y programas favoritos desde proveedores como iTunes, Hulu, Amazon y otros servicios de Estados Unidos y Reino Unido.","WEBSITE_ADDONS_YOUTUBE":"Mira tus canales favoritos de Youtube libres de publicidad y obtén notificaciones de nuevos vídeos de los contribuidores que sigues.","WEBSITE_ADDONS_FILMON":"Mira canales en vivo, películas y televisión pública gratis. 600 canales de televisión, 45000 películas, documentales y más gratis.","WEBSITE_ADDONS_OPENSUBTITLES":"Subtítulos de películas y televisión en múltiples lenguajes, miles de subtítulos traducidos subidos todos los días.","WEBSITE_ADDONS_COMMUNITY":"Complementos de la comunidad","WEBSITE_ADDONS_FILMON_VOD":"Mira vídeos bajo demanda desde Filmon.tv","WEBSITE_ADDONS_TWICH":"Mira programas en vivo desde Twitch.tv - una plataforma de transmisión de vídeo para la industria de deportes electrónicos.","WEBSITE_ADDONS_VODO":"Ve películas independientes completamente gratis.","WEBSITE_ADDONS_NETFLIX":"Ve películas de Netflix y series web.","WEBSITE_ADDONS_CREATE":"Crear un complemento","WEBSITE_ADDONS_CREATE_P1":"Si lo deseas, puedes desarrollar tu propio complemento. De esta manera, puedes darte a ti y a la comunidad acceso a nuevo contenido de vídeo, y alcanzar una nueva audiencia de millones de usuarios alrededor del mundo.","WEBSITE_ADDONS_START_CREATE":"Para empezar, visita la página del SDK de complementos de Stremio:","WEBSITE_DOWNLOADS":"Descargas","WEBSITE_DOWNLOADS_P1":"Para un óptimo rendimiento, recomendamos que uses la última versión disponible de las aplicaciones de Stremio. Si por alguna razón, deseas usar una versión anterior, puedes descargarla aquí.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio para Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio para macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio para Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio para Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio para Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio para Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio para Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio para iOS","WEBSITE_CONTRIBUTE":"Contribuye","WEBSITE_CONTRIBUTE_P1":"La plataforma Stremio es código abierto y puedes crear fácilmente un complemento para contenido que actualmente no posee fuente.","WEBSITE_CONTRIBUTE_WHY":"¿Por qué deberías crear una extensión?","WEBSITE_CONTRIBUTE_WHY_P1":"Alcanzar nueva audiencia para tu contenido de vídeo","WEBSITE_CONTRIBUTE_WHY_P2":"La base de usuarios de Stremio crece rápidamente - desde el primer año de lanzamiento, Stremio ha ganado 1 millón de usuarios alrededor del mundo, y en el segundo año de la existencia de la plataforma este número ha crecido a 2.5 millones.","WEBSITE_CONTRIBUTE_WHY_P3":"Con tu complemento fácilmente alcanzarás esta audiencia y distribuirás tu contenido de vídeo a ellos.","WEBSITE_CONTRIBUTE_ALL":"Mira tus películas, series y canales favoritos en un solo lugar.","WEBSITE_CONTRIBUTE_ALL_P1":"¿Eres aficionado de un un tipo particular de contenido no disponible aún en Stremio? Crea un complemento para este y disfruta de ver tus vídeos favoritos en uno de los centros de entretenimiento más grandes y fáciles de usar en el mercado.","WEBSITE_CONTRIBUTE_ALL_P2":"Además de eso, obtendrás la infinita gratitud de otros miembros de la comunidad de Stremio afines.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetiza tu complemento y gana dinero con su ayuda","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Una vez desarrolles un nuevo complemento para Stremio, puedes fácilmente monetizar este a través de diferentes maneras. Si estás considerando esto, siéntete libre de entrar en contacto con nosotros a ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - estaremos felices de consultarte y asesorarte sobre las opciones de monetización de tu complemento.","WEBSITE_CONTRIBUTE_TRANSLATE":"Conviértete en un traductor voluntario","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Si deseas disfrutar de las aplicaciones de Stremio en diferentes lenguajes, puedes unirte a nuestra comunidad de traductores voluntarios. Ellos nos ayudan a agregar versiones de Stremio en diferentes lenguajes.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"¿Estás ansioso por comenzar?","WEBSITE_TRANSALTE_STREMIO":"Traduce Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Comunidades oficiales","WEBSITE_COMMUNITY_OFFICIALS_P1":"Sé parte de la creciente comunidad de Stremio. Síguenos en redes sociales y no seas tímido de decir hola - ¡nos encanta escuchar a nuestros fanáticos! ","WEBSITE_COMMUNITY_UNOFFICIALS":"No oficial","STREMIO_COMMUNITY_NL":"Stremio Países Bajos","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Alemania","STREMIO_COMMUNITY_BELGIUM":"Stremio Bélgica","STREMIO_COMMUNITY_FRANCE":"Stremio Francia","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italia","STREMIO_COMMUNITY_UK":"Stremio Reino Unido","STREMIO_COMMUNITY_USA":"Stremio Estados Unidos","STREMIO_COMMUNITY_MEXICO":"Stremio México","STREMIO_COMMUNITY_ADDONS":"Complementos de Stremio","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Socios y partidarios","WEBSITE_COMMUNITY_GOODIES":"Stremio Goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Protectores de pantalla","WEBSITE_COMMUNITY_ART":"Galería de Arte de la Comunidad","WEBSITE_LINK_ART":"Galería de arte de la comunidad","WEBSITE_CONTACT_US":"Contacta con nosotros","WEBSITE_CONTACT_US_P1":"Si tienes alguna pregunta, comentario o sugerencia, siéntete libre de entrar en contacto con nosotros a través del formulario de contacto más abajo.","WEBSITE_CONTACT_US_P2":"Ten presente que nos ubicamos en Bulgaria, entonces habrá un retraso en la respuesta a su consulta debido a las diferencias de zona horaria.","WEBSITE_CONTACT_US_SUCCESS":"Tu mensaje ha sido enviado. Nos pondremos en contacto contigo lo antes posible.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"¡Por favor escribe un correo electrónico válido!","WEBSITE_CONTACT_US_Q_RELATED_TO":"¿Con qué se relaciona su pregunta?","WEBSITE_CONTACT_US_Q_OS":"¿Cuál es su sistema operativo?","WEBSITE_CONTACT_US_PH_EMAIL":"Su correo electrónico","WEBSITE_CONTACT_US_PH_MESSAGE":"Mensaje","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ENVIAR","WEBSITE_CONTACT_US_Q_1":"¿Cómo instalar?","WEBSITE_CONTACT_US_Q_2":"¿Cómo desinstalar?","WEBSITE_CONTACT_US_Q_3":"¿(HTML) Cómo hacer lasaña?","WEBSITE_CONTACT_US_Q_4":"Complementos","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Tecnología","WEBSITE_TECHNOLOGY_P1":"Amamos la tecnología y la ciencia loca.
Aquí está lo que potencia a Stremio (todo es código abierto).","WEBSITE_TECHNOLOGY_P_QT":"Desarrollo de software multiplataforma en su mejor momento.","WEBSITE_TECHNOLOGY_P_MPV":"Un reproductor libre, de código abierto y multiplataforma.","WEBSITE_TECHNOLOGY_P_RN":"React Native te permite desarrollar aplicaciones móviles usando solo Javascript.","WEBSITE_TECHNOLOGY_P_VLC":"Framework multimedia embebido en la aplicación para obtener multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm es una plataforma móvil y un reemplazo para SQlite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js es un entorno de Javascript multi-plataforma y de código abierto.","WEBSITE_TECHNOLOGY_P_RUST":"Rust es un lenguaje de programación de sistemas multi-paradigma que se enfoca en la seguridad, y más concretamente en ejecución concurrente de manera segura.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribuye al proyecto","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Hay dos formas en las que puedes contribuir a Stremio y ayudarnos a hacer el producto aún mejor.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Puedes donar tus habilidades en lenguaje traduciendo la plataforma...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"o","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... puedes emplear tus habilidades de programación para la creación de extensiones de la comunidad. ","WEBSITE_TRANSLATE_STREMIO":"Traduce Stremio","WEBSITE_404_OH_NO":"Ay no! La página que estás buscando no está aquí...","WEBSITE_GO_HOME":"Ir al inicio","WEBSITE_LINK_OTHER_DOWNLOADS":"Otras descargas","WEBSITE_FAQ_ABR":"Preguntas frecuentes","WEBSITE_SUPPORT":"Soporte","WEBSITE_DOWNLOAD_4_0_BETA":"Descarga ahora Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Para escritorio","WEBSITE_LINK_ADDON_COMPETITION":"Competición de complementos","WEBSITE_LINK_ART_CONTEST":"Competición artística","WEBSITE_MY_ACCOUNT":"Mi cuenta","WEBSITE_MAINPAGE_FAQ_001_H1":"¿Qué es Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio es un \'media center\' moderno que te da la libertad de ver todo lo que quieras.","WEBSITE_MAINPAGE_FAQ_002_H1":"¿Cómo funciona?","WEBSITE_MAINPAGE_FAQ_002_P1":"Una vez que Stremio esté instalado en tu dispositivo y hayas creado una cuenta, todo lo que tienes que hacer es ver el catálogo de complementos para instalar el complemento que quieras y estarás listo para comenzar a explorar contenido.","WEBSITE_MAINPAGE_FAQ_002_P2":"A continuación, puede ir a las secciones Descubrir o Panel para comenzar a explorar contenido.","WEBSITE_MAINPAGE_FAQ_003_H1":"¿Qué puedo ver?","WEBSITE_MAINPAGE_FAQ_003_P1":"Muchas cosas: Películas, series, canales web, deporte, canales de televisión, podcasts, etc. Gracias a nuestro sistema de complementos puedes acceder a una gran variedad de contenidos.","WEBSITE_MAINPAGE_FAQ_004_H1":"¿Es Stremio software libre?","WEBSITE_MAINPAGE_FAQ_004_P1":"Sí, puedes consultar los siguientes enlaces: ${1}aplicación de escritorio${2} y ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"¿Es Stremio seguro?","WEBSITE_MAINPAGE_FAQ_005_P1":"Sí: al ser software libre, el código es auditable publicamente y puedes revisarlo tú mismo.","WEBSITE_MAINPAGE_FAQ_006_H1":"¿Qué ocurre con mi privacidad?","WEBSITE_MAINPAGE_FAQ_006_P1":"Respetamos la privacidad de los usuarios y no guardamos ningún dato personal exceptuando lo mínimo necesario para poder crear y sincronizar tu cuenta.","WEBSITE_MAINPAGE_FAQ_006_P2":"Hay un ${1}modo invitado{2} al crear la cuenta, que no requiere ningún dato: en éste modo, no hay ninguna llamada a nuestros servidores. Sin embargo, ésto tiene el coste de no tener disponible algunas características útiles como sincronizar tu biblioteca entre distintos dispositivos.","WEBSITE_MAINPAGE_FAQ_007_H1":"¿Puedo enviar el contenido a mi TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Sí, damos soporte a Chromecast y puedes enviar contenido de video desde la aplicación de escritorio o aplicación móvil (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"¿Cuantos complementos tiene Stremio?","WEBSITE_MAINPAGE_FAQ_008_P1":"A finales de 2019, más de 50 - para más información, consulta nuestro catálogo de complementos.","WEBSITE_MAINPAGE_FAQ_009_H1":"¿Es posible ampliar Stremio más allá de lo que se ofrece en el catálogo de complementos?","WEBSITE_MAINPAGE_FAQ_009_P1":"Sí, deberías visitar: ${1}PimpMyStremio${2}, ${3}la comunidad en Reddit{4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"¿Qué dispositivos soporta Stremio?","WEBSITE_MAINPAGE_FAQ_010_P1":"Tenemos aplicaciones de escritorio para Windows, Mac y GNU/Linux. Para móviles o celulares, damos soporte a Android e iOS, aunque la funcionalidad en iOS es limitada (no soporta muchos complementos).","WEBSITE_MAINPAGE_FAQ_010_P2":"Hay muchos dispositivos basados en Android en los cuales puedes ejecutar Stremio, por ejemplo NVIDIA Shield y Amazon Fire Stick, aunque no damos soporte oficial.","WEBSITE_MAINPAGE_FAQ_011_H1":"¿Podeis añadir cierto contenido a Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Lo sentimos, nosotros no proveemos del contenido, sin embargo, cuantos más complementos tengas instalads, mayor será el contenido que tendrás disponible.","WEBSITE_MAINPAGE_FAQ_012_H1":"¿Puede Stremio reproducir enlaces magnet?","WEBSITE_MAINPAGE_FAQ_012_P1":"Sí, y también puede reproducir enlaces HTTP normales, así como ficheros torrent(mediante arrastrar y soltar).","WEBSITE_MAINPAGE_FAQ_013_H1":"¿Puedo descargar un video y verlo offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Tener el contenido offline es una característica en desarrollo que estará disponible más adelante, aunque si dejas que Stremio cachee el contenido en tu dispositivo (revisa el panel de administración) podrás ver el contenido posteriormente sin conexión.","WEBSITE_MAINPAGE_FAQ_014_H1":"¡No funciona nada, ayuda!","WEBSITE_MAINPAGE_FAQ_014_P1":"¿Estás seguro de que has instalado los complementos? Si la respuesta es sí, dirigete a nuestro ${1}centro de ayuda${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"¿Cómo mantiene Stremio los costes de desarrollo?","WEBSITE_MAINPAGE_FAQ_015_P1":"Usamos anuncios no intrusivos gracias a ${1}AdEx${2}, la cual es una compañía de los mismos miembros fundadores y también enfocada en salvaguardar la privacidad y con anuncios no intrusivos.","WEBSITE_MAINPAGE_FAQ_015_P2":"Si tienes más preguntas, visita nuestro ${1}centro de ayuda${2}.","HELP_LEARN_MORE":"Ayúdanos a saber más de ti.","LIFESTYLE":"Estilo de vida","SPORTS":"Deportes","FOOD_HEALTH":"Comida y Salud","BEAUTY_FASHION":"Belleza y Moda","NEWS":"Noticias","GAMING":"Juegos","SCIENCE_EDUCATION":"Ciencia y Educación","MUSIC":"Música","TRAVEL":"Viajes","LATE_NIGHT":"Espectáculo nocturno","REALITY":"Reality","COMEDY":"Comedia","DIY":"Hazlo tú mismo","TECH":"Tecnología","CINEMA":"Cinema","CONTINUE":"Continuar","SLOW_LOADING":"¿CARGANDO LENTO?","I_GIVE_UP":"Me rindo","LEARN_MORE":"Saber más","POOR_SOURCE":"Esta fuente posee poca disponibilidad o su conexión de internet no es suficientemente rápida","PICK_CATEGORIES_ERR":"Tienes que seleccionar al menos 3 categorías","ADJUST_TIMING":"Ajustar tiempo con ","ADJUST_SIZE":"Ajustar tamaño con ","SEARCH_ANYTHING":"Puedes buscar cualquier cosa...","ALL_CATEGORIES":"Todas","SEARCH_CATEGORIES":"Películas, Series, YouTube & TV","SEARCH_PERSONS":"Actores, Directores y Escritores","SEARCH_PROTOCOLS":"HTTP y enlaces magnéticos","SEARCH_TYPES":"Enlaces IMDB / TVDB","WATCHED":"Viendo","SHOW_LESS":"Mostrar menos","LAST_SEARCHES":"Últimas búsquedas","CLEAR_HISTORY":"Borrar historia","CHOOSE_SOME":"Escoge algunos de estos:","NO_WEB_REMOTE":"Web Remote no se pudo cargar","STREMIO_OFFLINE":"Stremio está desconectado","STREMIO_EXPENSIVE_CONNECTION":"La conexión de red es costosa","USE_DATA":"Usar datos","WARNING":"Advertencia","MORE_INFO":"Más información ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Cargando ...","STREMIO_TV_BACK_TO_LANGUAGES":"Regresar a lenguajes","STREMIO_TV_REMOTE":"Remoto","STREMIO_TV_GO_TO":"Ir a:","STREMIO_TV_OR_SCAN":"o escanear:","STREMIO_TV_ADDON_INSTRUCTIONS":"Por favor, siga las instrucciones para instalar su complemento preferido.","STREMIO_TV_LIVE_TV":"TV en directo","STREMIO_TV_RESUME_WATCHING":"Continuar viendo","STREMIO_TV_LOADING_BACKGROUND":"Cargando fondo","STREMIO_TV_CHECKING_AUTHENTICATION":"Verificando Autenticación","STREMIO_TV_LOADING_BOARD":"Cargando Panel","STREMIO_TV_LOGIN_HEADER_LINE_1":"Nosotros queremos que nuestros usuarios tengan la mejor experiencia personalizada posible con nuestro software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"Esta es la razón por la cual le pedimos cree una cuenta y/o ingrese a ella.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Gracias por su comprensión,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"El equipo Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Para usar el Control Web con su teléfono inteligente / tableta / escritorio:","STREMIO_TV_WIFI_SETUP":"Configuración wifi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle no detecta una conexión a internet.","STREMIO_TV_WIFI_DETAILS_1":"Conectar a:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Contraseña a usar:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Abrir navegador de internet con el enlace:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Por Último Visto","STREMIO_TV_LIBRARY_SORT_NAME":"Por Nombre","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Por Veces Visto","STREMIO_TV_DETAILS_SEASON_NUMBER":"Temporada ${1}","STREMIO_TV_STREAMS_LOADING":"Cargados ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} complemento continua cargando...","STREMIO_TV_PLAYER_SETTINGS":"Configuración del Reproductor","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Retraso de Subtítulos","STREMIO_TV_PLAYER_AUDIO_DELAY":"Retraso de audio","STREMIO_TV_PLAYER_VIDEO_SCALING":"Escalado de vídeo","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Fuente no soportada","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Fallo al abrir el enlace externo","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Reproducir con ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Reproducir con libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Cambiar al reproductor libVLC debido a un error de reproducción","STREMIO_TV_ADDONS_TITLE":"Utiliza Stremio en tu dispositivo móvil o PC para instalar o configurar complementos y pulsa \\"Sincronizar Complementos\\"","STREMIO_TV_ADDONS_SUBTITLE":"Nota: asegúrate de utilizar la misma cuenta de Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sincronizar Complementos","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Complementos sincronizados exitosamente","STREMIO_TV_ADDONS_SYNC_FAILED":"Fallo al sincronizar complementos","STREMIO_TV_META_LINK_FAILED":"Fallo al abrir meta enlace","STREMIO_TV_CATALOG_LOADING":"El catálogo sigue cargando...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Idioma de la interfaz actualizado","STREMIO_TV_SETTINGS_THEME_UPDATED":"Tema actualizado","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Idioma Preferido","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Idioma Preferido Secundario","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Reproducción tunelizada","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Posibles errores de reproducción en algunos dispositivos","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Algunos formatos de video pueden no funcionar","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Configurar cuadros por segundo automáticamente","STREMIO_TV_SETTINGS_NO_CACHING":"Sin caché","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Por Defecto","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Suave","STREMIO_TV_SETTINGS_PROFILE_FAST":"Rápido","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Rápido","STREMIO_TV_SETTINGS_SERVER_URL":"URL del servidor de streaming","STREMIO_TV_SETTINGS_SERVER_VERSION":"Versión del servidor","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Desconocido","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Versión de Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Editar URL del servidor","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Ingrese la URL del servidor de streaming","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Para leer la Política de privacidad de Stremio, visite:","STREMIO_TV_SETTINGS_TOS_TEXT":"Para leer los Términos y condiciones de Stremio, visite:","STREMIO_TV_NAV_SEARCH":"Buscar","STREMIO_TV_NAV_HOME":"Inicio","STREMIO_TV_NAV_DISCOVER":"Descubrir","STREMIO_TV_NAV_LIBRARY":"Biblioteca","STREMIO_TV_NAV_MOVIES":"Películas","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Canales","STREMIO_TV_NAV_TV":"TV en vivo","STREMIO_TV_NAV_SETTINGS":"Configuración","STREMIO_TV_NAV_ADDONS":"Complementos","STREMIO_TV_LOGIN_TITLE":"Asociar Cuenta","STREMIO_TV_LOGIN_EXPIRES_IN":"Expira en","STREMIO_TV_LOGIN_STEP_ONE":"Escanea el Código QR de arriba o visita","STREMIO_TV_LOGIN_STEP_TWO":"Inicia sesión a tu cuenta Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Solicitar un nuevo enlace","STREMIO_TV_LOGIN_LINK_REFRESHED":"Código de login actualizado","STREMIO_TV_SEARCH_PLACEHOLDER":"Escribe algo","STREMIO_TV_SEARCH_NO_ADDONS":"¡No se solicitaron complementos para los catálogos!","STREMIO_TV_SEARCH_BUTTON":"Buscal","STREMIO_TV_SEARCH_KEY_DEL":"Borrar","STREMIO_TV_SEARCH_KEY_SPACE":"Espacio","STREMIO_TV_SEARCH_KEY_CLEAR":"Limpiar","STREMIO_TV_SEARCH_HISTORY_TITLE":"Historial de Búsqueda","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Puedes buscar por Título, Actores, Canales y más...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Vaciar el Historial de Búsqueda","STREMIO_TV_FILTERS_DESCRIPTION":"Elige uno de los filtros a continuación","FILTERS":"Filtros","SETTINGS":"Configuración","ACCOUNT":"Cuenta","LOGOUT":"Cerrar Sesión","THEMES":"Temas","PLAYBACK":"Reproducción","PLAYBACK_SPEED":"Velocidad de Reproducción","AUDIO_TRACKS":"Pistas de Audio","VIDEOS":"Videos","SERVER":"Servidor","LINKS":"Enalces","ABOUT":"Acerca De","INTERFACE":"Interfaz","ANIMATIONS":"Animaciones","STATUS":"Estado","LANGUAGE":"Idioma","SIZE":"Tamaño","DELAY":"Retraso","BOLD":"Negrita","TEXT_COLOR":"Color del Texto","OUTLINE_COLOR":"Color del Contorno","BACKGROUND_COLOR":"Color de Fondo","BACKGROUND_BLUR":"Desenfoque de Fondo","SEEK_TIME_DURATION":"Duración del Tiempo de Búsqueda","AUTO_PLAY":"Reproducir el Episodio Siguiente automáticamente","PLAY_NOW":"Reproducir Ahora","MARK_AS_WATCHED":"Marcar como Visto","MARK_AS_UNWATCHED":"Marcar como No Visto","REWIND_TO_BEGINNING":"Rebobinar al Principio","CONTINUE_WATCHING":"Seguir Viendo","ALL":"Todo","SECONDS":"segundos","ON":"ON","OFF":"OFF","RELOAD":"Recargar","EDIT_URL":"Editar URL","NONE":"Ninguno","EMBEDDED":"Embebido","REMOTE_SWITCH_DEVICES":"Cambiar dispositivos","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Ajustar tiempo","REMOTE_ADJUST_SIZE":"Ajustar tamaño","REMOTE_COULD_NOT_BE_LOADED":"El Control Web podría no cargar","REMOTE_RETRY":"Volver a intentar","TORRENT_PROFILE_DEFAULT":"Por Defecto","TORRENT_PROFILE_SOFT":"Suave","TORRENT_PROFILE_FAST":"Rápido","TORRENT_PROFILE_ULTRA_FAST":"Ultra Rápido","FAQ_001_H1":"¿Qué es Stremio?","FAQ_001_P1":"Stremio es un software de centro multimedia diseñado para el entretenimiento de vídeo pensando en el fácil uso. Stremio te permite organizar y ver tu propia colección de películas, series, canales y programas en vivo.","FAQ_001_P2":"Stremio colecta el contenido que muestra desde tu disco local y nuestro sistema de complementos.","FAQ_001_P3":"Te notificará cuando nuevos episodios, películas y vídeos en los cuales estás interesado salgan y proveerá recomendaciones de películas para ti.","FAQ_02_H1":"¿Cómo se compara Stremio con Kodi y Plex?","FAQ_02_P1":"Estamos inspirados por estas dos piezas de software. Pero tenemos diferentes objetivos - Stremio es específicamente pensado en el entretenimiento de vídeo, y se esfuerza por convertirse en la solución principal para eso al ser muy fácil de usar.","FAQ_02_P2":"Stremio nunca será tan personalizable y rico en características como Kodi y Plex, pero es significativamente más fácil de usar. ${1} Obtén y mira ${2} :)","FAQ_03_H1":"¿Cómo se compara Stremio con Netflix?","FAQ_03_P1":"Nuevamente, Netflix es una de nuestras inspiraciones. Nos esforzamos por lograr la experiencia del usuario de Netflix, además de muchos extras adicionales. Pero más importante, te damos la libertad de manejar tu propia biblioteca y agregar nuevas fuentes de contenido con nuestro sistema de complementos.","FAQ_03_P2":"Esto hace a Stremio infinitamente extensible, entonces cuando usas Stremio, no estás limitado al contenido que Netflix decide licenciar. Por ejemplo, a través de Stremio puedes ver contenido desde ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} e incluso ¡${9}Netflix${10} mismo!","FAQ_04_H1":"¿Cómo se compara Stremio con Flipboard?","FAQ_04_P1":"No nos hacemos esa pregunta frecuentemente, excepto cuando hablamos con emprendedores :)","FAQ_04_P2":"Stremio es por diseño un recopilador de contenido, lo cual esencialmente lo hace un Flipboard para vídeo. Esto es muy evidente en nuestra sección de Panel, que te da un catálogo y notificaciones de nuevos episodios y vídeos que sigues, tal como Flipboard.","FAQ_05_H1":"¿Cómo se compara Stremio con Popcorn Time?","FAQ_05_P1":"Stremio y Popcorn Time son similares en la interfaz de usuario, porque no hay muchas formas de hacer catálogos de entretenimiento de vídeo correctamente :)","FAQ_05_P2":"Mientras que Popcorn Time es enfocado en transmitir torrents desde fuentes específicas, Stremio no es restrictivo y es meramente un recopilador de contenido - no se restringe a una fuente específica de contenido.","FAQ_05_P3":"Además, nosotros no proveemos ningún complemento torrent por defecto, así Stremio no cubre el caso de uso de Popcorn Time oficialmente.","FAQ_05_P4":"Otra diferencia notable es que Popcorn Time es completamente código abierto, mientras Stremio es ${1} parcialmente código abierto${2}.","FAQ_06_H1":"¿Agregarán esta película/serie?","FAQ_06_P1":"No, disculpa :(","FAQ_06_P2":"Como es mencionado en la mayoría de las otras preguntas, Stremio no provee contenido alguno por si mismo - todo es agregado a través de un sistema de complementos. En caso de quieras solicitar un contenido, puedes usar el botón “Reportar” en el reproductor, el cual enviará un correo al autor del complemento que estás usando actualmente.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"¿Crearan un complemento para X?","FAQ_08_P1":"Es completamente posible.","FAQ_08_P2":"Si tienes una idea para un complemento, escríbenos a ${1}office@stremio.com${2}, pero asegúrate de que tu idea complementaria no infrinja los derechos de autor ni los términos de uso.","FAQ_08_P3":"En el momento, la siguiente cosa en nuestro plan de trabajo son complementos para FandangoNOW, vídeo bajo demanda Filmon.tv y Crunchyroll.","FAQ_09_H1":"¿Usa Stremio BitTorrent?","FAQ_09_P1":"Si, Stremio soporta BitTorrent como un protocolo de transmisión. Puedes usar este con un complemento torrent, o por arrastrar y soltar un archivo .torrent en Stremio, o por pegar un enlace magnético en la barra de búsqueda.","FAQ_09_P2":"Por favor note que el único complemento oficial usando BitTorrent es ${1}Vodo${2}, el cual provee contenido independiente, todos permitidos para ser distribuidos con BitTorrent.","FAQ_09_P3":"No soportamos el uso de cualquier complemento de terceros que pueda infringir derechos de autor.","FAQ_10_H1":"¿Qué puedo ver en Stremio con los complementos oficiales?","FAQ_10_P1":"Por defecto, puedes ver contenido de Filmon.tv, YouTube y Vodo en Stremio mismo, con su reproductor embebido. Adicionalmente, tenemos un complemento para Twitch.tv y otros tantos.","FAQ_10_P2":"Esto combinado provee una selección de:","FAQ_10_L1":"Canales de televisión populares, proveídos por Filmon.tv - por ejemplo E4, BBC, Bollyworld TV","FAQ_10_L2":"Todo desde YouTube - por ejemplo BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Películas independientes con Vodo","FAQ_10_L4":"Transmisiones de juegos en línea con Twitch.tv","FAQ_10_P3":"Adicionalmente, hay muchas fuentes de contenido provistas con los complementos de Guidebox y Netflix, los cuales no reproducirán completamente dentro de Stremio, pero podría redirigirte al service dado. For example, el complemento de Guidebox puede darte una selección de películas que puedes reproducir en Estados Unidos gratuitamente, desde servicios como TubiTV y Crackle.","FAQ_11_H1":"Stremio no instala, ¿Qué puedo hacer?","FAQ_11_P1":"Si estás en Windows, intenta ${1}este instalador alternativo${2}.","FAQ_11_P2":"Si estás en Mac OS X, ten presente que no soportamos versiones anteriores a OS X Mavericks (10.9).","FAQ_11_P3":"Si estás en Linux, ten presente que solo soportamos Linux de 64 bits (x64) en el momento.","FAQ_11_P4":"Si aún no puede resolver su problema, por favor escríbanos a nuestro ${1}grupo de Facebook${2}.","FAQ_12_H1":"¿Por qué mi antivirus reclama? ¿Es Stremio seguro?","FAQ_12_P1":"Aseguramos que Stremio ${1}100% libre de virus${2}.","FAQ_12_P2":"Su antivirus está reclamando porque nosotros incluimos publicidad en nuestro instalador, la cual es reconocida por algunos antivirus como software publicitario.","FAQ_12_P3":"Si aún estás inseguro, puedes probar nuestro ${1}instalador alternativo${2}.","FAQ_13_H1":"¿Cómo puedo crear un complemento?","FAQ_13_P1":"Para principiantes, recomendamos que revises nuestro ${1}módulo de sistema de complementos${2} en GitHub.","FAQ_13_P2":"Después, puedes seguir el ${1}tutorial: Hello World${2}.","FAQ_13_P3":"Si no tienes habilidades en programación, por favor publica tu idea en ${1}la comunidad Reddit${2} y contáctanos con tu idea de complemento a ${3}office@stremio.com${4}.","FAQ_14_H1":"¿Cómo se publican complementos?","FAQ_14_P1":"Cuando creas un complemento y lo alojas, y pones un campo endpoint en su manifiesto, que apunta a una dirección de complemento funcional, el complemento automáticamente se publicará por si mismo en nuestro ${1}catálogo de complementos${2}.","FAQ_14_P2":"Esto sucede porque la parte del servidor del módulo stremio-addons realiza automáticamente una llamada a nuestra API para anunciar el complemento. Cuando nuestra API valida su endpoint como un complemento válido, comenzará a mostrarse en el catálogo.","FAQ_15_H1":"¿Puedo ejecutar Stremio en mi navegador?","FAQ_15_P1":"No en este momento, ¡pero vendrá pronto!","FAQ_15_P2":"Si tienes curiosidad de ver un alfa, puedes verlo aquí: ${1}alpha4.strem.io${2}. Ten en mente que la transmisión es deshabilitada en este alfa. Soportamos Chrome, Firefox, Opera y Edge.","FAQ_16_H1":"Transmitir al televisor no funciona / subtítulos no funcionas","FAQ_16_P1":"La transmisión al televisor usa tecnología DLNA, que es muy inconsistente entre diferentes marcas y modelos de televisor. Por esa razón, no tenemos la capacidad de probarlo en todos los casos, por lo que está lejos de ser perfecto. A pesar de esto, estamos trabajando para mejorarlo constantemente, pero no podemos darle una estimación de cuándo la tecnología DLNA comenzará a funcionar correctamente con su televisor.","FAQ_16_P2":"Si ni siquiera ve su televisor en el menú de transmisión, intente deshabilitar su conexión de red y volver a habilitarla (en Windows, haga clic derecho en la red y use Activar/Desactivar), y reinicie su enrutador, televisor y computador.","FAQ_16_P3":"Si aún presentas problemas, puedes ayudarnos enviándonos la información de marca y modelo de tu televisor a ${1}office@stremio.com${2}.","FAQ_16_P4":"En el momento, recomendamos Chromecast, el cual soportamos bastante bien, o simplemente conecta a tu televisor con un cable HDMI.","FAQ_17_H1":"Stremio se bloquea y/o cierra, ¿qué puedo hacer?","FAQ_17_P1":"Primero que todo, si estás usando Windows 7 con el antivirus AVG: tenemos un problema con esta combinación. El problema es en el mismo AVG y no hay forma razonable para resolver el problema para nuestro fin. Desafortunadamente, excepciones o deshabilitar el antivirus no funcionará. La única solución es reemplazar AVG con otro antivirus.","FAQ_17_P2":"Si esto no soluciona el problema, pero aún estás usando Windows, por favor actualiza al último service pack y actualiza/reinstala tus controladores de la GPU, luego intenta de nuevo.","FAQ_17_P3":"Si su problema aún no se resuelve, o estás usando un Mac o Linux, por favor escríbenos reportando los detalles exactos del problema a ${1}nuestro grupo de Facebook${2}.","FAQ_18_H1":"¿Cómo puedo crear un complemento?","FAQ_18_P1":"Para principiantes, recomendamos que revises nuestro ${1}módulo de sistema de complementos${2} en GitHub.","FAQ_18_P2":"Después, puedes seguir el ${1}tutorial: Hello World${2}.","FAQ_18_P3":"Si no tienes habilidades en programación, por favor publica tu idea en ${1}la comunidad Reddit${2} y contáctanos con tu idea de complemento a ${3}office@stremio.com${4}.","FAQ_19_H1":"¿Por qué Stremio ocupa espacio en disco?","FAQ_19_P1":"Stremio tiene una cache local para almacenar temporalmente los archivos de vídeo que ves.","FAQ_19_P2":"Esto tiene dos beneficios: primero, esto permite a Stremio precargar el vídeo y así asegurar una transmisión más fluida. Segundo, este guarda los vídeos en la cache local, así puedes continuar viéndolos sin conexión.","FAQ_19_P3":"La cantidad que almacena Stremio depende de la configuración de Cache en el panel de Configuración. Stremio puede ser configurado para almacenar una cantidad (ej. 2GB) en su disco local, a menos que el vídeo transmitido actualmente sea mayor que eso, en cuyo caso tendrá que ubicar suficiente almacenamiento para guardarlo hasta que lo retransmitas","FAQ_20_H1":"¿Donde está la carpeta de almacenamiento?","FAQ_20_P1":"En Windows, es stremio-cache en el disco que seleccionaste en Configuración (ej. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"En MacOS, es \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"En Linux, es \\"~/.stremio/stremio-cache\\" o \\"~/stremio-cache\\"","FAQ_21_H1":"Obtengo el error \\"Streaming server is not found\\", ¿qué puedo hacer?","FAQ_21_P1":"Si ves este error, quiere decir una de las siguientes cosas::","FAQ_21_P2":"1) Estás intentando usar un complemento que depende de fuentes de Youtube/BitTorrent, a través de nuestra ${1}versión web${2}. En este caso, deberías instalar nuestra versión de escritorio desde ${3}nuestro sitio web${4}.","FAQ_21_P3":"2) Algo está mal con tu instalación de Stremio. En este caso, intenta reinstalar nuestra última versión de escritorio desde ${1}el sitio web${2}. Si esto no ayuda, intenta deshabilitar los programas de antivirus y el cortafuegos, reinicia tu computador e intenta de nuevo. Si esto tampoco funciona, escríbenos por favor a ${3}nuestro grupo de facebook${4}.","FAQ_22_H1":"No puedo ver/usar la mayoría de complementos en iOS","FAQ_22_P1":"Debido a las restricciones de los términos y condiciones de Apple App Store, tenemos restringida la aplicación iOS solo a un conjunto particular de complementos.","FAQ_22_P2":"Pero puedes estar seguro - habrán más complementos para iOS en el futuro, y podríamos también agregar una integración que te permita usar todos los complementos de Stremio gracias a la conexión de la aplicación iOS con el servidor de transmisión de Stremio."}')},3236:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filma","TYPE_series":"Telesaila","TYPE_tv":"Telebista katea","TYPE_channel":"Kanala","TYPE_other":"Beste batzuk","TYPE_movie_PL":"Filmak","TYPE_series_PL":"Telesaila","TYPE_tv_PL":"Telebista kateak","TYPE_channel_PL":"Kanalak","TYPE_other_PL":"Beste batzuk","TYPE_ALL":"All","VIDEO":"Bideoa","BACK":"Atzera","MORE":"Gehiago","DONE":"Eginda","COPY":"Kopiatu","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Ezagutu","Board":"Arbela","Library":"Liburutegia","My Library":"Nire Liburutegia","Calendar":"Egutegia","NOTIFICATION_ONLINE":"Linean zaude orain","NOTIFICATION_OFFLINE":"Une honetan lineaz kanpo zaude","INTERNET_CONNECTION":"Sareko konexioa","STORAGE_FULL_TITLE":"Abisua: biltegiratzea beteta!","STORAGE_FULL_TEXT":"Stremio-k ezin izango ditu zure ezarpenak, lehentasunak edo saio-hasierako informazioa gorde. Baloratu Stremio berriro abiaraztea edo berriro instalatzea.","SEARCH":"bilatu","SEARCH_NO_RESULTS":"Ez da emaitzarik aurkitu","SEARCH_EXPLANATION_CONTENT":"Bilatu filmak, serieak, YouTube eta telebista kateak","SEARCH_EXPLANATION_PEOPLE":"Aktore, zuzendari eta idazleak bilatu","SEARCH_PASTE_LINKS":"Itsatsi HTTP eta Magnet estekak","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Gehitu liburutegian","REMOVE_FROM_LIB":"Kendu liburutegitik","ADDED_TO_LIB":"Liburutegian gehitu da","REMOVED_FROM_LIB":"Liburutegitik kendu da","TRAILER":"Trailerra","WATCH_TRAILER":"Ikusi Trailerra","WATCH_NOW":"Ikusi orain","SHOW":"Ikuskizuna","SHOW_MOVIE":"Erakutsi filma","WATCH_RANDOM":"Ikusi ausaz","IMDB_RATING":"IMDb balorazioa","YEAR":"Urtea","DIRECTOR":"Zuzendaria","WRITER":"Idazlea","LEAD_ACTORS":"Aktore nagusiak","CAST":"Aktoreak","CREW":"Tripulazioa","SHOW_MORE_CAST":"Erakutsi gehiago »","AIRED":"Erretransmititua","SEASONS":"Denboraldiak","GENRE":"Generoa","CATALOG":"Katalogoa","SUMMARY":"Laburpena","SHOW_MORE":"Erakutsi gehiago","SIMILAR":"Antzekoak","UPCOMING":"Datozenak","ENDED":"Bukatuta","DURATION":"Iraupena","FEATURED":"Nabarmenduak","METADATA":"Metadatuak","CATEGORY":"kategoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"bilatu bideoak","SEARCH_PLACEHOLDER":"bilatu edo itsatsi URLa","ADDON":"gehigarria","ADDONS":"Gehigarriak","OFFICIAL":"ofiziala","ADDONS_OFFICIAL":"Stremio gehigarri ofizialak","ADDONS_POPULAR":"Zure inguruan ezaguna","ADDON_FREE":"doan","ADDON_PEERED":"begiratu","ADDON_SUBSCRIPTION":"harpidetza","ADDON_STREAM_GEORESTRICTED":"ez dago erabilgarri zure eremuan","ADDON_STREAM_OFFLINECACHE":"Lineaz kanpoko cachea","ADDON_STREAM_LOCALFILE":"Tokiko fitxategia","SHARE_ADDON":"Partekatu gehigarria","AVAILABLE_STREAMS":"Eskuragarri dauden stream-ak","NO_STREAM":"Ez da stream-ik aurkitu","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Stream gehiagorako, instalatu gehigarriak","STREAM_NOT_SUPPORTED":"Aukeratutako stream-a ez da onartzen plataforma honetan.","ADDON_CATALOGUE":"Erakutsi gehigarri guztiak »","ADDON_CATALOGUE_MORE":"Instalatu gehigarriak","REPO_ADDED":"Biltegia gehitu da","ADDON_REPO_EXIST_ERR":"Gehigarrien bilduma hau dagoeneko existitzen da","ADDON_REPO_ERR":"Errore bat gertatu da bilduma gehitzean","ADDON_ADD_ERR":"Errore bat gertatu da gehigarria gehitzean","ERR_ADDON_PROTECTED":"Ezin da gehigarria desinstalatu, babestuta dago","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Arazoren bat izan da. Baliteke autentifikazioak huts egitea","ERR_NOT_COLLECTION_URL":"Ez da bildumaren URLa","ERR_NOT_ADDON_URL":"Ez da baliozko gehigarri URLa","ERR_DETECTFROMURL":"Ezin da URL honetatik gehigarririk/bildumarik aurkitu","ADDON_DUPLICATE_WARNING":"Abisua: gehigarri bikoiztua","ADDON_COLLECTION_SET_FAILED":"Instalatutako gehigarriak zure kontuan sinkronizatzeak huts egin du","SETTINGS_DATA_EXPORT":"Esportatu erabiltzaileen datuak","ADDON_PULL_FAILED":"Instalatutako gehigarriak zure kontutik sinkronizatzeak huts egin du","REFRESH_ON_CLICK":"Egin klik berriro saiatzeko","STILL_IN_THEATER":"Filma oraindik zinema aretoetan","WATCH_IN_CINEMA":"Ikusi zure tokiko zineman","IN_THEATER":"Zineman","GET_TICKETS":"Sarrerak eskuratu","UPCOMING_EPISODE":"Hurrengo atala","UPCOMING_EPISODE_MESSAGE":"Atal hau emitituko da","MISSING_DATE_EPISODE":"Atalaren data falta da","MISSING_DATE_EPISODE_MESSAGE":"Baliteke atal hau oraindik ez emititzea","CHANNEL_NOT_SCRAPED":"Kanal hau ez dago oraindik zatituta.
Itzuli minutu batzuen buruan.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Gehitu liburutegian erabilgarri dagoenean jakinarazpenak jasotzeko.","GET_NOTIFIED_WHEN_AVAILABLE":"Erabilgarri dagoenean jakinaraziko zaizu.","WARNING_STREAMING_SERVER":"Abisua: ez da aurkitu streaming lokaleko zerbitzaria. Tokiko fitxategietatik, YouTube-tik eta BitTorrent-etik erreproduzitzea ez da erabilgarri egongo.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Oharra: baliteke bideo hau zure hardwareak ez onartzea. Gogoan izan, erreprodukzioa motela izan daitekela.","PLAYER_ERROR":"Erreproduktorearen akatsa","PLAYER_ERROR_LOOKSLIKE":"Badirudi","PLAYER_ORIENTATION":"Erreproduktorearen orientazioa","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Blokeatuta","PLAYER_ORIENTATION_SENSOR_SHORT":"Sentsorea","PLAYER_ORIENTATION_LANDSCAPE":"Erreproduktorearen orientazio etzana blokeatuta dago","PLAYER_ORIENTATION_SENSOR":"Erreproduktorearen orientazio automatikoa (sentsorea)","PLAYER_PLAYBACK_SPEED":"Erreprodukzio abiadura","PLAYER_PLAYBACK_ERROR":"Erreprodukzioaren errorea. Saiatu berriro","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Errore ezezaguna","PLAYER_PLAYBACK_ERROR_DEFAULT":"Barkatu, bideo hau ezin du {{productName}} erabiltzaileak erreproduzitu.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Zuzenean","PLAYER_NEXT_VIDEO_TITLE":"Bueltan dator","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Baztertu","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Ikusi orain","STREAMING_FROM":"streaming jatorria","CASTING_TO":"(e)ra igortzen","NETWORK_STATUS":"Sarearen egoera","STREAM_SPEED":"Stream-aren abiadura:","STREAM_BUFFERED":"Bufferrean:","PEERS_INFO":"Peer informazioa","PEERS_ACTIVE":"Aktibo:","PEERS_CONNECTED":"Konektatuta:","PEERS_WAITING":"Itxaroten:","TRANSCODING_WARNING":"Abisua: bideoa transkodetzen.","STREAM_LOADING":"kargatzen...","PLAYING_LOCAL":"fitxategi lokaletik erreproduzitzen","PLAYING_CACHE":"cachetik erreproduzitzen","WRONG_SUBS":"Azpititulu okerrak?","ERR_SUBS_LOADING_TITLE":"Errorea azpitituluak kargatzean","ERR_SUBS_LOADING":"Ezin izan dira azpitituluak kargatu: arazoa izan daiteke erabiltzen ari zaren gehigarrian edo sareko konexioan","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Azpitituluen gehigarri hauek huts egin dute","ERR_CASTING_UPDATE_TITLE":"Ezin izan da eguneratu gailuaren informazioa: streaming zerbitzaria konexiorik gabe egon liteke","CHOOSE_DEVICE":"Aukeratu ikusi nahi duzun gailua","NO_CAST_DEVICES":"Ez dago galdaketa gailurik erabilgarri.","NO_SETTINGS":"Ez dago ezarpenik erabilgarri.","PHONE_TABLET":"Telefonoa / Tableta","SUBTITLES":"Azpitituluak","SUBTITLES_CHANGE":"Aldatu azpitituluak","SUBTITLES_CHANGE_NONE":"Ez dago hizkuntza honen azpititulurik, barkatu.","SUBTITLES_CHANGE_ACIVE":"Une honetan #{{subtitlesDialog.activeIdx + 1}} azpitituluak aktibatuta daude. Egin klik \\"Jarraitu\\" #{{subtitlesDialog.pickedIdx + 1}} azpitituluak aktibatzeko.","SUBTITLES_OR":"Bestela,","SUBTITLES_ADJUST_DELAY":"Doitu azpidatzien atzerapena:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Edo erabili G / H teklak erreproduzitzerakoan doiketarako.","SUBTITLES_ADJUST_DELAY_TIP":"AHOLKUA: G / H teklak erabil ditzakezu erreproduzitzerakoan doiketarako.","SUBTITLES_DELAY":"Azpitituluen atzerapena:","SUBTITLES_LOADING":"Azpitituluak kargatzen ...","SUBTITLES_UNAVAILABLE":"Ez dago kanpoko azpititulurik erabilgarri","SUBTITLES_DISABLED":"Desgaituta","AUDIO":"Audioa","DEFAULT_LANGUAGE":"Defektuzko hizkuntza","DEFAULT_SECONDARY_LANGUAGE":"Defektuzko Bigarren Hizkuntza","SEASON":"Denboraldia","EPISODE":"Atala","SPECIAL":"Berezia","SORT":"ordenatu","SORT_BY":"Ordenatu","FILTER":"iragazkia","SORT_TRENDING":"joera","SORT_RECENT":"berriena","SORT_ALPHABET":"a-z","SORT_RATING":"balorazioa","SORT_WATCHED":"ikusita","SORT_YEAR":"urtea","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Zuretzako berria","New Episodes":"Atal berriak","New Videos":"Bideo berriak","Recommendations":"Gomendioak","LIBRARY_RESUME":"Jarraitu","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Xehetasunak","LIBRARY_RESUME_DISMISS":"Baztertu","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Nabarmenduak","DISCOVER_TOP":"Gora","DISCOVER_OSCAR":"Oscar saridunak","DISCOVER_WARNING_TITLE":"Glubs!","DISCOVER_EMPTY_CATALOG":"Gehigarri honek eduki hutsa itzuli du.","DISCOVER_ADULT_WARNING":"Edukia helduentzat soilik dago ikusgai. 18 urte baino gehiago al dituzu?","DISCOVER_NOADDON_WARNING":"Abisua: ez dago Stremio gehigarririk aktibo mota honetarako. Gordetako elementuak erakutsiz, hemen ez da ezer eguneratuko.","DISCOVER_LOAD_ERR":"Edukia ez da kargatu, errorea gertatu da.","DISCOVER_ADDON_UNINSTALLED":"Eduki hau jada ez dago erabilgarri, baliteke gehigarria instalatuta ez izatea.","UNINSTALL_THIS_ADDON":"Desinstalatu gehigarri hau","ERR_ADDON_NOT_INSTALLED":"Gehigarri hau ez dago instalatuta. Orain instalatu nahi duzu?","DETAIL_RECEIVE_NOTIF_SERIES":"Jaso atal berrien jakinarazpenak","DETAIL_RECEIVE_NOTIF_VIDEOS":"Jaso bideo berrien jakinarazpenak","SIDEBAR_SHOW_STREAMS":"Erakutsi stream-ak","RELAUNCH":"Berrabiarazi orain!","UPGRADE":"Bertsio berria eskuragarri dago! Bertsio berritu Stremio azken bertsiora","RELOAD_UI":"Erabiltzailearen interfazea berriro kargatu","MANUAL_UPDATE_TITLE":"Eguneratu Stremio bertsioa","MANUAL_UPDATE_LINE1":"Oso gomendagarria ez den Stremioren bertsio zaharkitu bat erabiltzen ari zara.","MANUAL_UPDATE_LINE2":"Mesedez, eguneratu lehenbailehen.","BUTTON_UPDATE_LATTER":"Orain ez","BUTTON_UPDATE_NOW":"Eguneratu","ANONYMOUS_USER":"Erabiltzaile anonimoa","DONT_HAVE_ACC":"Ez duzu konturik?","HAVE_ACC":"Baduzu kontua?","PASSWORD":"Pasahitza","PASSWORD_CONFIRM":"Pasahitza baieztatu","EMAIL":"Posta elektronikoa","FB_LOGIN":"Jarraitu Facebook-ekin","FB_NOTHINGSHARED":"Ez da ezer partekatzen zure baimenik gabe","FB_NOPOST":"Ez dugu ezer argitaratuko zure izenean","OR":"edo","I_ACCEPT":"Onartzen dut","I_ACCEPT_BY_CLICKING":"Goiko botoian klik eginda onartzen dudala deklaratzen dut","TOS":"Terminoak eta baldintzak","MUST_ACCEPT_TERMS":"Baldintzak onartu behar dituzu","PASSWORDS_NOMATCH":"Pasahitzak ez datoz bat","SIGN_UP":"Izena eman","SIGN_UP_EMAIL":"Eman izena posta elektronikoz","CLICK_TO_SIGN_UP":"Izena emateko egin klik hemen.","LOG_IN":"Saioa hasi","LOG_OUT":"Saioa amaitu","EXIT_FULLSCREEN":"Irten pantaila osoko modutik","ENTER_FULLSCREEN":"Sartu pantaila osoko moduan","PLAY_URL_MAGNET_LINK":"Erreproduzitu URL/Magnet esteka","HELP_FEEDBACK":"Laguntza eta oharrak","TERMS_OF_SERVICE":"Zerbitzu-baldintzak","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"Stremiori buruz","USER_PANEL":"Erabiltzaile panela","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gonbidatuaren saioa hasi","GUEST_LOGIN_NOTICE":"Gonbidatuen saioa hastea ez da gomendagarria. Ohiko saio-hasiera erabiliz Stremio-k zure Liburutegia sinkronizatzeko eta telesail/kanal gogokoen jakinarazpenak jasotzeko aukera ematen du. Ziur zaude jarraitu nahi duzula?","GUEST_LOGIN_NOTICE_2":"Gonbidatuen saioa hastea ez da gomendagarria; ez dituzu Liburutegi eta Taularen jakinarazpenak sinkronizatuko eta ezinbesteko Stremio funtzioak dira. Ziur zaude jarraitu nahi duzula?","CLICK_HERE":"klikatu hemen","WRONG_PASSWORD":"Posta elektroniko edo pasahitz okerra. Pasahitza ahaztu baduzu,","SET_A_PASS":"ezarri pasahitza","RESET_PASSWORD":"Pasahitza berrezarri","FORGOT_PASSWORD":"Pasahitza ahaztu duzu?","EMAIL_USED_WITH_FB":"Mezu elektronikoa Facebookeko saio hasierarekin erabili da.","INVALID_EMAIL":"Mesedez, sar ezazu helbide elektroniko egokia","INVALID_PASSWORD":"Mesedez, sartu baliozko pasahitza","CONN_ERR":"Konexioaren errorea. Saiatu berriro geroago.\\n\\nHonek jarraitzen badu, desgaitu firewall/antibirusa (batez ere Bitdefender).","IMPORT_FROM_GUEST":"Inportatu liburutegia zure gonbidatu kontutik","RECEIVE_UPDATES_EMAIL":"Jaso zure posta elektronikoaren eguneratzeak Stremioren eskutik","LOGIN_FAILED":"Errorea saioa hastean.","SIGNUP_FAILED":"Ezin izan da erregistratu.","SEARCH_FAILED":"Bilaketak huts egin du","EMAIL_USED":"Mezu elektronikoa dagoeneko erabiltzen ari da.","WAITING_FB_LOGIN":"Facebook-ekin saioa hasten...","EXTERNAL_PLAYER_TITLE":"Erreproduzitu kanpoko erreproduzitzailean","EXTERNAL_REMEMBER_PLAYER":"Zure aukera gogoratu nahi al duzu?","EXTERNAL_ALWAYS_PLAY":"Bai","EXTERNAL_ONLY_ONCE":"Ez","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Konta iezaguzu zer gustatzen zaizun","INTRO_TASTE_LONG":"Kontatu zer ikusi nahiko zenukeen","INTRO_TASTE_PICK":"Aukeratu {{interestRemaining}} interesak","INTRO_TASTE_PICK_MORE":"Aukeratu {{interestRemaining}} interes gehiago","INTRO_TASTE_HELP_US":"Lagundu iezaguzu zure inguruan gehiago jakiten.","INTRO_TASTE_CHOOSE_THESE":"Aukeratu hauetako batzuk:","INTRO_TASTE_CHOOSE_MIN":"Aukeratu gutxienez 3 kategoria","INTRO_TASTE_CHOOSE_MIN_ERR":"Gutxienez 3 kategoria aukeratu behar dituzu!","INTRO_TASTE_LIFESTYLE":"Bizimodua","INTRO_TASTE_SPORTS":"Kirolak","INTRO_TASTE_FOOD_HEALTH":"Elikadura eta Osasuna","INTRO_TASTE_BEAUTY_FASHION":"Edertasuna eta Moda","INTRO_TASTE_NEWS":"Albisteak","INTRO_TASTE_GAMING":"Jokoa","INTRO_TASTE_SCIENCE_EDU":"Zientzia eta Hezkuntza","INTRO_TASTE_MUSIC":"Musika","INTRO_TASTE_TRAVEL":"Bidaia","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Errealitatea","INTRO_TASTE_COMEDY":"Komedia","INTRO_TASTE_DIY":"Nola egin zerorrek","INTRO_TASTE_TECH":"Teknologia","INTRO_TASTE_CINEMA":"Zinema","ADDON_NOT_SUPPORTED":"Aukeratutako gehigarria ez da plataforma honetan onartzen.","ADDON_DISCLAIMER":"Hirugarrenen gehigarriak erabiltzea beti egongo da zure erantzukizunaren eta kokatzen zaren jurisdikzioaren lege arauaren menpe.","ADDON_ACTIVATE":"Gehigarri hau aktibatu nahi duzu?","ADDON_REPO_ADD":"Gehigarrien bildumaren URLa","ADDON_ADD":"Gehitu","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Berriak","BUTTON_CONTINUE":"Jarraitu","BUTTON_ACTIVATE":"Aktibatu","BUTTON_ACTIVATED":"Aktibatuta","BUTTON_CANCEL":"Utzi","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Baztertu guztiak","BUTTON_VIEW_ALL":"ikusi guztiak","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Liburutegia hutsik dago. Deskubritu zeinen erabilgarria den :)","HOW_START":"Hona hemen nola hasi:","LIB_EMPTY_CAL":"Zure Egutegian liburutegiko telesailak agertzen dira.","HOW_START_CAL":"Hemen duzu telesailak nola gehitu:","LIB_EMPTY_BOARD":"Taulan jakinarazpenak agertzen dira & zure Liburutegiari lotutako gomendioak.","HOW_START_BOARD_WAIT":"Mesedez, gehitu telesail edo kanal batzuk zure liburutegian, eman iezaguzu minutu batzuk prozesatzeko :)","HOW_START_BOARD":"Hona hemen nola gehi ditzakezu telesailak & filmak:","IMPORT_FB":"Inportatu gustuko dituzun gauzak Facebooketik","IMPORT_TRAKT":"Inportatu mediateka Traktetik","IMPORT_DISCOVER":"Bilatu Ezagutu-ko gauza interesgarriak","IMPORT_DISK":"Inportatu zure disko lokalean dituzun filmak edo saioak","PLEASE_CREATE_ACC":"Mesedez, sortu kontua Liburutegiaren sinkronizazioa eta & Taula aktibatzeko.","IMPORT_DISCOVER_SIGNUP":"Erregistratu eta aurkitu gauza interesgarriak Ezagutu atalean","IMPORT_DISK_SIGNUP":"Erregistratu eta inportatu zure disko lokalean dituzun filmak edo saioak","LIB_EMPTY_CLOUD":"Hodei liburutegia","LIB_EMPTY_CLOUD_DESC":"Hodei liburutegi pertsonala gailu guztietan sinkronizatuta","LIB_EMPTY_EARLY":"Txori goiztiarra","LIB_EMPTY_EARLY_DESC":"Jaso atal berrien jakinarazpenak","LIB_EMPTY_PERSONAL":"Pertsonala","LIB_EMPTY_PERSONAL_DESC":"Jaso gomendio pertsonalak","LIB_EMPTY_CALENDAR_DESC":"Antolatu zure behaketa egutegi pertsonala","LIB_EMPTY_ALL":"Izena eman hauek guztiak lortzeko:","LIB_EMPTY_BEST":"Eman izena Stremioren onena lortzeko","LIB_EMPTY_OTHER":"Eman izena Egutegia eta beste funtzio interesgarri batzuk gaitzeko","CALENDAR_ADDED":"Stremio egutegia zure mahaigaineko egutegi lehenetsian gehitu da.","CALENDAR_ADDED_MSG":"Honek funtzionatzen ez badu, gehitu URL hau zure egutegiko aplikazioan eskuz","TRAKT_EXPIRED":"Trakt autentifikazioa iraungita dago, joan Ezarpenak atalera eta berriro autentifikatu","TRAKT_REQUIRES_LOGIN":"Trakt errorea","TRAKT_REQUIRES_LOGIN_MSG":"Saioa hasi behar duzu","SETTINGS_LABEL":"Ezarpenak","SETTINGS_NAV_GENERAL":"Orokorra","SETTINGS_NAV_PLAYER":"Erreproduktorea","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Freskatu app-a","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Irten / Atzera joan","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Igo bolumena","SETTINGS_SHORTCUT_VOLUME_DOWN":"Jaitsi bolumena","SETTINGS_SHORTCUT_SEEK_NEXT":"Eskatu hurrengoa","SETTINGS_SHORTCUT_SEEK_PREV":"Eskatu aurrekoa","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Erreproduzitu hurrengoa","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Handitu azpitituluen tamaina","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Txikitu azpitituluen tamaina","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Handitu azpitituluen atzerapena","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Txikitu azpitituluen atzerapena","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Ireki/Itxi alboko barra","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Abiarazi piztean","SETTINGS_VLC_DEFAULT":"Erreproduzitu VLC-rekin","SETTINGS_UI_LANGUAGE":"UI hizkuntza","SETTINGS_FULLSCREEN_EXIT":"Esc teklarekin irten pantaila osotik","SETTINGS_GAMEPAD":"Gaitu gamepad laguntza","SETTINGS_CLOSE_WINDOW":"Itxi aplikazioa leihoa itxita dagoenean","SETTINGS_SUBTITLES_LANGUAGE":"Azpitituluen hizkuntza lehenetsia","SETTINGS_SUBTITLES_SIZE":"Azpitituluen tamaina lehenetsia","SETTINGS_SUBTITLES_BACKGROUND":"Azpitituluen atzeko planoa","SETTINGS_SUBTITLES_COLOR":"Azpitituluen kolorea","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Azpitituluen eskema kolorea","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Azpitituluen atzeko kolorea","SETTINGS_SEEK_KEY":"Geziek denbora bilatzen dute","SETTINGS_SEEK_KEY_SHIFT":"Gezien teklek Shift tekla sakatuta dagoenean denbora bilatzen dute","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Erreproduzitu automatikoki hurrengo atala","SETTINGS_NEXT_VIDEO":"Erakutsi jakinarazpena hurrengo atala hasteko","SETTINGS_NEXT_VIDEO_TRIGGER":"Erakutsi hurrengo atalaren jakinarazpena:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Aldatu automatikoki leihoa erreproduzitu aurretik","SETTINGS_OVERRIDE_SERVER":"Gainidatzi streaming zerbitzariaren URLa (aurreratua)","SETTINGS_SERVER_URL":"Streaming zerbitzariaren URLa:","SETTINGS_SERVER_AVAILABLE":"Streaming zerbitzaria eskuragarri dago.","SETTINGS_SERVER_UNAVAILABLE":"Streaming zerbitzaria ez dago erabilgarri.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS amaiera:","SETTINGS_USE_BETA":"Erabili beti azken bertsioa","SETTINGS_IMPORT_FB":"Inportatu Facebooketik","SETTINGS_IMPORT_DISK":"Inportatu disko lokaletik","SETTINGS_IMPORT_TRAKT":"Inportatu Trakt-etik","SETTINGS_PAUSE_MINIMIZED":"Pausatu erreprodukzioa minimizatutakoan","SETTINGS_HWDEC":"Hardwarea azeleratutako deskodetzea","SETTINGS_BACKGROUND":"Atzeko planoaren erreprodukzioa","SETTINGS_SUBSCRIBE_CALENDAR":"Harpidetu egutegira","SETTINGS_REQ_EXPORT":"Eskatu datuak esportatzeko","SETTINGS_ACC_DELETE":"Eskatu kontua ezabatzeko","SETTINGS_CHANGE_PASSWORD":"Aldatu pasahitza","SETTINGS_TOS":"Zerbitzu-baldintzak","SETTINGS_SUPPORT":"Jarri harremanetan laguntza zerbitzuarekin","SETTING_LANGUAGE":"Hizkuntza","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Amaitu saioa Trakt.tv-tik","SETTINGS_SCAN_FOR_REMOTE":"Eskaneatu QR kodea urrunekoa irekitzeko","SETTINGS_DESKTOP_NOTIFICATIONS":"Mahaigaineko jakinarazpenak","SETTINGS_DATA_SAVER":"Datu aurrezlea","SETTINGS_LANGUAGE_INTERFACE":"interfazea","SETTINGS_LANGUAGE_SUBS":"azpititulu lehenetsiak","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Aukeratu automatikoki Audio pista","SETTINGS_DEFAULT_AUDIO_TRACK":"Audio pista lehenetsia","SETTINGS_ACCOUNT":"kontua","SETTINGS_VERSION":"bertsioa","SETTINGS_MPV_WINDOW":"Abiarazi erreproduzitzailea beste leiho batean (aurreratua)","SETTINGS_PLAY_IN_EXTERNAL":"Hasi beti bideoa kanpoko erreproduzitzailean","SETTINGS_STORAGE_BUTTON":"Garbitu tokiko biltegiratzea","SETTINGS_STORAGE_MODAL_TITLE":"Ziur zaude ?","SETTINGS_STORAGE_MODAL_MESSAGE":"Honek tokiko biltegia garbitu eta saioa amaituko du.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Irten","CONNECTED":"Konektatuta","AUTHENTICATE":"Autentifikatu","CACHING":"Cachea","SETTINGS_CACHING_DRIVE":"Caching unitatea","ENABLE_LOCAL_FILES_ADDON":"Gaitu fitxategi lokalen gehigarria (berrabiarazi behar da)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Gaitu urruneko HTTPS konexioak","TORRENT_PROFILE":"Torrent profila","DATA_CACHING":"Datuen cache-a","MAGNET_PARSING":"Magnet parseoa","January":"Urtarrila","February":"Otsaila","March":"Martxoa","April":"Apirila","May":"Maiatza","June":"Ekaina","July":"Uztaila","August":"Abuztua","September":"Iraila","October":"Urria","November":"Azaroa","December":"Abendua","Monday":"Astelehena","Tuesday":"Asteartea","Wednesday":"Asteazkena","Thursday":"Osteguna","Friday":"Ostirala","Saturday":"Larunbata","Sunday":"Igandea","Action":"Akzioa","Comedy":"Komedia","War":"Gerra","Family":"Familia","Animation":"Animazioa","Adventure":"Abentura","Fantasy":"Fantasia","Crime":"Delitua","Mystery":"Misterioa","Romance":"Erromantikoa","Drama":"Drama","Horror":"Beldurra","Thriller":"Thrillerra","Sci-Fi":"Zientzia-fikzioa","Music":"Musika","Biography":"Biografia","Documentary":"Dokumentala","Sport":"Kirola","Musical":"Musikala","Western":"Westerna","Film-Noir":"Film-Noir","News":"Albisteak","History":"Historia","Game-Show":"Joko-Ikuskizuna","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Zinema eta aisialdia","Gaming":"Gaming","From TV":"Telebistatik","Lifestyle":"Bizimodua","Science & Education":"Zientzia eta Hezkuntza","Cooking & Health":"Sukaldaritza eta Osasuna","Beauty & Fashion":"Edertasuna eta Moda","Sports":"Kirolak","News & Politics":"Albisteak eta politika","How-to & DIY":"Nola egin eta DIY","Tech":"Teknologia","Automotive":"Automobilgintza","Causes & Non-Profits":"Kausak eta irabazi asmorik gabekoak","Movies":"Filmak","Uk Live Tv":"Uk Live Tv","Fashion":"Moda","Business News Radio":"Business News Radio","Business Tv":"Business Telebista","Cars & Auto":"Autoak","Comedy Radio":"Komedia Irratia","Lifestyle Radio":"Bizimodu Irratia","News Tv":"Albiste Telebista","Food And Wine":"Janaria eta ardoa","Latino Tv":"Latino Tv","Shopping Tv":"Erosketa Telebista","Religion":"Erlijioa","Kids":"Haurrak","Body & Soul":"Gorputza eta Arima","Education":"Hezkuntza","Indian Tv":"Indiako telebista","Extreme Sports":"Muturreko Kirolak","Middle Eastern Tv":"Ekialde Hurbileko Telebista","Celebrity Tv":"Celebrity telebista","Science Tv":"Zientzia telebista","Bikini babe":"Bikini babe","Outdoors":"Aire librean","German Tv":"Alemaniako telebista","French Tv":"Telebista frantsesa","Italian Tv":"Italiako telebista","Gamer Tv":"Gamer telebista","Travel":"Bidaia","Asian Tv":"Asiako telebista","Entertainment":"Aisialdia","News Radio":"Albiste Irratia","Music Radio":"Musika Irratia","Language Learning":"Hizkuntzen ikaskuntza","Science Radio":"Zientzia Irratia","Tech Radio":"Tech Radio","Science & Technology Vod":"Zientzia eta Teknologia Vod","new video":"bideo berria","new episode":"atal berria","new movie":"film berria","recommended":"gomendatua","we recommend":"gomendatzen dugu","offer of the day":"eguneko eskaintza","news":"berriak","music video":"bideoklipa","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Baztertu jakinarazpenak","CTX_DISMISS_ALL":"Baztertu guztiak","CTX_SHARE":"Partekatu","CTX_COPY_SHARE_LINK":"Kopiatu partekatzeko esteka","CTX_COPY_MAGNET_LINK":"Kopiatu magnet esteka","CTX_COPY_STREAM_LINK":"Kopiatu stream-aren esteka","CTX_DOWNLOAD_VIDEO":"Deskargatu bideo hau","CTX_DOWNLOAD_SUBS":"Deskargatu azpitituluak","CTX_VIEW_ON_YOUTUBE":"Ikusi Youtuben","CTX_SHOW":"Ikuskizuna","CTX_PLAY":"Erreproduzitu","CTX_PLAY_IN":"Erreproduzitu","CTX_PLAY_ON":"Erreproduzitu","CTX_WATCH_ON":"Ikusi","CTX_WATCH":"Ikusi","CTX_WATCHED":"Ikusita","CTX_WATCH_BEGINNING":"Ikusi hasieratik","CTX_WATCH_MOBILE":"Ikusi gailu mugikorrean","CTX_REWIND":"Atzera hasierara","CTX_MARK_WATCHED":"Markatu ikusitako moduan","CTX_MARK_NON_WATCHED":"Markatu ez ikusi gisa","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Markatu gainerakoa ikusi bezala","CTX_UNMARK_REST":"Markatu gainerakoak ez ikusi gisa","CTX_RECEIVE_NEW_NOTIF":"Jaso jakinarazpen berriak","CTX_REMOVE_CACHE":"Kendu cache-tik","CTX_REMOVE_CACHE_EP":"Kendu pasartea katxetik","CTX_OPEN_CONTAINING":"Ireki duen karpeta","CTX_REMOVE":"Kendu liburutegitik","CTX_AVAILABLE_OFFLINE":"Lineaz kanpo eskuragarri","CTX_PAUSED":"Pausatuta","CTX_ALWAYS_ON_TOP":"Beti gainean","CTX_FULLSCREEN":"Pantaila osoa","CTX_WRONG_SUBS":"Azpititulu okerrak?","CTX_REPORT_ISSUES":"Salatu alea","CTX_COPY":"Kopiatu","CTX_PASTE":"Itsatsi","CTX_CLEAR":"Garbi","CTX_CLEAR_RECENT_SEARCHES":"Garbitu azken bilaketak","HELLO_THERE":"Kaixo","HOPE_YOU_ENJOY":"Stremio gustatuko zaizula espero dugu eta laster zure aplikazio gogokoenetako bat izango da!","WHO_ARE_WE":"Nor gara gu? Atzean dagoen taldea gara. Azken 3 urteetan egunero gogor lan egiten duten bi mutil produktu hau gero eta hobea izan dadin.","SUPPORT_US":"Stremio erabiltzea gustatzen bazaizu, Stremio zuretzat baliotsua bada - zabaldu!","SPREAD_THE_WORD":"Partekatu orain zure lagunekin, zabaldu Stremioren berri","MORE_PEOPLE":"Zenbat eta jende gehiagok erabili Stremio, orduan eta hobeto lortuko du!","SEND_A_LINK":"Edo bidali esteka gure webgunera","TIP_LOCALFILES":"Aholkua: bideo fitxategi lokalak arrastatu eta askatu ditzakezu Stremiora","ADDON_MY":"Nire gehigarriak","ADDON_COMMUNITY":"Komunitateko gehigarriak","ADDON_OFFICIAL":"Addon ofizialak","ADDON_REPOS":"Gehigarrien bildumak","ADDON_SEARCH":"Bilatu gehigarriak","ADDON_INSTALL":"Instalatu","ADDON_CONFIGURE":"Konfiguratu","ADDON_UNINSTALL":"Desinstalatu","ADDON_UPGRADE":"Berritu","ADDON_INSTALLED":"Instalatuta","ADDON_INSTALLED_MSG":"Gehigarria instalatuta!","ADDON_UPGRADED_MSG":"Gehigarria bertsio-berritu da!","ADDON_UNKNOWN":"Ezezaguna","ADDON_ERR":"Gehigarri instalazio errorea!","ADDON_DISCONNECTED":"Deskonektatuta","ADDON_APP_MISSING":"iturri honen aplikazioa ez dago instalatuta. Orain instalatu nahi duzu?","ADDON_APP_INSTALL":"Instalatu orain","ADDON_PAGE":"Gehigarrien orria","ADDON_TOP_CONTENT":"Onena Addon honetatik","ADDON_PROVIDES":"Gehigarri honek emango dizu:","ADDON_WATCH":"Ikusi #{types} orain!","ADDON_WATCH_FREE":"Ikusi DOAKO #{types} orain!","ADDON_ADDON":"Gehitu","ADDON_SUPPORTED_TYPES":"Onartutako motak","ADDON_SUPPORTED_CATALOGS":"Onartutako katalogoak","ADDON_PROVIDES_DISCOVER":"#{types} gehiago Ezagutu-n","ADDON_PROVIDES_STREAMS":"Ikusi #{types}","ADDON_PROVIDES_STREAMS_FREE":"Ikusi DOAKO #{types}","ADDON_PROVIDES_SUBTITLES":"#{types}(r)en azpitituluak","ADDON_CANTDETECT":"Ezin izan dugu Stremio exekutatzen ari den detektatu, beraz, ezin dugu detektatu zer gehigarri instalatu dituzun.","ERR_NO_META":"Ez da honi buruzko informaziorik aurkitu","ERR_GETTING_META":"Errorea honi buruzko informazioa eskuratzean.","ERR_CANT_PARSE_MAGNET":"Ezin da magnet parseatu","ERR_NO_MAGNET_INFOHASH":"Ez da baliozko hash-a magnetentzat","ERR_NO_FILE_PATH":"Ezin da eskaera bidali artxiborako biderik gabe","ERR_NO_TORRENT":"Ez da torrentik itzuli","ERR_NO_SUPPORTERD_FILES":"Ez da onartutako fitxategirik aurkitu","ERR_OPENING_FILES":"Ezin izan dira kanpoko fitxategiak ireki","ERR_INVALID_LINK":"Esteka baliogabea","ERR_REGISTERED_ONLY":"Aukera hau erregistratutako erabiltzaileentzat bakarrik dago erabilgarri.","ERR_CLIPBOARD":"Ezin da arbeletik erreproduzitu","ERR_CLIPBOARD_READ":"Ezin da plataforma honetako arbela irakurri","ERR_CLIPBOARD_GENERIC":"Ez da arbelean erreproduzitzeko URLrik aurkitu. Kopiatu URL bat (adibidez, magnet esteka) bideo batera.","BOARD_CONTINUE_WATCHING":"Jarraitu ikusten","BOARD_EXPLANATION_RECOMMENDATIONS":"Zuretzat bereziki aukeratutako filmak.
Film hau gomendio lagin bat da.","BOARD_EXPLANATION_EPISODES":"Zure telesail gogokoen atal berriak datoz hona.
Gehitu jarraitzen dituzun serieak liburutegian.","BOARD_EXPLANATION_VIDEOS":"Zure kanal gogokoen atal berriak etorriko dira.
Gehitu jarraitzen dituzun YouTube kanalak Liburutegian.","WEBSITE_SLOGAN_WATCH":"Ikusi berehala","WEBSITE_SLOGAN_ALL":"Leku bakarrean gozatzen duzun bideo eduki guztia","WEBSITE_SLOGAN_NEW":"Ikus dezakezun guztia","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Ikusi hemendik","WEBSITE_DOWNLOAD":"Deskargatu orain","WEBSITE_DOWNLOAD_FOR":"Deskargatu orain","WEBSITE_IS_DESKTOP":"Stremio mahaigaineko aplikazioa da, ireki orri hau zure ordenagailuan eta deskargatu","WEBSITE_DESKTOP_DEMO_VID":"Mahaigaineko demoa","WEBSITE_PAGE_HOME":"Hasiera","WEBSITE_PAGE_FEATURES":"Ezaugarriak","WEBSITE_PAGE_ADDONS":"Gehigarriak","WEBSITE_PAGE_TECH":"Teknologia","WEBSITE_PAGE_CREATE_ADDON":"Sortu gehigarria","WEBSITE_PAGE_CONTACTS":"Kontaktuak","WEBSITE_PAGE_BLOG":"Bloga","WEBSITE_TYPE_movie":"Filmak","WEBSITE_TYPE_series_PL":"Telesaila","WEBSITE_TYPE_tv":"Zuzeneko telebista","WEBSITE_TYPE_channel":"Kanalak","WEBSITE_STREMIO_WHAT_IS":"Stremio zure gogoko bideoak, filmak, telesailak eta telebista kateak antolatzen eta berehala ikusten laguntzen duen aplikazioa da.","WEBSITE_FEATURES_WATCH":"Ikusi berehala HD formatuan","WEBSITE_FEATURES_WATCH_DETAIL":"Egin klik eta erreproduzitu gogoko dituzun filmak, telesailak, bideoak eta telebista kateak.","WEBSITE_FEATURES_SUBS":"Azpititulu automatikoak","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio-k zure hizkuntzarako azpitituluak automatikoki hautatzen ditu.","WEBSITE_FEATURES_SUBS_LABEL":"Zure mugimendua, buruzagi.","WEBSITE_FEATURES_CAST":"Erreproduzitu telebistan eta gailu mugikorretan","WEBSITE_FEATURES_CAST_DETAIL":"Igorri AppleTV, Chromecast, Smart TV (DLNA/UPnP) eta gailu mugikorretara.","WEBSITE_LIB":"Gozatu zure gailu guztietan sinkronizatutako liburutegi pertsonalarekin","WEBSITE_LIB_COLLECT":"Bildu Stremiotik","WEBSITE_LIB_IMPORT":"Inportatu Facebooketik","WEBSITE_LIB_LOCAL":"Gehitu zure disko lokaletik","WEBSITE_BOARD":"Taula - Jakinarazpen eta gomendioetarako lekua","WEBSITE_BOARD_RECOMMEND":"Gomendatutako telesaila","WEBSITE_BOARD_TRENDING":"Modako filma","WEBSITE_BOARD_NEW":"Bideo berria","WEBSITE_BOARD_EPISODE":"Atal berria","WEBSITE_BOARD_1":"Ikusteko zerbait interesgarria bilatzen al duzu? Jaso gomendioak zure gustuaren arabera!","WEBSITE_BOARD_2":"Jaso jakinarazpen zure gogoko telesaio edo YouTube kanaleko atal berri bat ateratzen denean!","WEBSITE_BOARD_YOUTUBE":"YouTube kanalen bideo berriak","WEBSITE_BOARD_EPISODES":"Jarraitzen dituzun telesailen atal berriak","WEBSITE_ADDONS":"Edukien gehigarriak","WEBSITE_TECH_DETAIL":"Teknologia maite dugu, zientzia eroa maite dugu!\\nStremio kode irekiko teknologia hauek erabiltzen ari da:","WEBSITE_TECH_WCJS":"WebChimera.js-k Stremio-k edozein bideo formatu erreproduzitzeko aukera ematen du errendimendu onarekin.","WEBSITE_TECH_WCJS_EXTRA":"Proiektuaren laguntzaileak gara","WEBSITE_TECH_ELECTRON":"Electronek Stremio eraikitzeko plataforma berritzailea eskaintzen du.","WEBSITE_TECH_ELECTRON_EXTRA":"Proiektuaren laguntzaileak gara","WEBSITE_TECH_LINVODB":"Zure datuak saioa hasten zaren edozein lekutan antolatuta eta eskuragarri daudela bermatzen duen datu basearen teknologia.","WEBSITE_TECH_LINVODB_EXTRA":"Barne teknologia","WEBSITE_CREATE_ADDON":"Sortu zure gehigarria","WEBSITE_CREATE_ADDON_DETAIL":"Ba al duzu bideo edukia eskaintzen duen zerbitzurik? Stremioren ezaugarriez baliatzen lagunduko dizugu zure gehigarria sortuz.","WEBSITE_CREATE_ADDON_BENEFITS":"Stremiorako gehigarria sortzearen abantailak","WEBSITE_P2P_BEAUTY":"Peer-to-Peer Streaming-en edertasuna","WEBSITE_P2P_1":"HD/4K bideo fidagarria eta merkea, eskariaren arabera edo zuzeneko erreprodukzioarekin","WEBSITE_P2P_2":"Erabiltzaileen esperientzia bikaina eskaintzen duen banaketa plataforma","WEBSITE_P2P_3":"Zure beharretara egokitzen den gehigarri bat sortuko dugu","WEBSITE_P2P_CONTACT":"Interesatuta? Jarri gurekin harremanetan.","WEBSITE_P2P_CONTACT_EXTRA":"Pozik lagunduko dizugu zure edukia Stremio-rekin integratzen!","WEBSITE_P2P":"Noizean behin, jokoaren izena aldatzen duen teknologia bat dator. Denbora eta ahalegin ugari inbertitu dugu Peer-to-Peer (P2P) bideo bidezko erreprodukzio motorra eraikitzen, edozein erabilera kasutan egokitzeko errendimendu eta aldakortasun bikaina eskaintzen duena.\\nJarri gurekin harremanetan DRM gaitutako P2P bideoa eskatuta edo zuzenean igortzeko.","WEBSITE_THOUGHTS":"Partekatzen ditugun pentsamenduak:","WEBSITE_SPREAD":"Zabaldu Stremiori buruz:","WEBSITE_CONTACT":"Jar zaitez gurekin harremanetan, pozik jasoko dugu zure berri!","WEBSITE_OPENSOURCE":"Gure kode irekiko proiektuak ikusteko, joan gure webgunera","WEBSITE_BITCOIN":"Eman bitcoinak:","WEBSITE_FAQ":"Ohiko galderak","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Galderak","WEBSITE_TOS":"Erabilera baldintzak","WEBSITE_LEGAL":"Legezkoa","WEBSITE_PAGE_ABOUT":"Buruz","WEBSITE_PAGE_BECOME_PARTNER":"Egin bazkide","WEBSITE_ALL_YOU_CAN_WATCH":"Zuk nahi duzuna\\nIkusteko askatasuna.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Zer da stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio bideoaren edukiak batzeko gune bakarra da. Ezagutu, antolatu eta ikusi bideoa zure iturri mota guztietako zure gailu guztietan.","WEBSITE_WHAT_IS_STREMIO_P2":"Filmak, telebista saioak, telesailak, zuzeneko telebistak edo YouTube eta Twitch.tv bezalako web kateak - hori guztia Stremion aurkituko duzu.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio multimedia zentro modernoa da, bideo entretenimendurako irtenbide bakarra eskaintzen duena. Bideo edukia instalatzeko erraza den gehigarrietatik deskubritu, ikusi eta antolatzen duzu.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmak, telesailak, zuzeneko telebista edo web kateak. Aurkitu hau guztia Stremion.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Gozatu zure multimedia gailu guztietan","WEBSITE_DEVICES_COLLECT":"Bildu Stremiotik","WEBSITE_DEVICES_IMPORT_FB":"Inportatu facebooketik","WEBSITE_DEVICES_LOCAL":"Gehitu tokiko unitatetik","WEBSITE_JOIN_THE_PARTY_NOW":"Sartu orain festara","WEBSITE_DEVICES_ALL":"Erraza zure gailu guztietan erabiltzeko;","WEBSITE_EXTENDABLE_CATALOG":"Bideo katalogo luzagarria infinituki;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Ezaugarri bikainak zure komunikabideak antolatzeko;","WEBSITE_AS_SEEN_ON":"Ikusitakoan","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Guri buruz","WEBSITE_LINK_TECHNOLOGY":"Teknologia","WEBSITE_LINK_APPS":"Aplikazioak","WEBSITE_LINK_DOWNLOADS":"Deskargak","WEBSITE_MORE":"Gehiago","WEBSITE_LINK_ADDONS":"Gehigarriak","WEBSITE_LINK_ADDON_SDK":"Gehigarriaren SDK","WEBSITE_LINK_CONTRIBUTE":"Lagundu","WEBSITE_LINK_COMMUNITY":"Komunitatea","WEBSITE_LINK_BLOG":"Bloga","WEBSITE_MORE_MORE":"... eta gehiago","WEBSITE_LINK_HELP":"Laguntza zentroa","WEBSITE_LINK_CONTACTS":"Enpresa kontsultak","WEBSITE_LINK_TOS":"Baldintzak","WEBSITE_LINK_PRAVACY":"Pribatutasun politika","WEBSITE_SUBSCRIBE":"Harpidetu","WEBSITE_NEWSLETTER":"Sartu gure buletinera gauza harrigarrietarako","WEBSITE_PLACEHOLDER_EMAIL":"Zure emaila","WEBSITE_COMMUNITY":"Komunitatea","WEBSITE_LINK_PRAVACY_LEGAL":"Pribatutasuna eta legea","WEBSITE_WHY":"Zergatik egiten dugun","WEBSITE_WHY_P1":"Stremion, egunero lan egitera gatoz, bideo-eskaeraren industriaren arazo garrantzitsu bat konpondu nahi dugulako. Hainbeste eduki berri argitaratzen dira minuturo, ia ezinezkoa baita zure bidea aurkitzea.","WEBSITE_WHY_P2":"Jendeari bideo entretenimendu mundu erraldoi horretan nabigatzen eta gozatzeko eduki berriak aurkitzen laguntzen diogu. Gure aplikazioek filmak, serieak, zuzeneko telebista, web kateak eta beste biltzen dituzte. Erabiltzaileek gustuko dituzten izenburuak eta emisorak aurkitzea oso erraz bihurtzeaz arduratzen gara.","WEBSITE_WHY_P3":"Gure zerbitzua edozein gailutan eta noiznahi erabil dezakezu, Stremio inoiz beharko duzun bideo entretenimendu zentro bakarra bihurtuz.","WEBSITE_TEAM":"TALDEA","WEBSITE_TEAM_P":"Stremio taldea txikia baina indartsua da: gutako hamar artean X hizkuntzatan kodetzen dugu eta softwarearen garapenean, UI eta UX diseinuan, marketinean eta publizitatean eta negozioetan eta startupetan espezializazioa partekatzen dugu.","WEBSITE_FEATURES":"Ezaugarriak","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Ezagutu eduki berriak erraz","WEBSITE_FEATURES_DISCOVER_P":"Ikusi erraz ikusteko film, telesail, serie eta kanal berriak. Arakatu kategoriaren, generoaren, balorazioaren, berritasunen eta abarren arabera edo idatzi izen bat aurkitzeko. Stremio-k bideo-eduki berriak aurkitzea tarta bihurtzen du.","WEBSITE_FEATURES_ALL_CONTENT":"Zure bideoaren eduki guztia pantaila batean","WEBSITE_FEATURES_ALL_CONTENT_P1":"Ikusi zer film, serie edo bideo amaitu ez zenituen eta jarraitu ikusten; atal berri eta estreinaldien berri jaso; eta arakatu ikusmen ohituretan oinarrituta jasoko dituzun gomendioak.","WEBSITE_FEATURES_LIBRARY":"Antolatu zure bideoteka","WEBSITE_FEATURES_LIBRARY_P1":"Gehitu edozein titulu zure Stremio liburutegian klik bakarrarekin eta bilatu zure edukia, motaren, berritasunaren edo alfabetoaren arabera ordenatuta.","WEBSITE_FEATURES_CALENDAR":"Jarrai ezazu ikusten duzun guztiaren jarraipena","WEBSITE_FEATURES_CALENDAR_P1":"Lortu liburutegian gehitzen dituzun film eta serie guztien egutegia bistaratzea. Esportatu Stremio egutegia eta sinkronizatu, atal berri bat edo estreinaldi bat noiz iritsi behar den jakiteko.","WEBSITE_FEATURES_BIG_SCREEN":"Gozatu zure bideo edukia pantaila handiago batean","WEBSITE_FEATURES_BIG_SCREEN_P1":"Igorri ikusten ari zena beste gailu batera, izan telefono, tableta edo telebista klik bakarrarekin.","WEBSITE_FEATURES_SOURCES":"Ikusi bideoa iturri askotatik","WEBSITE_FEATURES_SOURCES_P":"Instalatu gehigarri ofizialak eta komunitarioak hornitzaile desberdinetatik ateratako bideoaz gozatzeko - aplikazio dotore eta erraz batean.","WEBSITE_CREATE_AN_ADDON":"Sortu gehigarri bat","WEBSITE_FEATURES_SYNC":"Sinkronizatu liburutegia gailu desberdinetan eta hasi berriro erreprodukzioa","WEBSITE_FEATURES_SYNC_P1":"Hasi saioa zure kontuarekin gailu guztietan eta gozatu liburutegia, gehigarriak, erreprodukzioa eta egutegia sinkronizatuta.","WEBSITE_FEATURES_EXTENDABLE":"Gehigarrien bideo katalogo luzagarria","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio gehigarrien katalogoak hainbat gehigarri eskaintzen ditu hainbat bideo eduki instalatu eta ikusteko. Filmak, saioak, zuzeneko telebista, kirola, albisteak, podcastak, web kateak, bideojokoak eta beste biltzen ditu.","WEBSITE_FEATURES_AUTO_SUBS":"Azpititulu automatikoak","WEBSITE_FEATURES_AUTO_SUBS_P1":"Gure azpitituluen gehigarriekin automatikoki hautatutako aukerak lortuko dituzu zure gustuko hizkuntzarako.","WEBSITE_FEATURES_CHROMECAST":"Chromecast-era igortzen","WEBSITE_FEATURES_CHROMECAST_P1":"Gozatu zure bideoaren edukia pantaila handiago batean edo ikusi zer ikusten ari zaren beste gailu batera.","WEBSITE_FEATURES_KEEP_TRACK":"Jarrai itzazu zure gogoko telebista saioak eta web kateak","WEBSITE_FEATURES_KEEP_TRACK_P1":"Lortu egutegia bistaratzea eta zure serie eta kanal gogokoen atal berrien jakinarazpenak.","WEBSITE_FEATURES_POWER_USER":"Erabiltzaile indartsuen ezaugarriak","WEBSITE_FEATURES_POWER_USER_P1":"Erreproduzitu kanpoko erreproduzitzailean","WEBSITE_FEATURES_POWER_USER_P2":"Erreproduzitu torrent fitxategi edo iman esteka batetik","WEBSITE_FEATURES_POWER_USER_P3":"Inportatu liburutegira Facebook atsegin dut edo disko lokaletik","WEBSITE_ADD_ONS":"Gehigarriak","WEBSITE_ADD_ONS_P1":"Stremio-k eskaintzen duen bideo guztia gehigarri sistema baten bidez lortzen da - aplikazioan ez da eduki edo eduki hornitzailerik sartu.","WEBSITE_ADD_ONS_P2":"Gehigarrien bi talde daude eskuragarri: gehigarri ofizialak eta komunitarioak.","WEBSITE_ADD_ONS_P3":"Ofizialak Stremio-k garatu eta ostatatzen ditu, eta komunitateko gehigarriak, aldiz, gure komunitateko kideek sortzen dituzte, hauek ere ostatatzen baitituzte.","WEBSITE_ADDONS_OFFICIAL":"Gehigarri ofizialak","WEBSITE_ADDONS_WATCHUB":"Erreproduzitu zure gogoko filmak, serieak eta ikuskizunak, hala nola iTunes, Hulu, Amazon eta Erresuma Batuko / AEBetako beste zerbitzu batzuen hornitzaileek.","WEBSITE_ADDONS_YOUTUBE":"Ikusi gogoko dituzun YouTube kanalak iragarkirik gabe eta jaso jarraitzen dituzun laguntzaileen kargatze berrien berri.","WEBSITE_ADDONS_FILMON":"Ikusi zuzenean telebista, filmak eta telebista sozialak doan. 600 telebista kate, doako 45.000 film, dokumental eta gehiago.","WEBSITE_ADDONS_OPENSUBTITLES":"Filma eta telebistako azpitituluak hizkuntza anitzetan, egunero kargatutako milaka azpitituluak.","WEBSITE_ADDONS_COMMUNITY":"Komunitateko gehigarriak","WEBSITE_ADDONS_FILMON_VOD":"Ikusi bideoa Filmon.tv-k eskatuta","WEBSITE_ADDONS_TWICH":"Ikusi zuzeneko erreprodukzioak Twitch.tv - kirol bideo elektronikoaren industriarako bideoa erreproduzitzeko plataforma.","WEBSITE_ADDONS_VODO":"Ikusi indie filmak guztiz doan.","WEBSITE_ADDONS_NETFLIX":"Ikusi Netflix filmak eta web serieak.","WEBSITE_ADDONS_CREATE":"Sortu gehigarri bat","WEBSITE_ADDONS_CREATE_P1":"Nahi izanez gero, zure gehigarria garatu dezakezu. Horrela, zure buruari eta gure komunitateari bideo eduki berrietarako sarbidea eman ahal izango diezu eta mundu osoko milioika erabiltzaileri zuzendutako ikusle berri batengana heldu.","WEBSITE_ADDONS_START_CREATE":"Hasteko, bisitatu Stremio Addon SDK orria:","WEBSITE_DOWNLOADS":"Deskargak","WEBSITE_DOWNLOADS_P1":"Errendimendu optimoa lortzeko, Stremio aplikazioen eskuragarri dagoen azken bertsioa erabiltzea gomendatzen dugu. Arrazoiren batengatik, ordea, bertsio zaharragoa erabili nahi baduzu, hemen deskarga dezakezu.","WEBSITE_DOWNLOADS_FOR_WIN":"Windows-erako Stremio","WEBSITE_DOWNLOADS_FOR_MAC":"MacOS-erako Stremio","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio Linuxerako","WEBSITE_DOWNLOADS_FOR_ANDROID":"Androiderako Stremio","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"IOS Stremio (bertsio mugatua)","WEBSITE_CONTRIBUTE":"Lagundu","WEBSITE_CONTRIBUTE_P1":"Stremio plataforma kode irekia da eta gaur egun iturri gabeko edukirako gehigarri bat sor dezakezu.","WEBSITE_CONTRIBUTE_WHY":"Zergatik sortu behar zenuke gehigarri bat?","WEBSITE_CONTRIBUTE_WHY_P1":"Iritsi ikusle berrietara zure bideoaren edukira","WEBSITE_CONTRIBUTE_WHY_P2":"Stremioren erabiltzaile-oinarria bizkor hazten ari da - merkaturatu zen lehen urtean, Stremiok milioi bat erabiltzaile irabazi zituen mundu osoan, eta plataformaren existentziaren bigarren urtean kopuru hori 2,5 milioi izatera iritsi zen.","WEBSITE_CONTRIBUTE_WHY_P3":"Zure gehigarriarekin, ikusle honetara erraz irits zaitezke eta zure bideo edukia haiei banatu.","WEBSITE_CONTRIBUTE_ALL":"Ikusi gogoko dituzun filmak, bideoak, serieak eta kanalak leku bakarrean.","WEBSITE_CONTRIBUTE_ALL_P1":"Oraindik Stremion erabilgarri ez dagoen eduki mota jakin baten zalea zara? Sortu gehigarri bat eta disfrutatu zure bideo gogokoenak merkatuan dauden entretenimendu zentro handienetako eta erabilerrazenetako batean ikustean.","WEBSITE_CONTRIBUTE_ALL_P2":"Horretaz gain, gogo bereko beste Stremio komunitateko kideen esker on amaigabea lortuko duzu.","WEBSITE_CONTRIBUTE_MONETIZE":"Dirua irabazi zure gehigarria eta irabazi dirua bere laguntzarekin","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Stremiorako gehigarri berri bat garatu ondoren, modu desberdinetan irabazteko aukera dezakezu. Hori aztertzen ari bazara, jar zaitez gurekin harremanetan harremanetan","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":"- Gehigarriak dirua irabazteko aukerei buruz kontsultatu eta aholkuak emango dizkizugu.","WEBSITE_CONTRIBUTE_TRANSLATE":"Egin itzultzaile boluntario","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Stremio aplikazioak hizkuntza desberdinetan gozatu nahi badituzu, itzultzaile boluntarioen komunitatean sar zaitezke. Stremioren bertsioak hizkuntza desberdinetan gehitzen laguntzen digute.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Hasteko gogoz zaude?","WEBSITE_TRANSALTE_STREMIO":"Itzuli Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Komunitate ofizialak","WEBSITE_COMMUNITY_OFFICIALS_P1":"Bihur zaitez hazten ari den Stremio komunitatearen parte. Jarrai iezaguzu sare sozialetan eta ez izan lotsarik agurtzeko: maite dugu gure zaleengandik entzutea!","WEBSITE_COMMUNITY_UNOFFICIALS":"Komunitate ez ofizialak","STREMIO_COMMUNITY_NL":"Stremio Herbehereak","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Alemania","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgika","STREMIO_COMMUNITY_FRANCE":"Stremio Frantzia","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italia","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio AEB","STREMIO_COMMUNITY_MEXICO":"Stremio Mexiko","STREMIO_COMMUNITY_ADDONS":"Stremio gehigarriak","STREMIO_COMMUNITY_AWESOME":"Stremio zoragarria","WEBSITE_COMMUNITY_PARTNERS":"Bazkideak eta laguntzaileak","WEBSITE_COMMUNITY_GOODIES":"Stremio opariak","WEBSITE_COMMUNITY_WALLPAPERS":"Atzeko irudiak","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Jarri gurekin harremanetan","WEBSITE_CONTACT_US_P1":"Galderarik, iruzkinik edo iradokizunik baduzu, jar zaitez gurekin harremanetan beheko harremanetarako formularioaren bidez.","WEBSITE_CONTACT_US_P2":"Gogoan izan Bulgarian gaudela, beraz, zure kontsultari erantzuteko denbora atzeratu daiteke ordu-zona desberdintasunengatik.","WEBSITE_CONTACT_US_SUCCESS":"Zure mezua bidali da. Guregana lehenbailehen itzuliko gara.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Mesedez, sartu baliozko mezu elektronikoa!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Zein da zure galdera lotuta?","WEBSITE_CONTACT_US_Q_OS":"Zein da zure Eragiketa Sistema?","WEBSITE_CONTACT_US_PH_EMAIL":"Zure emaila","WEBSITE_CONTACT_US_PH_MESSAGE":"Mezua","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"BIDALI","WEBSITE_CONTACT_US_Q_1":"Nola instalatu?","WEBSITE_CONTACT_US_Q_2":"Nola desinstalatu?","WEBSITE_CONTACT_US_Q_3":"(HTML) Nola egin lasagna?","WEBSITE_CONTACT_US_Q_4":"Gehigarriak","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Teknologia","WEBSITE_TECHNOLOGY_P1":"Teknologia eta zientzia eroa maite ditugu.
Hona hemen zerk bultzatzen duen Stremio (kode irekikoa da guztia).","WEBSITE_TECHNOLOGY_P_QT":"Plataforma anitzeko softwarearen garapena onenean.","WEBSITE_TECHNOLOGY_P_MPV":"Doako, kode irekiko eta plataforma anitzeko multimedia erreproduzitzailea.","WEBSITE_TECHNOLOGY_P_RN":"React Native-k aplikazio mugikorrak JavaScript soilik erabiliz eraikitzeko aukera ematen du.","WEBSITE_TECHNOLOGY_P_VLC":"Multimedia esparrua aplikazioan txertatuta multimedia lortzeko.","WEBSITE_TECHNOLOGY_P_REALM":"Realm plataforma mugikorra da eta SQLite & Core Data-ren ordezkoa da.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js iturburu irekiko, plataforma anitzeko JavaScript exekuzio ingurunea da.","WEBSITE_TECHNOLOGY_P_RUST":"Herdoila paradigma anitzeko sistemaren programazio lengoaia da, segurtasunera bideratua, batez ere aldi bereko segurura.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Lagundu proiektuan","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Bi modu daude Stremioren ekarpenak egiteko eta produktua hobetzen lagun gaitzazun.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Zure hizkuntza trebetasun baliotsuak eman ditzakezu plataforma itzulita ...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"edo","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... zure kodeketa gaitasunak erabil ditzakezu komunitatearen gehigarriak sortzeko.","WEBSITE_TRANSLATE_STREMIO":"Itzuli Stremio","WEBSITE_404_OH_NO":"Ui ui ui! Bilatzen ari zaren orria ez dago hemen ...","WEBSITE_GO_HOME":"Hasierara","WEBSITE_LINK_OTHER_DOWNLOADS":"Beste deskarga batzuk","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Laguntza","WEBSITE_DOWNLOAD_4_0_BETA":"Deskargatu Stremio 4 beta orain","WEBSITE_GET_FOR_DESKTOP":"Lortu mahaigainerako","WEBSITE_LINK_ADDON_COMPETITION":"Addon lehiaketa","WEBSITE_LINK_ART_CONTEST":"Arte lehiaketa","WEBSITE_MY_ACCOUNT":"Nire kontua","WEBSITE_MAINPAGE_FAQ_001_H1":"Zer da Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio nahi duzun guztia ikusteko askatasuna ematen duen media zentro modernoa da.","WEBSITE_MAINPAGE_FAQ_002_H1":"Nola dabil?","WEBSITE_MAINPAGE_FAQ_002_P1":"Stremio gailuan instalatu eta kontu bat sortu ondoren, egin behar duzun guztia gehigarrien katalogoa bisitatzea eta nahi duzun gehigarria instalatzea da, eta listo!","WEBSITE_MAINPAGE_FAQ_002_P2":"Horren ondoren, Ezagutu edo Taula ataletara joan zaitezke edukia aztertzen hasteko.","WEBSITE_MAINPAGE_FAQ_003_H1":"Zer ikusi dezaket hemen?","WEBSITE_MAINPAGE_FAQ_003_P1":"Asko: filmak, telebista saioak, web kateak, kirola, telebista kateak, podcastak eta beste. Gure gehigarri sistemari esker, hainbat eduki sar dezakezu.","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio kode irekia al da?","WEBSITE_MAINPAGE_FAQ_004_P1":"Bai, lotura hauek ikus ditzakezu: ${1}mahaigaineko aplikazioa${2} eta ${3}GitHub erakundea${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio segurua al da?","WEBSITE_MAINPAGE_FAQ_005_P1":"Bai: kode irekiko softwarea denez, kodea publikoki ikuskatzen da eta zuk zeuk berrikus dezakezu.","WEBSITE_MAINPAGE_FAQ_006_H1":"Zer moduz nire pribatutasuna?","WEBSITE_MAINPAGE_FAQ_006_P1":"Erabiltzaileen pribatutasuna errespetatzen dugu eta ez dugu zure kontua sortzeko eta sinkronizatzeko ezinbesteko gutxieneko datu pertsonalik biltzen.","WEBSITE_MAINPAGE_FAQ_006_P2":"Erregistratzerakoan ${1}Gonbidatu modua${2} ere badago, inolako daturik behar ez duena: modu honetan, ez da deirik egiten gure backendera. Hala ere, funtzio erabilgarrien kaltetan dator, hala nola liburutegia gailuetan sinkronizatu ahal izatea.","WEBSITE_MAINPAGE_FAQ_007_H1":"Telebistara bota al dezaket?","WEBSITE_MAINPAGE_FAQ_007_P1":"Bai, Chromecast-a onartzen dugu eta mahaigaineko zein mugikorreko aplikazioetatik (Android) bota ditzakezu.","WEBSITE_MAINPAGE_FAQ_008_H1":"Zenbat gehigarri ditu Stremiok?","WEBSITE_MAINPAGE_FAQ_008_P1":"2019 amaieran, 50 urte baino gehiago. Informazio gehiagorako, begiratu gure gehigarrien katalogoa.","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio gehigarrien katalogoan dagoenaz haratago al daiteke?","WEBSITE_MAINPAGE_FAQ_009_P1":"Bai, hauek egiaztatu beharko zenituzke: ${1}PimpMyStremio${2}, ${3}Reddit komunitateak${4}, ${5}Stremio Downloader${6}, etab.","WEBSITE_MAINPAGE_FAQ_010_H1":"Zer gailu onartzen ditu Stremiok?","WEBSITE_MAINPAGE_FAQ_010_P1":"Windows, Mac eta Linuxerako mahaigaineko aplikazioak ditugu. Mugikorretarako, Android eta iOS onartzen ditugu, baina kontuan izan iOS funtzionalitate mugatua duela (ez ditu gehigarri gehien onartzen).","WEBSITE_MAINPAGE_FAQ_010_P2":"Android-en oinarritutako gailu ugari daude Stremio exekutatu ahal izateko, adibidez NVIDIA Shield eta Amazon Fire Stick, baina ez ditugu ofizialki onartzen.","WEBSITE_MAINPAGE_FAQ_011_H1":"Stremioren zenbait eduki gehi al ditzakezu?","WEBSITE_MAINPAGE_FAQ_011_P1":"Barkatu, guk ez dugu edukirik eskaintzen, baina zenbat eta Stremio gehigarri gehiago instalatu, orduan eta eduki gehiago aurkituko duzu.","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio-k magnet estekak erreproduzitu al ditzake?","WEBSITE_MAINPAGE_FAQ_012_P1":"Bai, eta HTTP esteka normalak eta torrent fitxategiak erreproduzi ditzake (arrastatu eta jaregin).","WEBSITE_MAINPAGE_FAQ_013_H1":"Bideo bat deskargatu eta konexiorik gabe ikusi al dezaket?","WEBSITE_MAINPAGE_FAQ_013_P1":"Lineaz kanpoko erabilgarritasuna laster datorren eginbidea da, baina Stremio gailuan gordetzeko baimena ematen baduzu (ezarpenen paneletik) bideoak geroago ikusi ahal izango dituzu konexiorik gabe.","WEBSITE_MAINPAGE_FAQ_014_H1":"Ezerk ez du funtzionatzen, lagundu iezadazu!","WEBSITE_MAINPAGE_FAQ_014_P1":"Ziur zaude gehigarriak instalatu dituzula? Bai bada, begiratu ${2} laguntza zentroarekin ${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Nola eusten dio Stremiok bere garapen eragiketei?","WEBSITE_MAINPAGE_FAQ_015_P1":"Intrusiboak ez diren iragarkiak argitaratzen ditugu ${1}AdEx${2} bidez, hau da, sortzaile talde beraren konpainia, pribatutasuna babesteko eta iragarki gardenak ardatz dituena.","WEBSITE_MAINPAGE_FAQ_015_P2":"Galdera gehiagorako, joan ${1}laguntza-zentrora${2}.","HELP_LEARN_MORE":"Lagundu iezaguzu zure inguruan gehiago jakiten.","LIFESTYLE":"Bizimodua","SPORTS":"Kirolak","FOOD_HEALTH":"Elikadura eta osasuna","BEAUTY_FASHION":"Edertasuna eta Moda","NEWS":"Albisteak","GAMING":"Jokoa","SCIENCE_EDUCATION":"Zientzia eta hezkuntza","MUSIC":"Musika","TRAVEL":"Bidaia","LATE_NIGHT":"Late Night","REALITY":"Realitya","COMEDY":"Komedia","DIY":"Nola egin zerorrek","TECH":"Teknologia","CINEMA":"Zinema","CONTINUE":"Jarraitu","SLOW_LOADING":"KARGA MOTELA?","I_GIVE_UP":"AMORE EMATEN DUT","LEARN_MORE":"Gehiago ikasi","POOR_SOURCE":"Iturri hau ez dago erabilgarri edo zure Interneteko konexioa ez da behar bezain azkarra","PICK_CATEGORIES_ERR":"Gutxienez 3 kategoria aukeratu behar dituzu","ADJUST_TIMING":"Egokitu denborarekin","ADJUST_SIZE":"Doitu tamaina honekin","SEARCH_ANYTHING":"Edozer gauza bila dezakezu ...","ALL_CATEGORIES":"Guztiak","SEARCH_CATEGORIES":"Filmak, Telesailak, YouTube eta Telebista","SEARCH_PERSONS":"Aktoreak, Zuzendariak eta Idazleak","SEARCH_PROTOCOLS":"HTTP eta iman estekak","SEARCH_TYPES":"IMDB/TVDB estekak","WATCHED":"Ikusita","SHOW_LESS":"Erakutsi gutxiago","LAST_SEARCHES":"Azken bilaketak","CLEAR_HISTORY":"Garbitu historia","CHOOSE_SOME":"AUKERATU HEMENDIK BATZUK:","NO_WEB_REMOTE":"Urruneko Web-a ezin izan da kargatu","STREMIO_OFFLINE":"Stremio lineaz kanpo dago","STREMIO_EXPENSIVE_CONNECTION":"Mugikorreko datu konexioa erabiltzen ari zarela antzeman dugu, jarraitu nahi al duzu?","USE_DATA":"Erabili datuak","WARNING":"Abisua","MORE_INFO":"Informazio gehiago ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Kargatzen ...","STREMIO_TV_BACK_TO_LANGUAGES":"Itzuli hizkuntzetara","STREMIO_TV_REMOTE":"Urrunekoa","STREMIO_TV_GO_TO":"Joan:","STREMIO_TV_OR_SCAN":"edo eskaneatu:","STREMIO_TV_ADDON_INSTRUCTIONS":"Mesedez, jarraitu argibideak nahiago dituzun gehigarriak instalatzeko.","STREMIO_TV_LIVE_TV":"Zuzeneko telebista","STREMIO_TV_RESUME_WATCHING":"Berrekin Ikustea","STREMIO_TV_LOADING_BACKGROUND":"Aurrekariak kargatzen","STREMIO_TV_CHECKING_AUTHENTICATION":"Autentifikazioa egiaztatzen","STREMIO_TV_LOADING_BOARD":"Kargatzeko taula","STREMIO_TV_LOGIN_HEADER_LINE_1":"Gure erabiltzaileek ahalik eta esperientzia pertsonalizatu onena izan dezaten nahi dugu gure softwarearekin.","STREMIO_TV_LOGIN_HEADER_LINE_2":"Arrazoi horregatik eskatzen dizugu zure kontua egitea edota saioa hastea.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Eskerrik asko ulertzeagatik,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio Taldea","STREMIO_TV_REMOTE_INSTRUCTIONS":"Urruneko Web-a zure Smartphone/Tablet/Mahaigainarekin erabiltzeko:","STREMIO_TV_WIFI_SETUP":"Wi-Fi konfigurazioa","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle-k ez du Interneteko konexiorik antzeman.","STREMIO_TV_WIFI_DETAILS_1":"Konektatu hona:","STREMIO_TV_WIFI_DETAILS_2":"estremio-zirkulua","STREMIO_TV_WIFI_DETAILS_3":"Erabili pasahitza:","STREMIO_TV_WIFI_DETAILS_4":"estremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Ireki web arakatzailea estekarekin:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Azpitituluen atzerapena","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Bilatu","STREMIO_TV_NAV_HOME":"Hasiera","STREMIO_TV_NAV_DISCOVER":"Deskubritu","STREMIO_TV_NAV_LIBRARY":"Liburutegia","STREMIO_TV_NAV_MOVIES":"Pelikulak","STREMIO_TV_NAV_SERIES":"Serieak","STREMIO_TV_NAV_CHANNELS":"Kanalak","STREMIO_TV_NAV_TV":"Zuzeneko Telebista","STREMIO_TV_NAV_SETTINGS":"Ezarpenak","STREMIO_TV_NAV_ADDONS":"Addon-ak","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Idatzi zerbait","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Bilatu","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Espazio","STREMIO_TV_SEARCH_KEY_CLEAR":"Garbitu","STREMIO_TV_SEARCH_HISTORY_TITLE":"Bilatu historialean","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Izenburu, aktore, kanal eta gehiagoren arabera bilatu dezakezu","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Garbitu bilaketa historiala","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Iragazkiak","SETTINGS":"Ezarpenak","ACCOUNT":"Kontua","LOGOUT":"Irten","THEMES":"Theme-ak","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Pistak","VIDEOS":"Bideoak","SERVER":"Zerbitzaria","LINKS":"Estekak","ABOUT":"About","INTERFACE":"Interfazea","ANIMATIONS":"Animazioak","STATUS":"Egoera","LANGUAGE":"Hizkuntza","SIZE":"Tamaina","DELAY":"Atzerapena","BOLD":"Lodia","TEXT_COLOR":"Testuaren Kolorea","OUTLINE_COLOR":"Outline Kolorea","BACKGROUND_COLOR":"Atzealdeko Kolorea","BACKGROUND_BLUR":"Atzealde lausoa","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Erreproduzitu orain","MARK_AS_WATCHED":"Markatu ikusita","MARK_AS_UNWATCHED":"Markatu ikusi gabe","REWIND_TO_BEGINNING":"Itzuli hasierara","CONTINUE_WATCHING":"Jarraitu ikusten","ALL":"Guztia","SECONDS":"segundu","ON":"ON","OFF":"OFF","RELOAD":"Eguneratu","EDIT_URL":"Aldatu URLa","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Aldatu gailuak","REMOTE_VIDEOS":"Bideoak","REMOTE_ADJUST_TIMING":"Egokitu denbora","REMOTE_ADJUST_SIZE":"Doitu neurria","REMOTE_COULD_NOT_BE_LOADED":"Web urrunekoa ezin izan da kargatu","REMOTE_RETRY":"Saiatu berriro","TORRENT_PROFILE_DEFAULT":"Defektuzkoa","TORRENT_PROFILE_SOFT":"Leuna","TORRENT_PROFILE_FAST":"Azkarra","TORRENT_PROFILE_ULTRA_FAST":"Ultra Azkarra","FAQ_001_H1":"Zer da Stremio?","FAQ_001_P1":"Stremio bideo entretenimendurako diseinatutako multimedia zentroen softwarea da, erabiltzeko erraztasunak kontuan hartuta. Stremio-k & amp; ikusi zure film, serie, kanal eta zuzeneko telebista bilduma.","FAQ_001_P2":"Stremio-k zure disko lokaletik eta gure gehigarri sistematik erakusten duen edukia bildu.","FAQ_001_P3":"Era berean, interesatzen zaizkizun atal/bideo/film berriak ateratzen direnean jakinaraziko zaizu eta filmen gomendioak emango dizkizu.","FAQ_02_H1":"Nola alderatzen da Stremio Kodi eta Plexekin?","FAQ_02_P1":"Bi softwareak inspiratzen gaitu. Baina helburu desberdinak ditugu - Stremio entretenimendu bideoetara bideratuta dago bereziki, eta horretarako oso konponbide nagusia bilakatzen ahalegintzen da erabiltzeko oso erraza izanik.","FAQ_02_P2":"Stremio ez da inoiz Kodi eta Plex bezain pertsonalizagarria eta aberatsa izango, baina errazagoa da erabiltzea. ${1}eskuratu eta ikusi${2} :)","FAQ_03_H1":"Nola alderatzen da Stremio Netflix-ekin?","FAQ_03_P1":"Berriro ere, Netflix da gure inspirazioetako bat. Netflix-en erabiltzailearen esperientzia lortzen ahalegintzen gara, eta gehitutako opari asko. Baina garrantzitsuena, zure liburutegia kudeatzeko eta eduki gehigarri berriak gehitzeko askatasuna ematen dizugu gure addon sistemarekin.","FAQ_03_P2":"Horrek Stremio ezin du luzatu, beraz, Stremio erabiltzen duzunean ez zara inoiz Netflix-ek lizentzia ematea erabakitzen duen edukira mugatzen. Adibidez, Stremioren bidez ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} edukia ikusi dezakezu. eta baita ${9}Netflix${10} bera ere!","FAQ_04_H1":"Nola alderatzen da Stremio Flipboard-ekin?","FAQ_04_P1":"Galdera hori ez dugu hain maiz jasotzen, hasierako jendearekin hitz egitean izan ezik :)","FAQ_04_P2":"Stremio edukien agregatzailea diseinatzean datza, eta horrek bideoetarako Flipboard bihurtzen du. Hori oso agerikoa da gure Batzordearen atalean, katalogoak eta atal berrien / bideo berrien jakinarazpenak eskaintzen dizkizu, Flipboard-ek bezala.","FAQ_05_H1":"Nola alderatzen da Stremio krispeten denborarekin?","FAQ_05_P1":"Stremio eta Popcorn Time erabiltzailearen interfazean antzekoak dira, bideo entretenimendu katalogoak ondo egiteko modu asko ez dagoelako :)","FAQ_05_P2":"Popcorn Time iturri zehatzetatik torrent-ekin erreproduzitzera bideratuta dagoen arren, Stremio mugarik gabe dago eta eduki-agregatzailea besterik ez da, ez dago eduki-iturri zehatz batean blokeatuta.","FAQ_05_P3":"Gainera, ez dugu torrent gehigarririk ematen lehenespenez, beraz, Stremiok ez du krispeten denboraren erabilera-kasua funtzionalitate ofizialarekin estaltzen.","FAQ_05_P4":"Beste desberdintasun aipagarri bat Popcorn Time erabat irekia dela da, Stremio ${1}partzialki irekita${2} dela.","FAQ_06_H1":"Gehituko al duzu film/telesail hau?","FAQ_06_P1":"Ez, barkatu :(","FAQ_06_P2":"Beste galdera gehienetan aipatzen den bezala, Stremiok ez du berez edukirik eskaintzen - dena gehigarrien sistemaren bidez gehitzen da. Eduki eskaera izanez gero, erreproduzitzailean dagoen \\"Salatu\\" botoia erabil dezakezu, mezu elektroniko bat bidaliko dio unean erabiltzen ari zaren gehigarriaren egileari.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"X-rako gehigarria sortuko al duzu?","FAQ_08_P1":"Erabat posible da.","FAQ_08_P2":"Gehigarri bat egiteko ideia baduzu, idatzi ${1}office@stremio.com${2} helbidera, baina ziurtatu gehigarrien ideiak ez dituela inolako copyright edo erabilera baldintzak urratuko.","FAQ_08_P3":"Momentuz, gure bide orriko hurrengo gauzak FandangoNOW, Filmon.tv bideoaren eskaera eta Crunchyroll-en gehigarriak dira.","FAQ_09_H1":"Stremiok BitTorrent erabiltzen al du?","FAQ_09_P1":"Bai, Stremiok BitTorrent onartzen du streaming protokolo gisa. Hori erabil dezakezu torrent gehigarri batekin edo .torrent fitxategi bat Stremiora arrastatuz eta jareginez edo Bilaketa barran iman esteka itsatsita.","FAQ_09_P2":"Kontuan izan BitTorrent erabiltzen duen gehigarri ofizial bakarra ${1} Vodo ${2} dela, indie edukia eskaintzen duena, guztia BitTorrent-ekin banatzeko baimendua.","FAQ_09_P3":"Ez dugu onartzen copyright-urraketa egin dezaketen hirugarrenen gehigarririk erabiltzea.","FAQ_10_H1":"Zer ikusi dezaket Stremion gehigarri ofizialekin?","FAQ_10_P1":"Berez, Filmon.tv, YouTube eta Vodo edukiak Stremio beraren barruan ikus ditzakezu, kapsulatutako erreproduzitzailearekin. Gainera, Twitch.tv-rako gehigarria dugu eta beste batzuk.","FAQ_10_P2":"Konbinatu honek aukera hauek eskaintzen ditu:","FAQ_10_L1":"Filmon.tv-k eskainitako telebista kate ezagunak - adibidez, E4, BBC, Bollyworld TV","FAQ_10_L2":"YouTube-tik dena - adibidez BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Film indiarrak Vodorekin","FAQ_10_L4":"Lineako jokoen emisioak Twitch.tv-rekin","FAQ_10_P3":"Gainera, gida-kutxa eta Netflix gehigarriekin hornitutako eduki iturri ugari daude, ez Stremio barruan guztiz erreproduzitzen direnak, baina emandako zerbitzura birbideratuko lirateke. Adibidez, Guidebox gehigarriak AEBetan doan erreproduzi ditzakezun filmen aukeraketa emango dizu TubiTV eta Crackle bezalako zerbitzuetatik.","FAQ_11_H1":"Stremiok ez du instalatuko, zer egin behar dut?","FAQ_11_P1":"Windows-en bazaude, probatu ${1} ${2} instalatzaile alternatibo hau.","FAQ_11_P2":"Mac OS X erabiltzen baduzu, kontuan izan ez dugula OS X Mavericks (10.9) baino zaharragoak onartzen.","FAQ_11_P3":"Linux erabiltzen baduzu, kontuan izan momentuz 64 bit (x64) Linux soilik onartzen ditugula.","FAQ_11_P4":"Oraindik arazoa konpondu ezin baduzu, idatzi iezaguzu ${1}Facebook taldean${2}.","FAQ_12_H1":"Zergatik kexatzen da nire birusaren kontrakoa? Stremio segurua al da?","FAQ_12_P1":"Stremio ${1}%100 garbi${2} dagoela ziurtatzen dizugu.","FAQ_12_P2":"Birusen aurkako arazoa kexatzen ari da publizitatea gure instalatzailean sartzen dugulako, birusen aurkako programa batzuek iragarki gisa aitortzen baitute.","FAQ_12_P3":"Oraindik ziur ez bazaude, ${1}instalatzaile alternatiboa${2} probatu dezakezu.","FAQ_13_H1":"Nola egin dezaket gehigarri bat?","FAQ_13_P1":"Hasiberrientzat, GitHub-en gure ${1}addons sistemaren modulua${2} begiratzea gomendatzen dugu.","FAQ_13_P2":"Ondoren, ${1}Hello World tutoriala${2} jarraitu dezakezu.","FAQ_13_P3":"Programaziorako trebetasunik ez baduzu, idatzi zure ideia ${1}Reddit komunitatean${2} eta jarri gurekin harremanetan zure addon ideiarekin ${3}office@stremio.com${4} helbidean.","FAQ_14_H1":"Nola argitaratzen dira gehigarriak?","FAQ_14_P1":"Gehigarri eta ostalari bat sortzen duzunean eta zure manifestuan amaiera eremua jartzen duzunean, funtzionatzen duen gehigarrien helbidea seinalatzen duena, gehigarriak automatikoki argitaratuko du gure ${1} gehigarrien katalogoan ${2} .","FAQ_14_P2":"Stremio-addons moduluko zerbitzariaren zatiak automatikoki dei egiten duelako gure APIra gehigarria iragartzeko. Gure APIak zure amaierako puntua baliozko gehigarri gisa balioztatzen duenean, katalogoan erakusten hasiko da.","FAQ_15_H1":"Exekutatu al dezaket Stremio nire arakatzailean?","FAQ_15_P1":"Momentuz ez, baina badator hau!","FAQ_15_P2":"Alpha bat ikusteko jakinmina baduzu, hemen ikus dezakezu: ${1} alpha4.strem.io ${2}. Gogoan izan streaming hau alfa honetan desgaituta dagoela. Chrome, Firefox, Opera eta Edge onartzen ditugu.","FAQ_16_H1":"Telebistara igortzeak ez du funtzionatzen / azpitituluak ez dira funtzionatzen","FAQ_16_P1":"Telebistara igotzeak telebista marka eta modelo desberdinen artean oso bat ez datorren DLNA teknologia erabiltzen du. Hori dela eta, kasu guztietan ez dugu probatzeko gaitasunik, beraz, oso urrun dago perfektua izatetik. Hala ere, etengabe hobetzeko lanean ari gara, baina ezin dugu DLNA zure telebistarekin ondo funtzionatzen noiz hasiko den kalkulatzeko denbora.","FAQ_16_P2":"Zure telebista casting menuan ikusten ez baduzu ere, saiatu sareko konexioa desgaitzen eta berriro gaitzen (Windows-en, egin klik eskuineko botoiarekin Sarea eta erabili Gaitu / Desgaitu), baita router, telebista eta ordenagailua berrabiarazi ere. .","FAQ_16_P3":"Oraindik arazoak topatzen badituzu, lagun diezagukezu telebistaren marka eta modeloaren informazioa ${1}office@stremio.com${2} helbidera bidalita.","FAQ_16_P4":"Bitartean, oso ondo onartzen dugun Chromecast gomendatzen dugu edo, besterik gabe, zure telebista ordenagailura HDMI kable batekin konektatzea.","FAQ_17_H1":"Stremio izoztu edota huts egiten du, zer egin dezaket?","FAQ_17_P1":"Lehenik eta behin, Windows 7 AVG antibirusarekin erabiltzen ari bazara: arazo bat dugu konbinazio horrekin. Arazoa AVG-n dago, eta ez dago arrazoizko modurik gure aldetik konpontzeko. Zoritxarrez, salbuespenak edo birusen aurkako desgaitzea ez dira funtzionatuko. Irtenbide bakarra AVG beste zerbaitengatik ordezkatzea da.","FAQ_17_P2":"Hori ez bada arazoa, baina Windows erabiltzen jarraitzen baduzu, eguneratu azken zerbitzu-paketera eta eguneratu/instalatu berriro GPU kontrolatzaileak, eta saiatu berriro.","FAQ_17_P3":"Arazoa oraindik konpontzen ez bada edo Mac edo Linux erabiltzen ari bazara, idatzi iezaguzu arazoaren xehetasun zehatzen berri ${1}gure Facebook taldeko${2} helbidean.","FAQ_18_H1":"Nola egin dezaket gehigarri bat?","FAQ_18_P1":"Hasiberrientzat, GitHub-en gure ${1}addons sistemaren modulua${2} begiratzea gomendatzen dugu.","FAQ_18_P2":"Ondoren, ${1} Hello World tutoretza ${2} jarraitu dezakezu.","FAQ_18_P3":"Programaziorako trebetasunik ez baduzu, idatzi zure ideia ${1}Reddit komunitatean${2} eta jarri gurekin harremanetan zure addon ideiarekin ${3}office@stremio.com${4} helbidean.","FAQ_19_H1":"Zergatik ari da Stremio diskoan lekua hartzen?","FAQ_19_P1":"Stremio-k cache lokal bat du igortzen dituzun bideo fitxategiak aldi baterako mantentzeko.","FAQ_19_P2":"Horrek bi abantaila ditu: lehenik, Stremiok bideoa aurrez bufferrean uzteko aukera ematen du, streaming zuzenagoa bermatzeko. Bigarrenik, bideoak cache lokalean gordetzen ditu, lineaz kanpo ikusten jarraitu ahal izateko.","FAQ_19_P3":"Stremio-k zenbat gordetzen duen ezarpenen paneleko Cache ezarpenaren araberakoa da. Stremio-k zure diskoan ezarritako zenbatekoa (adibidez, 2 GB) gorde dezake, unean erreproduzitutako bideoa hori baino handiagoa ez bada, kasu horretan, gordetzeko adina biltegiratze esleitu behar du erreproduzitu arte.","FAQ_20_H1":"Non dago cache karpeta?","FAQ_20_P1":"Windows-en, Stremio-cache da Ezarpenetan aukeratu duzun unitatean (adibidez, \\"E: \\\\ stremio-cache\\")","FAQ_20_P2":"MacOS-en \\"~ /Library/Application Support/Stremio/stremio-cache\\" da","FAQ_20_P3":"Linux-en \\"~/.stremio/stremio-cache\\" edo \\"~/stremio-cache\\" da.","FAQ_21_H1":"\\"Streaming zerbitzaria ez da aurkitu\\" errorea dut. Zer egin dezaket?","FAQ_21_P1":"Akats hau jasoz gero, gauza gutxietako bat esan nahi du:","FAQ_21_P2":"1) YouTube/BitTorrent iturriak babestutako gehigarri bat erabiltzen saiatzen ari zara, gure ${1}web bertsioaren${2} bidez. Kasu honetan, gure mahaigaineko bertsioa ${3}webgunetik${4} instalatu beharko zenuke.","FAQ_21_P3":"2) Zerbait ez dago gaizki zure Stremio instalazioarekin. Kasu honetan, saiatu berriro instalatzen mahaigaineko azken bertsioa ${1} ${2} webgunetik. Honek laguntzen ez badu, saiatu birusen aurkako programak eta suebakiak desgaitzen, ordenagailua berrabiarazi eta saiatu berriro. Honek ere funtzionatzen ez badu, idatzi iezaguzu ${3}gure Facebook taldean${4}.","FAQ_22_H1":"Ezin ditut iOSeko gehigarri gehienak ikusi/erabili","FAQ_22_P1":"Apple App Store-ren baldintzak eta mugak direla eta, iOS aplikazioa gehigarri jakin batzuetara soilik mugatu dugu.","FAQ_22_P2":"Baina lasai - etorkizunean iOS-erako gehigarri gehiago egongo dira, eta Stremio gehigarri guztiak erabiltzea ahalbidetuko duen integrazioa ere gehi dezakegu iOS aplikazioa Stremio Streaming Server-era konektatzeari esker."}')},2381:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"فیلم","TYPE_series":"سریال","TYPE_tv":"برنامه تلویزیونی","TYPE_channel":"کانال","TYPE_other":"سایر","TYPE_movie_PL":"فیلم ها","TYPE_series_PL":"سریال ها","TYPE_tv_PL":"برنامه های تلویزیونی","TYPE_channel_PL":"کانال ها","TYPE_other_PL":"سایر","TYPE_ALL":"All","VIDEO":"ویدیو","BACK":"قبلی","MORE":"بیشتر","DONE":"اتمام","COPY":"کپی","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"مشاهده","Board":"بورد","Library":"کتابخانه","My Library":"کتابخانه من","Calendar":"تقویم","NOTIFICATION_ONLINE":"شما الان آنلاینید","NOTIFICATION_OFFLINE":"شما افلاینید","INTERNET_CONNECTION":"کانکشن شبکه","STORAGE_FULL_TITLE":"هشدار: فضای دیسک شما پر شده است!!!","STORAGE_FULL_TEXT":"استریمیو نمی تواند تنظیمات شما را ذخیره کند، شاید دوباره نصب کردن یا ری استارت کردن آن به حل این مشکل کمک کند.","SEARCH":"جستجو","SEARCH_NO_RESULTS":"نتیجه ای یافت نشد","SEARCH_EXPLANATION_CONTENT":"در لیست فیلم ، سریال ، یوتیوب یا کانال های تلویزیونی جستجو کنید","SEARCH_EXPLANATION_PEOPLE":"در لیست بازیگران ،‌نویسندگان یا کارگردان ها جستجو کنید","SEARCH_PASTE_LINKS":" HTTP یا Magnet links را در اینجا کپی کنید","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"افزودن به کتابخانه","REMOVE_FROM_LIB":"حذف از کتابخانه","ADDED_TO_LIB":"به کتابخانه اضافه شد","REMOVED_FROM_LIB":"از کتابخانه حذف شد","TRAILER":"تریلر","WATCH_TRAILER":"مشاهده تریلر","WATCH_NOW":"تماشا کنید","SHOW":"نمایش","SHOW_MOVIE":"نمایش فیلم","WATCH_RANDOM":"تصادفی مشاهده کنید","IMDB_RATING":"IMDb رتبه","YEAR":"سال","DIRECTOR":"کارگردان","WRITER":"نویسنده","LEAD_ACTORS":"بازیگران اصلی","CAST":"سایر بازیگران","CREW":"خدمه","SHOW_MORE_CAST":"نمایش بیشتر »","AIRED":"پخش شده","SEASONS":"فصل ها","GENRE":"ژانر","CATALOG":"کاتالوگ","SUMMARY":"خلاصه","SHOW_MORE":"نمایش بیشتر","SIMILAR":"مشابه","UPCOMING":"بزودی عرضه می شود","ENDED":"پایان یافته","DURATION":"طول","FEATURED":"ویژه شده","METADATA":"متا دیتا","CATEGORY":"دسته بندی","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"جستجوی ویدیو","SEARCH_PLACEHOLDER":"جستجو کنید یا URL را وارد کنید","ADDON":"افزونه","ADDONS":"افزونه ها","OFFICIAL":"رسمی","ADDONS_OFFICIAL":"افزونه های رسمی استریمیو","ADDONS_POPULAR":"پرطرفدارها در کشور شما","ADDON_FREE":"رایگان","ADDON_PEERED":"peer شده","ADDON_SUBSCRIPTION":"عضویت","ADDON_STREAM_GEORESTRICTED":"در کشور شما در دسترس نیست","ADDON_STREAM_OFFLINECACHE":"کش آفلاین","ADDON_STREAM_LOCALFILE":"فایل لوکال","SHARE_ADDON":"به اشتراک گذاری افزونه","AVAILABLE_STREAMS":"استریم های در دسترس","NO_STREAM":"استریمی یافت نشد.","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"برای استفاده از استریم های بیشتر ، می توانید آن ها را نصب کنید","STREAM_NOT_SUPPORTED":"این استریم انتخابی شما برای این پلتفورم قابل استفاده نیست","ADDON_CATALOGUE":"نمایش همه افزونه ها »","ADDON_CATALOGUE_MORE":"نصب افزونه ها","REPO_ADDED":"مخزن نصب شد","ADDON_REPO_EXIST_ERR":"این آلبوم از قبل موجود بود","ADDON_REPO_ERR":"در هنگام افزودن مخزن مشکلی بوجود آمد","ADDON_ADD_ERR":"در هنگام افزودن افزونه مشکلی بوجود آمد","ERR_ADDON_PROTECTED":"این افزونه محافظت شده و قابل حذف نیست","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"یوزر پسوورد اشتباه است، مشکلی بوجود امد","ERR_NOT_COLLECTION_URL":"URL آلبوم نیست","ERR_NOT_ADDON_URL":"URL افزونه اشتباه است","ERR_DETECTFROMURL":"از این URL چیزی پیدا نکردیم","ADDON_DUPLICATE_WARNING":"هشدار:افزونه تکراری است","ADDON_COLLECTION_SET_FAILED":"عملیات همگام سازی افزونه های نصب شده به پنل کاربری شما ، با شکست مواجه شد","SETTINGS_DATA_EXPORT":"اکسپورت اطلاعات یوزر","ADDON_PULL_FAILED":"عملیات همگام سازی افزونه های نصب شده شکست خورد","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"فیلم فعلا فقط قابل نمایش در سالن تئاتر است","WATCH_IN_CINEMA":"در سینمای محله ی خودتان ببینید","IN_THEATER":"در سینما","GET_TICKETS":"بلیط بگیرید","UPCOMING_EPISODE":"اپیزود های آینده","UPCOMING_EPISODE_MESSAGE":"این ایپزود منتشر می شود در","MISSING_DATE_EPISODE":"تاریخی در دسترس نیست","MISSING_DATE_EPISODE_MESSAGE":"این اپیزود هنوز منتشر نشده","CHANNEL_NOT_SCRAPED":"اطلاعات این کانال هنوز دریافت نشده
لطفا چند دقیقه دیگر مراجعه کنید.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"به کتابخانه شما افزوده شد وقتی در دسترس شد به شما اطلاع رسانی می شود.","GET_NOTIFIED_WHEN_AVAILABLE":"زمانی که در دسترس شد به شما اطلاع رسانی می شود","WARNING_STREAMING_SERVER":"هشدار: استریم سرور یافت نشد، استریم قابل انجام نیست","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"هشدار: سخت افزار شما این ویدیو را پشتیبانی نمی کند، حواستان باشد که ممکن است این ویدیو برای شما با سرعت پایینتری پخش شود","PLAYER_ERROR":"اوپس ، مشکلی در پخش کننده پیش آمده","PLAYER_ERROR_LOOKSLIKE":"انگار","PLAYER_ORIENTATION":"جهت نمایش","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"قفل شده","PLAYER_ORIENTATION_SENSOR_SHORT":"سنسور","PLAYER_ORIENTATION_LANDSCAPE":"نمایش بصورت عمودی قفل شده","PLAYER_ORIENTATION_SENSOR":"جهت نمایش پخش کننده بصورت اتوماتیک تنظیم می شود","PLAYER_PLAYBACK_SPEED":"سرعت پخش","PLAYER_PLAYBACK_ERROR":"پخش ویدیوبا مشکل مواجه شد ، دوباره سعی کنید","PLAYER_PLAYBACK_ERROR_UNKNOWN":"خطای نا شناخته","PLAYER_PLAYBACK_ERROR_DEFAULT":"این ویدیو نمی تواند در {{productName}} پخش شود.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"لایو","PLAYER_NEXT_VIDEO_TITLE":"می آید در","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"کنسل کردن","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"مشاهده کنید","STREAMING_FROM":"استریم شده از","CASTING_TO":"کست شده از","NETWORK_STATUS":"وضعیت شبکه","STREAM_SPEED":"سرعت استریم:","STREAM_BUFFERED":"بافر شده:","PEERS_INFO":"Peers اطلاعات","PEERS_ACTIVE":"فعال:","PEERS_CONNECTED":"وصل شده:","PEERS_WAITING":"منظتر باشید:","TRANSCODING_WARNING":"هشدار: در حال ترانسکد کرد ویدیو","STREAM_LOADING":"کمی شکیبا باشید...","PLAYING_LOCAL":"در حال پخش از اوکال","PLAYING_CACHE":"در حال پخش از کش","WRONG_SUBS":"زیرنویس اشتباه است؟","ERR_SUBS_LOADING_TITLE":"خطا در دریافت زیرنویس","ERR_SUBS_LOADING":"خطایی در دریافت زیر نویس ها پیش آمده شاید بخاطر افزونه زیرنویس است یا حتی مشکل از اینترنت شماست","WARN_FOLLOWING_SUB_ADDONS_FAILED":"افزونه زیرنویس فوق مشکل دارد","ERR_CASTING_UPDATE_TITLE":"نمی توانیم اطلاعات دستگاه شما را بروزرسانی کنید ،سرور استریمینگ ممکن است مشکل داشته باشد","CHOOSE_DEVICE":"دستگاه را انتخاب کنید","NO_CAST_DEVICES":"دستگاهی پیدا نشد","NO_SETTINGS":"تنظیمات یافت نشد","PHONE_TABLET":"گوشی یا تبلت","SUBTITLES":"زیرنویس ها","SUBTITLES_CHANGE":"زیرنویس را انتخاب کنید برای","SUBTITLES_CHANGE_NONE":"هیچ زیرنویس دیگری پیدا نشد","SUBTITLES_CHANGE_ACIVE":"زیرنویس های موجود : #{{subtitlesDialog.activeIdx + 1}} . بر روی دکمه \\"Continue\\" کلیک کنید تا زیرنویس را مشاهده کنید. #{{subtitlesDialog.pickedIdx + 1}}","SUBTITLES_OR":"جایگزین,","SUBTITLES_ADJUST_DELAY":"زیرنویس delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"یا کلید G / H را در هنگام پخش استفاده کنید","SUBTITLES_ADJUST_DELAY_TIP":"توجه: شما می توانید کلید G / H را هنگام پخش استفاده کنید.","SUBTITLES_DELAY":"زیرنویس ها delay:","SUBTITLES_LOADING":"در حال دریافت زیرنویس ها","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"غیرفعال شده","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"فصل","EPISODE":"اپیزود","SPECIAL":"Special","SORT":"مرتب سازی","SORT_BY":"مرتب سازی بر","FILTER":"فیلتر","SORT_TRENDING":"ترند","SORT_RECENT":"آخرین","SORT_ALPHABET":"a-z","SORT_RATING":"رتبه","SORT_WATCHED":"مشاهده شده","SORT_YEAR":"سال","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"جدیدترین ها برای شما","New Episodes":"اپیزودهای جدید","New Videos":"ویدیو های جدید","Recommendations":"پیشنهاد شده:","LIBRARY_RESUME":"Resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"اطلاعات بیشتر","LIBRARY_RESUME_DISMISS":"Dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"ویژه ها","DISCOVER_TOP":"برترین ها","DISCOVER_OSCAR":"برندگان اسکار","DISCOVER_WARNING_TITLE":"اوپس!","DISCOVER_EMPTY_CATALOG":"افزونه خالی است","DISCOVER_ADULT_WARNING":"مخصوص بزرگسالان است ، ایا سن شما بالاتر از ۱۸ است؟","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"حذف این اددان(افزونه)","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"الان نه","BUTTON_UPDATE_NOW":"بروزرسانی","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"رمزعبور","PASSWORD_CONFIRM":"تایید رمزعبور","EMAIL":"ایمیل","FB_LOGIN":"Continue with Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"یا","I_ACCEPT":"I accept the","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terms and Conditions","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passwords don\'t match","SIGN_UP":"ثبت نام","SIGN_UP_EMAIL":"ثبت نام با ایمیل","CLICK_TO_SIGN_UP":"برای ثبت نام اینجا کلیک نمایید.","LOG_IN":"ورود","LOG_OUT":"خروج","EXIT_FULLSCREEN":"خروج از مود تمام صفحه","ENTER_FULLSCREEN":"ورود به مود تمام صفحه","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"پنل کاربر","LOGIN_LABEL":"ورود","GUEST_LOGIN":"ورود مهمان","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"اینجا را کلیک کنید","WRONG_PASSWORD":"Wrong email or password. In case you have forgotten your password, ","SET_A_PASS":"تنظیم رمزعبور","RESET_PASSWORD":"بازیابی رمزعبور","FORGOT_PASSWORD":"رمزعبور را فراموش کردید?","EMAIL_USED_WITH_FB":"This email was used with a Facebook login.","INVALID_EMAIL":"لطفا یک ایمیل معتبر وارد نمایید","INVALID_PASSWORD":"لطفا یک رمزعبور معتبر وارد نمایید","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"ورود ناموفق بود.","SIGNUP_FAILED":"عضویت ناموفق بود.","SEARCH_FAILED":"جستجو ناموفق بد","EMAIL_USED":"این ایمیل استفاده شده است.","WAITING_FB_LOGIN":"ورود توسط فیسبوک...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"بله","EXTERNAL_ONLY_ONCE":"خیر","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"ورزشی","INTRO_TASTE_FOOD_HEALTH":"تغذیه و سلامت","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"اخبار","INTRO_TASTE_GAMING":"گیمینگ","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"موزیک","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"کمدی","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"تکنولوژی","INTRO_TASTE_CINEMA":"سینما","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Activate this addon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"افزودن","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"What\'s new","BUTTON_CONTINUE":"ادامه","BUTTON_ACTIVATE":"Activate","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"انصراف","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"شما باید وارد شوید.","SETTINGS_LABEL":"تنظیمات","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"تغییر رمز عبور","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"تماس با پشتیبانی","SETTING_LANGUAGE":"زبان","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"زیرنویس های پیشفرض","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"حساب کاربری","SETTINGS_VERSION":"نسخه","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"روشن","NAVIGATION_OFF":"خاموش","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Quit","CONNECTED":"متصل شده است","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"January","February":"February","March":"March","April":"April","May":"May","June":"June","July":"July","August":"August","September":"September","October":"October","November":"November","December":"December","Monday":"Monday","Tuesday":"Tuesday","Wednesday":"Wednesday","Thursday":"Thursday","Friday":"Friday","Saturday":"Saturday","Sunday":"Sunday","Action":"Action","Comedy":"Comedy","War":"War","Family":"Family","Animation":"Animation","Adventure":"Adventure","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romance","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"اخبار","music video":"موزیک ویدیو","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"اشتراک گزاری","CTX_COPY_SHARE_LINK":"کپی کردن لینک اشتراک گزاری","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"نمایش","CTX_PLAY":"پخش","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"حذف از کتابخانه","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"تمام صفحه","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"کپی","CTX_PASTE":"بیست","CTX_CLEAR":"پاکسازی","CTX_CLEAR_RECENT_SEARCHES":"پاکسازی جستجو های اخیر","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"افزونه های من","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon collections","ADDON_SEARCH":"جستجوی افزونه","ADDON_INSTALL":"نصب","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"حذف","ADDON_UPGRADE":"بروزرسانی","ADDON_INSTALLED":"نصب شده","ADDON_INSTALLED_MSG":"افزونه نصب شد!","ADDON_UPGRADED_MSG":"افزونه برزورسانی شد!","ADDON_UNKNOWN":"ناشناس","ADDON_ERR":"خطا در نصب افزونه!","ADDON_DISCONNECTED":"قطع شده","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"اکنون نصب کن","ADDON_PAGE":"صفحه افزونه","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"افزونه","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"لینک نامعتبر است","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"ادامه تماشا","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You Can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"خانه","WEBSITE_PAGE_FEATURES":"امکانات","WEBSITE_PAGE_ADDONS":"افزونه ها","WEBSITE_PAGE_TECH":"تکنولوژی","WEBSITE_PAGE_CREATE_ADDON":"ساخت افزونه","WEBSITE_PAGE_CONTACTS":"مخاطبین","WEBSITE_PAGE_BLOG":"بلاگ","WEBSITE_TYPE_movie":"فیلم ها","WEBSITE_TYPE_series_PL":"سریال ها","WEBSITE_TYPE_tv":"تلویزیون زنده","WEBSITE_TYPE_channel":"کانال ها","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"ویدیو جدید","WEBSITE_BOARD_EPISODE":"قسمت جدید","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"افزونه های محتوا","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"افزونتو بساز","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"حمایت با بیتکوین:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"سوالات متداول","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"مجاز","WEBSITE_PAGE_ABOUT":"درباره","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"درباره ما","WEBSITE_LINK_TECHNOLOGY":"تکنولوژی","WEBSITE_LINK_APPS":"برنامه ها","WEBSITE_LINK_DOWNLOADS":"دانلود ها","WEBSITE_MORE":"بیشتر","WEBSITE_LINK_ADDONS":"افزونه ها","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"انجمن","WEBSITE_LINK_BLOG":"بلاگ","WEBSITE_MORE_MORE":"... & بیشتر","WEBSITE_LINK_HELP":"مرکز راهنما","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"سابسکرایب","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"امکانات","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"افزونه ها","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"ی افزونه بساز","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"دانلود ها","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio برای ویندوز","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio برای لینوکس","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio برای اندروید","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio برای تلویزیون اندروید","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"تماس باما","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"ایمیل شما","WEBSITE_CONTACT_US_PH_MESSAGE":"پیغام","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ارسال","WEBSITE_CONTACT_US_Q_1":"چطوری نصب کنیم?","WEBSITE_CONTACT_US_Q_2":"چطوری حذف کنیم?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"افزونه ها","WEBSITE_CONTACT_US_OS_1":"ویندوز","WEBSITE_CONTACT_US_OS_2":"مک","WEBSITE_CONTACT_US_OS_3":"لینوکس","WEBSITE_CONTACT_US_OS_4":"اندروید","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"تکنولوژی","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"برو خانه","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"سوالات متداول","WEBSITE_SUPPORT":"پشتیبانی","WEBSITE_DOWNLOAD_4_0_BETA":"Download Stremio 4 beta Now","WEBSITE_GET_FOR_DESKTOP":"دریافت برای دسکتاپ","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"اکانت من","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can access a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"اخبار","GAMING":"گیمینگ","SCIENCE_EDUCATION":"Science & education","MUSIC":"موزیک","TRAVEL":"سفر","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"کمدی","DIY":"How to DIY","TECH":"تکنولوژی","CINEMA":"سینما","CONTINUE":"ادامه","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"همه","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"مشاده شده","SHOW_LESS":"نمایش کمتر","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"هشدار","MORE_INFO":"اطلاعات بیشتر ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"درحال بارگذاری ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"استفاده از رمزعبور:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"جستجو","STREMIO_TV_NAV_HOME":"خانه","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"کتابخانه","STREMIO_TV_NAV_MOVIES":"فیلم ها","STREMIO_TV_NAV_SERIES":"سریال ها","STREMIO_TV_NAV_CHANNELS":"کانال ها","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"تنظیمات","STREMIO_TV_NAV_ADDONS":"افزونه ها","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"جستجو","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"تنظیمات","ACCOUNT":"حساب","LOGOUT":"خروج","THEMES":"تم ها","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"ویدیو ها","SERVER":"سرور","LINKS":"لینک ها","ABOUT":"درباره","INTERFACE":"Interface","ANIMATIONS":"انیمیشن ها","STATUS":"وضعیت","LANGUAGE":"زبان","SIZE":"سایز","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"روشن","OFF":"خاموش","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"تغییر دستگاه ها","REMOTE_VIDEOS":"ویدیو ها","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"تلاش مجدد","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},5829:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Série","TYPE_tv":"Chaîne TV","TYPE_channel":"Chaîne","TYPE_other":"Autre","TYPE_movie_PL":"Film","TYPE_series_PL":"Séries","TYPE_tv_PL":"Chaînes TV","TYPE_channel_PL":"Chaînes","TYPE_other_PL":"Autres","TYPE_ALL":"Tous","VIDEO":"Vidéo","BACK":"Retour","MORE":"Plus","DONE":"Terminer","COPY":"Copier","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Découverte","Board":"Tableau","Library":"Bibliothèque","My Library":"Ma Bibliothèque","Calendar":"Calendrier","NOTIFICATION_ONLINE":"Vous êtes maintenant connecté","NOTIFICATION_OFFLINE":"Vous êtes maintenant hors-ligne","INTERNET_CONNECTION":"Connexion Internet","STORAGE_FULL_TITLE":"Attention: Espace de stockage plein !","STORAGE_FULL_TEXT":"Stremio sera incapable de sauvegarder vos réglages, préférences ou informations de connexion. N\'hésitez pas à relancer ou réinstaller Stremio.","SEARCH":"recherche","SEARCH_NO_RESULTS":"Aucun résultat trouvé","SEARCH_EXPLANATION_CONTENT":"Recherchez des films, séries, chaines YouTube ou TV...","SEARCH_EXPLANATION_PEOPLE":"Recherchez des acteurs, directeurs et réalisateurs","SEARCH_PASTE_LINKS":"Collez une URL ou un lien magnet","SEARCH_OR_PASTE_LINK":"Rechercher ou coller un lien","ADD_TO_LIB":"Ajouter à la bibliothèque","REMOVE_FROM_LIB":"Retirer de la bibliothèque","ADDED_TO_LIB":"Ajouté à la bibliothèque","REMOVED_FROM_LIB":"Retiré de la bibliothèque","TRAILER":"Bande Annonce","WATCH_TRAILER":"Regarder la bande annonce","WATCH_NOW":"Regarder","SHOW":"Regarder","SHOW_MOVIE":"Afficher le film","WATCH_RANDOM":"Regarder aléatoirement","IMDB_RATING":"Note IMDb","YEAR":"Année","DIRECTOR":"Réalisateur","WRITER":"Scénariste","LEAD_ACTORS":"Acteurs Principaux","CAST":"Casting","CREW":"Équipe","SHOW_MORE_CAST":"Afficher plus","AIRED":"Sortie","SEASONS":"Saisons","GENRE":"Genre","CATALOG":"Catalogue","SUMMARY":"Résumé","SHOW_MORE":"Afficher Plus","SIMILAR":"Similaire","UPCOMING":"À venir","ENDED":"Terminé","DURATION":"Durée","FEATURED":"À l\'affiche","METADATA":"Métadonnées","CATEGORY":"catégorie","LINKS_GENRES":"Genres","LINKS_CAST":"Casting","LINKS_DIRECTORS":"Réalisateurs","SEARCH_VIDEOS":"rechercher des vidéos","SEARCH_PLACEHOLDER":"chercher ou coller un lien magnet","ADDON":"Addon","ADDONS":"Addons","OFFICIAL":"officiels","ADDONS_OFFICIAL":"Addons Stremio officiels","ADDONS_POPULAR":"Populaire près de chez vous","ADDON_FREE":"gratuit","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"abonnement","ADDON_STREAM_GEORESTRICTED":"non disponible chez vous","ADDON_STREAM_OFFLINECACHE":"Cache Hors ligne","ADDON_STREAM_LOCALFILE":"Fichier local","SHARE_ADDON":"Partager cet addon","AVAILABLE_STREAMS":"Flux disponibles","NO_STREAM":"Aucun flux n\'a été trouvé","ALL_ADDONS":"Tous","INSTALL_MORE_ADDONS":"Pour plus de flux, veuillez installer plus d\'addons","STREAM_NOT_SUPPORTED":"Le flux sélectionné n\'est pas supporté par la plateforme","ADDON_CATALOGUE":"Afficher tous les addons »","ADDON_CATALOGUE_MORE":"Installer des addons","REPO_ADDED":"Répertoire ajouté","ADDON_REPO_EXIST_ERR":"Cette collection d\'addons existe déjà","ADDON_REPO_ERR":"Une erreur s\'est produite lors de l\'ajout de la collection","ADDON_ADD_ERR":"Une erreur est survenue lors de l\'ajout du répertoire","ERR_ADDON_PROTECTED":"Extension protégé","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Quelque chose n\'a pas fonctionné - l\'authentification a peut-être échoué","ERR_NOT_COLLECTION_URL":"Ce n\'est pas une url de collection","ERR_NOT_ADDON_URL":"Ce n\'est pas une url d\'extension","ERR_DETECTFROMURL":"Impossible de trouver un addon/collection à partir de cette URL","ADDON_DUPLICATE_WARNING":"Attention: addon dupliqué","ADDON_COLLECTION_SET_FAILED":"La synchronisation des addons installés vers votre compte a échoué","SETTINGS_DATA_EXPORT":"Exporter mes données","ADDON_PULL_FAILED":"La synchronisation des addons installés depuis de votre compte a échoué","REFRESH_ON_CLICK":"Cliquez pour réessayer","STILL_IN_THEATER":"Movie still in theaters","WATCH_IN_CINEMA":"Regardez-le dans votre cinéma local","IN_THEATER":"In cinema","GET_TICKETS":"Acheter des places","UPCOMING_EPISODE":"Épisode à venir","UPCOMING_EPISODE_MESSAGE":"Cet épisode sera diffusé le","MISSING_DATE_EPISODE":"Date d\'épisode manquante","MISSING_DATE_EPISODE_MESSAGE":"Cet épisode n\'a peut-être pas encore été diffusé","CHANNEL_NOT_SCRAPED":"Cette chaîne n\'est pas disponible.
Revenez dans quelques minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Ajoutez le à votre bibliothèque pour être notifié une fois sorti.","GET_NOTIFIED_WHEN_AVAILABLE":"Vous serez notifié une fois disponible.","WARNING_STREAMING_SERVER":"Attention, serveur de streaming local non trouvé. Le streaming depuis Youtube et BitTorrent ne sera pas disponible.","WARNING_STREAMING_SERVER_DISMISS":"Ignorer","WARNING_STREAMING_SERVER_LATER":"Plus tard","DECODER_WARNING":"Attention : cette vidéo peut ne pas être supportée par votre matériel. Gardez à l\'esprit que la lecture peut être lente.","PLAYER_ERROR":"Oups, Erreur du lecteur","PLAYER_ERROR_LOOKSLIKE":"On dirait que","PLAYER_ORIENTATION":"Orientation du lecteur","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Verrouillé","PLAYER_ORIENTATION_SENSOR_SHORT":"Capteur","PLAYER_ORIENTATION_LANDSCAPE":"Orientation du lecteur verrouillé en paysage","PLAYER_ORIENTATION_SENSOR":"Orientation automatique du lecteur (capteur)","PLAYER_PLAYBACK_SPEED":"Vitesse de lecture","PLAYER_PLAYBACK_ERROR":"Erreur de lecture, veuillez réessayer","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Erreur inconnue","PLAYER_PLAYBACK_ERROR_DEFAULT":"Désolé, cette vidéo ne peut pas être lue par {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Langues des Sous-Titres","PLAYER_SUBTITLES_VARIANTS":"Variantes des Sous-Titres","PLAYER_SUBTITLES_SETTINGS":"Réglages des Sous-Titres","PLAYER_SUBTITLES_DISABLED":"Les sous-titres sont désactivés","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Position verticale","PLAYER_PLAY":"Lecture","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Vidéo Suivante","PLAYER_MUTE":"Muter","PLAYER_UNMUTE":"Démuter","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"À venir dans","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Ignorer","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Regarder maintenant","STREAMING_FROM":"diffusé à partir de","CASTING_TO":"Transmis à","NETWORK_STATUS":"Statut du réseau","STREAM_SPEED":"Vitesse du stream:","STREAM_BUFFERED":"Mis en cache:","PEERS_INFO":"Informations sur les pairs","PEERS_ACTIVE":"Actif:","PEERS_CONNECTED":"Connecté:","PEERS_WAITING":"En attente:","TRANSCODING_WARNING":"Attention: transcodage vidéo.","STREAM_LOADING":"chargement...","PLAYING_LOCAL":"lecture à partir d\'un fichier local","PLAYING_CACHE":"lecture à partir du cache","WRONG_SUBS":"Mauvais sous-titres ?","ERR_SUBS_LOADING_TITLE":"Erreur de chargement des sous-titres","ERR_SUBS_LOADING":"Échec du chargement des sous-titres: il peut s\'agir d\'un problème avec l\'addon que vous utilisez, ou avec votre connexion réseau.","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Les addons de sous-titres suivants ont échoués","ERR_CASTING_UPDATE_TITLE":"Impossible de mettre à jour les informations sur le périphérique de casting: le serveur de streaming est peut-être hors ligne.","CHOOSE_DEVICE":"Choisissez un appareil sur lequel regarder","NO_CAST_DEVICES":"Aucun appareil de casting n\'est disponible.","NO_SETTINGS":"Aucun réglages disponible.","PHONE_TABLET":"Téléphone / Tablette","SUBTITLES":"Sous-titres","SUBTITLES_CHANGE":"Changer les sous-titres pour ","SUBTITLES_CHANGE_NONE":"Il n\'y a pas d\'autres sous-titres pour cette langue, désolé.","SUBTITLES_CHANGE_ACIVE":"Les sous-titres #{{subtitlesDialog.activeIdx + 1}} sont actuellement activés. Cliquez sur \\"Continue\\" pour activer les sous-titres #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Sinon,","SUBTITLES_ADJUST_DELAY":"vous pouvez ajuster le décalage des sous-titres:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Utilisez les touches G / H pour les ajuster.","SUBTITLES_ADJUST_DELAY_TIP":"ASTUCE: vous pouvez utiliser les touches G / H pendant la lecture pour les régler.","SUBTITLES_DELAY":"Delai des sous-titres:","SUBTITLES_LOADING":"Chargement des sous-titres...","SUBTITLES_UNAVAILABLE":"Uncun sous-titres externes disponibles","SUBTITLES_DISABLED":"Désactivés","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Saison","EPISODE":"Épisode","SPECIAL":"Spécial","SORT":"trier","SORT_BY":"Trier par","FILTER":"filtrer","SORT_TRENDING":"tendances","SORT_RECENT":"récent","SORT_ALPHABET":"a-z","SORT_RATING":"note","SORT_WATCHED":"regardé","SORT_YEAR":"année","SELECT_TYPE":"Sélectionner le type","SELECT_SORT":"Sélectionner le filtre","SELECT_CATALOG":"Sélectionner le catalogue","SELECT_GENRE":"Sélectionner le genre","SORT_LASTWATCHED":"Par dernier regardé","SORT_NAME":"Par nom","SORT_TIMESWATCHED":"Par temps regardé","New for You":"Nouveau pour vous","New Episodes":"Nouveaux épisodes","New Videos":"Nouvelles Vidéos","Recommendations":"Recommandations","LIBRARY_RESUME":"Reprendre","LIBRARY_PLAY":"Lire","LIBRARY_DETAILS":"Détails","LIBRARY_RESUME_DISMISS":"Effacer","LIBRARY_CLEAR_PROGRESS":"Effacer l\'avancée de la lecture","LIBRARY_REMOVE":"Retirer","DISCOVER_FEATURED":"Têtes d\'affiches","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Primés aux Oscars","DISCOVER_WARNING_TITLE":"Oups !","DISCOVER_EMPTY_CATALOG":"Cet addon a renvoyé un contenu vide.","DISCOVER_ADULT_WARNING":"Ce contenu n\'est visible que pour les adultes. Avez-vous plus de 18 ans ?","DISCOVER_NOADDON_WARNING":"Attention: aucune extension Stremio active pour ce type. Les fichiers sauvegardés seront montrés, rien ne sera mis à jour.","DISCOVER_LOAD_ERR":"Discover: n\'a pas réussi à charger le catalogue à partir de l\'addon","DISCOVER_ADDON_UNINSTALLED":"Ce contenu n\'est plus disponible, vous avez peut-être désinstallé l\'addon.","UNINSTALL_THIS_ADDON":"Désinstallez cet addon","ERR_ADDON_NOT_INSTALLED":"Cet addon n\'est pas installé. L\'installer maintenant ?","DETAIL_RECEIVE_NOTIF_SERIES":"Recevoir des notifications pour les nouveaux épisodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Recevoir des notifications pour les nouvelles vidéos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Redémarrez maintenant!","UPGRADE":"Nouvelle version disponible ! Mise à jour vers la dernière version de Stremio","RELOAD_UI":"Rafraîchir l\'interface utilisateur","MANUAL_UPDATE_TITLE":"Mettez à jour votre version de Stremio","MANUAL_UPDATE_LINE1":"Vous utilisez une version obsolète de Stremio, ce qui est fortement déconseillé.","MANUAL_UPDATE_LINE2":"Veuillez mettre à jour dès que possible.","BUTTON_UPDATE_LATTER":"Pas maintenant.","BUTTON_UPDATE_NOW":"Mettre à jour","ANONYMOUS_USER":"Utilisateur anonyme","DONT_HAVE_ACC":"Vous n\'avez pas de compte ?","HAVE_ACC":"Vous avez déjà un compte ?","PASSWORD":"Mot de passe","PASSWORD_CONFIRM":"Confirmer le mot de passe","EMAIL":"E-mail","FB_LOGIN":"Continuer avec Facebook","FB_NOTHINGSHARED":"Rien ne sera partagé sans votre permission","FB_NOPOST":"Nous ne posterons rien en votre nom","OR":"ou","I_ACCEPT":"J\'accepte les","I_ACCEPT_BY_CLICKING":"En cliquant sur le bouton ci-dessus, je certifie que j\'accepte les ","TOS":"Conditions d\'utilisation","MUST_ACCEPT_TERMS":"Vous devez accepter les conditions","PASSWORDS_NOMATCH":"Les mots de passe ne correspondent pas","SIGN_UP":"Inscription","SIGN_UP_EMAIL":"S\'inscrire par email","CLICK_TO_SIGN_UP":"Cliquez ici pour vous inscrire.","LOG_IN":"Connexion","LOG_OUT":"Déconnexion","EXIT_FULLSCREEN":"Quitter le mode plein écran","ENTER_FULLSCREEN":"Entrer en mode plein écran","PLAY_URL_MAGNET_LINK":"Lire un URL/lien magnet","HELP_FEEDBACK":"Aide & Commentaires","TERMS_OF_SERVICE":"Conditions d\'utilisation","PRIVACY_POLICY":"Politique de Confidentialité","ABOUT_STREMIO":"À propos de Stremio","USER_PANEL":"Panneau utilisateur","LOGIN_LABEL":"Login","GUEST_LOGIN":"Connexion invité","GUEST_LOGIN_NOTICE":"La connexion en tant qu\'invité n\'est pas recommandée. Se connecter de façon régulière permet à Stremio de synchroniser votre bibliothèque et de recevoir des notifications pour vos séries/chaines favorites. Êtes-vous sûr de vouloir continuer ?","GUEST_LOGIN_NOTICE_2":"La connexion en tant qu\'invité n\'est pas recommandée - vous n\'aurez pas de notifications synchronisées pour votre Bibliothèque ou Tableau, qui sont des fonctionnalités vitales de Stremio. Êtes-vous sûr de vouloir continuer ?","CLICK_HERE":"cliquez ici","WRONG_PASSWORD":"Mauvais mot de passe. Si vous avez oublié votre mot de passe, ","SET_A_PASS":"choisissez-en un","RESET_PASSWORD":"Réinitialiser le mot de passe","FORGOT_PASSWORD":"Mot de passe oublié ?","EMAIL_USED_WITH_FB":"Cet e-mail a été utilisé avec une connexion Facebook.","INVALID_EMAIL":"Veuillez entrer une adresse email valide","INVALID_PASSWORD":"Veuillez entrer un mot de passe valide","CONN_ERR":"Erreur de connexion - Réessayez plus tard.\\n\\nSi le problème persiste, désactivez le pare-feux/anti-virus (particulièrement Bitdefender).","IMPORT_FROM_GUEST":"Importer la bibliothèque à partir de votre compte invité","RECEIVE_UPDATES_EMAIL":"Recevoir des muses à jour par email de la part de Stremio","LOGIN_FAILED":"La connexion à échouée.","SIGNUP_FAILED":"L\'inscription a échoué.","SEARCH_FAILED":"Echec de la recherche","EMAIL_USED":"Cet email est déjà utilisé.","WAITING_FB_LOGIN":"Se connecter avec Facebook ....","EXTERNAL_PLAYER_TITLE":"Lire dans un lecteur externe","EXTERNAL_REMEMBER_PLAYER":"Voulez-vous vous souvenir de votre choix","EXTERNAL_ALWAYS_PLAY":"Oui","EXTERNAL_ONLY_ONCE":"Non","BEST_FIT":"Meilleur ajustement","FIT_SCREEN":"Ajuster à l\'écran","FILL":"Remplir","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Dites-nous ce que vous aimez","INTRO_TASTE_LONG":"Dites-nous ce que vous aimeriez regarder","INTRO_TASTE_PICK":"Choisissez {{interestsRemaining}} centres d\'intérêt","INTRO_TASTE_PICK_MORE":"Choisissez encore {{interestsRemaining}} centres d\'intérêt","INTRO_TASTE_HELP_US":"Aidez-nous à mieux vous connaître.","INTRO_TASTE_CHOOSE_THESE":"Choisis-en quelques-unes :","INTRO_TASTE_CHOOSE_MIN":"Choisissez au moins 3 catégories","INTRO_TASTE_CHOOSE_MIN_ERR":"Vous devez choisir au moins 3 catégories !","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Alimentation & Santé","INTRO_TASTE_BEAUTY_FASHION":"Beauté & Mode","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Éducation","INTRO_TASTE_MUSIC":"Musique","INTRO_TASTE_TRAVEL":"Voyages","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"TV Réalité","INTRO_TASTE_COMEDY":"Comédie","INTRO_TASTE_DIY":"DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinéma","ADDON_NOT_SUPPORTED":"L\'addon sélectionné n\'est pas supporté sur cette plate-forme.","ADDON_DISCLAIMER":"Utiliser des extensions tierces sera toujours sujet à votre responsabilité ainsi qu\'aux lois et juridictions de votre lieu de résidence.","ADDON_ACTIVATE":"Activer cette extension?","ADDON_REPO_ADD":"URL de la collection de l\'addon","ADDON_ADD":"Ajouter","ADD_ADDON":"Ajouter un Addon","ADD_ADDON_DESCRIPTION":"Vous pouvez ajouter un addon via un lien externe, qui apparaîtra dans la rubrique Addons installés.","PASTE_ADDON_URL":"Collez l\'URL de l\'addon","WHATS_NEW":"Nouveautés","BUTTON_CONTINUE":"Continuer","BUTTON_ACTIVATE":"Activer","BUTTON_ACTIVATED":"Activé","BUTTON_CANCEL":"Annuler","BUTTON_SUBMIT":"Valider","BUTTON_DISMISS_ALL":"Tout Effacer","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"Voir tous","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Votre bibliothèque est vide. Découvrez à quel point c\'est utile :) ","HOW_START":"Voilà comment démarrer:","LIB_EMPTY_CAL":"Votre calendrier affiche les séries qui sont dans votre bibliothèque.","HOW_START_CAL":"Voici comment ajouter des séries:","LIB_EMPTY_BOARD":"Le tableau montre les notifications & recommendations liées à votre Bibliothèque.","HOW_START_BOARD_WAIT":"S\'il vous plait, ajoutez quelques séries ou chaînes à votre Bibliothèque et laissez-nous quelques minutes pour procéder :)","HOW_START_BOARD":"Voici comment y ajouter des séries & des films :","IMPORT_FB":"Importez des choses que vous aimez depuis Facebook","IMPORT_TRAKT":"Importez votre médiathèque depuis Trakt.","IMPORT_DISCOVER":"Trouver des choses intéressantes dans Découverte","IMPORT_DISK":"Importez des séries ou films que vous avez dans votre disque dur","PLEASE_CREATE_ACC":"S\'il vous plait créez un compte pour activer la Bibliothèque sync & et le Tableau.","IMPORT_DISCOVER_SIGNUP":"Inscrivez-vous et trouvez des choses intéressantes à partir de DiscoverDécouvrez","IMPORT_DISK_SIGNUP":"Inscrivez-vous et importez les films ou émissions que vous avez sur votre disque Disque local.","LIB_EMPTY_CLOUD":"Bibliothèque Cloud","LIB_EMPTY_CLOUD_DESC":"Bibliothèque cloud personnelle synchronisé sur tous les appareils","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Recevoir des notifications pour les nouveaux épisodes","LIB_EMPTY_PERSONAL":"Personnel","LIB_EMPTY_PERSONAL_DESC":"Obtenir des recommandations personnelles","LIB_EMPTY_CALENDAR_DESC":"Planifiez votre calendrier personnel de visionnage","LIB_EMPTY_ALL":"Inscrivez-vous pour obtenir tout cela :","LIB_EMPTY_BEST":"Inscrivez-vous pour profiter pleinement de Stremio","LIB_EMPTY_OTHER":"Inscrivez-vous pour activer l\'option Calendrier et d\'autres fonctions intéressantes","CALENDAR_ADDED":"Le calendrier Stremio a été ajouté à votre calendrier de bureau par défaut.","CALENDAR_ADDED_MSG":"Si cela ne fonctionne pas, veuillez ajouter manuellement cette URL à votre application de calendrier.","TRAKT_EXPIRED":"L\'authentification à Trakt a expiré, allez dans Paramètres et ré-authentifiez-vous.","TRAKT_REQUIRES_LOGIN":"erreur de Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Vous devez vous connecter","SETTINGS_LABEL":"Réglages","SETTINGS_NAV_GENERAL":"Général","SETTINGS_NAV_PLAYER":"Lecteur vidéo","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Raccourcis","SETTINGS_SHORTCUT_RELOAD_APP":"Rafraichir l\'application","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Ouvrir les réglages","SETTINGS_SHORTCUT_SWITCH_TABS":"Changer d\'onglet","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Parcourir les onglets en avant","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Parcourir les onglets en arrière","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Naviguer entre les menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Aller à la Recherche","SETTINGS_SHORTCUT_EXIT_BACK":"Quitter / Retour","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Afficher le menu de Vitesse de Lecture","SETTINGS_SHORTCUT_MENU_VIDEOS":"Afficher le menu Vidéos","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Basculer le menu des Sous-Titres","SETTINGS_SHORTCUT_MENU_INFO":"Basculer le menu d\'Information","SETTINGS_SHORTCUT_FULLSCREEN":"Basculer en mode plein écran","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Afficher les contrôles","SETTINGS_SHORTCUT_PLAY_PAUSE":"Lecture / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Augmenter le volume","SETTINGS_SHORTCUT_VOLUME_DOWN":"Réduire le volume","SETTINGS_SHORTCUT_SEEK_NEXT":"Avancer la lecture","SETTINGS_SHORTCUT_SEEK_PREV":"Reculer la lecture","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Reculer dans la lecture","SETTINGS_SHORTCUT_SEEK_FORWARD":"Avancer dans la lecture","SETTINGS_SHORTCUT_PLAY_NEXT":"Lancer la vidéo suivante","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Augmenter la taille des sous-titres","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Réduire la taille des sous-titres","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Augmenter le délai des sous-titres","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Réduire le délai des sous-titres","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Afficher la barre latérale","SETTINGS_SHORTCUT_OR":"ou","SETTINGS_SHORTCUT_TO":"à","SETTINGS_SHORTCUT_SPACE":"Esapce","SETTINGS_SHORTCUT_SHIFT":"Maj","SETTINGS_SHORTCUT_ESC":"Échap","SETTINGS_TRAKT_AUTHENTICATE":"Authentifier","SETTINGS_FACEBOOK_IMPORT":"Importer","SETTINGS_CALENDAR_SUBSCRIBE":"S\'abonner","SETTINGS_INTERFACE_LANGUAGE":"Langage de l\'interface","SETTINGS_LAUNCH_STARTUP":"Lancer au démarrage","SETTINGS_VLC_DEFAULT":"Lire avec VLC","SETTINGS_UI_LANGUAGE":"Langue de l\'interface","SETTINGS_FULLSCREEN_EXIT":"Touche Echap pour quitter le plein écran","SETTINGS_GAMEPAD":"Activer le support de la manette de jeu","SETTINGS_CLOSE_WINDOW":"Fermer l\'application lorsque la fenêtre est fermée","SETTINGS_SUBTITLES_LANGUAGE":"Langue des sous-titres par défaut","SETTINGS_SUBTITLES_SIZE":"Taille par défaut des sous-titres","SETTINGS_SUBTITLES_BACKGROUND":"Arrière-plan des sous-titres","SETTINGS_SUBTITLES_COLOR":"Couleur des sous-titres","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Couleur du contour des sous-titres","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Couleur de l\'arrière-plan des sous-titres","SETTINGS_SEEK_KEY":"Touches directionnelles pour naviguer dans le temps","SETTINGS_SEEK_KEY_SHIFT":"Touches directionnelles pour naviguer dans le temps lorsque Maj est maintenue","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Durée du rembobinage et de l\'avance rapide","SETTINGS_BINGE":"Lire automatiquement le prochain épisode","SETTINGS_NEXT_VIDEO":"Afficher une notification pour commencer l\'épisode suivant","SETTINGS_NEXT_VIDEO_TRIGGER":"Afficher la notification du prochain épisode pendant :","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Durée de la popup pour la vidéo suivante","SETTINGS_PLAY_IN_BACKGROUND":"Lire en arrière-plan","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Lecture dans un lecteur externe","SETTINGS_RESIZE":"Redimensionnement automatique la fenêtre avant la lecture","SETTINGS_OVERRIDE_SERVER":"Remplacer l\'URL du serveur de streaming (avancé)","SETTINGS_SERVER_URL":"URL du serveur de streaming: ","SETTINGS_SERVER_AVAILABLE":"Le serveur de streaming est disponible.","SETTINGS_SERVER_UNAVAILABLE":"Le serveur de streaming n\'est pas disponible.","SETTINGS_SERVER_STATUS_ONLINE":"En ligne","SETTINGS_SERVER_STATUS_ERROR":"Erreur","SETTINGS_SERVER_CONFIGURE_TITLE":"Configurer l\'url du serveur de streaming","SETTINGS_SERVER_CONFIGURE_INPUT":"Entrez l\'URL du serveur de streaming","SETTINGS_SERVER_CACHE_SIZE":"Taille du cache","SETTINGS_SERVER_TORRENT_PROFILE":"Profil de torrent","SETTINGS_HTTPS_ENDPOINT":"Point d\'acces au streaming HTTPS:","SETTINGS_USE_BETA":"Toujours utiliser les dernières version bêta","SETTINGS_IMPORT_FB":"Importer depuis Facebook","SETTINGS_IMPORT_DISK":"Importer depuis le disque dur","SETTINGS_IMPORT_TRAKT":"Importer depuis Trakt","SETTINGS_PAUSE_MINIMIZED":"Mettre en pause la lecture lorsque la fenêtre est réduite","SETTINGS_HWDEC":"Décodage accéléré par le matériel","SETTINGS_BACKGROUND":"Lecture en arrière-plan","SETTINGS_SUBSCRIBE_CALENDAR":"Inscrire au calendrier","SETTINGS_REQ_EXPORT":"Demande d\'exportation de données","SETTINGS_ACC_DELETE":"Demander la suppression du compte","SETTINGS_CHANGE_PASSWORD":"Changer de mot de passe","SETTINGS_TOS":"Conditions d\'utilisation","SETTINGS_SUPPORT":"Contacter le support","SETTING_LANGUAGE":"Langue","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Déconnexion de Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scanner le code QR pour ouvrir la télécommande","SETTINGS_DESKTOP_NOTIFICATIONS":"Notifications de bureau","SETTINGS_DATA_SAVER":"Économiseur de données","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"sous-titres par défaut","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Sélection automatique de la piste audio","SETTINGS_DEFAULT_AUDIO_TRACK":"Piste audio par défaut","SETTINGS_ACCOUNT":"compte","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Lancer le lecteur dans une fenêtre séparée (avancé)","SETTINGS_PLAY_IN_EXTERNAL":"Toujours lancer la vidéo dans un lecteur externe","SETTINGS_STORAGE_BUTTON":"Effacer le stockage local","SETTINGS_STORAGE_MODAL_TITLE":"Etes-vous sûr ?","SETTINGS_STORAGE_MODAL_MESSAGE":"Cela effacera le stockage local et vous déconnectera.","SETTINGS_HWDEC_PICKER":"Choisir un paramètre de décodage accéléré par le matériel","SETTINGS_HW_AUTOMATIC":"Automatique","SETTINGS_HW_DISABLED":"Désactivé","SETTINGS_HW_ACCELERATED":"Accélération du décodage","SETTINGS_HW_FULL":"Accélération complète","SETTINGS_HW_LEGACY":"Normal","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Sous-titres Addons","SUBSPICKER_BLACK_BACKGROUND":"Utiliser un fond de couleur noir","SUBSPICKER_VERTICAL_OFFSET":"Décalage vertical","SUBSPICKER_SIZE":"Taille","SUBSPICKER_DELAY":"Retard","SUBSPICKER_EMBEDDED_SUBS":"Sous-titres intégrés","MOBILE_PRIVACY_POLICY":"Politique de confidentialité","MOBILE_CRASH_REPORTING":"Rapport d\'incident","MOBILE_ZOOM_TO_FILL":"Agrandir pour remplir l\'écran","MOBILE_PASSTHROUGH":"Sortie audio numérique (passthrough)","MOBILE_RUN_LOW_BATTERY":"Fonctionne avec une batterie faible","MOBILE_RUN_FOREGROUND":"Exécuter en tant que service de premier plan","MOBILE_PERFORMANCE":"PERFORMANCES ET STABILITÉ","MOBILE_SERVER_ONLINE":"En ligne","MOBILE_SERVER_OFFLINE":"Hors ligne","MOBILE_QR_EXPIRES":"Le code QR expire dans ","MOBILE_LOG_INTO":"Connectez-vous à votre compte Stremio ","MOBILE_SCAN_QR":"Scannez le code QR ci-dessus ou rendez-vous sur ","MOBILE_LINK_ACCOUNT":"Lien du compte","MOBILE_SPEEDPICKER_CANCEL":"Annuler","MOBILE_SPEEDPICKER_LABEL":"Choisir la vitesse de lecture","MOBILE_EMPTY_LIBRARY":"Votre bibliothèque est vide","MOBILE_NO_ADDON_ACTIVE":"Aucun addon Stremio actif pour ce type.","MOBILE_ORGANIZER_WARNING":"L\'application Stremio Organizer offre des fonctionnalités limitées. Pour une liste des flux lisibles et l\'expérience complète de Stremio, utilisez Stremio sur ordinateur.","MOBILE_ADDON_LOADING":"est toujours en cours de chargement","MOBILE_ADDONS_LOADING":"les addons sont toujours en cours de chargement","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configurez votre addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configurer l\'Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"L\'application Stremio Organizer fournit une sélection limitée d\'addons. Pour profiter pleinement de l\'expérience Stremio, utilisez Stremio sur ordinateur.","MOBILE_DISCONNECT":"Déconnecter","MOBILE_LOOKING_FOR_DEVICES":"Recherche d\'appareils...","MOBILE_CAST_TO":"Diffuser sur","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"J\'accepte de recevoir des communications marketing de Stremio","QUIT":"Quitter","CONNECTED":"Connecté","AUTHENTICATE":"S\'authentifier","CACHING":"Mise en cache","SETTINGS_CACHING_DRIVE":"Emplacement du cache","ENABLE_LOCAL_FILES_ADDON":"Activer l\'addon pour les fichiers locaux (nécessite un redémarrage)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Activer les connexions HTTPS à distance","TORRENT_PROFILE":"Profil du client Torrent","DATA_CACHING":"Mise en cache des données","MAGNET_PARSING":"Analyser un lien magnet","January":"Janvier","February":"Février","March":"Mars","April":"Avril","May":"Mai","June":"Juin","July":"Juillet","August":"Août","September":"Septembre","October":"Octobre","November":"Novembre","December":"Décembre","Monday":"Lundi","Tuesday":"Mardi","Wednesday":"Mercredi","Thursday":"Jeudi","Friday":"Vendredi","Saturday":"Samedi","Sunday":"Dimanche","Action":"Action","Comedy":"Comédie","War":"Guerre","Family":"Famille","Animation":"Animation","Adventure":"Aventure","Fantasy":"Fantaisie","Crime":"Crime","Mystery":"Mystère","Romance":"Romance","Drama":"Drame","Horror":"Horreur","Thriller":"Thriller","Sci-Fi":"Science Fiction","Music":"Musique","Biography":"Biographie","Documentary":"Documentaire","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Actualité","History":"Histoire","Game-Show":"Game-Show","Reality-TV":"Télé Réalité","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Divertissement","Gaming":"Gaming","From TV":"Depuis la TV","Lifestyle":"Lifestyle","Science & Education":"Science & Éducation","Cooking & Health":"Cuisine & Santé","Beauty & Fashion":"Beauté & Mode","Sports":"Sports","News & Politics":"Actualités & Politique","How-to & DIY":"Tutoriels","Tech":"Tech","Automotive":"Auto-Moto","Causes & Non-Profits":"Causes & Humanitaire","Movies":"Films","Uk Live Tv":"TV Live Britannique","Fashion":"Mode","Business News Radio":"Radio Actualité Business","Business Tv":"Business Tv","Cars & Auto":"Voiture & Auto","Comedy Radio":"Radio Comédie","Lifestyle Radio":"Radio Lifestyle","News Tv":"TV Actualité","Food And Wine":"Nourriture et Vin","Latino Tv":"TV Latino","Shopping Tv":"TV Shopping","Religion":"Religion","Kids":"Enfants","Body & Soul":"Corps & Ame","Education":"Éducation","Indian Tv":"TV Indienne","Extreme Sports":"Sports Extrêmes","Middle Eastern Tv":"TV Moyen Orient","Celebrity Tv":"TV Célébrité","Science Tv":"TV Science","Bikini babe":"Bikini","Outdoors":"Extérieur","German Tv":"TV Allemande","French Tv":"TV Française","Italian Tv":"TV Italienne","Gamer Tv":"TV Gamer","Travel":"Voyage","Asian Tv":"TV Asiatique","Entertainment":"Divertissement","News Radio":"Radio Actualité","Music Radio":"Radio Musique","Language Learning":"Apprentissage de Langues","Science Radio":"Radio Science","Tech Radio":"Radio Tech","Science & Technology Vod":"VOD Science & Technologie","new video":"Nouvelle vidéo","new episode":"Nouvel épisode","new movie":"Nouveau film","recommended":"recommander","we recommend":"Nous vous conseillons","offer of the day":"offre du jour","news":"news","music video":"musique vidéo","CTX_SHOW_HOTKEYS":"Afficher les raccourcis","CTX_DISMISS_NOTIF":"Ignorer les notifications","CTX_DISMISS_ALL":"Effacer tout","CTX_SHARE":"Partager","CTX_COPY_SHARE_LINK":"Copier le lien de partage","CTX_COPY_MAGNET_LINK":"Copier le lien magnet","CTX_COPY_STREAM_LINK":"Copier le lien du stream","CTX_DOWNLOAD_VIDEO":"Télécharger cette vidéo","CTX_DOWNLOAD_SUBS":"Télécharger les sous-titres","CTX_VIEW_ON_YOUTUBE":"Regarder sur YouTube","CTX_SHOW":"Regarder","CTX_PLAY":"Lire","CTX_PLAY_IN":"Lire dans","CTX_PLAY_ON":"Lire sur","CTX_WATCH_ON":"Regarder sur","CTX_WATCH":"Regarder","CTX_WATCHED":"Regardé","CTX_WATCH_BEGINNING":"Regarder depuis le début","CTX_WATCH_MOBILE":"Regarder sur un appareil mobile","CTX_REWIND":"Redémarrer","CTX_MARK_WATCHED":"Marquer comme vu","CTX_MARK_NON_WATCHED":"Marquer comme non-vu","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Recevoir les nouvelles notifications","CTX_REMOVE_CACHE":"Supprimer du cache","CTX_REMOVE_CACHE_EP":"Supprimer l\'épisode du cache","CTX_OPEN_CONTAINING":"Ouvrir le fichier cible","CTX_REMOVE":"Retirer de la bibliothèque","CTX_AVAILABLE_OFFLINE":"Disponible hors-ligne","CTX_PAUSED":"Mis en pause","CTX_ALWAYS_ON_TOP":"Toujours en haut","CTX_FULLSCREEN":"Plein écran","CTX_WRONG_SUBS":"Mauvais sous-titres ?","CTX_REPORT_ISSUES":"Rapporter un problème","CTX_COPY":"Copier","CTX_PASTE":"Coller","CTX_CLEAR":"Effacer","CTX_CLEAR_RECENT_SEARCHES":"Effacer les recherches récentes","HELLO_THERE":"Salut","HOPE_YOU_ENJOY":"Nous espérons que vous apprécierez Stremio et que c\'est déjà une de vos applications préférées !","WHO_ARE_WE":"Qui sommes-nous ? L\'équipe derrière ça, deux mecs travaillant très dur dans un seul but : rendre ce logiciel de mieux en mieux.","SUPPORT_US":"Si vous aimez Stremio - aidez-nous !","SPREAD_THE_WORD":"Parlez-en à vos amis, partagez l\'application","MORE_PEOPLE":"Plus de personnes utiliseront Stremio, mieux l\'application sera !","SEND_A_LINK":"ou envoyez un lien vers notre site !","TIP_LOCALFILES":"Astuce : vous pouvez glisser-déposer des fichiers vidéo locaux dans Stremio","ADDON_MY":"Mes Addons","ADDON_COMMUNITY":"Addons Communautaires","ADDON_OFFICIAL":"Addons Officiels","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Rechercher des addons","ADDON_INSTALL":"Installer","ADDON_CONFIGURE":"Configurer","ADDON_UNINSTALL":"Désinstaller","ADDON_UPGRADE":"Mettre à jour","ADDON_INSTALLED":"Installés","ADDON_INSTALLED_MSG":"Addon installé !","ADDON_UPGRADED_MSG":"Addon mis à jour !","ADDON_UNKNOWN":"Inconnu","ADDON_ERR":"Erreur d\'installation de l\'addon!","ADDON_DISCONNECTED":"Déconnecté","ADDON_APP_MISSING":"l\'application pour cette source n\'est pas installée. Voulez-vous l\'installer maintenant ?","ADDON_APP_INSTALL":"Installer maintenant","ADDON_PAGE":"Page des Addons","ADDON_TOP_CONTENT":"Le meilleur de cet Addon","ADDON_PROVIDES":"délivre","ADDON_WATCH":"Regardez des #{types} maintenant !","ADDON_WATCH_FREE":"Regardez des #{types} GRATUITEMENT maintenant !","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Types pris en charge","ADDON_SUPPORTED_CATALOGS":"Catalogues pris en charge","ADDON_PROVIDES_DISCOVER":"Plus de #{types} dans Découverte","ADDON_PROVIDES_STREAMS":"Regarder #{types}","ADDON_PROVIDES_STREAMS_FREE":"Regarder #{types} GRATUITEMENT","ADDON_PROVIDES_SUBTITLES":"Sous-titres pour #{types}","ADDON_CANTDETECT":"Nous n\'avons pas pu détecter une instance Stremio en cours d\'exécution, nous ne pouvions donc pas détecter quels addons vous avez installés.","ERR_NO_META":"Aucune information trouvée à ce sujet ","ERR_GETTING_META":"Erreur lors de la récupération d\'informations à ce sujet.","ERR_CANT_PARSE_MAGNET":"Impossible d\'analyser le magnet","ERR_NO_MAGNET_INFOHASH":"Pas de hachage d\'info valide pour le magnet","ERR_NO_FILE_PATH":"Impossible d\'envoyer une requête sans chemin d\'accès au fichier","ERR_NO_TORRENT":"Aucun torrent retourné","ERR_NO_SUPPORTERD_FILES":"Aucun fichier supporté trouvé","ERR_OPENING_FILES":"Impossible d\'ouvrir les fichiers externes","ERR_INVALID_LINK":"Lien invalide","ERR_REGISTERED_ONLY":"Cette option n\'est disponible que pour les utilisateurs enregistrés seulement.","ERR_CLIPBOARD":"Impossible de lire à partir du presse-papiers","ERR_CLIPBOARD_READ":"Impossible de lire le presse-papiers sur cette plateforme","ERR_CLIPBOARD_GENERIC":"Aucune URL lisible trouvée dans le presse-papiers. Veuillez copier une URL (par exemple un lien magnet) vers une vidéo.","BOARD_CONTINUE_WATCHING":"Continuer de regarder","BOARD_EXPLANATION_RECOMMENDATIONS":"Films sélectionnés spécialement pour vous.
Ce film est un exemple de recommandation.","BOARD_EXPLANATION_EPISODES":"Les nouveaux épisodes de vos Séries préférées arrivent ici.
Ajouter les séries que vous suivez à votre bibliothèque.","BOARD_EXPLANATION_VIDEOS":"Les nouveaux épisodes de vos Chaînes préférées arrivent ici.
Ajouter les chaînes YouTube que vous suivez dans votre bibliothèque.","WEBSITE_SLOGAN_WATCH":"Regarder instantanément","WEBSITE_SLOGAN_ALL":"Toutes les vidéos que vous aimez au même endroit","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Regarder depuis","WEBSITE_DOWNLOAD":"Télécharger maintenant","WEBSITE_DOWNLOAD_FOR":"Télécharger maintenant pour","WEBSITE_IS_DESKTOP":"Stremio est une application de bureau, ouvrez cette page sur votre PC et téléchargez la","WEBSITE_DESKTOP_DEMO_VID":"Démo","WEBSITE_PAGE_HOME":"Accueil","WEBSITE_PAGE_FEATURES":"Fonctionnalités","WEBSITE_PAGE_ADDONS":"Extensions","WEBSITE_PAGE_TECH":"Technologies","WEBSITE_PAGE_CREATE_ADDON":"Créer une extension","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Films","WEBSITE_TYPE_series_PL":"Séries","WEBSITE_TYPE_tv":"TV en live","WEBSITE_TYPE_channel":"Chaînes","WEBSITE_STREMIO_WHAT_IS":"Stremio set une application qui vous aide à organiser et à accéder instantanément à vos vidéos, films, séries TV et chaînes TV préférées","WEBSITE_FEATURES_WATCH":"Regarder immédiatement en HD","WEBSITE_FEATURES_WATCH_DETAIL":"Cliquer pour lancer vos vidéos, films, séries TV et chaînes TV préférées","WEBSITE_FEATURES_SUBS":"Sous-titres automatiques","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio choisit automatiquement les sous-titres pour votre langue.","WEBSITE_FEATURES_SUBS_LABEL":"À vous, chef","WEBSITE_FEATURES_CAST":"Lecture sur TV et appareils mobiles","WEBSITE_FEATURES_CAST_DETAIL":"Envoyer vers une AppleTV, Chromecast, Smart TV (DLNA/UPnP) ou un appareil mobile.","WEBSITE_LIB":"Profitez de votre bibliothèque personnelle, synchronisée sur tous vos appareils","WEBSITE_LIB_COLLECT":"Récupérer depuis Stremio","WEBSITE_LIB_IMPORT":"Importer depuis Facebook","WEBSITE_LIB_LOCAL":"Ajouter depuis votre disque","WEBSITE_BOARD":"Le tableau - Votre étape pour les Notifications et Recommandations","WEBSITE_BOARD_RECOMMEND":"Show TV recommandé","WEBSITE_BOARD_TRENDING":"Film tendance","WEBSITE_BOARD_NEW":"Nouvelle vidéo","WEBSITE_BOARD_EPISODE":"Nouvel Épisode","WEBSITE_BOARD_1":"Envie de regarder quelque chose d\'intéressant? Recevez des recommandations basées sur vos goûts!","WEBSITE_BOARD_2":"Soyez notifié dès qu\'un nouvel épisode de votre show TV ou chaîne youtube favorite sort!","WEBSITE_BOARD_YOUTUBE":"Nouvelles vidéos des chaînes YouTube","WEBSITE_BOARD_EPISODES":"Nouveaux épisodes des séries que vous suivez","WEBSITE_ADDONS":"Extensions de contenu","WEBSITE_TECH_DETAIL":"Nous aimons les nouvelles technologies et les expérimentations!\\nStremio utilise les technologies open source suivantes :","WEBSITE_TECH_WCJS":"WebChimera.js permet à Stremio de lire n\'importe quel format vidéo avec de bonnes performances.","WEBSITE_TECH_WCJS_EXTRA":"Nous sommes des contributeurs principaux du projet.","WEBSITE_TECH_ELECTRON":"Electron fournit une plateforme innovante sur laquelle bâtir Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Nous contribuons au projet.","WEBSITE_TECH_LINVODB":"Une technologie de base de données qui assure une bonne organisation et une mise à disposition partout.","WEBSITE_TECH_LINVODB_EXTRA":"Technologie maison","WEBSITE_CREATE_ADDON":"Créez votre extension","WEBSITE_CREATE_ADDON_DETAIL":"Vous avez un service qui fournit des vidéos? Nous vous aiderons à bénéficier des fonctionnalités de Stremio en faisant votre propre extension.","WEBSITE_CREATE_ADDON_BENEFITS":"Avantages de créer une extension pour Stremio","WEBSITE_P2P_BEAUTY":"La beauté du Streaming En peer to peer","WEBSITE_P2P_1":"Vidéos full HD /4K fiables et accessibles en VoD ou streaming","WEBSITE_P2P_2":"Plateforme de distribution avec une expérience utilisateur optimale","WEBSITE_P2P_3":"Nous vous crééerons une extension sur mesure","WEBSITE_P2P_CONTACT":"Interessé? Nous vous invitons à nous contacter.","WEBSITE_P2P_CONTACT_EXTRA":"Nous serions heureux de vous aider à intégrer votre contenu à Stremio!","WEBSITE_P2P":"De temps en temps, une nouvelle technologie vient changer la donne. Nous avons investi énormément de temps et d\'efforts pour construire un moteur de streaming peer to perr (P2P) fournissant une bonne performance et polyvalence, s\'adaptant à tous les cas de figure.\\nContactez nous pour mettre en place des vidéos en P2P ou streaming avec DRM.","WEBSITE_THOUGHTS":"Des pensées à partager:","WEBSITE_SPREAD":"Passer le mot à propos de Stremio:","WEBSITE_CONTACT":"Si vous voulez nous contatez, utilisez ","WEBSITE_OPENSOURCE":"Pour nos projets open source, rendez-vous sur notre","WEBSITE_BITCOIN":"Faites nous une donation de Bitcoin:","WEBSITE_FAQ":"Questions fréquemment posées","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Conditions d\'utilisation","WEBSITE_LEGAL":"Juridique","WEBSITE_PAGE_ABOUT":"À propos","WEBSITE_PAGE_BECOME_PARTNER":"Devenez partenaire","WEBSITE_ALL_YOU_CAN_WATCH":"La Liberté de Regarder\\nTout ce que Vous Voulez.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Qu\'est-ce que Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio est un hub unique pour l\'agrégation de contenu vidéo. Découvrez, organisez et regardez des vidéos provenant de toutes sortes de sources sur n\'importe quel appareil que vous possédez.","WEBSITE_WHAT_IS_STREMIO_P2":"Films, émissions de télévision, séries, chaînes de télévision en direct ou chaînes web comme YouTube et Twitch.tv - vous trouverez tout cela sur Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio est un centre de médias moderne qui constitue une solution unique pour vos divertissements vidéo. Vous découvrez, regardez et organisez le contenu vidéo à partir d\'addons faciles à installer.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Films, émissions de télévision, télévision en direct ou chaînes web - trouvez tout cela sur Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Profitez sur tous vos appareils","WEBSITE_DEVICES_COLLECT":"Collecter depuis Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importer depuis facebook","WEBSITE_DEVICES_LOCAL":"Ajouter depuis un disque local","WEBSITE_JOIN_THE_PARTY_NOW":"Rejoignez la fête dès maintenant","WEBSITE_DEVICES_ALL":"Facile à utiliser sur tous vos appareils;","WEBSITE_EXTENDABLE_CATALOG":"Catalogue vidéo extensible à l\'infini;","WEBSITE_ORGANIZE_YOUR_MEDIA":"De superbes fonctionnalités pour organiser vos médias;","WEBSITE_AS_SEEN_ON":"As été vu sur","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"A propos de nous","WEBSITE_LINK_TECHNOLOGY":"Technologie","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Téléchargement","WEBSITE_MORE":"Plus","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribuer","WEBSITE_LINK_COMMUNITY":"Communauté","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & Plus","WEBSITE_LINK_HELP":"Centre d\'aide","WEBSITE_LINK_CONTACTS":"Contactez-nous","WEBSITE_LINK_TOS":"Conditions d\'utilisation","WEBSITE_LINK_PRAVACY":"Politique de confidentialité","WEBSITE_SUBSCRIBE":"Souscrire","WEBSITE_NEWSLETTER":"Rejoignez notre newsletter pour des nouvelles incroyables","WEBSITE_PLACEHOLDER_EMAIL":"Votre Email","WEBSITE_COMMUNITY":"Communauté","WEBSITE_LINK_PRAVACY_LEGAL":"Confidentialité et mentions légales","WEBSITE_WHY":"Pourquoi nous le faisons","WEBSITE_WHY_P1":"Chez Stremio, nous venons travailler tous les jours parce que nous voulons résoudre un problème important pour l\'industrie de la vidéo à la demande. Il y a tellement de nouveaux contenus publiés chaque minute qu\'il est pratiquement impossible de s\'y retrouver.","WEBSITE_WHY_P2":"Nous aidons les gens à naviguer dans cet immense monde de divertissement vidéo et à découvrir de nouveaux contenus pour en profiter. Nos applications regroupent des films, des séries, des émissions de TV en direct, des chaînes Web et plus encore. Nous nous engageons à faire en sorte qu\'il soit incroyablement facile pour les utilisateurs de trouver les titres et les diffuseurs qu\'ils aiment.","WEBSITE_WHY_P3":"Vous pouvez utiliser notre service sur n\'importe quel appareil et à tout moment, faisant de Stremio le seul centre de divertissement vidéo dont vous aurez jamais besoin.","WEBSITE_TEAM":"L\'ÉQUIPE","WEBSITE_TEAM_P":"L\'équipe de Stremio est petite mais puissante : à nous dix, nous codons en X langages et partageons notre expertise en développement logiciel, conception d\'interface utilisateur et d\'interface utilisateur, marketing et publicité, ainsi qu\'en business et startups.","WEBSITE_FEATURES":"Fonctionnalités","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Découvrez facilement de nouveaux contenus","WEBSITE_FEATURES_DISCOVER_P":"Découvrez facilement les nouveaux films, émissions de télévision, séries et chaînes à regarder. Parcourez par catégorie, genre, classement, récence, etc. ou tapez simplement un nom pour trouver. Stremio fait de la recherche d\'un nouveau contenu vidéo un jeu d\'enfant.","WEBSITE_FEATURES_ALL_CONTENT":"Tout votre contenu vidéo sur un seul écran","WEBSITE_FEATURES_ALL_CONTENT_P1":"Voyez quels films, séries ou vidéos vous n\'avez pas terminés et continuez à les regarder ; soyez averti des nouveaux épisodes et sorties ; et parcourez les recommandations que vous recevrez en fonction de vos habitudes de visionnage.","WEBSITE_FEATURES_LIBRARY":"Organisez votre vidéothèque","WEBSITE_FEATURES_LIBRARY_P1":"Ajoutez n\'importe quel titre à votre bibliothèque Stremio d\'un simple clic et trouvez votre chemin à travers votre contenu, classé par type, récence ou ordre alphabétique.","WEBSITE_FEATURES_CALENDAR":"Gardez une trace de tout ce que vous regardez","WEBSITE_FEATURES_CALENDAR_P1":"Obtenez une visualisation du calendrier de tous les films et séries que vous ajoutez à votre bibliothèque. Exportez votre calendrier Stremio et synchronisez-le afin de toujours savoir quand un nouvel épisode ou une première est prévu.","WEBSITE_FEATURES_BIG_SCREEN":"Profitez de votre contenu vidéo sur un écran plus grand","WEBSITE_FEATURES_BIG_SCREEN_P1":"Lancez tout ce que vous regardez sur un autre appareil, qu\'il s\'agisse d\'un téléphone, d\'une tablette ou d\'un téléviseur d\'un simple clic.","WEBSITE_FEATURES_SOURCES":"Regarder des vidéos provenant de nombreuses sources différentes","WEBSITE_FEATURES_SOURCES_P":"Installez des modules complémentaires officiels et communautaires pour profiter de vidéos provenant de nombreux fournisseurs différents - le tout dans une seule application élégante et facile à utiliser.","WEBSITE_CREATE_AN_ADDON":"Créer un addon","WEBSITE_FEATURES_SYNC":"Synchronisez votre bibliothèque sur différents appareils et reprenez votre lecture","WEBSITE_FEATURES_SYNC_P1":"Connectez-vous avec votre compte sur tous vos appareils et profitez de la synchronisation de votre bibliothèque, de vos addons, de la lecture et de votre calendrier.","WEBSITE_FEATURES_EXTENDABLE":"Catalogue vidéo extensible via l\'ajout d\'addons","WEBSITE_FEATURES_EXTENDABLE_P1":"Le catalogue d\'addons de Stremio propose un certain nombre d\'addons à installer vous permetant de regarder une variété de contenus vidéo. Cela comprend des films, émissions, télévisions en direct, du sport, des actualités, podcasts, chaînes web, jeux vidéo et bien d\'autres encore.","WEBSITE_FEATURES_AUTO_SUBS":"Sous-titres automatiques","WEBSITE_FEATURES_AUTO_SUBS_P1":"Avec nos addons de sous-titres, vous obtenez automatiquement des options pour votre langue préférée.","WEBSITE_FEATURES_CHROMECAST":"Caster vers un Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Profitez de votre contenu vidéo sur un écran plus grand ou diffusez simplement ce que vous regardez sur un autre appareil.","WEBSITE_FEATURES_KEEP_TRACK":"Gardez une trace de vos émissions TV et de vos chaînes Web préférées","WEBSITE_FEATURES_KEEP_TRACK_P1":"Bénéficiez d\'un calendrier et de notifications pour les nouveaux épisodes de vos séries et chaînes web préférées.","WEBSITE_FEATURES_POWER_USER":"Fonctionnalités pour les utilisateurs avancés","WEBSITE_FEATURES_POWER_USER_P1":"Jouer dans un lecteur externe","WEBSITE_FEATURES_POWER_USER_P2":"Lecture à partir d\'un fichier torrent ou d\'un lien magnet","WEBSITE_FEATURES_POWER_USER_P3":"Importation dans votre bibliothèque à partir de favoris Facebook ou d\'un disque local","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"Tout le contenu vidéo fourni par Stremio provient d\'un système d\'addon - aucun contenu ou fournisseur de contenu n\'a été intégré dans l\'application.","WEBSITE_ADD_ONS_P2":"Il y a deux groupes d\'addons disponibles : les addons officiels et les addons communautaires.","WEBSITE_ADD_ONS_P3":"Les officiels sont développés et hébergés par Stremio, tandis que les addons communautaires sont créés par les membres de notre communauté, qui les hébergent également.","WEBSITE_ADDONS_OFFICIAL":"Addons officiels","WEBSITE_ADDONS_WATCHUB":"Diffusez vos films, séries et émissions préférés de fournisseurs tels que iTunes, Hulu, Amazon et d\'autres services du Royaume-Uni et des États-Unis.","WEBSITE_ADDONS_YOUTUBE":"Regardez vos chaînes YouTube préférées sans publicité et recevez des notifications pour les nouveaux uploads des contributeurs que vous suivez.","WEBSITE_ADDONS_FILMON":"Regardez la télévision en direct, les films et la télévision gratuitement. 600 chaînes de télévision, 45 000 films, film gratuits, documentaires et plus encore","WEBSITE_ADDONS_OPENSUBTITLES":"Sous-titres de films et de télévision en plusieurs langues, des milliers de sous-titres traduits sont mis en ligne chaque jour.","WEBSITE_ADDONS_COMMUNITY":"Addons de la communauté","WEBSITE_ADDONS_FILMON_VOD":"Regarder la vidéo à la demande de Filmon.tv","WEBSITE_ADDONS_TWICH":"Regardez les flux en direct de Twitch.tv - une plateforme de streaming vidéo pour l\'industrie du e-sport","WEBSITE_ADDONS_VODO":"Regardez des films indépendants totalement gratuitement.","WEBSITE_ADDONS_NETFLIX":"Regardez des films et des séries Web de Netflix.","WEBSITE_ADDONS_CREATE":"Créer un addon","WEBSITE_ADDONS_CREATE_P1":"Si vous le souhaitez, vous pouvez développer votre propre addon. De cette façon, vous pouvez vous donner, ainsi qu\'à notre communauté, accès à un nouveau contenu vidéo et atteindre un nouveau public ciblé de millions d\'utilisateurs dans le monde entier.","WEBSITE_ADDONS_START_CREATE":"Pour commencer, visitez la page Stremio Addon SDK:","WEBSITE_DOWNLOADS":"Téléchargements","WEBSITE_DOWNLOADS_P1":"Pour des performances optimales, nous vous recommandons d\'utiliser la dernière version disponible des applications Stremio. Si, pour une raison quelconque, vous souhaitez utiliser une version plus ancienne, vous pouvez la télécharger ici.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio pour Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio pour macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio pour Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio pour Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio pour iOS (version limitée)","WEBSITE_CONTRIBUTE":"Contribuer","WEBSITE_CONTRIBUTE_P1":"La plateforme Stremio est open source et vous pouvez facilement créer un addon pour du contenu qui n\'est actuellement pas sourcé.","WEBSITE_CONTRIBUTE_WHY":"Pourquoi créer un addon ?","WEBSITE_CONTRIBUTE_WHY_P1":"Atteignez un nouveau public pour votre contenu vidéo","WEBSITE_CONTRIBUTE_WHY_P2":"La base d\'utilisateurs de Stremio s\'accroît rapidement - au cours de la première année du lancement, Stremio avait gagné 1 million d\'utilisateurs à travers le monde, et au cours de la deuxième année d\'existence de la plate-forme, ce nombre est passé à 2,5 millions.","WEBSITE_CONTRIBUTE_WHY_P3":"Avec votre addon, vous pouvez facilement atteindre cet audience et lui distribuer votre contenu vidéo.","WEBSITE_CONTRIBUTE_ALL":"Regardez vos films, vidéos, séries et chaînes préférés en un seul endroit.","WEBSITE_CONTRIBUTE_ALL_P1":"Vous êtes fan d\'un type particulier de contenu qui n\'est pas encore disponible sur Stremio ? Créez un addon et regardez vos vidéos préférées dans l\'un des hubs de divertissement les plus grands et les plus faciles à utiliser sur le marché.","WEBSITE_CONTRIBUTE_ALL_P2":"En plus de cela, vous obtiendrez la gratitude infinie d\'autres membres de la communauté Stremio partageant les mêmes idées.","WEBSITE_CONTRIBUTE_MONETIZE":"Monétisez votre addon et gagnez de l\'argent grâce à lui","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Une fois que vous avez développé un nouvel addon pour Stremio, vous pouvez facilement le monétiser de différentes manières. Si vous envisagez de le faire, n\'hésitez pas à nous contacter à l\'adresse suivante ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - nous nous ferons un plaisir de vous consulter et de vous conseiller sur les options de monétisation des addons.","WEBSITE_CONTRIBUTE_TRANSLATE":"Devenez traducteur bénévole","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Si vous souhaitez profiter des applications Stremio dans différentes langues, vous pouvez rejoindre notre communauté de traducteurs bénévoles. Ils nous aident à ajouter des versions de Stremio dans de nombreuses langues différentes.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Vous avez hâte de commencer ?","WEBSITE_TRANSALTE_STREMIO":"Traduire Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Communautés officielles","WEBSITE_COMMUNITY_OFFICIALS_P1":"Devenez membre de la communauté Stremio en pleine croissance. Suivez-nous sur les réseaux sociaux et n\'hésitez pas à nous dire bonjour - nous adorons avoir des nouvelles de nos fans ! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Communautés non officielles","STREMIO_COMMUNITY_NL":"Stremio Pays-Bas","STREMIO_COMMUNITY_BRASIL":"Stremio Brésil","STREMIO_COMMUNITY_GERMANY":"Stremio Allemagne","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgique","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italie","STREMIO_COMMUNITY_UK":"Stremio Royaume-Uni","STREMIO_COMMUNITY_USA":"Stremio Etats-Unis","STREMIO_COMMUNITY_MEXICO":"Stremio Mexique","STREMIO_COMMUNITY_ADDONS":"Addons Stremio","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partenaires et supporters","WEBSITE_COMMUNITY_GOODIES":"Goodies Stremio","WEBSITE_COMMUNITY_WALLPAPERS":"Fonds d\'écran","WEBSITE_COMMUNITY_ART":"Galerie d\'Art de la Communauté","WEBSITE_LINK_ART":"Galerie d\'Art de la Communauté","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"Si vous avez des questions, commentaires ou suggestions, n\'hésitez pas à nous contacter via le formulaire de contact ci-dessous.","WEBSITE_CONTACT_US_P2":"Gardez à l\'esprit que nous sommes situés en Bulgarie, il peut donc y avoir un retard dans le traitement de votre demande en raison de différences de fuseau horaire.","WEBSITE_CONTACT_US_SUCCESS":"Votre message a bien été envoyé. Nous vous répondrons dans les plus brefs délais.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Veuillez entrer un email valide !","WEBSITE_CONTACT_US_Q_RELATED_TO":"Sur quoi porte votre question ?","WEBSITE_CONTACT_US_Q_OS":"Quel est votre système d\'exploitation ?","WEBSITE_CONTACT_US_PH_EMAIL":"Votre E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ENVOYER","WEBSITE_CONTACT_US_Q_1":"Comment installer ?","WEBSITE_CONTACT_US_Q_2":"Comment désinstaller ?","WEBSITE_CONTACT_US_Q_3":"(HTML) Comment faire des lasagnes ?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technologie","WEBSITE_TECHNOLOGY_P1":"Nous aimons la technologie et la science folle.
Voici ce qui fait fonctionner Stremio (tout est open-source).","WEBSITE_TECHNOLOGY_P_QT":"Le développement logiciel multiplateforme à son meilleur.","WEBSITE_TECHNOLOGY_P_MPV":"Un lecteur multimédia gratuit, open source et multiplateforme.","WEBSITE_TECHNOLOGY_P_RN":"React Native vous permet de créer des applications mobiles en utilisant uniquement JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework intégré à l\'application pour obtenir du multimédia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm est une plateforme mobile qui remplace SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribuer au projet","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Il y a deux façons de contribuer à Stremio et de nous aider à rendre le produit encore mieux.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Vous pouvez faire don de vos précieuses compétences linguistiques en traduisant la plateforme ...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"ou","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... vous pouvez utiliser vos compétences en développement pour créer des addons communautaires. ","WEBSITE_TRANSLATE_STREMIO":"Traduire Stremio","WEBSITE_404_OH_NO":"Oh, oh ! La page que vous cherchez n\'est pas ici ...","WEBSITE_GO_HOME":"Retourner à l\'accueil","WEBSITE_LINK_OTHER_DOWNLOADS":"Autres téléchargements","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Télécharger Stremio 4 beta maintenant","WEBSITE_GET_FOR_DESKTOP":"Télécharger pour le bureau","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"Mon compte","WEBSITE_MAINPAGE_FAQ_001_H1":"Qu\'est-ce que Stremio ?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio est un centre de médias moderne qui vous donne la liberté de regarder tout ce que vous voulez.","WEBSITE_MAINPAGE_FAQ_002_H1":"Comment cela fonctionne ?","WEBSITE_MAINPAGE_FAQ_002_P1":"Une fois que vous avez installé Stremio sur votre appareil et que vous avez créé un compte, il vous suffit de vous rendre dans le catalogue d\'addons et d\'installer tous les addons que vous voulez, et c\'est parti !","WEBSITE_MAINPAGE_FAQ_002_P2":"Ensuite, vous pouvez vous rendre dans les sections Découvrir ou Tableau pour commencer à explorer le contenu.","WEBSITE_MAINPAGE_FAQ_003_H1":"Que puis-je regarder ici ?","WEBSITE_MAINPAGE_FAQ_003_P1":"Beaucoup : Films, émissions de télévision, chaînes Internet, sport, chaînes de télévision, écouter de podcasts et bien d\'autres choses encore. Grâce à notre système d\'addons, vous pouvez accéder à une grande variété de contenus.","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio est-il open-source ?","WEBSITE_MAINPAGE_FAQ_004_P1":"Oui, vous pouvez consulter les liens suivants: ${1}application de bureau${2} et ${3}Organisation GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio est-il sans danger ?","WEBSITE_MAINPAGE_FAQ_005_P1":"Oui: comme il s\'agit d\'un logiciel open-source, le code est publiquement contrôlable et vous pouvez l\'examiner vous-même.","WEBSITE_MAINPAGE_FAQ_006_H1":"Qu\'en est-il de ma vie privée ?","WEBSITE_MAINPAGE_FAQ_006_P1":"Nous respectons la vie privée des utilisateurs et ne recueillons aucune donnée personnelle en dehors du minimum indispensable pour créer et synchroniser votre compte.","WEBSITE_MAINPAGE_FAQ_006_P2":"Il existe également un ${1}Mode invité${2} à l\'inscription, qui ne nécessite aucune donnée particulière : dans ce mode, aucune requète n\'est effectuée vers notre serveur. Toutefois, cela se fait au détriment de fonctions importantes, telles que la possibilité de synchroniser votre bibliothèque entre les appareils.","WEBSITE_MAINPAGE_FAQ_007_H1":"Puis-je caster sur ma TV ?","WEBSITE_MAINPAGE_FAQ_007_P1":"Oui, nous supportons Chromecast et vous pouvez caster à partir des applications bureau et mobiles (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Combien d\'addons possède Stremio ?","WEBSITE_MAINPAGE_FAQ_008_P1":"Fin 2019, plus de 50 - pour plus d\'informations, consultez notre catalogue d\'addons.","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio peut-il être étendu au-delà de ce qui se trouve dans le catalogue de l\'addon ?","WEBSITE_MAINPAGE_FAQ_009_P1":"Oui, vous devriez faire un tour ici: ${1}PimpMyStremio${2}, ${3}Communautés Reddit${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"Quels sont les appareils pris en charge par Stremio ?","WEBSITE_MAINPAGE_FAQ_010_P1":"Nous avons des applications de bureau pour Windows, Mac et Linux. Pour les mobiles, nous prenons en charge Android et iOS, tout en gardant à l\'esprit que la version iOS est limitée dans ses fonctionnalités (elle ne prend pas en charge la plupart des addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"Il existe de nombreux appareils basés sur Android sur lesquels vous pouvez faire tourner Stremio, comme NVIDIA Shield et Amazon Fire Stick, mais nous ne les supportons pas officiellement.","WEBSITE_MAINPAGE_FAQ_011_H1":"Pouvez-vous ajouter certains contenus à Stremio ?","WEBSITE_MAINPAGE_FAQ_011_P1":"Désolé, nous ne fournissons pas de contenu nous-mêmes, mais plus vous avez installé d\'addons Stremio, plus vous serez en mesure de trouver du contenu.","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio peut-il jouer les liens magnet ?","WEBSITE_MAINPAGE_FAQ_012_P1":"Oui, et il peut également lire des liens HTTP normaux et des fichiers torrents (glisser-déposer).","WEBSITE_MAINPAGE_FAQ_013_H1":"Puis-je télécharger une vidéo et la regarder hors ligne ?","WEBSITE_MAINPAGE_FAQ_013_P1":"La disponibilité hors ligne est une fonctionnalité à venir, mais si vous autorisez Stremio à se mettre en cache sur votre appareil (à partir du panneau de configuration), vous pouvez regarder les vidéos plus tard sans connexion.","WEBSITE_MAINPAGE_FAQ_014_H1":"Rien ne marche, aidez-moi !","WEBSITE_MAINPAGE_FAQ_014_P1":"Êtes-vous sûr d\'avoir installé des addons ? Si oui, vérifiez auprès de notre ${1}centre d\'aide${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Comment Stremio soutient-il ses opérations de développement ?","WEBSITE_MAINPAGE_FAQ_015_P1":"Nous diffusons des annonces non intrusives par le biais de ${1}AdEx${2}, qui est une entreprise de la même équipe fondatrice qui se concentre sur la préservation de la vie privée et la transparence des annonces.","WEBSITE_MAINPAGE_FAQ_015_P2":"Pour plus de questions, consultez notre ${1}centre d\'aide${2}.","HELP_LEARN_MORE":"Aidez-nous à mieux vous connaître.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Alimentation & Santé","BEAUTY_FASHION":"Beauté & Mode","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & Education","MUSIC":"Musique","TRAVEL":"Voyages","LATE_NIGHT":"Late Night","REALITY":"TV Realité","COMEDY":"Comédie","DIY":"DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continuer","SLOW_LOADING":"CHARGEMENT LENT ?","I_GIVE_UP":"J\'ABANDONNE","LEARN_MORE":"En savoir plus","POOR_SOURCE":"Cette source est difficilement accessible ou votre connexion Internet n\'est pas assez rapide.","PICK_CATEGORIES_ERR":"Vous devez choisir au moins 3 catégories","ADJUST_TIMING":"Ajuster le timing avec ","ADJUST_SIZE":"Ajuster la taille avec ","SEARCH_ANYTHING":"Vous pouvez tout rechercher ...","ALL_CATEGORIES":"Tous","SEARCH_CATEGORIES":"Films, Séries, YouTube & TV","SEARCH_PERSONS":"Acteurs, Réalisateurs et Scénaristes","SEARCH_PROTOCOLS":"HTTP & Liens Magnet","SEARCH_TYPES":"Liens IMDB / TVDB","WATCHED":"Regardé","SHOW_LESS":"Afficher Moins","LAST_SEARCHES":"Dernières recherches","CLEAR_HISTORY":"Effacer l\'historique","CHOOSE_SOME":"CHOISISSEZ-EN CERTAINS:","NO_WEB_REMOTE":"La télécommande Web n\'a pas pu être chargée","STREMIO_OFFLINE":"Stremio est hors-ligne","STREMIO_EXPENSIVE_CONNECTION":"Une connexion réseau coûte cher","USE_DATA":"Utiliser les données","WARNING":"Attention","MORE_INFO":"Plus d\'infos ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Chargement ...","STREMIO_TV_BACK_TO_LANGUAGES":"Retour aux langues","STREMIO_TV_REMOTE":"Télécommande","STREMIO_TV_GO_TO":"Aller à:","STREMIO_TV_OR_SCAN":"ou scanner :","STREMIO_TV_ADDON_INSTRUCTIONS":"Veuillez suivre les instructions afin d\'installer vos addons préférés.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Reprendre le Visionnage","STREMIO_TV_LOADING_BACKGROUND":"Chargement de l\'Arrière-plan","STREMIO_TV_CHECKING_AUTHENTICATION":"Vérification de l\'Authentification","STREMIO_TV_LOADING_BOARD":"Chargement du Tableau","STREMIO_TV_LOGIN_HEADER_LINE_1":"Nous voulons que nos utilisateurs bénéficient de la meilleure expérience personnalisée possible avec notre logiciel.","STREMIO_TV_LOGIN_HEADER_LINE_2":"C\'est pour cette raison que nous vous demandons de bien vouloir créer et/ou vous connecter à votre compte.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Merci de votre compréhension,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"L\'équipe Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Pour utiliser la télécommande Web avec votre Smartphone / Tablette / Bureau:","STREMIO_TV_WIFI_SETUP":"Configuration Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle n\'a pas détecté de connexion Internet.","STREMIO_TV_WIFI_DETAILS_1":"Connectez-vous à :","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Utilisez le mot de passe :","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Ouvrez un navigateur Web avec le lien :","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Utilisez Stremio sur votre téléphone ou votre PC pour installer ou configurer les addons et appuyez sur \\"Synchroniser les Addons\\".","STREMIO_TV_ADDONS_SUBTITLE":"Note: assurez-vous que vous utilisez le même compte Stremio.","STREMIO_TV_ADDONS_SYNC_ADDONS":"Synchroniser les Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Synchronisation des Addons réussie","STREMIO_TV_ADDONS_SYNC_FAILED":"Échec de la synchronisation des Addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Editer l\'URL du serveur","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Entrez l\'URL d\'un serveur de streaming","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Recherche","STREMIO_TV_NAV_HOME":"Accueil","STREMIO_TV_NAV_DISCOVER":"Découvrir","STREMIO_TV_NAV_LIBRARY":"Bibliothèque","STREMIO_TV_NAV_MOVIES":"Films","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Chaînes","STREMIO_TV_NAV_TV":"TV en Direct","STREMIO_TV_NAV_SETTINGS":"Réglages","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Lier un Compte","STREMIO_TV_LOGIN_EXPIRES_IN":"Expire dans","STREMIO_TV_LOGIN_STEP_ONE":"Scannez le code QR ci-dessus ou rendez-vous sur","STREMIO_TV_LOGIN_STEP_TWO":"Connectez-vous à votre compte Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Demander un nouveau lien","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Entrez quelque chose","STREMIO_TV_SEARCH_NO_ADDONS":"Aucun addon n\'a été demandé pour les catalogues !","STREMIO_TV_SEARCH_BUTTON":"Rechercher","STREMIO_TV_SEARCH_KEY_DEL":"Suppr","STREMIO_TV_SEARCH_KEY_SPACE":"Espace","STREMIO_TV_SEARCH_KEY_CLEAR":"Effacer","STREMIO_TV_SEARCH_HISTORY_TITLE":"Historique de recherche","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Vous pouvez rechercher des titres, des acteurs, des chaînes et plus encore...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Effacer l\'historique de recherche","STREMIO_TV_FILTERS_DESCRIPTION":"Choisissez l\'un des filtres ci-dessous","FILTERS":"Filtres","SETTINGS":"Réglages","ACCOUNT":"Compte","LOGOUT":"Déconnexion","THEMES":"Thèmes","PLAYBACK":"Lecture","PLAYBACK_SPEED":"Vitesse de Lecture","AUDIO_TRACKS":"Pistes Audio","VIDEOS":"Videos","SERVER":"Serveur","LINKS":"Liens","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Langue","SIZE":"Taille","DELAY":"Delai","BOLD":"Bold","TEXT_COLOR":"Couleur du Texte","OUTLINE_COLOR":"Couleur de la Bordure","BACKGROUND_COLOR":"Couleur de l\'Arrière-Plan","BACKGROUND_BLUR":"Flouter l\'Arrière-Plan","SEEK_TIME_DURATION":"Durée de la navigation de la lecture","AUTO_PLAY":"Lecture automatique du prochain épisode","PLAY_NOW":"Regarder","MARK_AS_WATCHED":"Marquer comme Regardé","MARK_AS_UNWATCHED":"Marquer comme Non Regardé","REWIND_TO_BEGINNING":"Rembobiner au Début","CONTINUE_WATCHING":"Continuer de Regarder","ALL":"Tous","SECONDS":"secondes","ON":"ON","OFF":"OFF","RELOAD":"Actualiser","EDIT_URL":"Editer l\'URL","NONE":"Aucun","EMBEDDED":"Embarqué","REMOTE_SWITCH_DEVICES":"Changer d\'Appareil","REMOTE_VIDEOS":"Vidéos","REMOTE_ADJUST_TIMING":"Ajuster le chronométrage","REMOTE_ADJUST_SIZE":"Ajuster la taille","REMOTE_COULD_NOT_BE_LOADED":"La télécommande Web n\'a pas pu être chargée","REMOTE_RETRY":"Réessayer","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Qu\'est-ce que le Stremio ?","FAQ_001_P1":"Stremio est un logiciel de centre multimédia conçu pour le divertissement vidéo avec une facilité d\'utilisation à l\'esprit. Stremio vous permet d\'organiser & regardez votre propre collection de films, séries, chaînes et TV en direct.","FAQ_001_P2":"Stremio collecte le contenu qu\'il vous montre à partir de votre disque local et de notre système d\'addons.","FAQ_001_P3":"Il vous avertira également de la sortie de nouveaux épisodes/vidéos/films qui vous intéressent et vous fournira des recommandations de films.","FAQ_02_H1":"Comment Stremio se compare-t-il à Kodi et Plex ?","FAQ_02_P1":"Nous nous inspirons de ces deux logiciels. Mais nous avons des objectifs différents - Stremio est spécifiquement destiné à la vidéo de divertissement et s\'efforce de devenir la solution grand public pour cela en étant très facile à utiliser.","FAQ_02_P2":"Stremio ne sera jamais aussi personnalisable et riche en fonctionnalités que Kodi et Plex, mais il est nettement plus facile à utiliser. Juste ${1} l\'obtenir et voir ${2} :)","FAQ_03_H1":"Comment Stremio se compare-t-il à Netflix ?","FAQ_03_P1":"Encore une fois, Netflix est l\'une de nos inspirations. Nous nous efforçons d\'obtenir l\'expérience utilisateur de Netflix, ainsi que de nombreux avantages supplémentaires. Mais plus important encore, nous vous donnons la liberté de gérer votre propre bibliothèque et d\'ajouter de nouvelles sources de contenu avec notre système d\'extensions.","FAQ_03_P2":"Cela rend Stremio extensible à l\'infini, donc lorsque vous utilisez Stremio, vous n\'êtes jamais limité au contenu que Netflix décide d\'octroyer via une licence. Par exemple, via Stremio, vous pouvez regarder le contenu de ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo$ {8} et même ${9}Netflix${10}","FAQ_04_H1":"Comment Stremio se compare-t-il à Flipboard ?","FAQ_04_P1":"Nous ne recevons pas souvent cette question, sauf lorsque nous parlons à des start-up :)","FAQ_04_P2":"Stremio est par conception un agrégateur de contenu, ce qui en fait essentiellement Flipboard pour la vidéo. Cela est très évident dans notre section Tableau, qui vous donne des catalogues et des notifications de nouveaux épisodes/nouvelles vidéos en lien avec se que vous suivez, tout comme Flipboard.","FAQ_05_H1":"Comment Stremio se compare-t-il à Popcorn Time ?","FAQ_05_P1":"Stremio et Popcorn Time sont similaires dans l\'interface utilisateur, car il n\'y a pas beaucoup de façons de faire des catalogues de divertissement vidéo correctement :)","FAQ_05_P2":"Mais alors que Popcorn Time se concentre sur la diffusion de torrents à partir de sources spécifiques, Stremio est illimité et est simplement un agrégateur de contenu - il n\'est pas verrouillé dans une source de contenu spécifique.","FAQ_05_P3":"De plus, nous ne fournissons aucun addon torrent par défaut, donc Stremio ne couvre pas le cas d\'utilisation de Popcorn Time avec des fonctionnalités officielles.","FAQ_05_P4":"Une autre différence notable est que Popcorn Time est entièrement open source, tandis que Stremio est ${1} partiellement open source${2}.","FAQ_06_H1":"Allez-vous ajouter ce film/série ?","FAQ_06_P1":"Non désolé :(","FAQ_06_P2":"Comme mentionné dans la plupart des autres questions, Stremio ne fournit aucun contenu par lui-même - tout est ajouté via le système d\'addons. Si vous avez une demande de contenu, vous pouvez utiliser le bouton “Signaler” dans le lecteur, qui enverra un e-mail à l\'auteur de l\'addon que vous utilisez actuellement.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Allez-vous créer un addon pour X ?","FAQ_08_P1":"C\'est tout à fait possible.","FAQ_08_P2":"Si vous avez une idée pour un addon, écrivez-nous à ${1}office@stremio.com${2}, mais assurez-vous que votre idée d\'addon n\'enfreindra aucun droit d\'auteur ou condition d\'utilisation.","FAQ_08_P3":"Pour le moment, les prochaines choses sur notre feuille de route sont des addons pour FandangoNOW, la vidéo à la demande Filmon.tv et Crunchyroll.","FAQ_09_H1":"Est-ce que Stremio utilise BitTorrent ?","FAQ_09_P1":"Oui, Stremio prend en charge BitTorrent comme protocole de streaming. Vous pouvez l\'utiliser soit avec un addon torrent, soit en glissant-déposant un fichier .torrent dans Stremio, soit en collant un lien magnet dans la barre de recherche.","FAQ_09_P2":"Veuillez noter que le seul addon officiel utilisant BitTorrent est ${1}Vodo${2}, qui fournit du contenu indépendant, tous autorisés à être distribués avec BitTorrent.","FAQ_09_P3":"Nous ne prenons pas en charge l\'utilisation d\'addons tierces susceptibles de permettre une violation du droit d\'auteur.","FAQ_10_H1":"Que puis-je regarder dans Stremio avec les addons officielles ?","FAQ_10_P1":"Par défaut, vous pouvez regarder du contenu Filmon.tv, YouTube et Vodo dans Stremio lui-même, avec son lecteur intégré. De plus, nous avons un addon pour Twitch.tv et quelques autres.","FAQ_10_P2":"Cette combinaison offre une sélection de :","FAQ_10_L1":"Chaînes de télévision populaires, fournies par Filmon.tv - par exemple E4, BBC, Bollyworld TV","FAQ_10_L2":"Tout sur YouTube - par exemple BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Films indépendants avec Vodo","FAQ_10_L4":"Diffusions de jeux en ligne avec Twitch.tv","FAQ_10_P3":"De plus, il existe de nombreuses sources de contenu fournies avec Guidebox et les addons Netflix, qui ne sont pas lues entièrement dans Stremio, mais redirigeraient vers le service donné. Par exemple, l\'addon Guidebox vous donnerait une sélection de films que vous pouvez diffuser gratuitement aux États-Unis, à partir de services tels que TubiTV et Crackle.","FAQ_11_H1":"Stremio ne s\'installe pas, que dois-je faire ?","FAQ_11_P1":"Si vous utilisez Windows, essayez ${1}cet programme d\'installation alternatif${2}.","FAQ_11_P2":"Si vous utilisez Mac OS X, sachez que nous ne prenons en charge aucune version antérieure à OS X Mavericks (10.9).","FAQ_11_P3":"Si vous êtes sous Linux, sachez que nous ne prenons en charge que Linux 64 bits (x64) pour le moment.","FAQ_11_P4":"Si vous ne parvenez toujours pas à résoudre votre problème, veuillez nous écrire sur notre ${1}groupe Facebook${2}.","FAQ_12_H1":"Pourquoi mon antivirus se plaint-il ? Est-ce que Stremio est sûr ?","FAQ_12_P1":"Nous vous assurons que Stremio est $ à {1}100% sûr${2}.","FAQ_12_P2":"Votre antivirus se plaint parce que nous incluons de la publicité dans notre programme d\'installation, que certains programmes antivirus reconnaissent comme un logiciel publicitaire.","FAQ_12_P3":"Si vous n\'êtes toujours pas sûr, vous pouvez essayer notre ${1}programme d\'installation alternatif${2}.","FAQ_13_H1":"Comment créer un addon ?","FAQ_13_P1":"Pour commencer, nous vous recommandons de consulter notre ${1}module système d\'addons${2} sur GitHub.","FAQ_13_P2":"Ensuite, vous pouvez suivre le ${1}tutoriel Hello World${2}.","FAQ_13_P3":"Si vous n\'avez aucune compétence en programmation, veuillez publier votre idée sur ${1}la communauté Reddit${2} et contactez-nous avec votre idée d\'extension sur ${3}office@stremio.com${4}.","FAQ_14_H1":"Comment les addons sont-ils publiés ?","FAQ_14_P1":"Lorsque vous créez un addon et un hôte, et que vous placez un champ endpoint dans votre répertoire, qui pointe vers une adresse d\'addon fonctionnelle, l\'addon se publiera automatiquement dans notre ${1}catalogue d\'addons${2} .","FAQ_14_P2":"Cela se produit parce que la partie serveur du module stremio-addons fait automatiquement un appel à notre API pour annoncer l\'addon. Lorsque notre API validera votre endpoint comme un addon valide, il commencera à apparaître dans le catalogue.","FAQ_15_H1":"Puis-je exécuter Stremio dans mon navigateur ?","FAQ_15_P1":"Pas pour le moment, mais ça s\'en vient !","FAQ_15_P2":"Si vous êtes curieux de voir une version Alpha, vous pouvez le voir ici : ${1}alpha4.strem.io${2}. Gardez à l\'esprit que le streaming est désactivé sur cette version alpha. Nous prenons en charge Chrome, Firefox, Opera et Edge.","FAQ_16_H1":"La diffusion sur la télévision ne fonctionne pas/les sous-titres ne fonctionnent pas","FAQ_16_P1":"La diffusion sur téléviseur utilise la technologie DLNA qui varie entre les différentes marques et modèles de téléviseurs. Pour cette raison, nous n\'avons pas la capacité de la tester dans tous les cas, il est donc loin d\'être parfait. Malgré cela, nous travaillons constamment à son amélioration, mais nous ne pouvons pas vous donner une estimation du moment où DLNA commencera à fonctionner correctement sur votre téléviseur.","FAQ_16_P2":"Si vous ne voyez même pas votre téléviseur dans le menu de diffusion, essayez de désactiver votre connexion réseau et de la réactiver (sous Windows, cliquez avec le bouton droit sur le réseau et utilisez Activer/Désactiver), ainsi que de redémarrer votre routeur, votre téléviseur et votre PC..","FAQ_16_P3":"Si vous rencontrez toujours des problèmes, vous pouvez nous aider en envoyant des informations sur la marque et le modèle de votre téléviseur à l\'adresse ${1}office@stremio.com${2}.","FAQ_16_P4":"En attendant, nous vous recommandons Chromecast, que nous supportons très bien, ou simplement brancher votre téléviseur à votre PC avec un câble HDMI.","FAQ_17_H1":"Stremio se fige et/ou plante, que puis-je faire ?","FAQ_17_P1":"Tout d\'abord, si vous utilisez Windows 7 avec l\'antivirus AVG : nous avons un problème avec cette combinaison. Le problème est dans AVG lui-même, et il n\'y a aucun moyen raisonnable de le résoudre de notre côté. Malheureusement, les exceptions ou la désactivation de l\'antivirus ne fonctionneront pas. La seule solution est de remplacer AVG par autre chose.","FAQ_17_P2":"Si ce n\'est pas le problème, mais que vous utilisez toujours Windows, veuillez mettre à jour le dernier service pack et mettre à jour/réinstaller vos pilotes GPU, puis réessayer.","FAQ_17_P3":"Si votre problème n\'est toujours pas résolu, ou si vous utilisez un Mac ou Linux, veuillez nous écrire pour nous signaler les détails exacts du problème sur ${1}notre groupe Facebook${2}.","FAQ_18_H1":"Comment créer un addon ?","FAQ_18_P1":"Pour commencer, nous vous recommandons de consulter notre ${1}système de addons${2} sur GitHub.","FAQ_18_P2":"Ensuite, vous pouvez suivre le ${1}tutoriel Hello World${2}.","FAQ_18_P3":"Si vous n\'avez aucune compétence en programmation, veuillez publier votre idée sur ${1}la communauté Reddit${2} et contactez-nous avec votre idée d\'extension sur ${3}office@stremio.com${4}.","FAQ_19_H1":"Pourquoi Stremio prend-il de l\'espace disque ?","FAQ_19_P1":"Stremio dispose d\'un cache local pour conserver temporairement les fichiers vidéo que vous diffusez.","FAQ_19_P2":"Cela présente deux avantages : premièrement, cela permet à Stremio de pré-charger en mémoire tampon la vidéo à l\'avance afin d\'assurer un streaming plus fluide. Deuxièmement, il conserve les vidéos dans le cache local afin que vous puissiez continuer à les regarder hors ligne.","FAQ_19_P3":"La quantité conservée par Stremio dépend du paramètre Cache dans le panneau Paramètres. Stremio peut conserver jusqu\'à la quantité définie (par exemple 2 Go) sur votre disque, à moins que la vidéo actuellement diffusée ne soit plus grande que cela, auquel cas il doit allouer suffisamment de stockage pour la conserver jusqu\'à ce que vous la regardiez.","FAQ_20_H1":"Où est le dossier contenant les caches ?","FAQ_20_P1":"Sous Windows, c\'est stremio-cache dans le lecteur que vous avez choisi dans les paramètres (ex. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"Sur Mac c\'est \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"Sur Linux, c\'est \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"J\'obtiens l\'erreur \\"Le serveur de streaming est introuvable\\", que puis-je faire ?","FAQ_21_P1":"Si vous obtenez cette erreur, cela signifie l\'une des rares choses suivantes :","FAQ_21_P2":"1) Vous essayez d\'utiliser un module complémentaire soutenu par la source YouTube/BitTorrent, via notre ${1}version Web${2}. Dans ce cas, vous devez installer notre version de bureau à partir de ${3}notre site Web${4}.","FAQ_21_P3":"2) Quelque chose ne va pas avec votre installation Stremio. Dans ce cas, essayez de réinstaller notre dernière version de bureau à partir du ${1}site Web${2}. Si cela ne résout pas le problème, essayez de désactiver les programmes antivirus et les pare-feu, redémarrez votre PC et réessayez. Si cela ne fonctionne pas non plus, écrivez-nous à notre ${3}notre groupe Facebook${4}.","FAQ_22_H1":"Je ne peux pas voir/utiliser la plupart des addons sur iOS","FAQ_22_P1":"En raison de restrictions dans les termes et conditions de l\'App Store d\'Apple, nous avons limité l\'application iOS uniquement à un ensemble particulier d\'addons.","FAQ_22_P2":"Mais rassurez-vous - il y aura plus d\'addons pour iOS à l\'avenir, et nous pouvons également ajouter une intégration qui vous permettra d\'utiliser tous les addons Stremio grâce à la connexion de l\'application iOS au serveur de streaming Stremio."}')},1525:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"סרט","TYPE_series":"סדרה","TYPE_tv":"ערוץ טלויזיה","TYPE_channel":"ערוץ","TYPE_other":"אחר","TYPE_movie_PL":"סרטים","TYPE_series_PL":"סדרות","TYPE_tv_PL":"ערוצי טלויזיה","TYPE_channel_PL":"ערוצים","TYPE_other_PL":"אחרים","TYPE_ALL":"All","VIDEO":"וידאו","BACK":"חזור","MORE":"עוד","DONE":"סיום","COPY":"העתקה","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"גלה","Board":"לוח","Library":"ספרייה","My Library":"הספרייה שלי","Calendar":"לוח שנה","NOTIFICATION_ONLINE":"הנך כרגע מחובר","NOTIFICATION_OFFLINE":"הנך כרגע מנותק","INTERNET_CONNECTION":"חיבור רשת","STORAGE_FULL_TITLE":"אזהרה: כונן האחסון מלא!","STORAGE_FULL_TEXT":"Stremio לא תוכל לשמור את ההגדרות שלך, אפשרויות או פרטי ההתחברות. נא לשקול הסרה והתקנה מחדש של Stremio.","SEARCH":"חיפוש","SEARCH_NO_RESULTS":"לא נמצאו תוצאות","SEARCH_EXPLANATION_CONTENT":"YouTube-חפש סרטים, סדרות ועורצי טלויזיה ו","SEARCH_EXPLANATION_PEOPLE":"חפש שחקנים, בימאים ותסריטאים","SEARCH_PASTE_LINKS":"הדבקת קישורים ישירים ומגנט","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"הוסף לספרייה","REMOVE_FROM_LIB":"הסר מהספרייה","ADDED_TO_LIB":"נוסף לספרייה","REMOVED_FROM_LIB":"הוסר מהספרייה","TRAILER":"קדימון","WATCH_TRAILER":"צפייה בקדימון","WATCH_NOW":"צפה כעת","SHOW":"הצג","SHOW_MOVIE":"הצגת סרט","WATCH_RANDOM":"צפייה אקראית","IMDB_RATING":"דירוג IMDb","YEAR":"שנה","DIRECTOR":"במאי","WRITER":"כותב","LEAD_ACTORS":"שחקנים ראשיים","CAST":"משתתפים","CREW":"צוות","SHOW_MORE_CAST":"הצג יותר","AIRED":"תאריך שידור","SEASONS":"עונות","GENRE":"סוגה","CATALOG":"קטלוג","SUMMARY":"תקציר","SHOW_MORE":"להציג יותר","SIMILAR":"דומה","UPCOMING":"בקרוב","ENDED":"הסתיים","DURATION":"אורך","FEATURED":"מומלצים","METADATA":"מידע","CATEGORY":"קטגוריה","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"חפש וידאו","SEARCH_PLACEHOLDER":"חיפוש או שימוש בקישור מגנט","ADDON":"תוסף","ADDONS":"תוספים","OFFICIAL":"רשמי","ADDONS_OFFICIAL":"תוספי סטרימיו רשמיים","ADDONS_POPULAR":"פופולרי באזור שלך","ADDON_FREE":"חינם","ADDON_PEERED":"משותף","ADDON_SUBSCRIPTION":"הרשמה","ADDON_STREAM_GEORESTRICTED":"לא זמין באזורך","ADDON_STREAM_OFFLINECACHE":"מטמון לא מקוון","ADDON_STREAM_LOCALFILE":"קובץ מקומי","SHARE_ADDON":"שתף את ההרחבות","AVAILABLE_STREAMS":"מקורות זמינים","NO_STREAM":"לא נמצאו מקורות","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"לעוד אפשרויות הזרמה, אנא התקינו תוספים נוספים","STREAM_NOT_SUPPORTED":"ההזרמה שנבחרה אינה נתמכת בפלטפורמה זו.","ADDON_CATALOGUE":"כל התוספים »","ADDON_CATALOGUE_MORE":"עוד תוספים »","REPO_ADDED":"מקור נוסף","ADDON_REPO_EXIST_ERR":"מקור תוספים זה כבר קיים","ADDON_REPO_ERR":"ארעה שגיאה בזמן הוספת מקור","ADDON_ADD_ERR":"ארעה שגיאה זמן הוספת תוסף","ERR_ADDON_PROTECTED":"תוסף מוגן","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"משהו השתבש - התחברות נכשלה","ERR_NOT_COLLECTION_URL":"לא קישור לאוסף","ERR_NOT_ADDON_URL":"לא כתובת תוסף","ERR_DETECTFROMURL":"אין אפשרות לזהות בקישור","ADDON_DUPLICATE_WARNING":"אזהרה: כפילות תוסף","ADDON_COLLECTION_SET_FAILED":"אוסף תוספים נכשל","SETTINGS_DATA_EXPORT":"ייצוא מידע","ADDON_PULL_FAILED":"משיכת התוסף נכשל","REFRESH_ON_CLICK":"נא ללחוץ כאן כדי לנסות שוב","STILL_IN_THEATER":"הסרט עדיין בקולנוע","WATCH_IN_CINEMA":"צפה בו בקולנוע","IN_THEATER":"בקולנוע","GET_TICKETS":"קבל כרטיסים","UPCOMING_EPISODE":"הפרק הבא","UPCOMING_EPISODE_MESSAGE":"פרק זה ישודר בתאריך","MISSING_DATE_EPISODE":"תאריך הפרק חסר","MISSING_DATE_EPISODE_MESSAGE":"פרק זה כנראה טרם שודר","CHANNEL_NOT_SCRAPED":"ערוץ זה עדיין לא מוכן.
אנא חזור בעוד כמה דקות.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"הוסף לסיפריה וקבל התרעה מתי שיהיה מוכן.","GET_NOTIFIED_WHEN_AVAILABLE":"אתה תקבל התרעה שהוא יהיה מוכן.","WARNING_STREAMING_SERVER":"אזהרה: שרת שידור מקומי לא נמצא. שידור מ-YouTube ומ-BitTorrent אינו אפשרי.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"אזהרה: וידאו זה אינו נתמך עם החומרה שיש ברשותך. שימו לב, ההפעלה עשויה להיות איטית.","PLAYER_ERROR":"אופס, שגיאת נגן","PLAYER_ERROR_LOOKSLIKE":"נראה כי","PLAYER_ORIENTATION":"כיוון הנגן","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"נעול","PLAYER_ORIENTATION_SENSOR_SHORT":"חיישן","PLAYER_ORIENTATION_LANDSCAPE":"כיוון הנגן נעול לתצוגה רחבה","PLAYER_ORIENTATION_SENSOR":"כיוון הנגן אוטומטי (חיישן)","PLAYER_PLAYBACK_SPEED":"מהירות ניגון","PLAYER_PLAYBACK_ERROR":"תקלה במהירות ניגון, נא לנסות שוב","PLAYER_PLAYBACK_ERROR_UNKNOWN":"שגיאה לא ידועה","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"חי","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"הסתרה","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"צפייה כעת","STREAMING_FROM":"מזרים מ","CASTING_TO":"משדר ל","NETWORK_STATUS":"מצב הרשת","STREAM_SPEED":"מהירות זרימה:","STREAM_BUFFERED":"נאגר:","PEERS_INFO":"פרטי חיבורים","PEERS_ACTIVE":"פעילים:","PEERS_CONNECTED":"מחוברים:","PEERS_WAITING":"ממתינים:","TRANSCODING_WARNING":"אזהרה: מקודד וידאו.","STREAM_LOADING":"טוען...","PLAYING_LOCAL":"מנגן מקובץ מקומי","PLAYING_CACHE":"מנגן ממטמון","WRONG_SUBS":"כתוביות שגויות?","ERR_SUBS_LOADING_TITLE":"שגיאה בטעינת כתוביות","ERR_SUBS_LOADING":"טעינת כתוביות נכשלה: זאת יכולה להיות בעיה של תוסף, או חיבור לאינטרנט","WARN_FOLLOWING_SUB_ADDONS_FAILED":"תוספי הכתוביות הבאים כשלו","ERR_CASTING_UPDATE_TITLE":"לא ניתן לעדכן מידע של מכשיר המשודר: שרת שידור ככל הנראה כבוי","CHOOSE_DEVICE":"בחר מכשיר לצפות בו","NO_CAST_DEVICES":"אין מכירים להזרמה.","NO_SETTINGS":"אין הגדרות זמינות.","PHONE_TABLET":"סלולארי / טאבלט","SUBTITLES":"כתוביות","SUBTITLES_CHANGE":"שנה כתוביות עבור","SUBTITLES_CHANGE_NONE":"לא קיימים כתוביות אחרות לשפה זו, מתנצלים.","SUBTITLES_CHANGE_ACIVE":"כרגע כתוביות #{{subtitlesDialog.activeIdx + 1}} מופעלות. לחץ \\"המשך\\" להפעלת הכתוביות #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"לחילופין,","SUBTITLES_ADJUST_DELAY":"שנה השהיית כתוביות:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"או להשתמש במקשים G / H בזמן ניגון לשינוי.","SUBTITLES_ADJUST_DELAY_TIP":"טיפ: באפשרותך להשתמש במקשים G / H בזמן ניגון לשינוי.","SUBTITLES_DELAY":"השהיית כתוביות:","SUBTITLES_LOADING":"טוען כתוביות...","SUBTITLES_UNAVAILABLE":"אין כתוביות חיצוניות זמינות","SUBTITLES_DISABLED":"מבוטל","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"עונה","EPISODE":"פרק","SPECIAL":"Special","SORT":"מיון","SORT_BY":"מיון לפי","FILTER":"סינון","SORT_TRENDING":"פופולרי","SORT_RECENT":"חדש","SORT_ALPHABET":"א-ת","SORT_RATING":"דירוג","SORT_WATCHED":"נצפה","SORT_YEAR":"שנה","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"חדש בשבילך","New Episodes":"פרקים חדשים","New Videos":"סרטים חדשים","Recommendations":"המלצות","LIBRARY_RESUME":"המשך","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"פרטים","LIBRARY_RESUME_DISMISS":"המשך","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"מומלץ","DISCOVER_TOP":"מומלץ","DISCOVER_OSCAR":"זוכי אוסקר","DISCOVER_WARNING_TITLE":"אבוי!","DISCOVER_EMPTY_CATALOG":"תוסף זה החזיר תוכן ריק.","DISCOVER_ADULT_WARNING":"תוכן זה מיועד למבוגרים. האם גילך הוא 18 ומעלה?","DISCOVER_NOADDON_WARNING":"אזהרה: אין תוסף סטרימיו פעיל עבור סוג זה. מציג פריטים שמורים, כלום לא ישמר כאן.","DISCOVER_LOAD_ERR":"גילוי: טעינת קטלוג נכשלה","DISCOVER_ADDON_UNINSTALLED":"תוכן זה אינו זמין יותר, ייתכן שהתוסף הוסר.","UNINSTALL_THIS_ADDON":"הסרת תוסף זה","ERR_ADDON_NOT_INSTALLED":"תוסף זה אינו מותקן. האם להתקין אותו כעת?","DETAIL_RECEIVE_NOTIF_SERIES":"קבלת התראות עבור פרקים חדשים","DETAIL_RECEIVE_NOTIF_VIDEOS":"קבלת התראות עבור סרטים חדשים","SIDEBAR_SHOW_STREAMS":"הצגת זרימות","RELAUNCH":"הפעל מחדש כעת!","UPGRADE":"עדכן לגרסה האחרונה של סטרימיו","RELOAD_UI":"טעינה מחדש של ממשק המשתמש","MANUAL_UPDATE_TITLE":"עדכון גרסת Stremio","MANUAL_UPDATE_LINE1":"גרסה זו של Stremio אינה עדכנית והשימוש בה אינו מומלץ.","MANUAL_UPDATE_LINE2":"נא לעדכן בהקדם האפשרי.","BUTTON_UPDATE_LATTER":"לא כעת","BUTTON_UPDATE_NOW":"עדכון","ANONYMOUS_USER":"משתמש אנונימי","DONT_HAVE_ACC":"אין לך חשבון?","HAVE_ACC":"כבר יש לך חשבון?","PASSWORD":"סיסמה","PASSWORD_CONFIRM":"אישור סיסמה","EMAIL":"דואר אלקטרוני","FB_LOGIN":"התחבר באמצעות פייסבוק","FB_NOTHINGSHARED":"שום דבר לא ישותף ללא רשותך","FB_NOPOST":"לא נשלח על שמך שום דבר","OR":"או","I_ACCEPT":"אני מסכים","I_ACCEPT_BY_CLICKING":"על ידי לחיצה למעלה, אני מאשר את","TOS":"תנאי המשימוש","MUST_ACCEPT_TERMS":"חובה לאשר תנאי שימוש","PASSWORDS_NOMATCH":"סיסמאות לא תואמות","SIGN_UP":"הרשמה","SIGN_UP_EMAIL":"הרשמה עם כתובת מייל","CLICK_TO_SIGN_UP":"לחץ כאן להרשמה.","LOG_IN":"התחברות","LOG_OUT":"התנתקות","EXIT_FULLSCREEN":"יציאה ממצב מסך מלא","ENTER_FULLSCREEN":"כניסה למצב מסך מלא","PLAY_URL_MAGNET_LINK":"ניגון קישור URL/Magnet","HELP_FEEDBACK":"עזרה ומשוב","TERMS_OF_SERVICE":"תנאי שימוש","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"אודות Stremio","USER_PANEL":"לוח בקרת משתמש","LOGIN_LABEL":"Login","GUEST_LOGIN":"התחברות כאורח","GUEST_LOGIN_NOTICE":"התחברות כאורח אינה מומלצת. התחברות רגילה מאפשרת לStremio לסנכרן את הספריות שלך, לקבל התראות על סדרות ווידאו האהובים עליך. האם אתה בטוח שתרצה להמשיך?","GUEST_LOGIN_NOTICE_2":"התחברות כאורח אינה מומלצת - לא יסונכרנו התראות בספריה או הלוח שלך, שאלו תכונות של Stremio. האם אתה בטוח שברצונך להמשיך?","CLICK_HERE":"לחץ כאן","WRONG_PASSWORD":"סיסמה שגויה, במקרה ששכחת את הסיסמה,","SET_A_PASS":"קבע סיסמה","RESET_PASSWORD":"איפוס סיסמה","FORGOT_PASSWORD":"שכחת סיסמה?","EMAIL_USED_WITH_FB":"כתובת דואר אלקטרוני זה שומש בחיבור בעזרת פייסבוק.","INVALID_EMAIL":"נא לכתוב כתובת מייל תקינה","INVALID_PASSWORD":"נא לכתוב סיסמה תקינה","CONN_ERR":"בעיית התחברות - אנא נסו מאוחר יותר.\\n\\nאם הבעיה ממשיכה, נטרלו את חומת האש/אנטי וירוס שלכם (במיוחד Bitdefender).","IMPORT_FROM_GUEST":"ייבוא ספריה מחשבון האורח שלך","RECEIVE_UPDATES_EMAIL":"-קבל עדכונים לדואר האלקטרוני מStremio","LOGIN_FAILED":"התחברות כשלה.","SIGNUP_FAILED":"הרשמה כשלה.","SEARCH_FAILED":"חיפוש כשל","EMAIL_USED":"כתובת מייל זו כבר בשימוש.","WAITING_FB_LOGIN":"מתחבר עם פייסבוק...","EXTERNAL_PLAYER_TITLE":"שימוש בנגן חיצוני","EXTERNAL_REMEMBER_PLAYER":"האם לזכור בחירה זו","EXTERNAL_ALWAYS_PLAY":"כן","EXTERNAL_ONLY_ONCE":"לא","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"ספרו לנו מה אתם אוהבים","INTRO_TASTE_LONG":"תספרו לנו במה תרצו לצפות","INTRO_TASTE_PICK":"בחירת {{interestsRemaining}} נושאים","INTRO_TASTE_PICK_MORE":"בחירת {{interestsRemaining}} נושאים נוספים","INTRO_TASTE_HELP_US":"עזרו לנו ללמוד עליכם עוד.","INTRO_TASTE_CHOOSE_THESE":"בחירה מהרשימה:","INTRO_TASTE_CHOOSE_MIN":"נא לבחור לפחות 3 קטגוריות","INTRO_TASTE_CHOOSE_MIN_ERR":"חובה לבחור לפחות 3 קטגוריות!","INTRO_TASTE_LIFESTYLE":"סגנון חיים","INTRO_TASTE_SPORTS":"ספורט","INTRO_TASTE_FOOD_HEALTH":"אוכל ובריאות","INTRO_TASTE_BEAUTY_FASHION":"יופי ואופנה","INTRO_TASTE_NEWS":"חדשות","INTRO_TASTE_GAMING":"משחקים","INTRO_TASTE_SCIENCE_EDU":"מדעים וחינוך","INTRO_TASTE_MUSIC":"מוסיקה","INTRO_TASTE_TRAVEL":"טיולים","INTRO_TASTE_LATE_NIGHT":"תוכנית אירוח","INTRO_TASTE_REALITY":"ריאליטי","INTRO_TASTE_COMEDY":"קומדיה","INTRO_TASTE_DIY":"עשה זאת בעצמך","INTRO_TASTE_TECH":"טכנולוגיה","INTRO_TASTE_CINEMA":"קולנוע","ADDON_NOT_SUPPORTED":"התוסף הנבחר אינו תומך בפלטפורמה זו.","ADDON_DISCLAIMER":"שימוש בתוספים צד שלישי תמיד יהיו תחת אחריותך ותחת החוק הקיים באזור מגוריך.","ADDON_ACTIVATE":"הפעלת תוסף זה?","ADDON_REPO_ADD":"כתובת מקור התוסף","ADDON_ADD":"הוספה","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"מה חדש","BUTTON_CONTINUE":"המשך","BUTTON_ACTIVATE":"הפעל","BUTTON_ACTIVATED":"מופעל","BUTTON_CANCEL":"ביטול","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"התעלם מהכל","BUTTON_VIEW_ALL":"הצגת הכל","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"הספרייה שלך נראית ריקה. גלו כמה זה שימושי :) ","HOW_START":"ככה תוכל להתחיל:","LIB_EMPTY_CAL":"לוח השנה מציג סדרות בספרייה שלך","HOW_START_CAL":"כך אתה יכול להוסיף סדרות:","LIB_EMPTY_BOARD":"הלוח מציג התראות והמלצות אשר קשורים לספרייה שלך.","HOW_START_BOARD_WAIT":"אנא הוסף סדרות וערוצים לספרייה שלך ותן לנו כמה דקות לארגן את הכל :)","HOW_START_BOARD":"ככה אתה יכול להוסיף סדרות וסרטים אליו:","IMPORT_FB":"יבא דברים שאתה אוהב מפייסבוק","IMPORT_TRAKT":"ייבוא ספריה מאתר Trakt","IMPORT_DISCOVER":"מצא דברים מעניינים דרך טאב הגלה","IMPORT_DISK":"יבא סרטים או סדרות אשר נמצאים בדיסק המקומי","PLEASE_CREATE_ACC":"אנא צור חשבון כדי לאפשר סנכרון ספרייה ולוח.","IMPORT_DISCOVER_SIGNUP":"הירשמו ותמצאו דברים מעניינים בגילוי","IMPORT_DISK_SIGNUP":"הירשמו וייבאו סרטים וסדרות שיש ברשותכם בכונן מקומי","LIB_EMPTY_CLOUD":"ספריה בענן","LIB_EMPTY_CLOUD_DESC":"ענן אישי לסנכרון סיפריה עם כל המכשירים","LIB_EMPTY_EARLY":"לפני כולם","LIB_EMPTY_EARLY_DESC":"קבלת התראות על פרקים חדשים","LIB_EMPTY_PERSONAL":"אישי","LIB_EMPTY_PERSONAL_DESC":"קבלת המלצות אישיות","LIB_EMPTY_CALENDAR_DESC":"קביעת לוח שנה לצפיה האישית שלכם","LIB_EMPTY_ALL":"הירשמו כדי לקבל את כל זה:","LIB_EMPTY_BEST":"הירשמו בכדי לקבל את הטוב ביותר מStremio","LIB_EMPTY_OTHER":"הרשמה בכדי להפעיל לוח שנה לצפיה ועוד דברים מגניבים","CALENDAR_ADDED":"הלוח שנה של Stremio התווסף ללוח שנה של שולחן העבודה.","CALENDAR_ADDED_MSG":"אם זה לא עובד, אנא השתמש בקישור כדי להוסיף את לוח השנה בצורה ידנית","TRAKT_EXPIRED":"קישוריות עם Trakt פגה, אנא עבור להגדרות והתחבר שוב","TRAKT_REQUIRES_LOGIN":"Trakt שגיאה","TRAKT_REQUIRES_LOGIN_MSG":"חובה להתחבר","SETTINGS_LABEL":"הגדרות","SETTINGS_NAV_GENERAL":"כללי","SETTINGS_NAV_PLAYER":"נגן","SETTINGS_NAV_STREAMING":"תזרימים","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"הפעל בעת הפעלת המחשב","SETTINGS_VLC_DEFAULT":"לנגן עם vlc","SETTINGS_UI_LANGUAGE":"שפת ממשק","SETTINGS_FULLSCREEN_EXIT":"יש ללחוץ על Escape כדי לצאת ממצב מסך מלא","SETTINGS_GAMEPAD":"הפעלת תמיכה בבקר משחק","SETTINGS_CLOSE_WINDOW":"סגירת היישום עם סגירת החלון","SETTINGS_SUBTITLES_LANGUAGE":"שפת כתוביות ברירת מחדל","SETTINGS_SUBTITLES_SIZE":"גודל כתוביות ברירת מחדל","SETTINGS_SUBTITLES_BACKGROUND":"צבע רקע עבור כתוביות","SETTINGS_SUBTITLES_COLOR":"צבע כתוביות","SETTINGS_SUBTITLES_COLOR_OUTLINE":"צבע מתאר עבור כתוביות","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"צבע רקע עבור כתוביות","SETTINGS_SEEK_KEY":"מקשי החצים כדי לנוע בזמן","SETTINGS_SEEK_KEY_SHIFT":"מקשי החצים כדי לנוע בזמן כאשר המקש Shift מוחזק","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"לנגן אוטומטית את הפרק הבא","SETTINGS_NEXT_VIDEO":"הצגת הודעה לתחילת הפרק הבא","SETTINGS_NEXT_VIDEO_TRIGGER":"משך הצגת ההודעה על הפרק הבא:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"שינוי גודל אוטומטי של החלון לפני תחילת ניגון","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"כתובת שרת הזרמה: ","SETTINGS_SERVER_AVAILABLE":"שרת הזרמה זמין.","SETTINGS_SERVER_UNAVAILABLE":"שרת הזרמה אינו זמין.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"כתובת הזרמה ב־HTTPS: ","SETTINGS_USE_BETA":"תמיד להשתמש ב Beta האחרונה","SETTINGS_IMPORT_FB":"ייבא מפייסבוק","SETTINGS_IMPORT_DISK":"ייבא מדיסק מקומי","SETTINGS_IMPORT_TRAKT":"ייבא מ-Trakt","SETTINGS_PAUSE_MINIMIZED":"השהיית ניגון כאשר החלון ממוזער","SETTINGS_HWDEC":"קידוד מואץ בחומרה","SETTINGS_BACKGROUND":"רקע נגן","SETTINGS_SUBSCRIBE_CALENDAR":"הרשמה ללוח שנה","SETTINGS_REQ_EXPORT":"בקשה לייצוא מידע","SETTINGS_ACC_DELETE":"בקשה להסרת חשבון","SETTINGS_CHANGE_PASSWORD":"שנה סיסמה","SETTINGS_TOS":"תנאי שימוש","SETTINGS_SUPPORT":"צור קשר עם התמיכה","SETTING_LANGUAGE":"שפה","SETTINGS_TRAKT":"Trakt שילוב","SETTINGS_TRAKT_LOGOUT":"התנתקות מ-Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"סריקת קוד QR לשימוש מרוחק","SETTINGS_DESKTOP_NOTIFICATIONS":"התראות שולחן עבודה","SETTINGS_DATA_SAVER":"חיסכון משאבים","SETTINGS_LANGUAGE_INTERFACE":"מראה","SETTINGS_LANGUAGE_SUBS":"כתוביות ברירת מחדל","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"בחירה אוטומטית בפס הקול","SETTINGS_DEFAULT_AUDIO_TRACK":"פס קול ברירת מחדל","SETTINGS_ACCOUNT":"חשבון","SETTINGS_VERSION":"גרסה","SETTINGS_MPV_WINDOW":"הפעלת נגן בחלון חיצוני (מתקדם)","SETTINGS_PLAY_IN_EXTERNAL":"תמיד התחלת ניגון בנגן חיצוני","SETTINGS_STORAGE_BUTTON":"ניקוי מטמון מקומי","SETTINGS_STORAGE_MODAL_TITLE":"האם אתה בטוח?","SETTINGS_STORAGE_MODAL_MESSAGE":"זה ינקה את המטמון המקומי וינתק אותך.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"אוטומטי","SETTINGS_HW_DISABLED":"מבוטל","SETTINGS_HW_ACCELERATED":"האצת קידוד","SETTINGS_HW_FULL":"האצה מלאה","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"יציאה","CONNECTED":"מחובר","AUTHENTICATE":"אימות","CACHING":"מטמון","SETTINGS_CACHING_DRIVE":"בחר כונן למטמון","ENABLE_LOCAL_FILES_ADDON":"הפעלת תוסף גישה לקבצים מקומיים (נדרשת הפעלה מחדש)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"הפעלת חיבורי HTTPS מרוחקים","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"מידע זמני","MAGNET_PARSING":"מנתח קישור מגנט","January":"ינואר","February":"פברואר","March":"מרץ","April":"אפריל","May":"מאי","June":"יוני","July":"יולי","August":"אוגוסט","September":"ספטמבר","October":"אוקטובר","November":"נובמבר","December":"דצמבר","Monday":"שני","Tuesday":"שלישי","Wednesday":"רביעי","Thursday":"חמישי","Friday":"שישי","Saturday":"שבת","Sunday":"ראשון","Action":"פעולה","Comedy":"קומדיה","War":"מלחמה","Family":"משפחה","Animation":"אנימציה","Adventure":"הרפתקה","Fantasy":"פנטזיה","Crime":"פשע","Mystery":"מיסתורי","Romance":"רומנטיקה","Drama":"דרמה","Horror":"אימה","Thriller":"מותחן","Sci-Fi":"מדע בדיוני","Music":"מוזיקה","Biography":"ביוגרפיה","Documentary":"תיעודי","Sport":"ספורט","Musical":"מוזיקלי","Western":"מערבונים","Film-Noir":"סרט-נואר","News":"חדשות","History":"היסטוריה","Game-Show":"שעשועונים","Reality-TV":"ריאלטי","Talk-Show":"טוק שואו","Film & Entertainment":"סרטים ובידור","Gaming":"גיימינג","From TV":"מהטלויזיה","Lifestyle":"לייף סטייל","Science & Education":"מדע וחינוך","Cooking & Health":"בישול ובריאות","Beauty & Fashion":"יופי ואופנה","Sports":"ספורט","News & Politics":"חדשות ופוליטיקה","How-to & DIY":"עשה זאת בעצמך","Tech":"טכנולוגיה","Automotive":"רכב","Causes & Non-Profits":"ללא מטרות רווח","Movies":"סרטים","Uk Live Tv":"טלויזיה לייב בריטית","Fashion":"אופנה","Business News Radio":"רדיו חדשות עסקים","Business Tv":"טלויזיה עסקית","Cars & Auto":"רכבים","Comedy Radio":"רדיו קומדיה","Lifestyle Radio":"רדיו לייף סטייל","News Tv":"טלויזית חדשות","Food And Wine":"אוכל ויין","Latino Tv":"טלויזיה לטינית","Shopping Tv":"טלויזיית קניות","Religion":"דת","Kids":"ילדים","Body & Soul":"גוף ונפש","Education":"חינוך","Indian Tv":"טלויזיה הודית","Extreme Sports":"ספורט אקסטרים","Middle Eastern Tv":"טלויזיה מזרח תיכונית","Celebrity Tv":"טלויזיית סלבריטי","Science Tv":"טלויזיית מדע","Bikini babe":"ביקיני","Outdoors":"באוויר הפתוח","German Tv":"טלויזיה גרמנית","French Tv":"טלויזיה צרפתית","Italian Tv":"טלויזיה איטלקית","Gamer Tv":"טלויזיית גיימרים","Travel":"טלויזיית טיולים","Asian Tv":"טלויזיה אסייתית","Entertainment":"בידור","News Radio":"רדיו חדשות","Music Radio":"רדיו מוזיקה","Language Learning":"לימוד שפות","Science Radio":"רדיו מדע","Tech Radio":"רדיו טכנולוגיה","Science & Technology Vod":"מדע וטכנולוגיה VOD","new video":"וידאו חדש","new episode":"פרק חדש","new movie":"סרט חדש","recommended":"מומלצים","we recommend":"אנו ממליצים","offer of the day":"הצעת היום","news":"חדשות","music video":"קליפ מוסיקה","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"התעלמות מהתראות","CTX_DISMISS_ALL":"התעלמות מהכל","CTX_SHARE":"שתף","CTX_COPY_SHARE_LINK":"העתקה ושיתוף קישור","CTX_COPY_MAGNET_LINK":"העתקת קישור magnet","CTX_COPY_STREAM_LINK":"העתקת קישור הזרמה stream","CTX_DOWNLOAD_VIDEO":"הורדת וידאו זה","CTX_DOWNLOAD_SUBS":"הורדת כתוביות","CTX_VIEW_ON_YOUTUBE":"צפיה בYouTube","CTX_SHOW":"הצג","CTX_PLAY":"הפעלה","CTX_PLAY_IN":"הפעלה בתוך","CTX_PLAY_ON":"הפעלה על","CTX_WATCH_ON":"צפה ב","CTX_WATCH":"צפה","CTX_WATCHED":"נצפה","CTX_WATCH_BEGINNING":"צפה מההתחלה","CTX_WATCH_MOBILE":"צפה במכשיר נייד","CTX_REWIND":"אחורה להתחלה","CTX_MARK_WATCHED":"סמן כנצפה","CTX_MARK_NON_WATCHED":"סמן כלא נצפה","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"סימון כל הבאים כנצפו","CTX_UNMARK_REST":"סימון כל הבאים שלא נצפו","CTX_RECEIVE_NEW_NOTIF":"קבל התראות חדשות","CTX_REMOVE_CACHE":"הסר ממטמון","CTX_REMOVE_CACHE_EP":"הסר פרק ממטמון","CTX_OPEN_CONTAINING":"פתח תיקייה מכילה","CTX_REMOVE":"הסר מהספריה","CTX_AVAILABLE_OFFLINE":"זמין במצב לא מקוון","CTX_PAUSED":"השהה","CTX_ALWAYS_ON_TOP":"תמיד למעלה","CTX_FULLSCREEN":"מסך מלא","CTX_WRONG_SUBS":"כתוביות שגויות?","CTX_REPORT_ISSUES":"דווח על בעיה","CTX_COPY":"העתק","CTX_PASTE":"הדבק","CTX_CLEAR":"נקה","CTX_CLEAR_RECENT_SEARCHES":"נקה חיפושים אחרונים","HELLO_THERE":"היי שם","HOPE_YOU_ENJOY":"אנו מקווים שאתם נהנים מהתוכנה Stremio ושהיא אחת המועדפות שלכם!","WHO_ARE_WE":"מי אנחנו? אנחנו צוות מאחורי זה - שני בחורים שעובדים קשה מאוד כבר 3 שנים, עם מטרה אחת - לשפר את המוצר עוד ועוד.","SUPPORT_US":"אם אתם נהנים מStremio, ו-Stremio בעל ערך עבורכם - תתמכו בנו!","SPREAD_THE_WORD":"תשתפו עם חברים שלכם, הפיצו את המילה על Stremio","MORE_PEOPLE":"אמרו לעוד אנשים להשתמש ב-Stremio, וכך נשתפר!","SEND_A_LINK":"או שליחת קישור אל האתר שלנו","TIP_LOCALFILES":"טיפ: אפשר לגרור ולשחרר מדיה מתיקיה אל תוך Stremio","ADDON_MY":"תוספים שלי","ADDON_COMMUNITY":"תוספים של הקהילה","ADDON_OFFICIAL":"תוספים רשמיים","ADDON_REPOS":"מקורות תוספים","ADDON_SEARCH":"חיפוש תוספים","ADDON_INSTALL":"התקן","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"הסר התקנה","ADDON_UPGRADE":"שדרוג","ADDON_INSTALLED":"מותקן","ADDON_INSTALLED_MSG":"התוסף מותקן!","ADDON_UPGRADED_MSG":"התוסף משודרג!","ADDON_UNKNOWN":"לא ידוע","ADDON_ERR":"שגיאה בהתקנת תוסף!","ADDON_DISCONNECTED":"מנותק","ADDON_APP_MISSING":"אפליקציה למקור זה אינה מותקנת. להתקין אותה?","ADDON_APP_INSTALL":"התקן כעת","ADDON_PAGE":"עמוד תוסף","ADDON_TOP_CONTENT":"תוכן הכי טוב מתוסף זה","ADDON_PROVIDES":"ספקים","ADDON_WATCH":"צפיה ב-#{types} כעט!","ADDON_WATCH_FREE":"צפה עכשיו ב-#{types} בחינם כעט!","ADDON_ADDON":"תוסף","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"עוד #{types} בגילוי","ADDON_PROVIDES_STREAMS":"צפיה ב-#{types}","ADDON_PROVIDES_STREAMS_FREE":"צפיה ב-#{types} בחינם","ADDON_PROVIDES_SUBTITLES":"כתוביות עבור #{types}","ADDON_CANTDETECT":"Stremio לא נמצא עובד, אז לא הצלחנו למצוא את התוספים המותקים.","ERR_NO_META":"לא נמצא מידע על זה ","ERR_GETTING_META":"שגיאה בהבאת מידע עבור זה.","ERR_CANT_PARSE_MAGNET":"לא ניתן לנתח קישור מגנט","ERR_NO_MAGNET_INFOHASH":"אין מידע hash עבור מגנט","ERR_NO_FILE_PATH":"אין אפשרות לשלוח את הבקשה ללא קישור אל הקובץ","ERR_NO_TORRENT":"אין טורנט חוזר","ERR_NO_SUPPORTERD_FILES":"קבצים לא נתמכים נמצאו","ERR_OPENING_FILES":"אין אפשרות לפתוח קבצים חיצוניים","ERR_INVALID_LINK":"קישור לא תקין","ERR_REGISTERED_ONLY":"אפשרות זו פעילה רק לרשומים בלבד.","ERR_CLIPBOARD":"לא ניתן לנגן מלוח הגזירים","ERR_CLIPBOARD_READ":"לא ניתן לקרוא את לוח הגזירים בפלטפורמה זו","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"המשך לצפות","BOARD_EXPLANATION_RECOMMENDATIONS":"סרטים נבחרים במיוחד בשבילך.
הסרט הזה הוא דוגמא להמלצה.","BOARD_EXPLANATION_EPISODES":"פרקים חדשים של הסדרות האהובות עליך יופיעו כאן.
הוסף סדרות שאתה עוקב אחריהן לספריה שלך.","BOARD_EXPLANATION_VIDEOS":"פרקים חדשים של הערוצים האהובים עליך יופיעו כאן.
הוסף ערוצי YouTube שאתה עוקב אחריהן לספריה שלך.","WEBSITE_SLOGAN_WATCH":"צפיה מיידית","WEBSITE_SLOGAN_ALL":"כל תוכן הוידאו במקום אחד להנאה מלאה","WEBSITE_SLOGAN_NEW":"כל מה שאתה יכול לצפות","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"צפה מ","WEBSITE_DOWNLOAD":"הורד עכשיו","WEBSITE_DOWNLOAD_FOR":"כעט מוריד עבור","WEBSITE_IS_DESKTOP":"Stremio היא תוכנת שולחן עבודה, פתח עמוד זה להורדה אל המחשב האישי","WEBSITE_DESKTOP_DEMO_VID":"הדגמת שולחן עבודה","WEBSITE_PAGE_HOME":"בית","WEBSITE_PAGE_FEATURES":"תכונות","WEBSITE_PAGE_ADDONS":"הרחבות","WEBSITE_PAGE_TECH":"טכנולוגיה","WEBSITE_PAGE_CREATE_ADDON":"צור הרחבה","WEBSITE_PAGE_CONTACTS":"צור קשר","WEBSITE_PAGE_BLOG":"בלוג","WEBSITE_TYPE_movie":"סרטים","WEBSITE_TYPE_series_PL":"סדרות","WEBSITE_TYPE_tv":"שידורים חיים","WEBSITE_TYPE_channel":"ערוצים","WEBSITE_STREMIO_WHAT_IS":"Stremio היא אפליקציה שעוזרת לך לארגן ולצפות מייד בסרטונים, סרטים, סדרות טלוויזיה וערוצי טלוויזיה האהובים עליך.","WEBSITE_FEATURES_WATCH":"צפיה מיידית באיכות HD","WEBSITE_FEATURES_WATCH_DETAIL":"לחץ ונגן את הסרטונים, סרטים, סדרות טלוויזיה וערוצי טלוויזיה האהובים עליך.","WEBSITE_FEATURES_SUBS":"כתוביות אוטומטיות","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio בוחרת לבד את הכתוביות על בסיס שפה שנבחרה.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"נגינה בטלויזיה & מכשירים ניידים","WEBSITE_FEATURES_CAST_DETAIL":"שידור בAppleTV, Chromecast, טלויזיה חכמה (DLNA/UPnP) ומכשירים ניידים.","WEBSITE_LIB":"תהנה מהספריה הפרטית שלך מסונכרת לכל מכשירך.","WEBSITE_LIB_COLLECT":"איסוף מStremio","WEBSITE_LIB_IMPORT":"ייבוא מFacebook","WEBSITE_LIB_LOCAL":"הוספה מכונן מקומי","WEBSITE_BOARD":"הלוח - נקודת העצירה להודעות וההמלצות שלך","WEBSITE_BOARD_RECOMMEND":"סדרות מומלצות","WEBSITE_BOARD_TRENDING":"סרט חם","WEBSITE_BOARD_NEW":"וידאו חדש","WEBSITE_BOARD_EPISODE":"פרק חדש","WEBSITE_BOARD_1":"מחפש משהו מעניין לצפות? קבל המלצות על בסיס טמעך האישי!","WEBSITE_BOARD_2":"קבל הודעה כאשר פרק חדש של הסדרה או ערוץ YouTube יוצא!","WEBSITE_BOARD_YOUTUBE":"סרטונים חדשים של ערוצי YouTube","WEBSITE_BOARD_EPISODES":"פרקים חדשים של הסדרות שהינך עוקב אחריהן","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"עלינו","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"עוד","WEBSITE_LINK_ADDONS":"תוספים","WEBSITE_LINK_ADDON_SDK":"SDK תוספים","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"קהילה","WEBSITE_LINK_BLOG":"בלוג","WEBSITE_MORE_MORE":"... & ועוד","WEBSITE_LINK_HELP":"מרכז עזרה","WEBSITE_LINK_CONTACTS":"יצירת קשר","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"יצירת תוסף","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"תוספים","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"תוספים רשמיים","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"תוספי קהילה","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"יצירת תוסף","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"הורדות","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio עבור Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio עבור macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio עבור Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio עבור Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio עבור iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"תרגום Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"קהילות רשמיות","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"כתובת דואר האלקטרוני שלך","WEBSITE_CONTACT_US_PH_MESSAGE":"הודעה","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"שליחה","WEBSITE_CONTACT_US_Q_1":"איך להתקין?","WEBSITE_CONTACT_US_Q_2":"איך להסיר?","WEBSITE_CONTACT_US_Q_3":"(HTML) איך לעשות lasagna?","WEBSITE_CONTACT_US_Q_4":"תוספים","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"תרגום Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"מעבר לבית","WEBSITE_LINK_OTHER_DOWNLOADS":"הורדות אחרות","WEBSITE_FAQ_ABR":"שאלות ותשובות","WEBSITE_SUPPORT":"תמיכה","WEBSITE_DOWNLOAD_4_0_BETA":"הורדת Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"הורדה לשולחן העבודה","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"חשבון שלי","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"עזרו לנו ללמוד עליכם יותר.","LIFESTYLE":"סגנון חיים","SPORTS":"ספורט","FOOD_HEALTH":"אוכל ובריאות","BEAUTY_FASHION":"יופי ואופנה","NEWS":"חדשות","GAMING":"גיימינג","SCIENCE_EDUCATION":"מדע וחינוך","MUSIC":"מוזיקה","TRAVEL":"טיולים","LATE_NIGHT":"תוכניות אירוח","REALITY":"ריאלטי","COMEDY":"קומדיה","DIY":"עשה זאת בעצמך","TECH":"טכנולוגיה","CINEMA":"קולנוע","CONTINUE":"המשך","SLOW_LOADING":"טעינה איטית?","I_GIVE_UP":"לוותר","LEARN_MORE":"מידע נוסף","POOR_SOURCE":"מקור זה בקושי זמין או שחיבור האינטרנט שלך איטי מאוד","PICK_CATEGORIES_ERR":"נא לבחור 3 קטגוריות מינימום","ADJUST_TIMING":"שינוי תזמון בעזרת ","ADJUST_SIZE":"שינוי גודל בעזרת","SEARCH_ANYTHING":"אפשר לחפש הכל...","ALL_CATEGORIES":"הכל","SEARCH_CATEGORIES":"סרטים, סדרות, יוטיוב & טלויזיה","SEARCH_PERSONS":"שחקנים, מפיקים & כותבים","SEARCH_PROTOCOLS":"קישורים ישירים או מגנט","SEARCH_TYPES":"IMDB / TVDB קישורים","WATCHED":"נצפה","SHOW_LESS":"הצג פחות","LAST_SEARCHES":"חיפושים אחרונים","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"בחירה של משהו מכאן:","NO_WEB_REMOTE":"שימוש מרוחק לא ניתן לטעינה","STREMIO_OFFLINE":"Stremio מנותק","STREMIO_EXPENSIVE_CONNECTION":"חיבור לאינטרנט הוא יקר","USE_DATA":"השתמש בנתונים ניידים","WARNING":"אזהרה","MORE_INFO":"מידע נוסף ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"טוען ...","STREMIO_TV_BACK_TO_LANGUAGES":"חזרה לשפות","STREMIO_TV_REMOTE":"שלט","STREMIO_TV_GO_TO":"מעבר אל:","STREMIO_TV_OR_SCAN":"או סריקה:","STREMIO_TV_ADDON_INSTRUCTIONS":"נא לעקוב אחר ההוראות בכדי להתקין את התוספים המועדפים עליכם.","STREMIO_TV_LIVE_TV":"טלויזיה חיה","STREMIO_TV_RESUME_WATCHING":"המשך צפיה","STREMIO_TV_LOADING_BACKGROUND":"טוען ברקע","STREMIO_TV_CHECKING_AUTHENTICATION":"בודק פרטי התחברות","STREMIO_TV_LOADING_BOARD":"טוען לוח","STREMIO_TV_LOGIN_HEADER_LINE_1":"אנו רוצים שהמשתמשים שלנו יזכו לחוויה המותאמת אישית הטובה ביותר עם התוכנה שלנו.","STREMIO_TV_LOGIN_HEADER_LINE_2":"מסיבה זו אנו מבקשים מכם לבקש ו / או להתחבר לחשבונכם.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"תודה על ההבנה,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"צוות Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"על מנת להשתמש מרחוק באמצעות טלפון חכם / טאבלט / מחשב:","STREMIO_TV_WIFI_SETUP":"התקנת Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle לא הצליח לזהות חיבור אינטרנט.","STREMIO_TV_WIFI_DETAILS_1":"חיבור אל:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"שימוש בסיסמה:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"פתיחת דפדפן עם קישור:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"שינוי מכשירים","REMOTE_VIDEOS":"וידאו","REMOTE_ADJUST_TIMING":"שינוי תזמון","REMOTE_ADJUST_SIZE":"שינוי גודל","REMOTE_COULD_NOT_BE_LOADED":"שליטה מרחוק לא אפשרית","REMOTE_RETRY":"לנסות שוב","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"?Stremio מה זה","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},4018:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"फ़िल्म","TYPE_series":"धारावाहिक","TYPE_tv":"टीवी चैनल","TYPE_channel":"चैनल","TYPE_other":"अन्य","TYPE_movie_PL":"फ़िल्म","TYPE_series_PL":"धारावाहिक","TYPE_tv_PL":"टी वी चैनल","TYPE_channel_PL":"चैनल","TYPE_other_PL":"अन्य","TYPE_ALL":"All","VIDEO":"वीडियो","BACK":"पीछे","MORE":"अधिक","DONE":"किया हुआ","COPY":"प्रतिलिपि","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"डिस्कवर","Board":"तख़्ता","Library":"पुस्तकालय","My Library":"मेरा पुस्तकालय","Calendar":"पंचांग","NOTIFICATION_ONLINE":"अब आप ऑनलाइन हैं","NOTIFICATION_OFFLINE":"आप वर्तमान में ऑफ़लाइन हैं","INTERNET_CONNECTION":"नेटवर्क कनेक्शन","STORAGE_FULL_TITLE":"चेतावनी: भंडारण पूर्ण!","STORAGE_FULL_TEXT":"Stremio आपकी सेटिंग्स वरीयताओं या लॉगिन जानकारी को सहेजने में सक्षम नहीं होगा। फिर से शुरू करने या फिर से स्थापित करने पर विचार करें।","SEARCH":"तलाशी","SEARCH_NO_RESULTS":"कोई परिणाम नहीं मिले थे","SEARCH_EXPLANATION_CONTENT":"फिल्में श्रृंखला यूट्यूब और टीवी चैनल खोजें","SEARCH_EXPLANATION_PEOPLE":"अभिनेता निदेशकों और लेखकों के लिए खोजें","SEARCH_PASTE_LINKS":"HTTP और चुंबक लिंक पेस्ट करें","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"पुस्तकालय में जोड़ें","REMOVE_FROM_LIB":"पुस्तकालय से निकालें","ADDED_TO_LIB":"पुस्तकालय में जोड़ा गया","REMOVED_FROM_LIB":"पुस्तकालय से हटा दिया गया","TRAILER":"ट्रेलर","WATCH_TRAILER":"ट्रेलर देखें","WATCH_NOW":"अब देखिए","SHOW":"प्रदर्शन","SHOW_MOVIE":"फिल्म दिखाओ","WATCH_RANDOM":"यादृच्छिक","IMDB_RATING":"आईएमडीबी रेटिंग","YEAR":"वर्ष","DIRECTOR":"निर्देशक","WRITER":"लेखक","LEAD_ACTORS":"मुख्य अभिनेता","CAST":"ढालना","CREW":"कर्मी दल","SHOW_MORE_CAST":"और दिखाओ","AIRED":"प्रसारित","SEASONS":"मौसम के","GENRE":"शैली","CATALOG":"सूची","SUMMARY":"सारांश","SHOW_MORE":"और दिखाओ","SIMILAR":"एक जैसा","UPCOMING":"आगामी","ENDED":"समाप्त","DURATION":"अवधि","FEATURED":"विशेष रुप से प्रदर्शित","METADATA":"मेटाडाटा","CATEGORY":"वर्ग","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"वीडियो खोजें","SEARCH_PLACEHOLDER":"यूआरएल खोजें या पेस्ट करें","ADDON":"ऐड ऑन","ADDONS":"ऐड-ऑन","OFFICIAL":"अधिकारी","ADDONS_OFFICIAL":"आधिकारिक स्ट्रीमियो एडॉन्स","ADDONS_POPULAR":"आपके क्षेत्र में लोकप्रिय","ADDON_FREE":"नि: शुल्क","ADDON_PEERED":"झाँका","ADDON_SUBSCRIPTION":"अंशदान","ADDON_STREAM_GEORESTRICTED":"आपके क्षेत्र में उपलब्ध नहीं है","ADDON_STREAM_OFFLINECACHE":"ऑफ़लाइन कैश","ADDON_STREAM_LOCALFILE":"स्थानीय संचिका","SHARE_ADDON":"शेयर एडन","AVAILABLE_STREAMS":"उपलब्ध धाराएं","NO_STREAM":"कोई धारा नहीं मिली","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"अधिक धाराओं के लिए कृपया अधिक addons स्थापित करें","STREAM_NOT_SUPPORTED":"चयनित स्ट्रीम इस मंच पर समर्थित नहीं है।","ADDON_CATALOGUE":"सभी एडॉन्स दिखाएं »","ADDON_CATALOGUE_MORE":"Addons स्थापित करें","REPO_ADDED":"रिपोजिटरी ने कहा","ADDON_REPO_EXIST_ERR":"यह एडॉन्स संग्रह पहले से मौजूद है","ADDON_REPO_ERR":"संग्रह जोड़ने के दौरान त्रुटि हुई","ADDON_ADD_ERR":"Addon जोड़ने के दौरान त्रुटि हुई","ERR_ADDON_PROTECTED":"Addon को अनइंस्टॉल नहीं कर सकता यह संरक्षित है","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"कुछ गलत हो गया - प्रमाणीकरण विफल हो सकता है","ERR_NOT_COLLECTION_URL":"एक संग्रह यूआरएल नहीं","ERR_NOT_ADDON_URL":"एक वैध एडन यूआरएल नहीं","ERR_DETECTFROMURL":"इस यूआरएल से एडन / संग्रह नहीं मिल रहा है","ADDON_DUPLICATE_WARNING":"चेतावनी: डुप्लिकेट एडन","ADDON_COLLECTION_SET_FAILED":"अपने खाते में स्थापित एडॉन्स को सिंक करना विफल रहा","SETTINGS_DATA_EXPORT":"निर्यात उपयोगकर्ता डेटा","ADDON_PULL_FAILED":"अपने खाते से स्थापित एडॉन्स को सिंक करना विफल रहा","REFRESH_ON_CLICK":"पुनः प्रयास करने के लिए क्लिक करें","STILL_IN_THEATER":"फिल्म अभी भी सिनेमाघरों में","WATCH_IN_CINEMA":"इसे अपने स्थानीय सिनेमा में देखें","IN_THEATER":"सिनेमा में","GET_TICKETS":"टिकिट पाएं","UPCOMING_EPISODE":"आगामी एपिसोड","UPCOMING_EPISODE_MESSAGE":"इस प्रकरण पर प्रसारित किया जाएगा","MISSING_DATE_EPISODE":"गायब एपिसोड तिथि","MISSING_DATE_EPISODE_MESSAGE":"यह एपिसोड अभी तक प्रसारित नहीं हो सकता है","CHANNEL_NOT_SCRAPED":"यह चैनल अभी तक स्क्रैप नहीं है।
कृपया कुछ मिनटों में वापस आएं।","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"इसे उपलब्ध होने के बाद अधिसूचित होने के लिए इसे अपनी लाइब्रेरी में जोड़ें।","GET_NOTIFIED_WHEN_AVAILABLE":"एक बार उपलब्ध होने के बाद आपको सूचित किया जाएगा।","WARNING_STREAMING_SERVER":"चेतावनी: स्थानीय स्ट्रीमिंग सर्वर नहीं मिला। स्थानीय फाइलों से स्ट्रीमिंग यूट्यूब और बिटटोरेंट उपलब्ध नहीं होंगे।","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"चेतावनी: इस वीडियो को आपके हार्डवेयर द्वारा समर्थित नहीं किया जा सकता है। ध्यान रखें प्लेबैक धीमा हो सकता है।","PLAYER_ERROR":"ओह खिलाड़ी त्रुटि","PLAYER_ERROR_LOOKSLIKE":"ऐसा लग रहा है","PLAYER_ORIENTATION":"खिलाड़ी अभिविन्यास","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"बंद","PLAYER_ORIENTATION_SENSOR_SHORT":"सेंसर","PLAYER_ORIENTATION_LANDSCAPE":"प्लेयर ओरिएंटेशन लैंडस्केप पर लॉक किया गया","PLAYER_ORIENTATION_SENSOR":"प्लेयर अभिविन्यास स्वचालित (सेंसर)","PLAYER_PLAYBACK_SPEED":"प्लेबैक गति","PLAYER_PLAYBACK_ERROR":"प्लेबैक त्रुटि कृपया पुनः प्रयास करें","PLAYER_PLAYBACK_ERROR_UNKNOWN":"अज्ञात त्रुटि","PLAYER_PLAYBACK_ERROR_DEFAULT":"क्षमा करें इस वीडियो को {{PRODUCTNAME}} द्वारा नहीं खेला जा सकता है।","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"रहना","PLAYER_NEXT_VIDEO_TITLE":"आगे आ रहा है","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"खारिज","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"अब देखिए","STREAMING_FROM":"से स्ट्रीमिंग","CASTING_TO":"कास्टिंग करना","NETWORK_STATUS":"नेटवर्क की स्थिति","STREAM_SPEED":"धारा गति:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"सहकर्मी सूचना","PEERS_ACTIVE":"सक्रिय:","PEERS_CONNECTED":"जुड़े हुए:","PEERS_WAITING":"इंतज़ार कर रही:","TRANSCODING_WARNING":"चेतावनी: ट्रांसकोडिंग वीडियो।","STREAM_LOADING":"लोड हो रहा है...","PLAYING_LOCAL":"स्थानीय फ़ाइल से बजाना","PLAYING_CACHE":"कैश से बजाना","WRONG_SUBS":"गलत उपशीर्षक?","ERR_SUBS_LOADING_TITLE":"उपशीर्षक लोड करने में त्रुटि","ERR_SUBS_LOADING":"असफल उपशीर्षक लोड हो रहा है: यह आपके द्वारा उपयोग किए जा रहे एडन के साथ या आपके नेटवर्क कनेक्शन के साथ एक समस्या हो सकती है","WARN_FOLLOWING_SUB_ADDONS_FAILED":"निम्नलिखित उपशीर्षक Addons विफल","ERR_CASTING_UPDATE_TITLE":"कास्टिंग डिवाइस जानकारी अपडेट नहीं कर सका: स्ट्रीमिंग सर्वर ऑफ़लाइन हो सकता है","CHOOSE_DEVICE":"देखने के लिए एक उपकरण चुनें","NO_CAST_DEVICES":"कोई कास्टिंग डिवाइस उपलब्ध नहीं है।","NO_SETTINGS":"कोई सेटिंग उपलब्ध नहीं है।","PHONE_TABLET":"फोन / टैबलेट","SUBTITLES":"उपशीर्षक","SUBTITLES_CHANGE":"के लिए उपशीर्षक बदलें","SUBTITLES_CHANGE_NONE":"इस भाषा के लिए कोई अन्य उपशीर्षक खेद नहीं है।","SUBTITLES_CHANGE_ACIVE":"वर्तमान में उपशीर्षक & # 35; {{subtitlesdialog.ActiveDX + 1}} सक्रिय हैं। उपशीर्षक सक्रिय करने के लिए जारी रखें & # 35; {{subtitlesdialog.pickedIDX + 1}}।","SUBTITLES_OR":"वैकल्पिक","SUBTITLES_ADJUST_DELAY":"उपशीर्षक देरी समायोजित करें:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"या समायोजित करने के लिए खेलते समय g / h कुंजी का उपयोग करें।","SUBTITLES_ADJUST_DELAY_TIP":"युक्ति: आप समायोजित करने के दौरान g / h कुंजी का उपयोग कर सकते हैं।","SUBTITLES_DELAY":"उपशीर्षक देरी:","SUBTITLES_LOADING":"उपशीर्षक लोड हो रहा है ...","SUBTITLES_UNAVAILABLE":"कोई बाहरी उपशीर्षक उपलब्ध नहीं है","SUBTITLES_DISABLED":"विकलांग","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"मौसम","EPISODE":"प्रकरण","SPECIAL":"Special","SORT":"तरह","SORT_BY":"इसके अनुसार क्रमबद्ध करें","FILTER":"फिल्टर","SORT_TRENDING":"ट्रेंडिंग","SORT_RECENT":"हालिया","SORT_ALPHABET":"ए-जेड","SORT_RATING":"रेटिंग","SORT_WATCHED":"देखा","SORT_YEAR":"वर्ष","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"आपके लिए नया","New Episodes":"नए एपिसोड","New Videos":"नए वीडियो","Recommendations":"सिफारिशों","LIBRARY_RESUME":"फिर शुरू करना","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"विवरण","LIBRARY_RESUME_DISMISS":"खारिज","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"विशेष रुप से प्रदर्शित","DISCOVER_TOP":"शीर्ष","DISCOVER_OSCAR":"ऑस्कर विजेता","DISCOVER_WARNING_TITLE":"उफ़!","DISCOVER_EMPTY_CATALOG":"यह एडन खाली सामग्री लौटा दी।","DISCOVER_ADULT_WARNING":"सामग्री केवल वयस्कों के लिए दिखाई दे रही है। क्या आप 18+ हैं?","DISCOVER_NOADDON_WARNING":"चेतावनी: इस प्रकार के लिए कोई स्ट्रैमियो एडन सक्रिय नहीं है। सहेजी गई वस्तुओं को यहां कुछ भी अपडेट नहीं किया जाएगा।","DISCOVER_LOAD_ERR":"सामग्री ने त्रुटि लोड नहीं की।","DISCOVER_ADDON_UNINSTALLED":"यह सामग्री अब उपलब्ध नहीं है कि आपने एडन को अन-इंस्टॉल किया हो सकता है।","UNINSTALL_THIS_ADDON":"इस एडन को अनइंस्टॉल करें","ERR_ADDON_NOT_INSTALLED":"यह एडन स्थापित नहीं है। अब स्थापित करें?","DETAIL_RECEIVE_NOTIF_SERIES":"नए एपिसोड के लिए सूचनाएं प्राप्त करें","DETAIL_RECEIVE_NOTIF_VIDEOS":"नए वीडियो के लिए सूचनाएं प्राप्त करें","SIDEBAR_SHOW_STREAMS":"स्ट्रीम दिखाएं","RELAUNCH":"अब पुनः प्रक्षेपण!","UPGRADE":"नया संस्करण उपलब्ध है! नवीनतम STREMIO संस्करण में अपग्रेड करें","RELOAD_UI":"उपयोगकर्ता इंटरफ़ेस को पुनः लोड करें","MANUAL_UPDATE_TITLE":"अपने STREMIO संस्करण को अपडेट करें","MANUAL_UPDATE_LINE1":"आप स्ट्रैमियो का पुराना संस्करण चला रहे हैं जो अत्यधिक अपरिचित है।","MANUAL_UPDATE_LINE2":"कृपया जल्द से जल्द अपडेट करें।","BUTTON_UPDATE_LATTER":"अभी नहीं","BUTTON_UPDATE_NOW":"अद्यतन","ANONYMOUS_USER":"अनाम उपयोगकर्ता","DONT_HAVE_ACC":"खाता नहीं है?","HAVE_ACC":"क्या आपके पास पहले से एक खाता मौजूद है?","PASSWORD":"कुंजिका","PASSWORD_CONFIRM":"पासवर्ड की पुष्टि कीजिये","EMAIL":"ईमेल","FB_LOGIN":"फेसबुक के साथ जारी रखें","FB_NOTHINGSHARED":"आपकी अनुमति के बिना कुछ भी साझा नहीं किया जाता है","FB_NOPOST":"हम आपकी ओर से कुछ भी पोस्ट नहीं करेंगे","OR":"या","I_ACCEPT":"मैं स्वीकारता हूँ","I_ACCEPT_BY_CLICKING":"उपरोक्त बटन पर क्लिक करके मैं प्रमाणित करता हूं कि मैं स्वीकार करता हूं","TOS":"नियम और शर्तें","MUST_ACCEPT_TERMS":"आपको शर्तों को स्वीकार करना होगा","PASSWORDS_NOMATCH":"पासवर्ड मेल नहीं खाते","SIGN_UP":"साइन अप करें","SIGN_UP_EMAIL":"ईमेल के लिए साइन इन करें","CLICK_TO_SIGN_UP":"साइन अप करने के लिए यहां क्लिक करें।","LOG_IN":"लॉग इन करें","LOG_OUT":"लॉग आउट","EXIT_FULLSCREEN":"पूर्णस्क्रीन मोड से बाहर निकलें","ENTER_FULLSCREEN":"पूर्णस्क्रीन मोड दर्ज करें","PLAY_URL_MAGNET_LINK":"यूआरएल / चुंबक लिंक खेलें","HELP_FEEDBACK":"सहायता और प्रतिक्रिया","TERMS_OF_SERVICE":"सेवा की शर्तें","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"STREMIO के बारे में","USER_PANEL":"उपयोगकर्ता पैनल","LOGIN_LABEL":"Login","GUEST_LOGIN":"मेहमान लॉगइन करें","GUEST_LOGIN_NOTICE":"अतिथि लॉगिन की अनुशंसा नहीं की जाती है। एक नियमित लॉगिन का उपयोग करने से आपकी लाइब्रेरी को सिंक करने के लिए STREMIO को पसंदीदा श्रृंखला / चैनलों के लिए अधिसूचनाएं प्राप्त होती हैं। क्या आप सुनिश्चित रूप से आगे बढ़ना चाहते हैं?","GUEST_LOGIN_NOTICE_2":"अतिथि लॉगिन की अनुशंसा नहीं की जाती है - आपके पास समन्वयित पुस्तकालय और बोर्ड अधिसूचनाएं नहीं होंगी जो महत्वपूर्ण स्ट्रमियो विशेषताएं हैं। क्या आप सुनिश्चित रूप से आगे बढ़ना चाहते हैं?","CLICK_HERE":"यहां क्लिक करें","WRONG_PASSWORD":"गलत ईमेल या पासवर्ड। मामले में आप अपना पासवर्ड भूल गए हैं","SET_A_PASS":"एक पासवर्ड सेट करें","RESET_PASSWORD":"पासवर्ड रीसेट","FORGOT_PASSWORD":"पासवर्ड भूल गए?","EMAIL_USED_WITH_FB":"इस ईमेल का उपयोग फेसबुक लॉगिन के साथ किया गया था।","INVALID_EMAIL":"कृपया एक वैध ई - मेल एड्रेस डालें","INVALID_PASSWORD":"कृपया एक वैध पासवर्ड दर्ज करें","CONN_ERR":"कनेक्शन त्रुटि - कृपया बाद में पुनः प्रयास करें। N NIf यह फायरवॉल / एंटी-वायरस सॉफ़्टवेयर (विशेष रूप से बिट डिडीफेंडर) को अक्षम करता है।","IMPORT_FROM_GUEST":"अपने अतिथि खाते से लाइब्रेरी आयात करें","RECEIVE_UPDATES_EMAIL":"STREMIO से अपने ईमेल पर अपडेट प्राप्त करें","LOGIN_FAILED":"लॉगिन विफल।","SIGNUP_FAILED":"साइन अप करने में विफल रहा।","SEARCH_FAILED":"खोज विफल","EMAIL_USED":"यह ईमेल पहले से प्रयोग में है।","WAITING_FB_LOGIN":"फेसबुक के साथ लॉग इन करना ...","EXTERNAL_PLAYER_TITLE":"बाहरी खिलाड़ी में खेलें","EXTERNAL_REMEMBER_PLAYER":"क्या आप अपनी पसंद को याद रखना चाहते हैं","EXTERNAL_ALWAYS_PLAY":"हां","EXTERNAL_ONLY_ONCE":"नहीं","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"हमें बताएं कि आपको क्या पसंद है","INTRO_TASTE_LONG":"हमें बताएं कि आप क्या देखना चाहते हैं","INTRO_TASTE_PICK":"{{HUSTERSREMAINAININININING}} हितों को चुनें","INTRO_TASTE_PICK_MORE":"{{REITAINSREMAINAINAING}} अधिक हितों को चुनें","INTRO_TASTE_HELP_US":"हमारे बारे में अधिक जानने में हमारी सहायता करें।","INTRO_TASTE_CHOOSE_THESE":"इनमें से कुछ चुनें:","INTRO_TASTE_CHOOSE_MIN":"कम से कम 3 श्रेणियां चुनें","INTRO_TASTE_CHOOSE_MIN_ERR":"आपको कम से कम 3 श्रेणियां चुननी होंगी!","INTRO_TASTE_LIFESTYLE":"बॉलीवुड","INTRO_TASTE_SPORTS":"खेल","INTRO_TASTE_FOOD_HEALTH":"भोजन और स्वास्थ्य","INTRO_TASTE_BEAUTY_FASHION":"सौंदर्य और फैशन","INTRO_TASTE_NEWS":"समाचार","INTRO_TASTE_GAMING":"जुआ","INTRO_TASTE_SCIENCE_EDU":"विज्ञान की शिक्षा","INTRO_TASTE_MUSIC":"संगीत","INTRO_TASTE_TRAVEL":"यात्रा","INTRO_TASTE_LATE_NIGHT":"देर रात शो","INTRO_TASTE_REALITY":"वास्तविकता","INTRO_TASTE_COMEDY":"कॉमेडी","INTRO_TASTE_DIY":"DIY कैसे करें","INTRO_TASTE_TECH":"तकनीक","INTRO_TASTE_CINEMA":"सिनेमा","ADDON_NOT_SUPPORTED":"चयनित एडन इस मंच पर समर्थित नहीं है।","ADDON_DISCLAIMER":"तीसरे पक्ष के एडॉन्स का उपयोग हमेशा आपकी जिम्मेदारी और आपके द्वारा स्थित क्षेत्राधिकार के शासकीय कानून के अधीन होंगे।","ADDON_ACTIVATE":"इस एडन को सक्रिय करें?","ADDON_REPO_ADD":"एडन संग्रह यूआरएल","ADDON_ADD":"जोड़ें","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"नया क्या है","BUTTON_CONTINUE":"जारी रखें","BUTTON_ACTIVATE":"सक्रिय","BUTTON_ACTIVATED":"सक्रिय","BUTTON_CANCEL":"रद्द करें","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"सभी खारिज","BUTTON_VIEW_ALL":"सभी देखें","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"आपकी पुस्तकालय खाली दिखता है। पता लगाएं कि यह कितना उपयोगी है :)","HOW_START":"यहां बताया गया है कि आप कैसे शुरू कर सकते हैं:","LIB_EMPTY_CAL":"आपका कैलेंडर आपकी लाइब्रेरी में श्रृंखला दिखाता है।","HOW_START_CAL":"यहां बताया गया है कि आप श्रृंखला कैसे जोड़ सकते हैं:","LIB_EMPTY_BOARD":"बोर्ड नोटिफिकेशन दिखाता है & amp; आपकी पुस्तकालय से संबंधित सिफारिशें।","HOW_START_BOARD_WAIT":"कृपया अपनी लाइब्रेरी में कुछ श्रृंखला या चैनल जोड़ें संसाधित करने के लिए हमें कुछ मिनट दें :)","HOW_START_BOARD":"यहां बताया गया है कि आप श्रृंखला कैसे जोड़ सकते हैं & amp; इसके लिए फिल्में:","IMPORT_FB":"उन आयातित चीजें जिन्हें आप फेसबुक से पसंद करते हैं","IMPORT_TRAKT":" trakt से अपनी मीडिया लाइब्रेरी आयात करें","IMPORT_DISCOVER":" डिस्कवर से दिलचस्प सामग्री खोजें","IMPORT_DISK":"अपने स्थानीय डिस्क पर आपके पास फिल्में या शो आयात करें","PLEASE_CREATE_ACC":"लाइब्रेरी सिंक और एएमपी सक्षम करने के लिए कृपया खाता बनाएं ; तख़्ता।","IMPORT_DISCOVER_SIGNUP":"साइन अप करें और डिस्कवर से दिलचस्प सामग्री खोजें","IMPORT_DISK_SIGNUP":"साइन अप करें और फिल्में आयात करें या आपके स्थानीय डिस्क पर दिखाएं","LIB_EMPTY_CLOUD":"बादल पुस्तकालय","LIB_EMPTY_CLOUD_DESC":"व्यक्तिगत क्लाउड लाइब्रेरी सभी उपकरणों पर समन्वयित","LIB_EMPTY_EARLY":"जल्दी उठ कर काम शुरू करने वाला व्यक्ति","LIB_EMPTY_EARLY_DESC":"नए एपिसोड के लिए सूचनाएं प्राप्त करें","LIB_EMPTY_PERSONAL":"निजी","LIB_EMPTY_PERSONAL_DESC":"व्यक्तिगत सिफारिशें प्राप्त करें","LIB_EMPTY_CALENDAR_DESC":"अपने व्यक्तिगत देखने के कैलेंडर को शेड्यूल करें","LIB_EMPTY_ALL":"इन सभी को पाने के लिए साइन अप करें:","LIB_EMPTY_BEST":"STREMIO का सर्वश्रेष्ठ पाने के लिए साइन अप करें","LIB_EMPTY_OTHER":"कैलेंडर और अन्य शानदार सुविधाओं को सक्षम करने के लिए साइन अप करें","CALENDAR_ADDED":"Stremio कैलेंडर को आपके डिफ़ॉल्ट डेस्कटॉप कैलेंडर में जोड़ा गया है।","CALENDAR_ADDED_MSG":"यदि यह काम नहीं करता है तो कृपया अपने कैलेंडर एप्लिकेशन को मैन्युअल रूप से इस यूआरएल को जोड़ें","TRAKT_EXPIRED":"ट्रैक्ट प्रमाणीकरण समाप्त हो गया कृपया सेटिंग्स पर जाएं और पुन: प्रमाणित करें","TRAKT_REQUIRES_LOGIN":"ट्रैक्ट त्रुटि","TRAKT_REQUIRES_LOGIN_MSG":"आपको लॉगिन करने की आवश्यकता है","SETTINGS_LABEL":"समायोजन","SETTINGS_NAV_GENERAL":"आम","SETTINGS_NAV_PLAYER":"खिलाड़ी","SETTINGS_NAV_STREAMING":"स्ट्रीमिंग","SETTINGS_NAV_SHORTCUTS":"शॉर्टकट","SETTINGS_SHORTCUT_RELOAD_APP":"रीलोड ऐप","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"बाहर निकलें / वापस जाएं","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"पूर्णस्क्रीन चालू करें","SETTINGS_SHORTCUT_SHOW_CONTROLS":"नियंत्रण दिखाएं","SETTINGS_SHORTCUT_PLAY_PAUSE":"चालू करे / रोके","SETTINGS_SHORTCUT_VOLUME_UP":"आवाज बढ़ाएं","SETTINGS_SHORTCUT_VOLUME_DOWN":"आवाज कम करे","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"उपशीर्षक आकार बढ़ाएँ","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"उपशीर्षक आकार कम करे","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"उपशीर्षक विलंब बढ़ाएँ","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"उपशीर्षक विलंब कम करे","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"स्टार्टअप शुरू","SETTINGS_VLC_DEFAULT":"वीएलसी के साथ खेलें","SETTINGS_UI_LANGUAGE":"यूआई भाषा","SETTINGS_FULLSCREEN_EXIT":"कुंजी से बाहर निकलें पूर्ण स्क्रीन से बाहर निकलें","SETTINGS_GAMEPAD":"गेमपैड समर्थन सक्षम करें","SETTINGS_CLOSE_WINDOW":"विंडो बंद होने पर ऐप बंद करें","SETTINGS_SUBTITLES_LANGUAGE":"डिफ़ॉल्ट उपशीर्षक भाषा","SETTINGS_SUBTITLES_SIZE":"डिफ़ॉल्ट उपशीर्षक आकार","SETTINGS_SUBTITLES_BACKGROUND":"उपशीर्षक पृष्ठभूमि","SETTINGS_SUBTITLES_COLOR":"उपशीर्षक रंग","SETTINGS_SUBTITLES_COLOR_OUTLINE":"उपशीर्षक रूपरेखा रंग","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"उपशीर्षक पृष्ठभूमि रंग","SETTINGS_SEEK_KEY":"तीर कुंजियाँ समय तलाशें","SETTINGS_SEEK_KEY_SHIFT":"तीर कुंजी समय की तलाश करते हैं जब Shift कुंजी आयोजित की जाती है","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"ऑटो-प्ले अगला एपिसोड","SETTINGS_NEXT_VIDEO":"अगले एपिसोड शुरू करने के लिए अधिसूचना दिखाएं","SETTINGS_NEXT_VIDEO_TRIGGER":"इसके लिए अगला एपिसोड अधिसूचना दिखाएं:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"खेलने से पहले स्वत: आकार बदलें","SETTINGS_OVERRIDE_SERVER":"स्ट्रीमिंग सर्वर URL (उन्नत) को ओवरराइड करें","SETTINGS_SERVER_URL":"स्ट्रीमिंग सर्वर यूआरएल:","SETTINGS_SERVER_AVAILABLE":"स्ट्रीमिंग सर्वर उपलब्ध है।","SETTINGS_SERVER_UNAVAILABLE":"स्ट्रीमिंग सर्वर उपलब्ध नहीं है।","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"स्ट्रीमिंग HTTPS एंडपॉइंट:","SETTINGS_USE_BETA":"हमेशा नवीनतम बीटा का उपयोग करें","SETTINGS_IMPORT_FB":"फेसबुक से आयात करें","SETTINGS_IMPORT_DISK":"स्थानीय डिस्क से आयात करें","SETTINGS_IMPORT_TRAKT":"ट्रैक्ट से आयात","SETTINGS_PAUSE_MINIMIZED":"कम से कम प्लेबैक रोकें","SETTINGS_HWDEC":"हार्डवेयर-त्वरित डिकोडिंग","SETTINGS_BACKGROUND":"पृष्ठभूमि प्लेबैक","SETTINGS_SUBSCRIBE_CALENDAR":"कैलेंडर की सदस्यता लें","SETTINGS_REQ_EXPORT":"डेटा निर्यात का अनुरोध करें","SETTINGS_ACC_DELETE":"खाता हटाने का अनुरोध करें","SETTINGS_CHANGE_PASSWORD":"पासवर्ड बदलें","SETTINGS_TOS":"सेवा की शर्तें","SETTINGS_SUPPORT":"सहयोग टीम से संपर्क करें","SETTING_LANGUAGE":"भाषा","SETTINGS_TRAKT":"ट्रैक्ट स्क्रोबिंग","SETTINGS_TRAKT_LOGOUT":"Trakt.tv से लॉग आउट करें","SETTINGS_SCAN_FOR_REMOTE":"रिमोट खोलने के लिए क्यूआर कोड स्कैन करें","SETTINGS_DESKTOP_NOTIFICATIONS":"डेस्कटॉप अधिसूचनाएं","SETTINGS_DATA_SAVER":"आंकड़ा बचतकर्ता","SETTINGS_LANGUAGE_INTERFACE":"इंटरफेस","SETTINGS_LANGUAGE_SUBS":"डिफ़ॉल्ट उपशीर्षक","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"ऑटोसेल ऑडियो ट्रैक","SETTINGS_DEFAULT_AUDIO_TRACK":"डिफ़ॉल्ट ऑडियो ट्रैक","SETTINGS_ACCOUNT":"कारण","SETTINGS_VERSION":"संस्करण","SETTINGS_MPV_WINDOW":"एक अलग विंडो में प्लेयर लॉन्च (उन्नत)","SETTINGS_PLAY_IN_EXTERNAL":"हमेशा बाहरी खिलाड़ी में वीडियो शुरू करें","SETTINGS_STORAGE_BUTTON":"स्थानीय भंडारण साफ़ करें","SETTINGS_STORAGE_MODAL_TITLE":"क्या आपको यकीन है ?","SETTINGS_STORAGE_MODAL_MESSAGE":"यह स्थानीय भंडारण को साफ़ करेगा और आपको लॉग आउट करेगा।","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"स्वचालित","SETTINGS_HW_DISABLED":"बंद","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"ऑडियो","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"ब्लैक बैकग्राउंड कलर का इस्तेमाल करें","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"आकार","SUBSPICKER_DELAY":"विलंब","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"गोपनीयता नीति","MOBILE_CRASH_REPORTING":"क्रैश रिपोर्टिंग","MOBILE_ZOOM_TO_FILL":"स्क्रीन भरने के लिए ज़ूम करें","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"कम बैटरी पर चलाएं","MOBILE_RUN_FOREGROUND":"अग्रभूमि सेवा के रूप में चलाएँ","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"ऑनलाइन","MOBILE_SERVER_OFFLINE":"ऑफलाइन","MOBILE_QR_EXPIRES":"क्यूआर कोड की समय सीमा समाप्त होगि ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"ऊपर क्यूआर कोड स्कैन करें या यहां जाएं ","MOBILE_LINK_ACCOUNT":"खाते लिंक करें","MOBILE_SPEEDPICKER_CANCEL":"रद्द करना","MOBILE_SPEEDPICKER_LABEL":"प्लेबैक स्पीड का चयन करें","MOBILE_EMPTY_LIBRARY":"आपकी लाइब्रेरी खाली है","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"मैं स्ट्रेमियो से मार्केटिंग संचार प्राप्त करने के लिए सहमत हूं","QUIT":"छोड़ना","CONNECTED":"जुड़े हुए","AUTHENTICATE":"प्रमाणित","CACHING":"कैशिंग","SETTINGS_CACHING_DRIVE":"कैशिंग ड्राइव","ENABLE_LOCAL_FILES_ADDON":"स्थानीय फ़ाइलें Addon सक्षम करें (पुनरारंभ की आवश्यकता है)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"रिमोट एचटीटीपीएस कनेक्शन सक्षम करें","TORRENT_PROFILE":"टोरेंट प्रोफाइल","DATA_CACHING":"डेटा कैशिंग","MAGNET_PARSING":"एक चुंबक लिंक पार्सिंग","January":"जनवरी","February":"फ़रवरी","March":"जुलूस","April":"अप्रैल","May":"मई","June":"जून","July":"जुलाई","August":"अगस्त","September":"सितंबर","October":"अक्टूबर","November":"नवंबर","December":"दिसंबर","Monday":"सोमवार","Tuesday":"मंगलवार","Wednesday":"बुधवार","Thursday":"गुरूवार","Friday":"शुक्रवार","Saturday":"शनिवार","Sunday":"रविवार","Action":"कार्य","Comedy":"कॉमेडी","War":"युद्ध","Family":"परिवार","Animation":"एनीमेशन","Adventure":"साहसिक","Fantasy":"कल्पना","Crime":"अपराध","Mystery":"रहस्य","Romance":"रोमांस","Drama":"नाटक","Horror":"डरावनी","Thriller":"थ्रिलर","Sci-Fi":"विज्ञान-कथा","Music":"संगीत","Biography":"जीवनी","Documentary":"दस्तावेज़ी","Sport":"खेल","Musical":"संगीत","Western":"वेस्टर्न","Film-Noir":"फिल्म नोयर","News":"समाचार","History":"इतिहास","Game-Show":"गेम शो","Reality-TV":"रियलिटी टीवी","Talk-Show":"टॉक शो","Film & Entertainment":"फिल्म और मनोरंजन","Gaming":"जुआ","From TV":"टीवी से","Lifestyle":"बॉलीवुड","Science & Education":"विज्ञान की शिक्षा","Cooking & Health":"खाना पकाने और स्वास्थ्य","Beauty & Fashion":"सौंदर्य और फैशन","Sports":"खेल","News & Politics":"समाचार और राजनीति","How-to & DIY":"कैसे और DIY","Tech":"तकनीक","Automotive":"मोटर वाहन","Causes & Non-Profits":"कारण और गैर लाभ","Movies":"चलचित्र","Uk Live Tv":"यूके लाइव टीवी","Fashion":"पहनावा","Business News Radio":"बिजनेस न्यूज रेडियो","Business Tv":"बिजनेस टीवी","Cars & Auto":"कारें और ऑटो","Comedy Radio":"कॉमेडी रेडियो","Lifestyle Radio":"लाइफस्टाइल रेडियो","News Tv":"समाचार टीवी","Food And Wine":"भोजन और शराब","Latino Tv":"लैटिनो टीवी","Shopping Tv":"शॉपिंग टीवी","Religion":"धर्म","Kids":"बच्चे","Body & Soul":"शरीर आत्मा","Education":"शिक्षा","Indian Tv":"भारतीय टीवी","Extreme Sports":"खतरनाक खेल","Middle Eastern Tv":"मध्य पूर्वी टीवी","Celebrity Tv":"सेलिब्रिटी टीवी","Science Tv":"विज्ञान टीवी","Bikini babe":"बिकिनी बेब","Outdoors":"सड़क पर","German Tv":"जर्मन टीवी","French Tv":"फ्रेंच टीवी","Italian Tv":"इतालवी टीवी","Gamer Tv":"गेमर टीवी","Travel":"यात्रा","Asian Tv":"एशियाई टीवी","Entertainment":"मनोरंजन","News Radio":"समाचार रेडियो","Music Radio":"संगीत रेडियो","Language Learning":"भाषा सीखना","Science Radio":"विज्ञान रेडियो","Tech Radio":"टेक रेडियो","Science & Technology Vod":"विज्ञान और प्रौद्योगिकी वोड","new video":"नया वीडियो","new episode":"नई कड़ी","new movie":"नई फिल्म","recommended":"अनुशंसित","we recommend":"हम अनुशंसा करते हैं","offer of the day":"दिन की पेशकश","news":"समाचार","music video":"वीडियो संगीत","CTX_SHOW_HOTKEYS":"हॉटकी दिखाएं","CTX_DISMISS_NOTIF":"सूचनाओं को खारिज करना","CTX_DISMISS_ALL":"सभी खारिज","CTX_SHARE":"साझा करना","CTX_COPY_SHARE_LINK":"शेयर लिंक कॉपी करें","CTX_COPY_MAGNET_LINK":"चुंबक लिंक कॉपी करें","CTX_COPY_STREAM_LINK":"स्ट्रीम लिंक कॉपी करें","CTX_DOWNLOAD_VIDEO":"इस वीडियो को डाउनलोड करें","CTX_DOWNLOAD_SUBS":"उपशीर्षक डाउनलोड करें","CTX_VIEW_ON_YOUTUBE":"यूट्यूब पर देखें","CTX_SHOW":"प्रदर्शन","CTX_PLAY":"खेल","CTX_PLAY_IN":"खेलना","CTX_PLAY_ON":"खेलो","CTX_WATCH_ON":"यहां देखें","CTX_WATCH":"घड़ी","CTX_WATCHED":"देखे","CTX_WATCH_BEGINNING":"शुरुआत से देखो","CTX_WATCH_MOBILE":"एक मोबाइल डिवाइस पर देखें","CTX_REWIND":"शुरुआत करने के लिए रिवाइंड","CTX_MARK_WATCHED":"देखा के रूप में चिह्नित","CTX_MARK_NON_WATCHED":"गैर-देखा के रूप में चिह्नित करें","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"जैसा कि देखा गया है","CTX_UNMARK_REST":"गैर-देखे गए के रूप में बाकी को चिह्नित करें","CTX_RECEIVE_NEW_NOTIF":"नई सूचनाएं प्राप्त करें","CTX_REMOVE_CACHE":"कैश से निकालें","CTX_REMOVE_CACHE_EP":"कैश से एपिसोड निकालें","CTX_OPEN_CONTAINING":"धारक फोल्डर खोलें","CTX_REMOVE":"पुस्तकालय से निकालें","CTX_AVAILABLE_OFFLINE":"उपलब्ध ऑफ़लाइन","CTX_PAUSED":"रोके गए","CTX_ALWAYS_ON_TOP":"हमेशा ऊपर","CTX_FULLSCREEN":"पूर्ण स्क्रीन","CTX_WRONG_SUBS":"गलत उपशीर्षक?","CTX_REPORT_ISSUES":"रिपोर्ट मुद्दा","CTX_COPY":"प्रतिलिपि","CTX_PASTE":"पेस्ट करें","CTX_CLEAR":"स्पष्ट","CTX_CLEAR_RECENT_SEARCHES":"हाल की खोजों को साफ़ करें","HELLO_THERE":"नमस्ते","HOPE_YOU_ENJOY":"हमें आशा है कि आप STREMIO का आनंद लेंगे और यह पहले से ही आपके पसंदीदा ऐप्स में से एक है!","WHO_ARE_WE":"हम कौन हैं? हम इसके पीछे टीम हैं - दो लोग जो इस उत्पाद को बेहतर और बेहतर बनाने के लिए पिछले 3 वर्षों से हर दिन कड़ी मेहनत करते हैं।","SUPPORT_US":"यदि आप STREMIO का उपयोग करने में आनंद लेते हैं यदि STREMIO आपके लिए मूल्यवान है - शब्द फैलाएं!","SPREAD_THE_WORD":"अपने दोस्तों के साथ साझा करें अब स्ट्रैमियो के बारे में शब्द फैलाएं","MORE_PEOPLE":"जितना अधिक लोग STREMIO का उपयोग करेंगे उतना ही बेहतर होगा!","SEND_A_LINK":"या हमारी वेबसाइट पर एक लिंक भेजें","TIP_LOCALFILES":"युक्ति: आप स्थानीय वीडियो फ़ाइलों को स्ट्रैमियो में खींच और छोड़ सकते हैं","ADDON_MY":"मेरे एडॉन्स","ADDON_COMMUNITY":"सामुदायिक एडॉन्स","ADDON_OFFICIAL":"सरकारी Addons","ADDON_REPOS":"एडन संग्रह","ADDON_SEARCH":"खोज एडॉन्स","ADDON_INSTALL":"इंस्टॉल","ADDON_CONFIGURE":"कॉन्फ़िगर","ADDON_UNINSTALL":"स्थापना रद्द करें","ADDON_UPGRADE":"अपग्रेड","ADDON_INSTALLED":"स्थापित","ADDON_INSTALLED_MSG":"Addon स्थापित!","ADDON_UPGRADED_MSG":"एडन अपग्रेड किया गया!","ADDON_UNKNOWN":"अनजान","ADDON_ERR":"Addon इंस्टॉल त्रुटि!","ADDON_DISCONNECTED":"डिस्कनेक्ट किया गया","ADDON_APP_MISSING":"इस स्रोत के लिए ऐप स्थापित नहीं है। क्या आप इसे अभी इंस्टॉल करना चाहते हैं?","ADDON_APP_INSTALL":"अब स्थापित करें","ADDON_PAGE":"एडन पेज","ADDON_TOP_CONTENT":"इस एडन से सर्वश्रेष्ठ","ADDON_PROVIDES":"यह एडन आपको देगा:","ADDON_WATCH":"देखो # {प्रकार} अब!","ADDON_WATCH_FREE":"अभी मुफ्त में # {प्रकार} देखें!","ADDON_ADDON":"ऐड ऑन","ADDON_SUPPORTED_TYPES":"समर्थित प्रकार","ADDON_SUPPORTED_CATALOGS":"समर्थित कैटलॉग","ADDON_PROVIDES_DISCOVER":"अधिक # {प्रकार} डिस्कवर में","ADDON_PROVIDES_STREAMS":"# {प्रकार} देखें","ADDON_PROVIDES_STREAMS_FREE":"मुफ्त में # {प्रकार} देखें","ADDON_PROVIDES_SUBTITLES":"# {प्रकार के लिए उपशीर्षक","ADDON_CANTDETECT":"हम एक रनिंग स्ट्रैमियो का पता नहीं लगा सके ताकि हम यह पता लगा सकें कि आपने कौन से एडॉन्स इंस्टॉल किए हैं।","ERR_NO_META":"इस बारे में कोई जानकारी नहीं मिली","ERR_GETTING_META":"इसके बारे में जानकारी पुनर्प्राप्त करने में त्रुटि।","ERR_CANT_PARSE_MAGNET":"चुंबक पार्स करने में असमर्थ","ERR_NO_MAGNET_INFOHASH":"चुंबक के लिए कोई वैध जानकारी हैश","ERR_NO_FILE_PATH":"फ़ाइल के लिए एक पथ के बिना अनुरोध भेजने में असमर्थ","ERR_NO_TORRENT":"कोई धार नहीं लौटा","ERR_NO_SUPPORTERD_FILES":"कोई समर्थित फाइल नहीं मिली","ERR_OPENING_FILES":"बाहरी फाइलें नहीं खोल सका","ERR_INVALID_LINK":"अमान्य लिंक","ERR_REGISTERED_ONLY":"यह विकल्प केवल पंजीकृत उपयोगकर्ताओं के लिए उपलब्ध है।","ERR_CLIPBOARD":"क्लिपबोर्ड से नहीं खेल सकते हैं","ERR_CLIPBOARD_READ":"इस मंच पर क्लिपबोर्ड नहीं पढ़ सकते हैं","ERR_CLIPBOARD_GENERIC":"क्लिपबोर्ड में पाया जाने वाला कोई भी यूआरएल नहीं मिला। कृपया एक वीडियो को एक यूआरएल (उदा। एक चुंबक लिंक) कॉपी करें।","BOARD_CONTINUE_WATCHING":"देखना जारी रखें","BOARD_EXPLANATION_RECOMMENDATIONS":"फिल्में आपके लिए विशेष रूप से चुने गए।
यह फिल्म नमूना सिफारिश है।","BOARD_EXPLANATION_EPISODES":"आपकी पसंदीदा श्रृंखला के नए एपिसोड यहां आते हैं।
श्रृंखला जोड़ें आप अपनी लाइब्रेरी में अनुसरण करते हैं।","BOARD_EXPLANATION_VIDEOS":"आपके पसंदीदा चैनलों के नए एपिसोड यहां आते हैं।
YouTube चैनल जोड़ें जो आप अपनी लाइब्रेरी में अनुसरण करते हैं।","WEBSITE_SLOGAN_WATCH":"तुरंत देखें","WEBSITE_SLOGAN_ALL":"एक ही स्थान पर आप सभी वीडियो सामग्री का आनंद लेते हैं","WEBSITE_SLOGAN_NEW":"आप सभी देख सकते हैं","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"से देखना","WEBSITE_DOWNLOAD":"अब डाउनलोड करो","WEBSITE_DOWNLOAD_FOR":"अभी डाउनलोड करें","WEBSITE_IS_DESKTOP":"Stremio एक डेस्कटॉप एप्लिकेशन है इस पृष्ठ को अपने पीसी पर खोलें और इसे डाउनलोड करें","WEBSITE_DESKTOP_DEMO_VID":"डेस्कटॉप डेमो","WEBSITE_PAGE_HOME":"घर","WEBSITE_PAGE_FEATURES":"विशेषताएं","WEBSITE_PAGE_ADDONS":"ऐड-ऑन","WEBSITE_PAGE_TECH":"प्रौद्योगिकी","WEBSITE_PAGE_CREATE_ADDON":"Addon बनाएँ","WEBSITE_PAGE_CONTACTS":"संपर्क","WEBSITE_PAGE_BLOG":"ब्लॉग","WEBSITE_TYPE_movie":"चलचित्र","WEBSITE_TYPE_series_PL":"श्रृंखला","WEBSITE_TYPE_tv":"लाइव टीवी","WEBSITE_TYPE_channel":"चैनल","WEBSITE_STREMIO_WHAT_IS":"Stremio एक ऐप है जो आपको व्यवस्थित करने और तुरंत अपने पसंदीदा वीडियो फिल्में टीवी श्रृंखला और टीवी चैनल देखने में मदद करता है।","WEBSITE_FEATURES_WATCH":"तुरंत एचडी में देखें","WEBSITE_FEATURES_WATCH_DETAIL":"क्लिक करें और अपने पसंदीदा मूवीज़ टीवी शो वीडियो और टीवी चैनल दिखाता है।","WEBSITE_FEATURES_SUBS":"स्वचालित उपशीर्षक","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio स्वचालित रूप से आपकी भाषा के लिए समन्वयित उपशीर्षक चुनता है।","WEBSITE_FEATURES_SUBS_LABEL":"आपका कदम प्रमुख।","WEBSITE_FEATURES_CAST":"टीवी और मोबाइल उपकरणों पर खेलते हैं","WEBSITE_FEATURES_CAST_DETAIL":"Appletv Chromecast स्मार्ट टीवी (डीएलएनए / यूपीएनपी) और मोबाइल उपकरणों के लिए कास्ट करें।","WEBSITE_LIB":"अपने सभी उपकरणों पर सिंक की गई अपनी व्यक्तिगत पुस्तकालय का आनंद लें","WEBSITE_LIB_COLLECT":"STREMIO से लीजिए","WEBSITE_LIB_IMPORT":"फेसबुक से आयात करें","WEBSITE_LIB_LOCAL":"अपने स्थानीय ड्राइव से जोड़ें","WEBSITE_BOARD":"बोर्ड - अधिसूचनाओं और सिफारिशों के लिए आपका एक-स्टॉप प्लेस","WEBSITE_BOARD_RECOMMEND":"अनुशंसित टीवी शो","WEBSITE_BOARD_TRENDING":"ट्रेंडिंग फिल्म","WEBSITE_BOARD_NEW":"नया वीडियो","WEBSITE_BOARD_EPISODE":"नई कड़ी","WEBSITE_BOARD_1":"देखने के लिए कुछ दिलचस्प खोज रहे हैं? अपने स्वाद के आधार पर सिफारिशें प्राप्त करें!","WEBSITE_BOARD_2":"अधिसूचित हो जाएं जब आपके पसंदीदा टीवी शो या यूट्यूब चैनल का एक नया एपिसोड बाहर है!","WEBSITE_BOARD_YOUTUBE":"YouTube चैनलों के नए वीडियो","WEBSITE_BOARD_EPISODES":"श्रृंखला के नए एपिसोड आप अनुसरण करते हैं","WEBSITE_ADDONS":"सामग्री एडॉन्स","WEBSITE_TECH_DETAIL":"हम लव टेक्नोलॉजी हम पागल विज्ञान से प्यार करते हैं! NStremio निम्नलिखित ओपन सोर्स टेक्नोलॉजीज का उपयोग कर रहा है:","WEBSITE_TECH_WCJS":"WebChimera.js STREMIO को अच्छे प्रदर्शन के साथ किसी भी वीडियो प्रारूप को चलाने की अनुमति देता है।","WEBSITE_TECH_WCJS_EXTRA":"हम कोर प्रोजेक्ट योगदानकर्ता हैं","WEBSITE_TECH_ELECTRON":"इलेक्ट्रॉन के साथ स्ट्रैमियो बनाने के लिए एक अभिनव मंच प्रदान करता है।","WEBSITE_TECH_ELECTRON_EXTRA":"हम परियोजना योगदानकर्ता हैं","WEBSITE_TECH_LINVODB":"एक डेटाबेस तकनीक जो सुनिश्चित करती है कि आपका डेटा व्यवस्थित हो और कहीं भी आपके पास उपलब्ध हो।","WEBSITE_TECH_LINVODB_EXTRA":"इन-हाउस टेक्नोलॉजी","WEBSITE_CREATE_ADDON":"अपना Addon बनाएँ","WEBSITE_CREATE_ADDON_DETAIL":"क्या आपके पास वीडियो सामग्री प्रदान करने वाली सेवा है? हम आपको अपने एडन बनाकर STREMIO की सुविधाओं से लाभान्वित होने में मदद करेंगे।","WEBSITE_CREATE_ADDON_BENEFITS":"स्ट्रैमियो के लिए एक एडन बनाने के लाभ","WEBSITE_P2P_BEAUTY":"पीयर-टू-पीयर स्ट्रीमिंग की सुंदरता","WEBSITE_P2P_1":"मांग या लाइव स्ट्रीमिंग पर विश्वसनीय और किफायती पूर्ण एचडी / 4 के वीडियो","WEBSITE_P2P_2":"वितरण मंच महान उपयोगकर्ता अनुभव प्रदान करते हैं","WEBSITE_P2P_3":"हम आपकी सटीक जरूरतों को पूरा करने वाले एडन को बनाएंगे","WEBSITE_P2P_CONTACT":"इच्छुक? आपका स्वागत है हमसे संपर्क करें ।","WEBSITE_P2P_CONTACT_EXTRA":"हमें आपकी सामग्री को स्ट्रैमियो के साथ एकीकृत करने में मदद करने में प्रसन्नता होगी!","WEBSITE_P2P":"एक बार थोड़ी देर में ऐसी तकनीक आती है जो गेम का नाम बदलता है। हमने अपने पीयर-टू-पीयर (पी 2 पी) वीडियो स्ट्रीमिंग इंजन के निर्माण में बहुत समय और प्रयास का निवेश किया जो किसी भी उपयोग केस के साथ अनुकूलित करने के लिए महान प्रदर्शन और बहुमुखी प्रतिभा प्रदान करता है। N Drm-सक्षम पी 2 पी वीडियो के लिए मांग या लाइव स्ट्रीमिंग के लिए हमसे संपर्क करें।","WEBSITE_THOUGHTS":"विचार हम साझा करते हैं:","WEBSITE_SPREAD":"स्ट्रैमियो के बारे में शब्द फैलाएं:","WEBSITE_CONTACT":"हमसे संपर्क करें हम आपसे सुनकर खुश होंगे!","WEBSITE_OPENSOURCE":"हमारे ओपन सोर्स प्रोजेक्ट्स के लिए हमारे पास जाते हैं","WEBSITE_BITCOIN":"बिटकॉइन दान करें:","WEBSITE_FAQ":"अक्सर पूछे जाने वाले प्रश्नों","WEBSITE_FAQ_SHORT":"सामान्य प्रश्न","WEBSITE_QUESTIONS":"प्रशन","WEBSITE_TOS":"उपयोग की शर्तें","WEBSITE_LEGAL":"कानूनी","WEBSITE_PAGE_ABOUT":"के बारे में","WEBSITE_PAGE_BECOME_PARTNER":"भागीदार बनें","WEBSITE_ALL_YOU_CAN_WATCH":"आप चाहते हैं Neverything देखने की स्वतंत्रता।","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"स्ट्रैमियो क्या है?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio वीडियो सामग्री एकत्रीकरण के लिए एक-स्टॉप हब है। अपने आप को किसी भी डिवाइस पर सभी प्रकार के स्रोतों से वीडियो व्यवस्थित करें और देखें।","WEBSITE_WHAT_IS_STREMIO_P2":"मूवीज़ टीवी श्रृंखला लाइव टेलीविजन या वेब चैनल जैसे यूट्यूब और ट्विच.टीवी दिखाता है - आप इसे स्ट्रैमियो पर पा सकते हैं।","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio एक आधुनिक मीडिया केंद्र है जो आपके वीडियो मनोरंजन के लिए एक-स्टॉप समाधान है। आप एडॉन्स स्थापित करने के लिए आसान से वीडियो सामग्री को देखते हैं और व्यवस्थित करते हैं।","WEBSITE_WHAT_IS_STREMIO_P2_V2":"मूवीज़ टीवी लाइव टीवी या वेब चैनल दिखाता है - यह सब स्ट्रैमियो पर खोजें।","WEBSITE_ENJOI_ON_ALL_DEVICES":"अपने सभी मीडिया उपकरणों पर आनंद लें","WEBSITE_DEVICES_COLLECT":"STREMIO से लीजिए","WEBSITE_DEVICES_IMPORT_FB":"फेसबुक से आयात करें","WEBSITE_DEVICES_LOCAL":"स्थानीय ड्राइव से जोड़ें","WEBSITE_JOIN_THE_PARTY_NOW":"अब पार्टी में शामिल हों","WEBSITE_DEVICES_ALL":"अपने सभी उपकरणों पर उपयोग करने में आसान;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly विस्तारणीय वीडियो कैटलॉग;","WEBSITE_ORGANIZE_YOUR_MEDIA":"अपने मीडिया को व्यवस्थित करने के लिए महान सुविधाएं;","WEBSITE_AS_SEEN_ON":"जैसा देखा गया","WEBSITE_STREMIO":"स्ट्रमियो","WEBSITE_LINK_ABOUT_US":"हमारे बारे में","WEBSITE_LINK_TECHNOLOGY":"प्रौद्योगिकी","WEBSITE_LINK_APPS":"ऐप्स","WEBSITE_LINK_DOWNLOADS":"डाउनलोड","WEBSITE_MORE":"अधिक","WEBSITE_LINK_ADDONS":"ऐड-ऑन","WEBSITE_LINK_ADDON_SDK":"एडन एसडीके","WEBSITE_LINK_CONTRIBUTE":"योगदान","WEBSITE_LINK_COMMUNITY":"समुदाय","WEBSITE_LINK_BLOG":"ब्लॉग","WEBSITE_MORE_MORE":"... & अधिक","WEBSITE_LINK_HELP":"सहायता केंद्र","WEBSITE_LINK_CONTACTS":"व्यापार पूछताछ","WEBSITE_LINK_TOS":"नियम एवं शर्तें","WEBSITE_LINK_PRAVACY":"गोपनीयता नीति","WEBSITE_SUBSCRIBE":"सदस्यता लेने के","WEBSITE_NEWSLETTER":"अद्भुत सामान के लिए हमारे न्यूजलेटर में शामिल हों","WEBSITE_PLACEHOLDER_EMAIL":"आपका ईमेल","WEBSITE_COMMUNITY":"समुदाय","WEBSITE_LINK_PRAVACY_LEGAL":"गोपनीयता और कानूनी","WEBSITE_WHY":"हम क्यों करते हैं","WEBSITE_WHY_P1":"Stremio में हम हर दिन काम करने के लिए आते हैं क्योंकि हम वीडियो-ऑन-डिमांड उद्योग के लिए एक महत्वपूर्ण समस्या हल करना चाहते हैं। हर मिनट प्रकाशित इतनी नई सामग्री है कि इसके चारों ओर अपना रास्ता ढूंढना लगभग असंभव है।","WEBSITE_WHY_P2":"हम लोगों को वीडियो मनोरंजन की विशाल दुनिया को नेविगेट करने में मदद करते हैं और आनंद लेने के लिए नई सामग्री की खोज करते हैं। हमारे ऐप्स एक साथ फिल्म श्रृंखला लाइव टीवी वेब चैनल और अधिक लाते हैं। हम उपयोगकर्ताओं के लिए शीर्षक और ब्रॉडकास्टरों को ढूंढने के लिए इसे अविश्वसनीय रूप से आसान बनाने के लिए समर्पित हैं।","WEBSITE_WHY_P3":"आप किसी भी डिवाइस पर हमारी सेवा का उपयोग कर सकते हैं और किसी भी समय STREMIO बनाने के लिए एकमात्र वीडियो मनोरंजन हब बनाने के लिए आपको कभी भी आवश्यकता होगी।","WEBSITE_TEAM":"टीम","WEBSITE_TEAM_P":"Stremio टीम छोटा है लेकिन शक्तिशाली है: हम में से दस के बीच हम एक्स भाषाओं में कोड और सॉफ्टवेयर विकास यूआई और यूएक्स डिजाइन विपणन और विज्ञापन और व्यापार और स्टार्टअप में विशेषज्ञता साझा करते हैं।","WEBSITE_FEATURES":"विशेषताएं","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"आसानी से नई सामग्री की खोज करें","WEBSITE_FEATURES_DISCOVER_P":"आसानी से नई फिल्में टीवी शो श्रृंखला और चैनलों को देखने के लिए खोजें। श्रेणी शैली रेटिंग रिकेंसी आदि द्वारा ब्राउज़ करें या बस खोजने के लिए एक नाम टाइप करें। Stremio नई वीडियो सामग्री केक का एक टुकड़ा खोजने बनाता है।","WEBSITE_FEATURES_ALL_CONTENT":"एक स्क्रीन पर आपकी सभी वीडियो सामग्री","WEBSITE_FEATURES_ALL_CONTENT_P1":"देखें कि आप किन फिल्मों या वीडियो को समाप्त नहीं करते हैं और उन्हें देखना जारी रखते हैं; नए एपिसोड और रिलीज के लिए अधिसूचित हो जाएं; और उन सिफारिशों के माध्यम से ब्राउज़ करें जिन्हें आप अपनी देखने की आदतों के आधार पर प्राप्त करेंगे।","WEBSITE_FEATURES_LIBRARY":"अपनी वीडियो लाइब्रेरी व्यवस्थित करें","WEBSITE_FEATURES_LIBRARY_P1":"अपने STREMIO लाइब्रेरी में किसी भी क्लिक के साथ किसी भी शीर्षक को जोड़ें और अपनी सामग्री के चारों ओर अपनी सामग्री को अच्छी तरह से व्यवस्थित रूप से व्यवस्थित तरीके से व्यवस्थित करें।","WEBSITE_FEATURES_CALENDAR":"आप जो कुछ भी देखते हैं उसका ट्रैक रखें","WEBSITE_FEATURES_CALENDAR_P1":"अपनी लाइब्रेरी में आपके द्वारा जोड़े गए सभी फिल्मों और श्रृंखला का कैलेंडर विज़ुअलाइजेशन प्राप्त करें। अपने STREMIO कैलेंडर निर्यात करें और इसे सिंक करें ताकि आप हमेशा जान सकें कि एक नया एपिसोड या प्रीमियर कब देय है।","WEBSITE_FEATURES_BIG_SCREEN":"एक बड़ी स्क्रीन पर अपनी वीडियो सामग्री का आनंद लें","WEBSITE_FEATURES_BIG_SCREEN_P1":"जो भी आप किसी अन्य डिवाइस पर देख रहे हैं उसे कास्ट करें - चाहे वह एक फोन टैबलेट हो या एक क्लिक के साथ एक टीवी हो।","WEBSITE_FEATURES_SOURCES":"कई अलग-अलग स्रोतों से वीडियो देखें","WEBSITE_FEATURES_SOURCES_P":"कई अलग-अलग प्रदाताओं से प्राप्त वीडियो का आनंद लेने के लिए आधिकारिक और सामुदायिक एडॉन्स स्थापित करें - सभी एक चिकना उपयोग करने में आसान ऐप में।","WEBSITE_CREATE_AN_ADDON":"एक एडन बनाएँ","WEBSITE_FEATURES_SYNC":"अपनी लाइब्रेरी को विभिन्न उपकरणों में सिंक करें और अपने प्लेबैक को फिर से शुरू करें","WEBSITE_FEATURES_SYNC_P1":"अपने सभी डिवाइसों में अपने खाते से लॉगिन करें और अपने लाइब्रेरी एडॉन्स प्लेबैक और कैलेंडर सिंक्रनाइज़ का आनंद लें।","WEBSITE_FEATURES_EXTENDABLE":"एडॉन्स द्वारा विस्तारणीय वीडियो कैटलॉग","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio Addon कैटलॉग विभिन्न प्रकार की वीडियो सामग्री को स्थापित करने और देखने के लिए कई एडॉन्स प्रदान करता है। इसमें फिल्में लाइव टीवी स्पोर्ट न्यूज़ पॉडकास्ट वेब चैनल वीडियो गेम और अधिक दिखाती हैं।","WEBSITE_FEATURES_AUTO_SUBS":"स्वचालित उपशीर्षक","WEBSITE_FEATURES_AUTO_SUBS_P1":"हमारे उपशीर्षक एडॉन्स के साथ आप अपनी पसंदीदा भाषा के लिए स्वचालित रूप से चयनित विकल्प प्राप्त करते हैं।","WEBSITE_FEATURES_CHROMECAST":"क्रोमकास्ट के लिए कास्टिंग","WEBSITE_FEATURES_CHROMECAST_P1":"एक बड़ी स्क्रीन पर अपनी वीडियो सामग्री का आनंद लें या जो भी आप किसी अन्य डिवाइस पर देख रहे हैं उसे डालें।","WEBSITE_FEATURES_KEEP_TRACK":"अपने पसंदीदा टीवी शो और वेब चैनलों का ट्रैक रखें","WEBSITE_FEATURES_KEEP_TRACK_P1":"अपनी पसंदीदा श्रृंखला और वेब चैनलों के नए एपिसोड के लिए कैलेंडर विज़ुअलाइजेशन और नोटिफिकेशन प्राप्त करें।","WEBSITE_FEATURES_POWER_USER":"पावर उपयोगकर्ता सुविधाएँ","WEBSITE_FEATURES_POWER_USER_P1":"बाहरी खिलाड़ी में खेलें","WEBSITE_FEATURES_POWER_USER_P2":"एक टोरेंट फ़ाइल या चुंबक लिंक से खेलें","WEBSITE_FEATURES_POWER_USER_P3":"फेसबुक पसंद या स्थानीय डिस्क से अपनी लाइब्रेरी में आयात करें","WEBSITE_ADD_ONS":"ऐड-ऑन","WEBSITE_ADD_ONS_P1":"सभी वीडियो सामग्री Stremio एक एडन सिस्टम के माध्यम से सोर्स प्रदान की जाती है - ऐप में कोई सामग्री या सामग्री प्रदाता नहीं बनाया गया है।","WEBSITE_ADD_ONS_P2":"एडॉन्स के दो समूह उपलब्ध हैं: आधिकारिक और सामुदायिक एडॉन्स।","WEBSITE_ADD_ONS_P3":"आधिकारिक लोगों को Stremio द्वारा विकसित और होस्ट किया गया है जबकि सामुदायिक एडॉन्स हमारे समुदाय के सदस्यों द्वारा बनाए जाते हैं जो उन्हें भी होस्ट करते हैं।","WEBSITE_ADDONS_OFFICIAL":"सरकारी Addons","WEBSITE_ADDONS_WATCHUB":"अपनी पसंदीदा फिल्में श्रृंखला को स्ट्रीम करें और आईट्यून्स हूलू अमेज़ॅन और अन्य यूके / यूएस सेवाओं जैसे प्रदाताओं से दिखाएं।","WEBSITE_ADDONS_YOUTUBE":"अपने पसंदीदा यूट्यूब चैनलों को विज्ञापन मुक्त देखें और आपके द्वारा अनुसरण किए गए योगदानकर्ताओं से नए अपलोड के लिए अधिसूचनाएं प्राप्त करें।","WEBSITE_ADDONS_FILMON":"मुफ्त में लाइव टीवी फिल्में और सामाजिक टेलीविजन देखें। 600 टीवी चैनल 45000 मुफ्त फिल्में वृत्तचित्र और अधिक।","WEBSITE_ADDONS_OPENSUBTITLES":"मूवी और टीवी उपशीर्षक कई भाषाओं में हजारों अनुवादित उपशीर्षक हर दिन अपलोड किए गए।","WEBSITE_ADDONS_COMMUNITY":"सामुदायिक एडॉन्स","WEBSITE_ADDONS_FILMON_VOD":"फिल्मऑन.टीवी से मांग पर वीडियो देखें","WEBSITE_ADDONS_TWICH":"Twitch.tv से लाइव स्ट्रीम देखें - ई-स्पोर्ट्स उद्योग के लिए एक वीडियो स्ट्रीमिंग प्लेटफ़ॉर्म।","WEBSITE_ADDONS_VODO":"इंडी फिल्में पूरी तरह से नि: शुल्क देखें।","WEBSITE_ADDONS_NETFLIX":"नेटफ्लिक्स फिल्में और वेब श्रृंखला देखें।","WEBSITE_ADDONS_CREATE":"एक एडन बनाएँ","WEBSITE_ADDONS_CREATE_P1":"यदि आप चाहें तो आप अपना खुद का एडन विकसित कर सकते हैं। इस तरह आप अपने आप को और हमारी सामुदायिक पहुंच को नई वीडियो सामग्री तक पहुंचा सकते हैं और दुनिया भर के लाखों उपयोगकर्ताओं के एक नए लक्षित दर्शकों तक पहुंच सकते हैं।","WEBSITE_ADDONS_START_CREATE":"शुरू करने के लिए Stremio Addon SDK पृष्ठ पर जाएं:","WEBSITE_DOWNLOADS":"डाउनलोड","WEBSITE_DOWNLOADS_P1":"इष्टतम प्रदर्शन के लिए हम अनुशंसा करते हैं कि आप STREMIO ऐप्स के नवीनतम उपलब्ध संस्करण का उपयोग करें। यदि किसी कारण से आप पुराने संस्करण का उपयोग करना चाहते हैं तो आप इसे यहां डाउनलोड कर सकते हैं।","WEBSITE_DOWNLOADS_FOR_WIN":"खिड़कियों के लिए STREMIO","WEBSITE_DOWNLOADS_FOR_MAC":"मैकोज़ के लिए स्ट्रेमियो","WEBSITE_DOWNLOADS_FOR_LINUX":"लिनक्स के लिए STREMIO","WEBSITE_DOWNLOADS_FOR_ANDROID":"एंड्रॉइड के लिए स्ट्रेमियो","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"आईओएस के लिए स्ट्रेमियो (सीमित संस्करण)","WEBSITE_CONTRIBUTE":"योगदान","WEBSITE_CONTRIBUTE_P1":"Stremio प्लेटफ़ॉर्म ओपन सोर्स है और आप आसानी से उस सामग्री के लिए एक एडन बना सकते हैं जो वर्तमान में सोर्स नहीं है।","WEBSITE_CONTRIBUTE_WHY":"आपको एडन क्यों बनाना चाहिए?","WEBSITE_CONTRIBUTE_WHY_P1":"अपनी वीडियो सामग्री के लिए नए दर्शकों तक पहुंचें","WEBSITE_CONTRIBUTE_WHY_P2":"स्ट्रैमियो का उपयोगकर्ता आधार तेजी से बढ़ रहा है - लॉन्च स्ट्रैमियो के पहले वर्ष के भीतर दुनिया भर में 1 मिलियन उपयोगकर्ता प्राप्त हुए थे और प्लेटफॉर्म के अस्तित्व के दूसरे वर्ष में यह संख्या 2.5 मिलियन हो गई थी।","WEBSITE_CONTRIBUTE_WHY_P3":"अपने एडन के साथ आप आसानी से इस दर्शकों तक पहुंच सकते हैं और अपनी वीडियो सामग्री को वितरित कर सकते हैं।","WEBSITE_CONTRIBUTE_ALL":"एक ही स्थान पर अपनी पसंदीदा फिल्में वीडियो श्रृंखला और चैनल देखें।","WEBSITE_CONTRIBUTE_ALL_P1":"आप एक विशेष प्रकार की सामग्री के प्रशंसक हैं जो अभी तक स्ट्रैमियो पर उपलब्ध नहीं हैं? इसके लिए एक एडन बनाएं और अपने पसंदीदा वीडियो को बाजार पर मनोरंजन केंद्रों का उपयोग करने के लिए सबसे बड़े और आसान में से एक में देखने का आनंद लें।","WEBSITE_CONTRIBUTE_ALL_P2":"इसके शीर्ष पर आपको अन्य समान विचारधारा वाले स्ट्रैमियो समुदाय के सदस्यों का अंतहीन आभार मिलेगा।","WEBSITE_CONTRIBUTE_MONETIZE":"अपने एडन का मुद्रीकरण करें और अपनी मदद से पैसे कमाएं","WEBSITE_CONTRIBUTE_MONETIZE_P1":"एक बार जब आप STREMIO के लिए एक नया एडन विकसित कर लेंगे तो आप आसानी से इसे कई अलग-अलग तरीकों से मुद्रीकृत कर सकते हैं। यदि आप इस पर विचार कर रहे हैं कि इस पर संपर्क करने के लिए स्वतंत्र महसूस करें","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - हम एडन मुद्रीकरण विकल्पों के बारे में परामर्श करने और सलाह देने में प्रसन्न होंगे।","WEBSITE_CONTRIBUTE_TRANSLATE":"एक स्वयंसेवक अनुवादक बनें","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"यदि आप विभिन्न भाषाओं में स्ट्रैमियो ऐप्स का आनंद लेना चाहते हैं तो आप स्वयंसेवी अनुवादकों के हमारे समुदाय में शामिल हो सकते हैं। वे हमें कई अलग-अलग भाषाओं में stremio के संस्करण जोड़ने में मदद करते हैं।","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"क्या आप शुरू करने के लिए उत्सुक हैं?","WEBSITE_TRANSALTE_STREMIO":"STREMIO का अनुवाद करें","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"सरकारी समुदाय","WEBSITE_COMMUNITY_OFFICIALS_P1":"बढ़ते स्ट्रैमियो समुदाय का हिस्सा बनें। सोशल मीडिया पर हमें का पालन करें और नमस्ते कहने के लिए शर्मिंदा न हों - हम अपने प्रशंसकों से सुनवाई पसंद करते हैं!","WEBSITE_COMMUNITY_UNOFFICIALS":"अनौपचारिक समुदाय","STREMIO_COMMUNITY_NL":"स्ट्रीमियो नीदरलैंड्स","STREMIO_COMMUNITY_BRASIL":"स्ट्रीमियो ब्रासिल","STREMIO_COMMUNITY_GERMANY":"Stremio जर्मनी","STREMIO_COMMUNITY_BELGIUM":"स्ट्रमियो बेल्जियम","STREMIO_COMMUNITY_FRANCE":"स्ट्रमियो फ्रांस","STREMIO_COMMUNITY_PORTUGAL":"स्ट्रमियो पुर्तगाल","STREMIO_COMMUNITY_ITALY":"स्ट्रीमियो इटली","STREMIO_COMMUNITY_UK":"स्ट्रमियो ब्रिटेन","STREMIO_COMMUNITY_USA":"स्ट्रमियो यूएसए","STREMIO_COMMUNITY_MEXICO":"Stremio मेक्सिको","STREMIO_COMMUNITY_ADDONS":"स्ट्रमियो एडॉन्स","STREMIO_COMMUNITY_AWESOME":"भयानक STREMIO","WEBSITE_COMMUNITY_PARTNERS":"भागीदारों और समर्थक","WEBSITE_COMMUNITY_GOODIES":"Stremio उपहार","WEBSITE_COMMUNITY_WALLPAPERS":"वॉलपेपर","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"संपर्क करें","WEBSITE_CONTACT_US_P1":"यदि आपके कोई प्रश्न हैं तो टिप्पणियां या सुझाव नीचे दिए गए संपर्क फ़ॉर्म के माध्यम से हमारे संपर्क में आने के लिए स्वतंत्र महसूस करते हैं।","WEBSITE_CONTACT_US_P2":"ध्यान रखें कि हम बुल्गारिया में स्थित हैं इसलिए समय क्षेत्र के अंतर के कारण आपकी क्वेरी को संबोधित करने में देरी हो सकती है।","WEBSITE_CONTACT_US_SUCCESS":"आपका संदेश भेज दिया गया है। हम आपकी सबसे पुरानी सुविधा पर आपके पास वापस आ जाएंगे।","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"कृपया एक मान्य ईमेल पता प्रवेश करें!","WEBSITE_CONTACT_US_Q_RELATED_TO":"आपका प्रश्न किससे संबंधित है?","WEBSITE_CONTACT_US_Q_OS":"आपका ऑपरेशन सिस्टम क्या है?","WEBSITE_CONTACT_US_PH_EMAIL":"आपका ईमेल","WEBSITE_CONTACT_US_PH_MESSAGE":"संदेश","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"भेजना","WEBSITE_CONTACT_US_Q_1":"स्थापित करने के लिए कैसे?","WEBSITE_CONTACT_US_Q_2":"अनइंस्टॉल कैसे करें?","WEBSITE_CONTACT_US_Q_3":"(HTML) Lasagna कैसे बनाया जाए?","WEBSITE_CONTACT_US_Q_4":"ऐड-ऑन","WEBSITE_CONTACT_US_OS_1":"खिड़कियाँ","WEBSITE_CONTACT_US_OS_2":"मैक ओ एस","WEBSITE_CONTACT_US_OS_3":"लिनक्स","WEBSITE_CONTACT_US_OS_4":"एंड्रॉयड","WEBSITE_CONTACT_US_OS_5":"आईओएस","WEBSITE_TECHNOLOGY":"प्रौद्योगिकी","WEBSITE_TECHNOLOGY_P1":"हम प्रौद्योगिकी और पागल विज्ञान से प्यार करते हैं।
यहां शक्तियां क्या हैं (यह सब ओपन-सोर्स है)।","WEBSITE_TECHNOLOGY_P_QT":"क्रॉस-प्लेटफार्म सॉफ्टवेयर विकास सबसे अच्छा है।","WEBSITE_TECHNOLOGY_P_MPV":"एक मुक्त ओपन सोर्स और क्रॉस-प्लेटफार्म मीडिया प्लेयर।","WEBSITE_TECHNOLOGY_P_RN":"प्रतिक्रिया देशी आपको केवल जावास्क्रिप्ट का उपयोग करके मोबाइल ऐप्स बनाने देता है।","WEBSITE_TECHNOLOGY_P_VLC":"मल्टीमीडिया प्राप्त करने के लिए आवेदन में एम्बेडेड मीडिया फ्रेमवर्क।","WEBSITE_TECHNOLOGY_P_REALM":"दायरे एक मोबाइल मंच और SQLite और कोर डेटा के लिए एक प्रतिस्थापन है।","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js एक ओपन-सोर्स क्रॉस-प्लेटफार्म जावास्क्रिप्ट रनटाइम पर्यावरण है।","WEBSITE_TECHNOLOGY_P_RUST":"जंग एक बहु-प्रतिमान प्रणाली प्रोग्रामिंग भाषा है जो सुरक्षा पर विशेष रूप से सुरक्षित सहमति पर केंद्रित है।","WEBSITE_TECHNOLOGY_CONTRIBUTE":"परियोजना में योगदान","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"STREMIO में दो तरीके हैं और उत्पाद को बेहतर बनाने में हमारी सहायता करें।","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"आप मंच का अनुवाद करके अपने मूल्यवान भाषा कौशल दान कर सकते हैं ...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"या","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... आप समुदाय के एडॉन्स बनाने के लिए अपने कोडिंग कौशल को नियोजित कर सकते हैं।","WEBSITE_TRANSLATE_STREMIO":"STREMIO का अनुवाद करें","WEBSITE_404_OH_NO":"उह ओह! जिस पृष्ठ को आप ढूंढ रहे हैं वह यहां नहीं है ...","WEBSITE_GO_HOME":"घर जाओ","WEBSITE_LINK_OTHER_DOWNLOADS":"अन्य डाउनलोड","WEBSITE_FAQ_ABR":"सामान्य प्रश्न","WEBSITE_SUPPORT":"सहायता","WEBSITE_DOWNLOAD_4_0_BETA":"अब Stremio 4 बीटा डाउनलोड करें","WEBSITE_GET_FOR_DESKTOP":"डेस्कटॉप के लिए जाओ","WEBSITE_LINK_ADDON_COMPETITION":"एडन प्रतियोगिता","WEBSITE_LINK_ART_CONTEST":"कला प्रतियोगिता","WEBSITE_MY_ACCOUNT":"मेरा खाता","WEBSITE_MAINPAGE_FAQ_001_H1":"स्ट्रैमियो क्या है?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio एक आधुनिक मीडिया केंद्र है जो आपको जो कुछ भी आप चाहते हैं उसे देखने की स्वतंत्रता देता है।","WEBSITE_MAINPAGE_FAQ_002_H1":"यह कैसे काम करता है?","WEBSITE_MAINPAGE_FAQ_002_P1":"एक बार जब आप अपने डिवाइस पर STREMIO स्थापित कर लेंगे और एक खाता बनाएं जो आपको करना है, वह एडन कैटलॉग पर जाना है और इच्छित किसी भी एडन को स्थापित करना है और आप जाने के लिए अच्छे हैं!","WEBSITE_MAINPAGE_FAQ_002_P2":"इसके बाद आप सामग्री की खोज शुरू करने के लिए खोज या बोर्ड अनुभागों में जा सकते हैं।","WEBSITE_MAINPAGE_FAQ_003_H1":"मैं यहाँ क्या देख सकता हूँ?","WEBSITE_MAINPAGE_FAQ_003_P1":"ए लॉट: मूवीज़ टीवी शो वेब चैनल स्पोर्ट टीवी चैनल पॉडकास्ट और अधिक सुनते हैं। हमारे एडन सिस्टम के लिए धन्यवाद, आप विभिन्न प्रकार की सामग्री तक पहुंच सकते हैं।","WEBSITE_MAINPAGE_FAQ_004_H1":"क्या स्टेमियो ओपन-सोर्स है?","WEBSITE_MAINPAGE_FAQ_004_P1":"हां आप निम्न लिंक देख सकते हैं: $ {1} डेस्कटॉप ऐप $ {2} और $ {3} github संगठन $ {4}।","WEBSITE_MAINPAGE_FAQ_005_H1":"क्या स्ट्रैमियो सुरक्षित है?","WEBSITE_MAINPAGE_FAQ_005_P1":"हां: क्योंकि यह ओपन-सोर्स सॉफ़्टवेयर है कोड पब्लिक रूप से ऑडिटेबल है और आप इसे स्वयं की समीक्षा कर सकते हैं।","WEBSITE_MAINPAGE_FAQ_006_H1":"मेरी गोपनीयता के बारे में कैसे?","WEBSITE_MAINPAGE_FAQ_006_P1":"हम उपयोगकर्ताओं की गोपनीयता का सम्मान करते हैं और आपके खाते को बनाने और सिंक करने के लिए आवश्यक न्यूनतम के अलावा कोई व्यक्तिगत डेटा एकत्र नहीं करते हैं।","WEBSITE_MAINPAGE_FAQ_006_P2":"साइनअप पर $ {1} अतिथि मोड $ {2} भी है जिसके लिए कोई डेटा नहीं चाहिए: इस मोड में हमारे बैकएंड में कोई कॉल नहीं की जाती है। हालांकि यह उपयोगी सुविधाओं की कीमत पर आता है जैसे कि डिवाइस पर अपनी लाइब्रेरी को सिंक करने में सक्षम होना।","WEBSITE_MAINPAGE_FAQ_007_H1":"क्या मैं अपने टीवी को डाला जा सकता हूं?","WEBSITE_MAINPAGE_FAQ_007_P1":"हां हम क्रोमकास्ट का समर्थन करते हैं और आप डेस्कटॉप और मोबाइल ऐप्स (एंड्रॉइड) दोनों से डाले जा सकते हैं।","WEBSITE_MAINPAGE_FAQ_008_H1":"स्ट्रैमियो में कितने एडॉन्स हैं?","WEBSITE_MAINPAGE_FAQ_008_P1":"2019 से अधिक के अंत तक - अधिक जानकारी के लिए हमारे एडन कैटलॉग की जांच करें।","WEBSITE_MAINPAGE_FAQ_009_H1":"Addon कैटलॉग में क्या है परे stremio विस्तारित किया जा सकता है?","WEBSITE_MAINPAGE_FAQ_009_P1":"हां आपको उन लोगों की जांच करनी चाहिए: $ {1} pimpmystremio $ {2} $ {3} Reddit समुदाय $ {4} $ {5} STREMIO डाउनलोडर $ {6} आदि","WEBSITE_MAINPAGE_FAQ_010_H1":"Stremio किस डिवाइस का समर्थन करता है?","WEBSITE_MAINPAGE_FAQ_010_P1":"हमारे पास विंडोज मैक और लिनक्स के लिए डेस्कटॉप ऐप्स हैं। मोबाइल के लिए हम एंड्रॉइड और आईओएस का समर्थन करते हैं हालांकि ध्यान रखें कि आईओएस कार्यक्षमता में सीमित है (अधिकांश एडॉन्स का समर्थन नहीं करता है)।","WEBSITE_MAINPAGE_FAQ_010_P2":"ऐसे कई एंड्रॉइड-आधारित डिवाइस हैं जिन्हें आप एनवीआईडीआईए शील्ड और अमेज़ॅन फायर स्टिक की तरह स्ट्रैमियो चला सकते हैं लेकिन हम आधिकारिक तौर पर उनका समर्थन नहीं करते हैं।","WEBSITE_MAINPAGE_FAQ_011_H1":"क्या आप STREMIO में कुछ सामग्री जोड़ सकते हैं?","WEBSITE_MAINPAGE_FAQ_011_P1":"क्षमा करें, हम खुद को कोई सामग्री प्रदान नहीं करते हैं लेकिन अधिक स्ट्रैमियो एडॉन्स आपने अधिक सामग्री स्थापित की है जिसे आप ढूंढ पाएंगे।","WEBSITE_MAINPAGE_FAQ_012_H1":"क्या स्ट्रैमियो चुंबक लिंक चला सकते हैं?","WEBSITE_MAINPAGE_FAQ_012_P1":"हां और यह सामान्य HTTP लिंक और टोरेंट फ़ाइलों (ड्रैग और ड्रॉप) भी चला सकता है।","WEBSITE_MAINPAGE_FAQ_013_H1":"क्या मैं एक वीडियो डाउनलोड कर सकता हूं और ऑफ़लाइन देख सकता हूं?","WEBSITE_MAINPAGE_FAQ_013_P1":"उपलब्ध ऑफ़लाइन एक आगामी सुविधा है लेकिन यदि आप अपने डिवाइस (सेटिंग्स पैनल से) को कैश करने की अनुमति देते हैं तो आप बिना किसी कनेक्शन के वीडियो देख सकते हैं।","WEBSITE_MAINPAGE_FAQ_014_H1":"कुछ भी नहीं काम करता है मेरी मदद करो!","WEBSITE_MAINPAGE_FAQ_014_P1":"क्या आप वाकई स्थापित किए गए हैं? यदि हां हमारे $ {1} सहायता केंद्र $ {2} से जांचें।","WEBSITE_MAINPAGE_FAQ_015_H1":"Stremio यह विकास संचालन को कैसे बनाए रखता है?","WEBSITE_MAINPAGE_FAQ_015_P1":"हम गैर-घुसपैठ विज्ञापन $ {1} ADEX $ {2} के माध्यम से चलाते हैं जो एक ही संस्थापक टीम द्वारा एक कंपनी है जो पारदर्शी विज्ञापनों को संरक्षित गोपनीयता पर केंद्रित है।","WEBSITE_MAINPAGE_FAQ_015_P2":"अधिक प्रश्नों के लिए हमारे $ {1} सहायता केंद्र $ {2} पर जाएं।","HELP_LEARN_MORE":"हमारे बारे में अधिक जानने में हमारी सहायता करें।","LIFESTYLE":"बॉलीवुड","SPORTS":"खेल","FOOD_HEALTH":"भोजन और स्वास्थ्य","BEAUTY_FASHION":"सौंदर्य और फैशन","NEWS":"समाचार","GAMING":"जुआ","SCIENCE_EDUCATION":"विज्ञान की पढ़ाई","MUSIC":"संगीत","TRAVEL":"यात्रा","LATE_NIGHT":"देर रात","REALITY":"वास्तविकता","COMEDY":"कॉमेडी","DIY":"DIY कैसे करें","TECH":"तकनीक","CINEMA":"सिनेमा","CONTINUE":"जारी रखें","SLOW_LOADING":"धीमी लोडिंग?","I_GIVE_UP":"मैं हार मानता हूं","LEARN_MORE":"और अधिक जानें","POOR_SOURCE":"यह स्रोत खराब उपलब्ध है या आपका इंटरनेट कनेक्शन पर्याप्त तेज़ नहीं है","PICK_CATEGORIES_ERR":"आपको कम से कम 3 श्रेणियां चुननी होंगी","ADJUST_TIMING":"के साथ समय समायोजित करें","ADJUST_SIZE":"के साथ आकार समायोजित करें","SEARCH_ANYTHING":"आप कुछ भी खोज सकते हैं ...","ALL_CATEGORIES":"सभी","SEARCH_CATEGORIES":"सिनेमा श्रृंखला यूट्यूब और टीवी","SEARCH_PERSONS":"अभिनेता निदेशकों और लेखकों","SEARCH_PROTOCOLS":"HTTP और चुंबक लिंक","SEARCH_TYPES":"आईएमडीबी / टीवीडीबी लिंक","WATCHED":"देखे","SHOW_LESS":"कम दिखाएं","LAST_SEARCHES":"अंतिम खोज","CLEAR_HISTORY":"इतिहास मिटा दें","CHOOSE_SOME":"इनमें से कुछ चुनें:","NO_WEB_REMOTE":"वेब रिमोट लोड नहीं किया जा सका","STREMIO_OFFLINE":"Stremio ऑफ़लाइन है","STREMIO_EXPENSIVE_CONNECTION":"हमने पाया है कि आप मोबाइल डेटा कनेक्शन का उपयोग कर रहे हैं क्या आप जारी रखना चाहते हैं?","USE_DATA":"डेटा का उपयोग करें","WARNING":"चेतावनी","MORE_INFO":"और जानकारी ...","STREMIO_TV_STREMIO":"स्ट्रमियो","STREMIO_TV_LOADING":"लोड हो रहा है ...","STREMIO_TV_BACK_TO_LANGUAGES":"वापस भाषाओं में","STREMIO_TV_REMOTE":"दूरस्थ","STREMIO_TV_GO_TO":"के लिए जाओ:","STREMIO_TV_OR_SCAN":"या स्कैन:","STREMIO_TV_ADDON_INSTRUCTIONS":"कृपया अपने पसंदीदा एडॉन्स को स्थापित करने के लिए निर्देशों का पालन करें।","STREMIO_TV_LIVE_TV":"लाइव टीवी","STREMIO_TV_RESUME_WATCHING":"फिर से देखना","STREMIO_TV_LOADING_BACKGROUND":"लोड हो रहा है पृष्ठभूमि","STREMIO_TV_CHECKING_AUTHENTICATION":"प्रमाणीकरण की जाँच","STREMIO_TV_LOADING_BOARD":"लोड हो रहा हुकुम","STREMIO_TV_LOGIN_HEADER_LINE_1":"हम चाहते हैं कि हमारे उपयोगकर्ताओं को हमारे सॉफ़्टवेयर के साथ सर्वोत्तम संभव व्यक्तिगत अनुभव हो।","STREMIO_TV_LOGIN_HEADER_LINE_2":"यही कारण है कि हम आपको अपने खाते में बनाने और / या लॉगिन करने के लिए कहेंगे।","STREMIO_TV_LOGIN_FOOTER_LINE_1":"समझने के लिए धन्यवाद","STREMIO_TV_LOGIN_FOOTER_LINE_2":"STREMIO टीम","STREMIO_TV_REMOTE_INSTRUCTIONS":"अपने स्मार्टफोन / टैबलेट / डेस्कटॉप के साथ वेब रिमोट का उपयोग करने के लिए:","STREMIO_TV_WIFI_SETUP":"वाई-फाई सेटअप","STREMIO_TV_WIFI_HEADER_LINE_1":"स्ट्रमियो सर्कल ने इंटरनेट कनेक्शन का पता नहीं लगाया।","STREMIO_TV_WIFI_DETAILS_1":"जुड़े:","STREMIO_TV_WIFI_DETAILS_2":"स्ट्रमियो-सर्कल","STREMIO_TV_WIFI_DETAILS_3":"पासवर्ड का प्रयोग करें:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"लिंक के साथ एक वेब ब्राउज़र खोलें:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"खोज","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"चैनल","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"समायोजन","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"खाते लिंक करें","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"खोज","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"साफ़","STREMIO_TV_SEARCH_HISTORY_TITLE":"खोज इतिहास","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"खोज इतिहास साफ़ करे","STREMIO_TV_FILTERS_DESCRIPTION":"नीचे दिए गए किसी एक फ़िल्टर में से चुनें","FILTERS":"फिल्टर","SETTINGS":"समायोजन","ACCOUNT":"खाता","LOGOUT":"लॉग आउट","THEMES":"Themes","PLAYBACK":"प्लेबैक","PLAYBACK_SPEED":"प्लेबैक स्पीड","AUDIO_TRACKS":"ऑडियो ट्रैक","VIDEOS":"वीडियो","SERVER":"सर्वर","LINKS":"Links","ABOUT":"के बारे में","INTERFACE":"इंटरफेस","ANIMATIONS":"एनिमेशन","STATUS":"Status","LANGUAGE":"भाषा","SIZE":"आकार","DELAY":"देरी","BOLD":"बोल्ड","TEXT_COLOR":"लिखावट का रंग","OUTLINE_COLOR":"रूपरेखा रंग","BACKGROUND_COLOR":"पीछे का रंग","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"समय अवधी देखे","AUTO_PLAY":"अगला एपिसोड अपने आप चालू करे","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"देखे गए के रूप में चिह्नित करें","MARK_AS_UNWATCHED":"अनदेखे के रूप में चिह्नित करें","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"देखणा चालू रखे","ALL":"सारे","SECONDS":"सेकंद्स","ON":"चालू","OFF":"बंद","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"स्विच डिवाइस","REMOTE_VIDEOS":"वीडियो","REMOTE_ADJUST_TIMING":"समय समायोजित करें","REMOTE_ADJUST_SIZE":"आकार समायोजित करें","REMOTE_COULD_NOT_BE_LOADED":"वेब रिमोट लोड नहीं किया जा सका","REMOTE_RETRY":"पुन: प्रयास करें","TORRENT_PROFILE_DEFAULT":"डिफ़ॉल्ट","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"स्ट्रैमियो क्या है?","FAQ_001_P1":"Stremio एक मीडिया सेंटर सॉफ्टवेयर है जो वीडियो मनोरंजन के लिए दिमाग में उपयोग के साथ डिज़ाइन किया गया है। STREMIO आपको व्यवस्थित करने की अनुमति देता है & amp; फिल्म श्रृंखला चैनल और लाइव टीवी का अपना संग्रह देखें।","FAQ_001_P2":"Stremio सामग्री को एकत्रित करें जो आपको अपनी स्थानीय डिस्क और हमारे एडॉन्स सिस्टम से दिखाता है।","FAQ_001_P3":"यह आपको यह भी सूचित करेगा कि नए एपिसोड / वीडियो / फिल्में जो आप में रुचि रखते हैं और आपके लिए मूवी सिफारिशें प्रदान करते हैं।","FAQ_02_H1":"STREMIO KODI और PLEX की तुलना कैसे करता है?","FAQ_02_P1":"हम सॉफ्टवेयर के उन दो टुकड़ों से प्रेरित हैं। लेकिन हमारे पास अलग-अलग लक्ष्य हैं - स्ट्रैमियो विशेष रूप से मनोरंजन वीडियो की ओर लक्षित है और इसका उपयोग करने में आसान होने के लिए मुख्यधारा के समाधान बनने का प्रयास करता है।","FAQ_02_P2":"स्ट्रैमियो कभी भी अनुकूलन योग्य और कोडी और प्लेक्स के रूप में समृद्ध नहीं होगा, लेकिन इसका उपयोग करना काफी आसान है। बस $ {1} इसे प्राप्त करें और $ {2} देखें :)","FAQ_03_H1":"Stremio नेटफ्लिक्स की तुलना कैसे करता है?","FAQ_03_P1":"फिर से नेटफ्लिक्स हमारी प्रेरणाओं में से एक है। हम नेटफ्लिक्स के उपयोगकर्ता अनुभव को बहुत से अतिरिक्त उपहारों को प्राप्त करने का प्रयास करते हैं। लेकिन सबसे महत्वपूर्ण बात यह है कि हम आपको अपनी लाइब्रेरी प्रबंधित करने और हमारे एडन सिस्टम के साथ नए सामग्री स्रोत जोड़ने की स्वतंत्रता दे रहे हैं।","FAQ_03_P2":"इससे स्ट्रैमियो असीमित रूप से विस्तार योग्य बनाता है, इसलिए जब आप स्ट्रैमियो का उपयोग करते हैं तो आप कभी भी सामग्री से सीमित नहीं होते हैं नेटफ्लिक्स लाइसेंस का फैसला करता है। उदाहरण के लिए स्ट्रैमियो के माध्यम से आप $ {1} filmon.tv $ {2} $ {3} twitch.tv $ {4} $ {5} youtube $ {6} $ {7} वोडो $ {8} और से सामग्री देख सकते हैं यहां तक ​​कि $ {9} netflix $ {10} ही!","FAQ_04_H1":"स्ट्रैमियो फ्लिपबोर्ड की तुलना कैसे करता है?","FAQ_04_P1":"हमें वह सवाल नहीं मिलता है जो अक्सर लोगों को स्टार्ट-अप करने के लिए छोड़कर को छोड़कर :)","FAQ_04_P2":"Stremio एक सामग्री एग्रीगेटर डिजाइन द्वारा है जो अनिवार्य रूप से इसे वीडियो के लिए फ्लिपबोर्ड बनाता है। यह हमारे बोर्ड सेक्शन में बहुत स्पष्ट है जो आपको फ्लिपबोर्ड की तरह अनुसरण करने के लिए कैटलॉग और नया एपिसोड / नई वीडियो अधिसूचना देता है।","FAQ_05_H1":"Stremio पॉपकॉर्न समय की तुलना कैसे करता है?","FAQ_05_P1":"Stremio और पॉपकॉर्न समय उपयोगकर्ता इंटरफ़ेस में समान हैं क्योंकि वीडियो मनोरंजन कैटलॉग सही करने के कई तरीके नहीं हैं :)","FAQ_05_P2":"लेकिन पॉपकॉर्न टाइम विशिष्ट स्रोतों से टॉरेंट स्ट्रीमिंग पर केंद्रित है Stremio अप्रतिबंधित है और केवल एक सामग्री एग्रीगेटर है - यह एक विशिष्ट सामग्री स्रोत में बंद नहीं है।","FAQ_05_P3":"इसके अलावा हम डिफ़ॉल्ट रूप से किसी भी टोरेंट एडॉन्स प्रदान नहीं करते हैं, इसलिए स्ट्रैमियो को आधिकारिक कार्यक्षमता के साथ पॉपकॉर्न टाइम उपयोग-केस को कवर नहीं किया जाता है।","FAQ_05_P4":"एक और उल्लेखनीय अंतर यह है कि पॉपकॉर्न टाइम पूरी तरह से खुला स्रोत है जबकि Stremio $ {1} आंशिक रूप से ओपन सोर्स $ {2} है।","FAQ_06_H1":"क्या आप इस फिल्म / श्रृंखला को जोड़ देंगे?","FAQ_06_P1":"कोई खेद नहीं :(","FAQ_06_P2":"जैसा कि अन्य प्रश्नों में उल्लेख किया गया है Stremio स्वयं से कोई सामग्री प्रदान नहीं करता है - सब कुछ एडॉन्स सिस्टम के माध्यम से जोड़ा जाता है। यदि आपके पास कोई सामग्री अनुरोध है तो आप उस खिलाड़ी में रिपोर्ट बटन का उपयोग कर सकते हैं जो वर्तमान में आपके द्वारा उपयोग किए जा रहे एडन के लेखक को एक ईमेल भेज देगा।","FAQ_07_H1":" ","FAQ_07_P1":" ","FAQ_07_P2":" ","FAQ_08_H1":"क्या आप एक्स के लिए एडन बनाएंगे?","FAQ_08_P1":"यह पूरी तरह से संभव है।","FAQ_08_P2":"यदि आपके पास Addon के लिए एक विचार है तो हमें $ {1} office@stremio.com पर एक लाइन छोड़ें, लेकिन कृपया सुनिश्चित करें कि आपका एडन विचार किसी भी कॉपीराइट या उपयोग की शर्तों का उल्लंघन नहीं करेगा।","FAQ_08_P3":"फिलहाल हमारे रोडमैप पर अगली चीजें मांग और क्रंचरोल पर fandangonow filmon.tv वीडियो के लिए Addons हैं।","FAQ_09_H1":"क्या Stremio बिटटोरेंट का उपयोग करता है?","FAQ_09_P1":"हां स्ट्रैमियो एक स्ट्रीमिंग प्रोटोकॉल के रूप में बिटटोरेंट का समर्थन करता है। आप या तो एक टोरेंट एडन के साथ या ड्रैग-एंड-ड्रॉप करके एक .torrent फ़ाइल को स्ट्रैमियो में या एक चुंबक लिंक को खोज बार में चिपकाने के साथ कर सकते हैं।","FAQ_09_P2":"कृपया ध्यान दें कि बिटटोरेंट का उपयोग कर एकमात्र आधिकारिक एडन $ {1} वोडो $ {2} है जो इंडी सामग्री प्रदान करता है सभी को बिटटोरेंट के साथ वितरित करने की अनुमति है।","FAQ_09_P3":"हम किसी तीसरे पक्ष के एडॉन्स के उपयोग का समर्थन नहीं करते हैं जो कॉपीराइट उल्लंघन को सक्षम कर सकता है।","FAQ_10_H1":"आधिकारिक एडॉन्स के साथ स्ट्रैमियो में मैं क्या देख सकता हूं?","FAQ_10_P1":"डिफ़ॉल्ट रूप से आप अपने एम्बेडेड प्लेयर के साथ स्ट्रैमियो के भीतर फिल्मऑन.टीवी यूट्यूब और वोडो सामग्री देख सकते हैं। इसके अतिरिक्त हमारे पास twitch.tv और कुछ अन्य लोगों के लिए एक एडन है।","FAQ_10_P2":"यह संयुक्त का चयन प्रदान करता है:","FAQ_10_L1":"Filmon.tv द्वारा प्रदान किए गए लोकप्रिय टीवी चैनल - उदाहरण के लिए ई 4 बीबीसी बॉलीवर्ल्ड टीवी","FAQ_10_L2":"यूट्यूब से सब कुछ - उदाहरण के लिए बीबीसी समाचार शीर्ष गियर vevo pewdiepie","FAQ_10_L3":"वोडो के साथ इंडी फिल्में","FAQ_10_L4":"Twitch.tv के साथ ऑनलाइन गेमिंग प्रसारण","FAQ_10_P3":"इसके अतिरिक्त गाइडबॉक्स और नेटफ्लिक्स एडॉन्स के साथ प्रदान किए गए कई सामग्री स्रोत हैं जो नहीं करते हैं पूरी तरह से स्ट्रैमियो के अंदर खेलते हैं लेकिन दी गई सेवा में रीडायरेक्ट करेंगे। उदाहरण के लिए गाइडबॉक्स एडन आपको उन फिल्मों का चयन करेगा जो आप अमेरिका में Tubitv और क्रैकल जैसी सेवाओं से मुक्त करने के लिए स्ट्रीम कर सकते हैं।","FAQ_11_H1":"Stremio स्थापित नहीं होगा कि मुझे क्या करना चाहिए?","FAQ_11_P1":"यदि आप विंडोज़ पर $ {1} इस वैकल्पिक इंस्टॉलर $ {2} का प्रयास करें।","FAQ_11_P2":"यदि आप मैक ओएस एक्स पर हैं तो कृपया ध्यान रखें कि हम ओएस एक्स मैवरिक्स (10.9) से पुराने कुछ भी समर्थन नहीं करते हैं।","FAQ_11_P3":"यदि आप लिनक्स पर हैं तो ध्यान रखें कि हम इस समय केवल 64 बिट (x64) लिनक्स का समर्थन करते हैं।","FAQ_11_P4":"यदि आप अभी भी अपनी समस्या का समाधान नहीं कर सकते हैं तो कृपया हमें $ {1} फेसबुक ग्रुप $ {2} पर लिखें।","FAQ_12_H1":"मेरा एंटी-वायरस क्यों शिकायत करता है? क्या स्ट्रैमियो सुरक्षित है?","FAQ_12_P1":"हम आपको आश्वस्त करते हैं कि STREMIO $ {1} 100% क्लीन $ {2} है।","FAQ_12_P2":"आपका एंटीवायरस शिकायत कर रहा है क्योंकि हम अपने इंस्टॉलर में विज्ञापन शामिल करते हैं जो कुछ एंटी-वायरस प्रोग्राम विज्ञापन-बर्तन के रूप में पहचानते हैं।","FAQ_12_P3":"यदि आप अभी भी अनिश्चित हैं तो आप हमारे $ {1} वैकल्पिक इंस्टॉलर $ {2} को आजमा सकते हैं।","FAQ_13_H1":"मैं एडन कैसे बना सकता हूं?","FAQ_13_P1":"शुरुआत करने वालों के लिए हम आपको गिटहब पर $ {1} एडॉन्स सिस्टम मॉड्यूल $ {2} की जांच करते हैं।","FAQ_13_P2":"बाद में आप $ {1} हैलो वर्ल्ड ट्यूटोरियल $ {2} का अनुसरण कर सकते हैं।","FAQ_13_P3":"यदि आपके पास कोई प्रोग्रामिंग कौशल नहीं है तो कृपया $ {1} reddit समुदाय $ {2} पर अपना विचार पोस्ट करें और $ {3}office@stremio.com $ {4} पर अपने एडन आइडिया के साथ हमसे संपर्क करें।","FAQ_14_H1":"एडॉन्स कैसे प्रकाशित होते हैं?","FAQ_14_P1":"जब आप एक एडन और होस्ट बनाते हैं और अपने मैनिफेस्ट में एंडपॉइंट फ़ील्ड बनाते हैं जो एक काम करने वाले एडन पते को इंगित करता है, एडन स्वचालित रूप से खुद को $ {1} एडन कैटलॉग $ {2} में प्रकाशित करेगा।","FAQ_14_P2":"ऐसा इसलिए होता है क्योंकि स्ट्रैमियो-एडॉन्स मॉड्यूल का सर्वर हिस्सा स्वचालित रूप से एडन की घोषणा करने के लिए हमारे एपीआई को कॉल करता है। जब हमारा एपीआई आपके एंडपॉइंट को मान्य एडन के रूप में मान्य करता है तो यह कैटलॉग में दिखाना शुरू कर देगा।","FAQ_15_H1":"क्या मैं अपने ब्राउज़र में STREMIO चला सकता हूं?","FAQ_15_P1":"फिलहाल नहीं, लेकिन यह आ रहा है!","FAQ_15_P2":"यदि आप एक अल्फा देखने के लिए उत्सुक हैं तो आप इसे यहां देख सकते हैं: $ {1} alpha4.strem.io $ {2}। ध्यान रखें कि इस अल्फा पर स्ट्रीमिंग अक्षम है। हम क्रोम फ़ायरफ़ॉक्स ओपेरा और एज का समर्थन करते हैं।","FAQ_16_H1":"टीवी के लिए कास्टिंग काम / उपशीर्षक काम नहीं करता है","FAQ_16_P1":"टीवी में कास्टिंग डीएलएनए तकनीक का उपयोग करता है जो विभिन्न टीवी ब्रांडों और मॉडलों के बीच बहुत असंगत है। इसी कारण से हमारे पास हर मामले में इसका परीक्षण करने की क्षमता नहीं है, इसलिए यह सही से दूर है। इसके बावजूद हम इसे लगातार सुधारने पर काम कर रहे हैं लेकिन हम आपको एक समय का अनुमान नहीं दे सकते हैं जब डीएलएनए आपके टीवी के साथ ठीक से काम करना शुरू कर देगा।","FAQ_16_P2":"यदि आप कास्टिंग मेनू में अपना टीवी भी नहीं देखते हैं तो कृपया अपने नेटवर्क कनेक्शन को अक्षम करने और इसे फिर से सक्षम करने का प्रयास करें (विंडोज़ राइट पर नेटवर्क पर क्लिक करें और सक्षम / अक्षम करें) के साथ ही अपने राउटर टीवी और पीसी को पुनरारंभ करें।","FAQ_16_P3":"यदि आप अभी भी मुद्दों का सामना कर रहे हैं तो आप अपने टीवी ब्रांड और मॉडल जानकारी को ${1}office@stremio.com $ {2} पर भेजकर हमारी सहायता कर सकते हैं।","FAQ_16_P4":"इस बीच हम क्रोमकास्ट की सलाह देते हैं कि हम एक अच्छी तरह से समर्थन करते हैं या बस अपने टीवी में अपने पीसी में एक एचडीएमआई केबल के साथ प्लगिंग करते हैं।","FAQ_17_H1":"Stremio फ्रीज और / या दुर्घटनाओं मैं क्या कर सकता हूँ?","FAQ_17_P1":"सबसे पहले यदि आप एवीजी एंटी-वायरस के साथ विंडोज 7 का उपयोग कर रहे हैं: हमें उस संयोजन के साथ एक समस्या है। समस्या एवीजी में ही है और हमारे अंत में इसे हल करने का कोई उचित तरीका नहीं है। दुर्भाग्य से एंटी-वायरस को अपवाद या अक्षम करना काम नहीं करेगा। एकमात्र समाधान एवीजी को किसी और चीज के साथ बदलने के लिए है।","FAQ_17_P2":"यदि यह समस्या नहीं है लेकिन आप अभी भी विंडोज़ का उपयोग कर रहे हैं तो कृपया नवीनतम सर्विस पैक में अपडेट करें और अपने जीपीयू ड्राइवरों को अपडेट / इंस्टॉल करें फिर पुन: प्रयास करें।","FAQ_17_P3":"यदि आप समस्या को हल नहीं कर रहे हैं या आप मैक या लिनक्स का उपयोग कर रहे हैं तो कृपया हमें $ {1} हमारे फेसबुक ग्रुप $ {2} पर समस्या के सटीक विवरण की रिपोर्टिंग करें।","FAQ_18_H1":"मैं एडन कैसे बना सकता हूं?","FAQ_18_P1":"शुरुआत करने वालों के लिए हम आपको गिटहब पर $ {1} एडॉन्स सिस्टम मॉड्यूल $ {2} की जांच करते हैं।","FAQ_18_P2":"बाद में आप $ {1} हैलो वर्ल्ड ट्यूटोरियल $ {2} का अनुसरण कर सकते हैं।","FAQ_18_P3":"यदि आपके पास कोई प्रोग्रामिंग कौशल नहीं है तो कृपया $ {1} reddit समुदाय $ {2} पर अपना विचार पोस्ट करें और $ {3}office@stremio.com $ {4} पर अपने एडन आइडिया के साथ हमसे संपर्क करें।","FAQ_19_H1":"STREMIO डिस्क स्थान क्यों ले रहा है?","FAQ_19_P1":"स्ट्रीमियो में अस्थायी रूप से स्ट्रीम करने वाली वीडियो फ़ाइलों को रखने के लिए स्थानीय कैश है।","FAQ_19_P2":"इसमें दो लाभ हैं: सबसे पहले यह STREMIO को आगे के वीडियो को पूर्व-बफर करने की अनुमति देता है ताकि चिकनी स्ट्रीमिंग सुनिश्चित हो सके। दूसरा यह वीडियो को स्थानीय कैश में रखता है ताकि आप उन्हें ऑफ़लाइन देखना जारी रख सकें।","FAQ_19_P3":"सेटिंग पैनल में कैश सेटिंग पर कितना स्ट्रैमियो निर्भर करता है। स्ट्रैमियो आपकी डिस्क पर सेट राशि (उदा। 2 जीबी) तक रख सकता है जब तक कि वर्तमान में स्ट्रीम किए गए वीडियो उस मामले से बड़े न हों, जिस स्थिति में इसे तब तक रखने के लिए पर्याप्त भंडारण आवंटित करना होगा जब तक कि आप इसे स्ट्रीम कर रहे हों।","FAQ_20_H1":"कैश फ़ोल्डर कहां है?","FAQ_20_P1":"विंडोज़ पर यह सेटिंग्स में चुने गए ड्राइव में स्ट्रैमियो-कैश है (उदा। E: stremio-cache)","FAQ_20_P2":"मैकोज़ पर यह ~ / पुस्तकालय / आवेदन समर्थन / stremio / stremio-cache","FAQ_20_P3":"लिनक्स पर यह ~ / .stremio / stremio-cache या ~ / stremio-cache","FAQ_21_H1":"मुझे मिलता है स्ट्रीमिंग सर्वर त्रुटि नहीं मिली है मैं क्या कर सकता हूं?","FAQ_21_P1":"यदि आपको यह त्रुटि मिलती है तो इसका मतलब कुछ चीजों में से एक है:","FAQ_21_P2":"1) आप हमारे $ {1} वेब संस्करण $ {2} के माध्यम से यूट्यूब / बिटटोरेंट स्रोत द्वारा समर्थित एडन का उपयोग करने की कोशिश कर रहे हैं। इस मामले में आपको हमारे डेस्कटॉप संस्करण को $ {3} हमारी वेबसाइट $ {4} से इंस्टॉल करना चाहिए।","FAQ_21_P3":"2) आपके STREMIO स्थापना के साथ कुछ गलत है। इस मामले में $ {1} वेबसाइट $ {2} से हमारे नवीनतम डेस्कटॉप संस्करण को पुनः स्थापित करने का प्रयास करें। यदि यह आपके पीसी को पुनरारंभ करने और फिर से कोशिश करने वाले एंटी-वायरस प्रोग्राम और फ़ायरवॉल को अक्षम करने का प्रयास करने में मदद नहीं करता है। यदि यह काम नहीं करता है तो कृपया हमें हमारे $ {3} हमारे फेसबुक समूह $ {4} पर लिखें।","FAQ_22_H1":"मैं आईओएस पर अधिकांश एडॉन्स को नहीं देख सकता / उपयोग नहीं कर सकता","FAQ_22_P1":"ऐप्पल ऐप स्टोर के नियमों और शर्तों में प्रतिबंधों के कारण हमने केवल आईओएस आवेदन को केवल एडॉन्स के एक विशेष सेट पर प्रतिबंधित कर दिया है।","FAQ_22_P2":"लेकिन बाकी आश्वासन दिया गया है - भविष्य में आईओएस के लिए और अधिक एडॉन्स होंगे और हम एक एकीकरण भी जोड़ सकते हैं जो आपको आईओएस ऐप को स्ट्रैमियो स्ट्रीमिंग सर्वर से जोड़ने के लिए सभी स्ट्रैमियो एडॉन्स का उपयोग करने की अनुमति देगा।"}')},487:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filmovi","TYPE_series":"Serije","TYPE_tv":"TV","TYPE_channel":"Kanal","TYPE_other":"Ostalo","TYPE_movie_PL":"Filmovi","TYPE_series_PL":"Serije","TYPE_tv_PL":"TV","TYPE_channel_PL":"Kanal","TYPE_other_PL":"Ostalo","TYPE_ALL":"All","VIDEO":"Video","BACK":"Povratak","MORE":"Više","DONE":"Završeno","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Otkrij","Board":"Početna","Library":"Videoteka","My Library":"Moja videoteka","Calendar":"Kalendar","NOTIFICATION_ONLINE":"Sada ste povezani","NOTIFICATION_OFFLINE":"Niste povezani","INTERNET_CONNECTION":"Greška povezivanja","STORAGE_FULL_TITLE":"Upozorenje: memorija je popunjena!","STORAGE_FULL_TEXT":"Vaše postavke, preferencije ili podaci za prijavu neće biti spremljeni. Ponovno pokrenite ili ponovno instalirajte Stremio.","SEARCH":"Tražilica...","SEARCH_NO_RESULTS":"Nema pronađenih rezltata","SEARCH_EXPLANATION_CONTENT":"Pretraži filmove, serije, YouTube i TV kanale","SEARCH_EXPLANATION_PEOPLE":"Pretraži glumce, redatelje i producente","SEARCH_PASTE_LINKS":"Kopiraj poveznice","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Dodaj u videoteku","REMOVE_FROM_LIB":"Ukloni iz videoteke","ADDED_TO_LIB":"Dodano u videoteku","REMOVED_FROM_LIB":"Uklonjeno iz videoteke","TRAILER":"Najava","WATCH_TRAILER":"Pogledaj najavu","WATCH_NOW":"Pokreni gledanje","SHOW":"Prikaži","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Gledaj nasumično","IMDB_RATING":"IMDb Ocjena","YEAR":"Godina","DIRECTOR":"Redatelj","WRITER":"Producent","LEAD_ACTORS":"Glavni glumci","CAST":"Uloge","CREW":"Ekipa","SHOW_MORE_CAST":"Prikaži više »","AIRED":"Emitirano","SEASONS":"Sezone","GENRE":"Žanr","CATALOG":"Katalog","SUMMARY":"Sažetak","SHOW_MORE":"Prikaži još","SIMILAR":"Slično","UPCOMING":"Nadolazeće","ENDED":"Završeno","DURATION":"Trajanje","FEATURED":"Istaknuto","METADATA":"Metadata","CATEGORY":"kategorija","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"pretraži videe","SEARCH_PLACEHOLDER":"traži sadržaj ili upiši magnet linkove","ADDON":"dodatak","ADDONS":"Dodaci","OFFICIAL":"službeni","ADDONS_OFFICIAL":"Službeni Stremio Dodaci","ADDONS_POPULAR":"Popularno na vašem području","ADDON_FREE":"besplatni dodaci","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"pretplata","ADDON_STREAM_GEORESTRICTED":"nije dostupno na vašem području","ADDON_STREAM_OFFLINECACHE":"Cache nije povezan","ADDON_STREAM_LOCALFILE":"Lokalni dokument","SHARE_ADDON":"Dijeli Dodatak","AVAILABLE_STREAMS":"Dostupni prijenosi","NO_STREAM":"Nema dostupnih prijenosa","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Za više prijenosa instalirajte još Dodataka","STREAM_NOT_SUPPORTED":"Odabrani prijenos nije podržan.","ADDON_CATALOGUE":"Prikaži sve dodatke »","ADDON_CATALOGUE_MORE":"Više dodataka »","REPO_ADDED":"Repozitorij je dodan","ADDON_REPO_EXIST_ERR":"Ovaj dodatak je već dodan","ADDON_REPO_ERR":"Greška prilikom dodavanja repozitorija","ADDON_ADD_ERR":"Greška prilikom dodavanja dodatka","ERR_ADDON_PROTECTED":"Dodatak je zaštićen","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Nešto je pošlo po krivu - autentifikacija možda nije uspjela","ERR_NOT_COLLECTION_URL":"Nije url kolekcije","ERR_NOT_ADDON_URL":"Nije url dodatka","ERR_DETECTFROMURL":"Nemoguće otkriti podatke iz url-a","ADDON_DUPLICATE_WARNING":"Upozorenje: duplicirani dodatak","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Dodavanje dodatka nije uspjelo","REFRESH_ON_CLICK":"Pritisni za ponovno učitavanje","STILL_IN_THEATER":"Film je i dalje u kinu","WATCH_IN_CINEMA":"Pogledaj ga u kinu","IN_THEATER":"U kinu","GET_TICKETS":"Nabavi karte","UPCOMING_EPISODE":"Nadolazeća epizoda","UPCOMING_EPISODE_MESSAGE":"Ova epizoda emitirati će se:","MISSING_DATE_EPISODE":"Nedostaje nadnevak epizode","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Ovaj kanal još nije spremljen.
Molimo vas pokušajte za nekoliko minuta.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Dodajte u svoju videoteku da budete obešteni kada bude dostupno.","GET_NOTIFIED_WHEN_AVAILABLE":"Biti ćete obavješteni kada bude dostupno.","WARNING_STREAMING_SERVER":"Upozorenje: lokalni server za prijenos nije pronađen. Prijenos sa YouTube-a i BitTorrent-a neće biti dostupan.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Upozorenje: ovaj video možda ne podržava vaš hardver. Imajte na umu da reprodukcija može biti spora.","PLAYER_ERROR":"Ups, greška playera","PLAYER_ERROR_LOOKSLIKE":"Izgleda kao","PLAYER_ORIENTATION":"Orijentacija playera","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Fiksno","PLAYER_ORIENTATION_SENSOR_SHORT":"Senzor","PLAYER_ORIENTATION_LANDSCAPE":"Orijentacija playera fiksirana je vodoravno","PLAYER_ORIENTATION_SENSOR":"Orijentacija playera je automatska (senzor)","PLAYER_PLAYBACK_SPEED":"Brzina prikazivanja","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Uživo","PLAYER_NEXT_VIDEO_TITLE":"U sljedećem nastavku","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Odbaci","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Gledaj odmah","STREAMING_FROM":"pokretanje iz","CASTING_TO":"Prikazivanje na","NETWORK_STATUS":"Mrežni status","STREAM_SPEED":"Brzina prikazivanja:","STREAM_BUFFERED":"Učitano:","PEERS_INFO":"Peer Informacije","PEERS_ACTIVE":"Aktivno:","PEERS_CONNECTED":"Spojeno:","PEERS_WAITING":"Na čekanju:","TRANSCODING_WARNING":"Upozorenje: pretvaranje videa.","STREAM_LOADING":"učitavanje...","PLAYING_LOCAL":"pokretanje iz lokalne datoteke","PLAYING_CACHE":"pokretanje iz privremenog skladišta","WRONG_SUBS":"Pogrešan prijevod?","ERR_SUBS_LOADING_TITLE":"Greška pri učitavanju podnapisa","ERR_SUBS_LOADING":"Greška pri učitavanju podnapisa: može biti do dodatka kojeg koristite, ili do internet povezanosti","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Sljedeći dodaci za podnapise ne rade","ERR_CASTING_UPDATE_TITLE":"Nemoguće ažurirati info o djeljenje ekrana: server možda nije spojen","CHOOSE_DEVICE":"Izaberi uređaj za gledanje","NO_CAST_DEVICES":"Nema dostupnih uređaja za odašiljanje.","NO_SETTINGS":"Nema dostupnih postavki.","PHONE_TABLET":"Mobitel / Tablet","SUBTITLES":"Podnapisi","SUBTITLES_CHANGE":"Promjeni podnapis za ","SUBTITLES_CHANGE_NONE":"Nažalost, nema drugih podnapisa za odabrani jezik","SUBTITLES_CHANGE_ACIVE":"Trenutno titl #{{subtitlesDialog.activeIdx + 1}} je aktivan. Klikni \\"Nastavi\\" da aktiviraš podnapis #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alterantivno,","SUBTITLES_ADJUST_DELAY":"Podešavanje kašnjenja podnapisa:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Ili koristi G / H gumb dok gledate da postavite podnapise.","SUBTITLES_ADJUST_DELAY_TIP":"Savjet: možete koristiti tipke G / H tijekom gledanja kako biste podesili kašnjenje podnapisa.","SUBTITLES_DELAY":"Kašnjenje podnapisa:","SUBTITLES_LOADING":"Učitavanje podnapisa...","SUBTITLES_UNAVAILABLE":"Nema dostupnih vanjskih podnapisa","SUBTITLES_DISABLED":"Isključeno","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sezona","EPISODE":"Epizoda","SPECIAL":"Special","SORT":"poredaj","SORT_BY":"Poredaj po","FILTER":"filtriraj","SORT_TRENDING":"popularno","SORT_RECENT":"nedavno","SORT_ALPHABET":"A-Ž","SORT_RATING":"ocjena","SORT_WATCHED":"gledano","SORT_YEAR":"godina","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Novo za vas","New Episodes":"Nove epizode","New Videos":"Novi Videi","Recommendations":"Preporuke","LIBRARY_RESUME":"nastavi","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Pojedinosti","LIBRARY_RESUME_DISMISS":"odbaci","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Istaktnut","DISCOVER_TOP":"Najbolji","DISCOVER_OSCAR":"Dobitnici Oskara","DISCOVER_WARNING_TITLE":"Ups!","DISCOVER_EMPTY_CATALOG":"Dodatak je vratio prazan sadržaj.","DISCOVER_ADULT_WARNING":"Ovaj sadržaj dostupan je samo odraslima. Imaš li 18+ godina?","DISCOVER_NOADDON_WARNING":"Upozorenje: nema aktivinog Stremio dodatka za ovaj tip. Prikazujemo spremljene stvari, ništa se neće promijeniti.","DISCOVER_LOAD_ERR":"Sadržaj nije pokrenut, greška.","DISCOVER_ADDON_UNINSTALLED":"Sadržaj više nije dostupan. Moguće da ste izbriali dodatak.","UNINSTALL_THIS_ADDON":"Ukloni dodatak","ERR_ADDON_NOT_INSTALLED":"Ovaj dodatak nije instaliran. Instalirati sada?","DETAIL_RECEIVE_NOTIF_SERIES":"Primaj obavijesti o novim epizodama","DETAIL_RECEIVE_NOTIF_VIDEOS":"Primaj obavijesti o novim videima","SIDEBAR_SHOW_STREAMS":"Prikaži prijenose","RELAUNCH":"Ponovo pokreni sada!","UPGRADE":"Nova verzija je dostupna! Nadogradi se na najnoviju inačicu Stremija","RELOAD_UI":"Ponovno učitaj korisničko sučelje","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"Koristite zastarjelu verziju Stremija što nije preporučljivo.","MANUAL_UPDATE_LINE2":"Molimo, ažurirajte čim prije.","BUTTON_UPDATE_LATTER":"Ne sada","BUTTON_UPDATE_NOW":"Ažuriraj","ANONYMOUS_USER":"Anonimni korisnik","DONT_HAVE_ACC":"Nemate račun?","HAVE_ACC":"Već imate račun?","PASSWORD":"Lozinka","PASSWORD_CONFIRM":"Potvrdite lozinku","EMAIL":"E-mail","FB_LOGIN":"Prijavi se preko Facebook-a","FB_NOTHINGSHARED":"Ništa se ne dijeli bez vaše dozvole","FB_NOPOST":"Nećemo objavljivati ništa u vaše ime","OR":"ili","I_ACCEPT":"Prihvaćam","I_ACCEPT_BY_CLICKING":"Klikom na gornji gumb prihvaćam uvjete","TOS":"Uvjete i Odredbe","MUST_ACCEPT_TERMS":"Morate prihvatiti uvjete","PASSWORDS_NOMATCH":"Lozinke se ne podudaraju","SIGN_UP":"Registracija","SIGN_UP_EMAIL":"Prijavite se putem e-pošte","CLICK_TO_SIGN_UP":"Ovdje pritisnite za registraciju.","LOG_IN":"Prijavi se","LOG_OUT":"Odjavi se","EXIT_FULLSCREEN":"Izađi iz punog prikaza","ENTER_FULLSCREEN":"Uđi u puni prikaz","PLAY_URL_MAGNET_LINK":"Pokreni URL/Magnet poveznicu","HELP_FEEDBACK":"Podrška i povratna informacija","TERMS_OF_SERVICE":"Uvjeti korištenja usluge","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"O Stremiju","USER_PANEL":"Korisniča traka","LOGIN_LABEL":"Login","GUEST_LOGIN":"Prijavi se kao gost","GUEST_LOGIN_NOTICE":"Gostujuća prijava nije preporučljiva. Koristeći redovnu prijavu, Stremio omogućava sinkronizaciju svoje videoteke, primanje obavještenja o omiljenim serijama / kanalima. Jeste li sigurni da želite nastaviti?","GUEST_LOGIN_NOTICE_2":"Gostujuća prijava nije preporučljiva - nećete imati sinkronizaciju obavijesti Videoteke i Ploče, koje su od važnosti za Stremio. Jeste li sigurni da želite nastaviti?","CLICK_HERE":"klikni ovdje","WRONG_PASSWORD":"Pogrešna lozinka. U slučaju da ste zaboravili lozinku, ","SET_A_PASS":"postavite lozinku","RESET_PASSWORD":"Ponovno postavi lozinku","FORGOT_PASSWORD":"Zaboravili ste lozinku?","EMAIL_USED_WITH_FB":"Ovaj email je korišten sa Facebook prijavom.","INVALID_EMAIL":"Unesite ispravnu e-mail adresu","INVALID_PASSWORD":"Molimo Vas da unesete ispravnu lozinku","CONN_ERR":"Greška pri povezivanju - molimo Vas pokušate kasnije.\\n\\nAko se ovo nastavi, onemogućite vatrozid/antivirus (posebice Bitdefender).","IMPORT_FROM_GUEST":"Uvezi videoteku iz gostujućeg računa","RECEIVE_UPDATES_EMAIL":"Primajte novosti od kompanije Stremio na vaš e-mail","LOGIN_FAILED":"Neuspjela Prijava.","SIGNUP_FAILED":"Prijava nije uspjela.","SEARCH_FAILED":"Pretraga nije uspjela","EMAIL_USED":"Ovaj email već je u upotrebi.","WAITING_FB_LOGIN":"Prijavljivanje preko Facebook-a...","EXTERNAL_PLAYER_TITLE":"Pokreni u vanjskom pregledniku","EXTERNAL_REMEMBER_PLAYER":"Zapamti moj izbor","EXTERNAL_ALWAYS_PLAY":"Da","EXTERNAL_ONLY_ONCE":"Ne","BEST_FIT":"Najprikladniji prikaz","FIT_SCREEN":"Uklopi u prikaz","FILL":"Ispuni prikaz","16:9":"16:9","4:3":"4:3","Original":"Izvorni prikaz","INTRO_TASTE":"Recite nam što volite","INTRO_TASTE_LONG":"Recite nam što biste željeli gledati","INTRO_TASTE_PICK":"Izaberite {{interestsRemaining}} zanimljivo","INTRO_TASTE_PICK_MORE":"Izaberite još {{interestsRemaining}} zanimljivog","INTRO_TASTE_HELP_US":"Pomozite nam da naučimo o vama.","INTRO_TASTE_CHOOSE_THESE":"Izaberite neke od ovih:","INTRO_TASTE_CHOOSE_MIN":"Izaberite bar tri kategorije","INTRO_TASTE_CHOOSE_MIN_ERR":"Morate izabrati bar tri kategorije!","INTRO_TASTE_LIFESTYLE":"Životni stil","INTRO_TASTE_SPORTS":"Sportovi","INTRO_TASTE_FOOD_HEALTH":"Hrana i zdravlje","INTRO_TASTE_BEAUTY_FASHION":"Ljepota i moda","INTRO_TASTE_NEWS":"Vijesti","INTRO_TASTE_GAMING":"Igrice","INTRO_TASTE_SCIENCE_EDU":"Znanost i obrazovanje","INTRO_TASTE_MUSIC":"Glazba","INTRO_TASTE_TRAVEL":"Putovanje","INTRO_TASTE_LATE_NIGHT":"Noćni talk-show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Komedija","INTRO_TASTE_DIY":"Uradi sam","INTRO_TASTE_TECH":"Tehnika","INTRO_TASTE_CINEMA":"Kinematografija","ADDON_NOT_SUPPORTED":"Izabrani dodatak nije podržan na ovoj platformi.","ADDON_DISCLAIMER":"Korištenje trećih dodataka uvijek će biti predmet osobne odgovornosti i zakonom zemlje u kojoj se nalazite.","ADDON_ACTIVATE":"Aktivirati ovaj dodatak?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Dodaj","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Što je novo","BUTTON_CONTINUE":"Nastavi","BUTTON_ACTIVATE":"Aktiviraj","BUTTON_ACTIVATED":"Aktivirano","BUTTON_CANCEL":"Prekini","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Poništni sve","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Vaša Videoteka izgleda prazno. Saznajte koliko je zapravo korisna :) ","HOW_START":"Ovako možete početi:","LIB_EMPTY_CAL":"Tvoj Kalendar prikazuje serije iz tvoje Videoteke.","HOW_START_CAL":"Ovako možeš dodati serije:","LIB_EMPTY_BOARD":"Tabla prikazuje notifikacije & preporuke slične tvojoj biblioteci.","HOW_START_BOARD_WAIT":"Molimo, dodajte par serija ili kanala u vašu videoteku i dozvolite nam par minuta da procesuiramo :)","HOW_START_BOARD":"Evo kako možete da dodate serije & flmove na nju:","IMPORT_FB":"Uvoz stvari koje vam se sviđaju na Facebook","IMPORT_TRAKT":"Uvezi videoteku sa: Trakt","IMPORT_DISCOVER":"Nađi zanimljive stvari u Otkrij","IMPORT_DISK":"Uvoz filmova ili serija koje imate na vašem lokalnom disku","PLEASE_CREATE_ACC":"Molimo Vas napravite račun da omogućite sinkronizaciju Videoteke & Table.","IMPORT_DISCOVER_SIGNUP":"Registrirajte se i otkrijte zanimljive stvari u Otkrij","IMPORT_DISK_SIGNUP":"Registrirajjte se i uvezite filmove i serije sa vašeg lokalnog diska","LIB_EMPTY_CLOUD":"Videoteka na oblaku","LIB_EMPTY_CLOUD_DESC":"Osobna videoteka ažuirana na svim uređajima","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Primaj obavijesti o novim epizodama","LIB_EMPTY_PERSONAL":"Osobno","LIB_EMPTY_PERSONAL_DESC":"Primaj personalizirane preporuke","LIB_EMPTY_CALENDAR_DESC":"Pripremi raspored za gledanje tvoje videoteke","LIB_EMPTY_ALL":"Prijavi se na neke od ovih:","LIB_EMPTY_BEST":"Prijavi se da dobiješ najbolje od Stremio-a","LIB_EMPTY_OTHER":"Prijavi se da dobiješ Kalendar & druge cool dodatke","CALENDAR_ADDED":"Stremio kalendar je dodan tvome kalendaru.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt autientifikacija nije valjana, molim vas u Postavkama autentificirajte","TRAKT_REQUIRES_LOGIN":"Trakt greška","TRAKT_REQUIRES_LOGIN_MSG":"Morate biti ulogirani","SETTINGS_LABEL":"Postavke","SETTINGS_NAV_GENERAL":"Općenito","SETTINGS_NAV_PLAYER":"Reproduktor","SETTINGS_NAV_STREAMING":"Prijenos","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Pokreni prilikom paljenja","SETTINGS_VLC_DEFAULT":"Pokreni preko VLC-a","SETTINGS_UI_LANGUAGE":"Jezik sučelja","SETTINGS_FULLSCREEN_EXIT":"Izlazak iz punog prikaza tipkom Esc","SETTINGS_GAMEPAD":"Omogući korištenje kontrolera","SETTINGS_CLOSE_WINDOW":"Zatvori program prilikom zatvaranja prozora","SETTINGS_SUBTITLES_LANGUAGE":"Zadani jezik podnapisa","SETTINGS_SUBTITLES_SIZE":"Zadana veličina podnapisa","SETTINGS_SUBTITLES_BACKGROUND":"Pozadina podnapisa","SETTINGS_SUBTITLES_COLOR":"Boja podnapisa","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Boja obruba podnapisa","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Boja pozadine podnapisa","SETTINGS_SEEK_KEY":"Premotavanje sadržaja strelicama","SETTINGS_SEEK_KEY_SHIFT":"Premotavanja sadržaja streliacam dok je tipka Shift pritisnuta","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Automatski pokreni sljedeću epizodu","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Automatski promjeni veličinu prozora prije puštanja","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Uvek koristi najnoviju BETA","SETTINGS_IMPORT_FB":"Uvezi sa Facebooka","SETTINGS_IMPORT_DISK":"Uvezi sa lokalnog diska","SETTINGS_IMPORT_TRAKT":"Uvezi sa Trakt-a","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Pozadinsko pokretanje","SETTINGS_SUBSCRIBE_CALENDAR":"Pretplati se na Kalendar","SETTINGS_REQ_EXPORT":"Zatraži izvoz podataka","SETTINGS_ACC_DELETE":"Zatraži brisanje naloga","SETTINGS_CHANGE_PASSWORD":"Promjeni lozinku","SETTINGS_TOS":"Uslovi korištenja","SETTINGS_SUPPORT":"Kontaktiraj podršku","SETTING_LANGUAGE":"Jezik","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Odjavi se sa Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"podrazumevani titlovi","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Pokreni u zasebnom prozoru (napredno)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Izađi","CONNECTED":"Povezan","AUTHENTICATE":"Prijavi se","CACHING":"Keširanje","SETTINGS_CACHING_DRIVE":"Izaberi disk za keširanje","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Siječanj","February":"Veljača","March":"Ožujak","April":"Travanj","May":"Svibanj","June":"Lipanj","July":"Srpanj","August":"Kolovoz","September":"Rujan","October":"Listopad","November":"Studeni","December":"Prosinac","Monday":"Ponedeljak","Tuesday":"Utorak","Wednesday":"Srijeda","Thursday":"Četvrtak","Friday":"Petak","Saturday":"Subota","Sunday":"Nedjelja","Action":"Akcija","Comedy":"Komedija","War":"Ratni","Family":"Obiteljski","Animation":"Animacija","Adventure":"Avanturistički","Fantasy":"Fantazija","Crime":"Kriminalistički","Mystery":"Misterija","Romance":"Ljubavni","Drama":"Drama","Horror":"Horor","Thriller":"Triler","Sci-Fi":"Znanstvena Fantastika","Music":"Glazba","Biography":"Biografija","Documentary":"Dokumentarni","Sport":"Sport","Musical":"Mujuzikl","Western":"Western","Film-Noir":"Film-Noir","News":"Novosti","History":"Povijesni","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Zabava","Gaming":"Gaming","From TV":"Iz TV-a","Lifestyle":"Lifestyle","Science & Education":"Znanost & Edukacija","Cooking & Health":"Kuhanje & Zdravlje","Beauty & Fashion":"Ljepota & Moda","Sports":"Sport","News & Politics":"Vijesti & Politika","How-to & DIY":"DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Dobra dijela & Neprofitno","Movies":"Filmovi","Uk Live Tv":"UK Uživo Tv","Fashion":"Moda","Business News Radio":"Poslovni radio","Business Tv":"Poslovni tv","Cars & Auto":"Auto","Comedy Radio":"Komedija","Lifestyle Radio":"Lifestyle","News Tv":"Vijesti Tv","Food And Wine":"Hrana i vino","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religija","Kids":"Djeca","Body & Soul":"Tijelo i duša","Education":"Edukacija","Indian Tv":"Indian Tv","Extreme Sports":"Extremni sportovi","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Znanstvena Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Putovanja","Asian Tv":"Asian Tv","Entertainment":"Zabava","News Radio":"Vijesti Radio","Music Radio":"Glazbeni Radio","Language Learning":"Učenje jezika","Science Radio":"Znanstveni Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"novi video","new episode":"nova epizoda","new movie":"novi film","recommended":"preporučeno","we recommend":"preporučujemo","offer of the day":"ponuda dana","news":"vijesti","music video":"spot","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Odbaci obavijesti","CTX_DISMISS_ALL":"Odustani","CTX_SHARE":"Podijeli","CTX_COPY_SHARE_LINK":"Kopiraj link za dijeljenje","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Prikaži","CTX_PLAY":"Pokreni","CTX_PLAY_IN":"Pokreni u","CTX_PLAY_ON":"Pokreni na","CTX_WATCH_ON":"Gledaj na","CTX_WATCH":"Gledaj","CTX_WATCHED":"Pogledano","CTX_WATCH_BEGINNING":"Gledaj od početka","CTX_WATCH_MOBILE":"Gledaj na mobilnom uređaju","CTX_REWIND":"Premotaj na početak","CTX_MARK_WATCHED":"Označi kao pogledano","CTX_MARK_NON_WATCHED":"Označi kao nepogledano","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Označi ostalo kao pogledano","CTX_UNMARK_REST":"Označi ostalo kao nepogledano","CTX_RECEIVE_NEW_NOTIF":"Primaj nove obavijesti","CTX_REMOVE_CACHE":"Obriši iz keša","CTX_REMOVE_CACHE_EP":"Ukloni epizodu iz keša","CTX_OPEN_CONTAINING":"Otvori mapu sadržaja","CTX_REMOVE":"Ukloni iz Videoteke","CTX_AVAILABLE_OFFLINE":"Dostupno izvanmrežno","CTX_PAUSED":"Pauzirano","CTX_ALWAYS_ON_TOP":"Uvijek na vrhu","CTX_FULLSCREEN":"Cijeli zaslon","CTX_WRONG_SUBS":"Pogrešan prijevod?","CTX_REPORT_ISSUES":"Prijavi problem","CTX_COPY":"Kopiraj","CTX_PASTE":"Naljepi","CTX_CLEAR":"Očisti","CTX_CLEAR_RECENT_SEARCHES":"Obriši skorašnje pretrage","HELLO_THERE":"Hej zdravo","HOPE_YOU_ENJOY":"Nadamo se da uživate uz Stremio i da je već jedna od vaših omiljenih aplikacija !","WHO_ARE_WE":"Tko smo mi? Mi smo tim iza njega - dva momka koja rade teško svaki dan već skoro 3 godine da bih napravili ovaj proizvod sve boljim i boljim.","SUPPORT_US":"Ako uživate koristeći Stremio, ako je Stremio vrijedan za vas - širite riječ !","SPREAD_THE_WORD":"Podijelite sa svojim prijateljima sada, širite riječi u vezi Stremio","MORE_PEOPLE":"Što više ljudi koristi Stremio, to će biti bolji !","SEND_A_LINK":"Ili pošaljite link ka našoj stranici","TIP_LOCALFILES":"Savjet: možeš prevući i ubaciti lokalne video datoteke u Stremio","ADDON_MY":"Moji Dodaci","ADDON_COMMUNITY":"Dodaci zajednice","ADDON_OFFICIAL":"Službeni dodaci","ADDON_REPOS":"Dodaci repozitoriji","ADDON_SEARCH":"Pretraži dodatke","ADDON_INSTALL":"Instaliraj","ADDON_CONFIGURE":"Promijeni","ADDON_UNINSTALL":"Deinstaliraj","ADDON_UPGRADE":"Nadogradi","ADDON_INSTALLED":"Instalirano","ADDON_INSTALLED_MSG":"Dodatak instaliran!","ADDON_UPGRADED_MSG":"Dodatak ažuriran!","ADDON_UNKNOWN":"Nepoznato","ADDON_ERR":"Greška pri instaliranju dodatka!","ADDON_DISCONNECTED":"Veza prekinuta","ADDON_APP_MISSING":"aplikacija za ovaj izvor nije instalirana. Želiš li sada instalirati?","ADDON_APP_INSTALL":"Instaliraj sada","ADDON_PAGE":"Stranica dodataka","ADDON_TOP_CONTENT":"Najbolje do ovog dodatka","ADDON_PROVIDES":"Ovaj dodatak će vam dati:","ADDON_WATCH":"Pogledaj #{types} sada!","ADDON_WATCH_FREE":"Pogledaj #{types} BESPLATNO sada !","ADDON_ADDON":"Dodatak","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Više #{types} u Otkrivanju","ADDON_PROVIDES_STREAMS":"Gledaj #{types}","ADDON_PROVIDES_STREAMS_FREE":"Gledaj #{types} BESPLATNO","ADDON_PROVIDES_SUBTITLES":"Prijevodi za #{types}","ADDON_CANTDETECT":"Nismo uspjeli pronaći i pokrenuti Stremio, tako da nismo uspjeli otkriti koje dodatke imate instaliarne.","ERR_NO_META":"Nisu pronađene informacije o ovome ","ERR_GETTING_META":"Greška pri preuzimanju podataka.","ERR_CANT_PARSE_MAGNET":"Nemoguće spojiti magnet","ERR_NO_MAGNET_INFOHASH":"Bez valjanog hash-a za magnet","ERR_NO_FILE_PATH":"Nije moguće poslati zahtjev bez lokacije datoteke","ERR_NO_TORRENT":"Nema torrent-a","ERR_NO_SUPPORTERD_FILES":"Nisu nađene podržane datoteke","ERR_OPENING_FILES":"Nije moguće otvoriti vanjske datoteke","ERR_INVALID_LINK":"Link nije valjan","ERR_REGISTERED_ONLY":"Ova mogućnost je dostupna samo registriranim korisnicima.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Nastavi gledanje","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmovi izabrani isključivo za vas.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Gledaj Odmah","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Skini sada","WEBSITE_DOWNLOAD_FOR":"Skini sada za","WEBSITE_IS_DESKTOP":"Stremio je desktop aplikacija, otvori ovu stranicu na svom PC i skini ga","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Glavna","WEBSITE_PAGE_FEATURES":"Karakteristike","WEBSITE_PAGE_ADDONS":"Dodaci","WEBSITE_PAGE_TECH":"Tehnologija","WEBSITE_PAGE_CREATE_ADDON":"Kreiraj dodatak","WEBSITE_PAGE_CONTACTS":"Kontakti","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmovi","WEBSITE_TYPE_series_PL":"Serije","WEBSITE_TYPE_tv":"Uživo TV","WEBSITE_TYPE_channel":"Kanali","WEBSITE_STREMIO_WHAT_IS":"Stremio je aplikacija koja vam pomaže da organizujete i odmah gledate vaše omiljene video, filmove, TV serije i TV kanale.","WEBSITE_FEATURES_WATCH":"Gledaj odmah u HD","WEBSITE_FEATURES_WATCH_DETAIL":"Kliknite i pokrenite svoje omiljene filmove, TV Emisije, video i TV kanale.","WEBSITE_FEATURES_SUBS":"Automatski Prevodi","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatski odabire sinkronizirane prijevode za vaš jezik.","WEBSITE_FEATURES_SUBS_LABEL":"Stremio automatski odabire sinkronizirane prijevode za vaš jezik.","WEBSITE_FEATURES_CAST":"Pokreni na TV & mobilnim uređajima","WEBSITE_FEATURES_CAST_DETAIL":"Emitiranje na AppleTV, Chromecast, Smart TV (DLNA/UPnP) i mobilne uređaje.","WEBSITE_LIB":"Uživajte u Svojoj osobnoj Videoteci sinkoniziranoj na Sve Vaše Uređaje","WEBSITE_LIB_COLLECT":"Prikupite sa Stremio","WEBSITE_LIB_IMPORT":"Uvezite sa Facebook-a","WEBSITE_LIB_LOCAL":"Dodajte sa vašeg lokalnog diska","WEBSITE_BOARD":"Ploča - Vaše one-stop mjesto za obavještenja i preporuke","WEBSITE_BOARD_RECOMMEND":"Preporučena TV Emisija","WEBSITE_BOARD_TRENDING":"Traženi Film","WEBSITE_BOARD_NEW":"Novi Video","WEBSITE_BOARD_EPISODE":"Nova Epizoda","WEBSITE_BOARD_1":"Tražite nešto interesantno da gledate? Dobijajte preporuke na osnovu vašeg ukusa!","WEBSITE_BOARD_2":"Primite obavještenja kada nova epizoda vaš omiljene TV emisije ili YouTube kanala izadje!","WEBSITE_BOARD_YOUTUBE":"Novi Videi na Youtube kanalima","WEBSITE_BOARD_EPISODES":"Nove epizode serije koje pratite","WEBSITE_ADDONS":"Dodaci za sadržaj","WEBSITE_TECH_DETAIL":"Volimo tehnologiju, volimo znanost!\\nStremio koristi sljedeći softver otvorenog koda:","WEBSITE_TECH_WCJS":"WebChimera.js omogućava gledanje u bilo kojem formatu sa dobrim performansama","WEBSITE_TECH_WCJS_EXTRA":"Mi smo glavni suradnici ","WEBSITE_TECH_ELECTRON":"Electron pruža inovativu platformu za Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Mi smo suradnici projekta","WEBSITE_TECH_LINVODB":"Baza podataka koja omogućava da su podaci organizirani i svugdje spremni.","WEBSITE_TECH_LINVODB_EXTRA":"Kućna tehnologija","WEBSITE_CREATE_ADDON":"Kreiraj svoj dodatak","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Zainteresirani? Dobrodošli ste da nas kontaktirate.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Mišljenja koja dijelimo:","WEBSITE_SPREAD":"Nek se čuje za Stremio:","WEBSITE_CONTACT":"Ako nas mislite kontaktirati, slobodno","WEBSITE_OPENSOURCE":"Za naš otvoreni kod idi na","WEBSITE_BITCOIN":"Doniraj bitcoin:","WEBSITE_FAQ":"Često postavljena pitanja","WEBSITE_FAQ_SHORT":"ČPP","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Uslovi korištenja","WEBSITE_LEGAL":"Zakoni","WEBSITE_PAGE_ABOUT":"O nama","WEBSITE_PAGE_BECOME_PARTNER":"Postani partner","WEBSITE_ALL_YOU_CAN_WATCH":"Sloboda gledanja\\nsvega što želiš.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Što je Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio dodaci","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partneri i pomagači","WEBSITE_COMMUNITY_GOODIES":"Stremio dobri","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpaperi","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sport","FOOD_HEALTH":"Hrana i zdravlje","BEAUTY_FASHION":"Ljepota i moda","NEWS":"Vijesti","GAMING":"Gaming","SCIENCE_EDUCATION":"Znanost i edukacija","MUSIC":"Glazba","TRAVEL":"Putovanje","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Komedija","DIY":"DIY","TECH":"Tech","CINEMA":"Kinomatografija","CONTINUE":"Nastavi","SLOW_LOADING":"Loše učitavanje?","I_GIVE_UP":"PREDAJEm SE","LEARN_MORE":"Saznaj više","POOR_SOURCE":"Ovaj izvor je slabo dostupan ili je Vaša internet konekcija prespora","PICK_CATEGORIES_ERR":"Moraš odabrati najmanje 3 kategorije","ADJUST_TIMING":"Promijeni vrijeme sa ","ADJUST_SIZE":"Promijeni veličinu sa ","SEARCH_ANYTHING":"Pretražuj sve...","ALL_CATEGORIES":"Sve","SEARCH_CATEGORIES":"Filmove, Serije, YouTube & TV","SEARCH_PERSONS":"Glumce, Režisere i Scenografe","SEARCH_PROTOCOLS":"HTTP i Magnet Linkove","SEARCH_TYPES":"IMDB / TVDB linkove","WATCHED":"Pregledano","SHOW_LESS":"Prikaži manje","LAST_SEARCHES":"Posljednje pretrage","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"ODABERI NEŠTO OD OVOGA:","NO_WEB_REMOTE":"Daljinski upravljač nije moguče učitati","STREMIO_OFFLINE":"Stremio nije povezan","STREMIO_EXPENSIVE_CONNECTION":"Prijenos podataka je skup","USE_DATA":"Korištenje podataka","WARNING":"Upozorenje","MORE_INFO":"Više Informacija ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Učitavanje ...","STREMIO_TV_BACK_TO_LANGUAGES":"Nazad na jezike","STREMIO_TV_REMOTE":"Daljinski upravljač","STREMIO_TV_GO_TO":"Idi na:","STREMIO_TV_OR_SCAN":"ili skeniraj:","STREMIO_TV_ADDON_INSTRUCTIONS":"Molim slijedite upute za instaliranje dodataka.","STREMIO_TV_LIVE_TV":"TV uživo","STREMIO_TV_RESUME_WATCHING":"Nastavi Gledanje","STREMIO_TV_LOADING_BACKGROUND":"Pozadina učitavanja","STREMIO_TV_CHECKING_AUTHENTICATION":"Provjera autentifikacije","STREMIO_TV_LOADING_BOARD":"Ploča učitavanja","STREMIO_TV_LOGIN_HEADER_LINE_1":"Želimo da naši korisnici imaju najbolje moguće personalizirano iskustvo sa našim softverom.","STREMIO_TV_LOGIN_HEADER_LINE_2":"To je razlog zašto vas ljubazno molimo da se prijavite u svoj račun.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Hvala na razumjevanju,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio Tim","STREMIO_TV_REMOTE_INSTRUCTIONS":"Da bi koristili Web daljinski upravljač sa Mobilnim uređajem / Tabletom / PC:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Postavke","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio krug nije detektirao internet vezu.","STREMIO_TV_WIFI_DETAILS_1":"Povezi se sa:","STREMIO_TV_WIFI_DETAILS_2":"stremio-krug","STREMIO_TV_WIFI_DETAILS_3":"Koristi lozinku:","STREMIO_TV_WIFI_DETAILS_4":"stremiokrug","STREMIO_TV_WIFI_DETAILS_5":"Otvori internet preglednik sa:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Promijeni uređaj","REMOTE_VIDEOS":"Videi","REMOTE_ADJUST_TIMING":"Namjesti vrijeme","REMOTE_ADJUST_SIZE":"Namjesti veličinu","REMOTE_COULD_NOT_BE_LOADED":"Web daljinski upravljač nije moguće učitati","REMOTE_RETRY":"Pokušaj ponovo","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},5657:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Sorozat","TYPE_tv":"TV csatorna","TYPE_channel":"Csatorna","TYPE_other":"Egyéb","TYPE_movie_PL":"Filmek","TYPE_series_PL":"Sorozatok","TYPE_tv_PL":"TV csatornák","TYPE_channel_PL":"Csatornák","TYPE_other_PL":"Egyebek","TYPE_ALL":"All","VIDEO":"Video","BACK":"Vissza","MORE":"Több","DONE":"Kész","COPY":"Másolás","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Felfedezés","Board":"Ajánlatok","Library":"Könyvtár","My Library":"Könyvtáram","Calendar":"Naptár","NOTIFICATION_ONLINE":"Jelenleg online vagy","NOTIFICATION_OFFLINE":"Jelenleg offline vagy","INTERNET_CONNECTION":"Hálózat csatlakoztatva","STORAGE_FULL_TITLE":"Figyelem: a tárhelye megtelt!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"Keresés","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Másoljon be HTTP vagy Mágnes linket","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Hozzáadás a könyvtárhoz","REMOVE_FROM_LIB":"Eltávolítás a könyvtárból","ADDED_TO_LIB":"Hozzáadva a könyvtárból","REMOVED_FROM_LIB":"Eltávolítva a könyvtárból","TRAILER":"Előzetes","WATCH_TRAILER":"Előzetes megtekintése","WATCH_NOW":"Indítás","SHOW":"Tovább","SHOW_MOVIE":"Film megtekintése","WATCH_RANDOM":"Véletlen megtekintése","IMDB_RATING":"IMDb értékelés","YEAR":"Év","DIRECTOR":"Rendező","WRITER":"Író","LEAD_ACTORS":"Főszereplők","CAST":"Szereposztás","CREW":"Crew","SHOW_MORE_CAST":"Mutass többet »","AIRED":"Vetítve","SEASONS":"Évad","GENRE":"Műfaj","CATALOG":"Katalógus","SUMMARY":"Tartalom","SHOW_MORE":"Mutass többet","SIMILAR":"Hasonló","UPCOMING":"Nemsokára","ENDED":"Vége","DURATION":"Időtartam","FEATURED":"Featured","METADATA":"Metaadat","CATEGORY":"Kategória","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Videó keresése","SEARCH_PLACEHOLDER":"Keress vagy másolj be mágnes linket","ADDON":"bővítmény","ADDONS":"Bővítmények","OFFICIAL":"hivatalos","ADDONS_OFFICIAL":"Hivatalos Streamio bővítmények","ADDONS_POPULAR":"Népszerű a környezetedben","ADDON_FREE":"ingyenes","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"előfizetés","ADDON_STREAM_GEORESTRICTED":"Nem erélhető a régiódban","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Elérhető streamek","NO_STREAM":"Nincs elérhető stream","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"A filmet még moziban játsszák","WATCH_IN_CINEMA":"Elérhető a közeli moziban","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Ez a csatorna még nincs tárolva.
Kérjük, térj vissza pár perc múlva.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Add hozzá a könyvtáradhoz és értesítünk, amikor elérhetővé válik.","GET_NOTIFIED_WHEN_AVAILABLE":"Értesítünk, amikor elérhetővé válik.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Lejátszási sebesség","PLAYER_PLAYBACK_ERROR":"Lejátszási hiba, próbáld újra","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"lejtászás innen","CASTING_TO":"Továbbítva","NETWORK_STATUS":"Kapcsolat állapota","STREAM_SPEED":"Letöltés sebessége:","STREAM_BUFFERED":"Betöltve:","PEERS_INFO":"Kapcsolatok","PEERS_ACTIVE":"Aktív:","PEERS_CONNECTED":"Kapcsolódva:","PEERS_WAITING":"Várakoznak:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"betöltés...","PLAYING_LOCAL":"lejátszás helyi fájlból","PLAYING_CACHE":"lejátszás gyorsítótárból","WRONG_SUBS":"Hibás felirat?","ERR_SUBS_LOADING_TITLE":"Hiba a feliratok betöltése közben","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Válassz egy készüléket a továbbításhoz","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Telefon / Táblagép","SUBTITLES":"Feliratok","SUBTITLES_CHANGE":"Másik felirat választása a következő nyelvhez: ","SUBTITLES_CHANGE_NONE":"Sajnáljuk, nem érhető el másik felirat ehhez a nyelvhez.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alteratively,","SUBTITLES_ADJUST_DELAY":"Felirat késleltetésének beállítása:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Feliratok késleltetése:","SUBTITLES_LOADING":"Feliratok betöltése...","SUBTITLES_UNAVAILABLE":"Nem érhető el felirat","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Évad","EPISODE":"Epizód","SPECIAL":"Special","SORT":"rendez","SORT_BY":"rendezés","FILTER":"filter","SORT_TRENDING":"Nézettség","SORT_RECENT":"legújabbak","SORT_ALPHABET":"A-tól Z-ig","SORT_RATING":"értékelés","SORT_WATCHED":"megtekintve","SORT_YEAR":"év","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Újdonságok Neked","New Episodes":"Új Epizódok","New Videos":"Új Videók","Recommendations":"Ajánlások","LIBRARY_RESUME":"folytatás","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Részletek","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Ajánlott","DISCOVER_TOP":"Népszerűek","DISCOVER_OSCAR":"Oscar nyertesek","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Figyelmeztetés: nincs bekapcsolt Stremio bővítmény ehhez a típushoz. Elmentett elemek mutatása, melyek nem fognak frissülni.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Újraindítás most!","UPGRADE":"Frissítés a legújabb Streamio verzióra","RELOAD_UI":"Felhasználói felület újratöltése","MANUAL_UPDATE_TITLE":"Frissítsd a Stremio verzióját","MANUAL_UPDATE_LINE1":"Egy már nem támogatott verzióját futtatod a Stremionak, mely erősen nem ajánlott.","MANUAL_UPDATE_LINE2":"Frissíts, amilyen gyorsan lehetséges.","BUTTON_UPDATE_LATTER":"Ne most","BUTTON_UPDATE_NOW":"Frissítés","ANONYMOUS_USER":"Anonymous felhasználó","DONT_HAVE_ACC":"Nincs fiókod?","HAVE_ACC":"Van már fiókod?","PASSWORD":"Jelszó","PASSWORD_CONFIRM":"Jelszó megerősítése","EMAIL":"E-mail","FB_LOGIN":"Bejelentkezés Facebookkal","FB_NOTHINGSHARED":"Semmit nem osztunk meg a beleegyezésed nélkül","FB_NOPOST":"Semmit nem posztolunk a részedről","OR":"vagy","I_ACCEPT":"Elfogadom a","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"felhasználói feltételeket","MUST_ACCEPT_TERMS":"El kell fogadnod a feltételeket","PASSWORDS_NOMATCH":"Jelszó nem egyezik","SIGN_UP":"Regisztráció","SIGN_UP_EMAIL":"Regisztráció email-lel","CLICK_TO_SIGN_UP":"Kattints ide a regisztrációhoz.","LOG_IN":"Bejelentkezés","LOG_OUT":"Kijelentkezés","EXIT_FULLSCREEN":"Kilépés teljes képernyőből","ENTER_FULLSCREEN":"Teljes képernyős mód","PLAY_URL_MAGNET_LINK":"URL/Mágnes link lejátszása","HELP_FEEDBACK":"Segítség & visszajelzés","TERMS_OF_SERVICE":"Szolgáltatás feltételei","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"A Stremioról","USER_PANEL":"Felhasználói panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Vendég belépés","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"kattins ide","WRONG_PASSWORD":"Rossz jelszó. Ha elfelejtetted a jelszavad, ","SET_A_PASS":"jelszó beállítása","RESET_PASSWORD":"Jelszó visszaállítása","FORGOT_PASSWORD":"Elfelejtett jelszó?","EMAIL_USED_WITH_FB":"Ez az email már hozzá van rendelve egy Facebookos regisztrációhoz.","INVALID_EMAIL":"Kérjük adjon meg egy érvényes email címet","INVALID_PASSWORD":"Kérjük adjon meg egy érvényes jelszót","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Harmadik féltől származó bővítmények használata mindig a felhasználó felelőssége, a felhasználó tartózkodási területén életben lévő törvényeket tiszteletben tartva.","ADDON_ACTIVATE":"Bekapcsolod ezt a bővítményt?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Újdonságok","BUTTON_CONTINUE":"Folytatás","BUTTON_ACTIVATE":"Bekapcsolás","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Mégse","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"A könyvtárad üres. Fedezd fel, milyen hasznos ez a funkció :) ","HOW_START":"Használatához ennyit kell tenned:","LIB_EMPTY_CAL":"A naptárad a könyvtáradban található sorozatokat mutatja.","HOW_START_CAL":"Sorozatok hozzáadásához a következőket kell tenned:","LIB_EMPTY_BOARD":"Az ajánlatok fül értesítéseket & javaslatokat mutat a könyvtárad alapján.","HOW_START_BOARD_WAIT":"Kérjük, addj pár sorozatot és csatornát a könyvtáradhoz, és mi pár perc alatt feldolgozzuk :)","HOW_START_BOARD":"Így adhatsz hozzá sorozatokat & filmeket:","IMPORT_FB":"Importálj általad kedvelt tartalmakat a Facebookról","IMPORT_TRAKT":"Importáld médiakönyvtárad a Traktról","IMPORT_DISCOVER":"Keress érdekes tartalmakat a Felfedezés fülről","IMPORT_DISK":"Importálj filmeket és sorozatokat a helyi lemezedről","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Alkalmazás indítása Windows indításakora","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Importálás Facebookról","SETTINGS_IMPORT_DISK":"Importálás helyi lemezről","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Feliratkozás naptárra","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Jelszó megváltoztatása","SETTINGS_TOS":"Felhasználói feltételek","SETTINGS_SUPPORT":"Kapcsolat felvétele","SETTING_LANGUAGE":"Nyelv","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Kilépés","CONNECTED":"Connected","AUTHENTICATE":"Bejelentkezés","CACHING":"Tárolás","SETTINGS_CACHING_DRIVE":"Válaszd ki a tárolás helyét","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Január","February":"Február","March":"Március","April":"Április","May":"Május","June":"Június","July":"Július","August":"Augusztus","September":"Szeptember","October":"Október","November":"November","December":"December","Monday":"Hétfő","Tuesday":"Kedd","Wednesday":"Szerda","Thursday":"Csütörtök","Friday":"Péntek","Saturday":"Szombat","Sunday":"Vasárnap","Action":"Akció","Comedy":"Vígjáték","War":"Háborús","Family":"Családi","Animation":"Animációs","Adventure":"Kaland","Fantasy":"Fantasztikus","Crime":"Bűntény","Mystery":"Misztikus","Romance":"Romantikus","Drama":"Dráma","Horror":"Horror","Thriller":"Krimi","Sci-Fi":"Sci-Fi","Music":"Zenei","Biography":"Életrajzi","Documentary":"Dokumentum","Sport":"Sport","Musical":"Musical","Western":"Vadnyugati","Film-Noir":"Noir","News":"Hírek","History":"Történelem","Game-Show":"Játék show","Reality-TV":"Reality","Talk-Show":"Beszélgetős műsor","Film & Entertainment":"Film & Szórakoztatás","Gaming":"Játék","From TV":"TV-ből","Lifestyle":"Életstílus","Science & Education":"Tudomány és oktatás","Cooking & Health":"Főzés és egészség","Beauty & Fashion":"Szépségápolás és divat","Sports":"Sport","News & Politics":"Hírek és politika","How-to & DIY":"Útmutatók és barkácsolás","Tech":"Technológia","Automotive":"Autó","Causes & Non-Profits":"Ügyek és non-profit","Movies":"Filmek","Uk Live Tv":"Egyesült Királyság beli élő TV","Fashion":"Divat","Business News Radio":"Rádiós üzleti hírek","Business Tv":"Üzleti TV","Cars & Auto":"Autók","Comedy Radio":"Rádiós komédia","Lifestyle Radio":"Életstílus rádió","News Tv":"TV-s hírek","Food And Wine":"Étel és ital","Latino Tv":"Latin TV","Shopping Tv":"TV-s vásárlás","Religion":"Vallás","Kids":"Gyerekek","Body & Soul":"Test és lélek","Education":"Oktatás","Indian Tv":"Indiai TV","Extreme Sports":"Extrém Sportok","Middle Eastern Tv":"Közel-Keleti TV","Celebrity Tv":"Hírességek TV","Science Tv":"Tudományos TV","Bikini babe":"Bikinis csajok","Outdoors":"Környezet","German Tv":"Német TV","French Tv":"Francia TV","Italian Tv":"Olasz TV","Gamer Tv":"Játékos TV","Travel":"Utazás","Asian Tv":"Ázsiai TV","Entertainment":"Szórakoztatás","News Radio":"Rádiós hírek","Music Radio":"Zenei rádió","Language Learning":"Nyelvtanulás","Science Radio":"Tudományos rádió","Tech Radio":"Technológiai rádió","Science & Technology Vod":"Tudomány és technológia","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years, with a single goal - to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - support us!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Nézd tovább","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Folytatás","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"Midenre Rá Tudsz Keresni...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Filmek, Sorozatok, YouTube & TV","SEARCH_PERSONS":"Színészek, Rendezők & Írók","SEARCH_PROTOCOLS":"HTTP & Mágnes Linkek","SEARCH_TYPES":"IMDB / TVDB Linkek","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Keresési előzmények","CLEAR_HISTORY":"Előzmények törlése","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"A Stremio nem érhető el","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},1472:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serial","TYPE_tv":"Saluran TV","TYPE_channel":"Saluran","TYPE_other":"Lainnya","TYPE_movie_PL":"Film - film","TYPE_series_PL":"Serial - serial","TYPE_tv_PL":"Saluran - saluran TV","TYPE_channel_PL":"Saluran - saluran","TYPE_other_PL":"Lainnya","TYPE_ALL":"All","VIDEO":"Vidio","BACK":"Kembali","MORE":"Lebih Banyak","DONE":"Selesai","COPY":"Salin","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Temukan","Board":"Papan","Library":"Perpustakaan","My Library":"Perpustakaan Saya","Calendar":"Kalender","NOTIFICATION_ONLINE":"Anda sedang online","NOTIFICATION_OFFLINE":"Anda saat ini sedang offline","INTERNET_CONNECTION":"Koneksi Jaringan","STORAGE_FULL_TITLE":"Peringatan: Penyimpanan penuh!","STORAGE_FULL_TEXT":"Stremio tidak akan dapat menyimpan pengaturan, preferensi, atau informasi login Anda. Pertimbangkan untuk memulai ulang atau menginstal ulang Stremio.","SEARCH":"cari","SEARCH_NO_RESULTS":"Tidak ada hasil yang ditemukan","SEARCH_EXPLANATION_CONTENT":"Pencarian untuk film, serial, YouTube dan saluran TV","SEARCH_EXPLANATION_PEOPLE":"Pencarian untuk aktor, direktur dan penulis","SEARCH_PASTE_LINKS":"Tempelkan HTTP dan Link Magnet","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Tambahkan ke perpustakaan","REMOVE_FROM_LIB":"Hapus dari perpustakaan","ADDED_TO_LIB":"Ditambahkan ke Perpustakaan","REMOVED_FROM_LIB":"Dihapus dari Perpustakaan","TRAILER":"Cuplikan","WATCH_TRAILER":"Lihat cuplikan","WATCH_NOW":"Lihat sekarang","SHOW":"Tampilkan","SHOW_MOVIE":"Tampilkan film","WATCH_RANDOM":"Lihat secara acak","IMDB_RATING":"Peringkat IMDb","YEAR":"Tahun","DIRECTOR":"Direktur","WRITER":"Penulis","LEAD_ACTORS":"Aktor utama","CAST":"Pemeran","CREW":"Kru","SHOW_MORE_CAST":"Tampilkan lebih banyak »","AIRED":"Ditayangkan","SEASONS":"Musim","GENRE":"Aliran","CATALOG":"Katalog","SUMMARY":"Ringkasan","SHOW_MORE":"Tampilkan lebih banyak","SIMILAR":"Serupa","UPCOMING":"Mendatang","ENDED":"Berakhir","DURATION":"Durasi","FEATURED":"Unggulan","METADATA":"Metadata","CATEGORY":"Kategori","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"pencarian vidio","SEARCH_PLACEHOLDER":"cari atau tempelkan URL","ADDON":"tambahan","ADDONS":"Tambahan","OFFICIAL":"Resmi","ADDONS_OFFICIAL":"Tambahan Resmi Stremio","ADDONS_POPULAR":"Populer Di Area Anda","ADDON_FREE":"Gratis","ADDON_PEERED":"Mengintip","ADDON_SUBSCRIPTION":"Berlangganan","ADDON_STREAM_GEORESTRICTED":"Tidak Tersedia Di Area Kamu","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"File lokal","SHARE_ADDON":"Berbagi Tambahan","AVAILABLE_STREAMS":"Aliran Yang Tersedia","NO_STREAM":"Tidak Tersedia Siaran","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Untuk lebih banyak streaming, silakan instal lebih banyak add-on","STREAM_NOT_SUPPORTED":"Aliran yang dipilih tidak didukung di platform ini.","ADDON_CATALOGUE":"Tampilkan semua addon »","ADDON_CATALOGUE_MORE":"Instal addon","REPO_ADDED":"Repository Ditambahkan","ADDON_REPO_EXIST_ERR":"Koleksi addon ini sudah ada","ADDON_REPO_ERR":"Terjadi kesalahan saat menambahkan koleksi","ADDON_ADD_ERR":"Terjadi kesalahan saat menambahkan addon","ERR_ADDON_PROTECTED":"Tidak dapat menghapus instalan addon, itu dilindungi","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Ada yang tidak beres - autentikasi mungkin gagal","ERR_NOT_COLLECTION_URL":"Bukan URL koleksi","ERR_NOT_ADDON_URL":"Bukan URL addon yang valid","ERR_DETECTFROMURL":"Tidak dapat menemukan addon/koleksi dari URL ini","ADDON_DUPLICATE_WARNING":"Peringatan: addon duplikat","ADDON_COLLECTION_SET_FAILED":"Sinkronisasi add-on yang diinstal ke akun Anda gagal","SETTINGS_DATA_EXPORT":"Ekspor data pengguna","ADDON_PULL_FAILED":"Sinkronisasi add-on yang diinstal dari akun Anda gagal","REFRESH_ON_CLICK":"Klik untuk mencoba lagi","STILL_IN_THEATER":"Masih Di Bioskop","WATCH_IN_CINEMA":"Menonton Di Bioskop","IN_THEATER":"Di Bioskop","GET_TICKETS":"Mendapatkan tiket","UPCOMING_EPISODE":"Episode Mendatang","UPCOMING_EPISODE_MESSAGE":"Pesan Episode Selanjutnya","MISSING_DATE_EPISODE":"Tanggal Episode Tidak Ditemukan","MISSING_DATE_EPISODE_MESSAGE":"Episode Belum Tayang Sekarang","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Tambahkan ke pustaka anda untuk mendapat notifikasi jika sudah tersedia.","GET_NOTIFIED_WHEN_AVAILABLE":"Mendapatkan Notifikasi Ketika Tersedia.","WARNING_STREAMING_SERVER":"Peringatan: server siaran lokal tidak ditemukan. Siaran dari lokal file, Youtube dan BitTorent tidak akan tersedia.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Peringatan: vidio ini mungkin tidak didukung perangkat anda. Pemutaran vidio mungkin akan lambat","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Terkunci","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Error tidak diketahui","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Langsung","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Hiraukan","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Tonton sekarang","STREAMING_FROM":"Siaran dari","CASTING_TO":"Casting to","NETWORK_STATUS":"Status jaringan","STREAM_SPEED":"Stream speed:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Aktif:","PEERS_CONNECTED":"Terhubung:","PEERS_WAITING":"Menunggu:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"memuat...","PLAYING_LOCAL":"memutar dari lokal file","PLAYING_CACHE":"playing from cache","WRONG_SUBS":"Subtitle bermasalah?","ERR_SUBS_LOADING_TITLE":"Error memuat subtitle","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Choose a device to watch on","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Phone / Tablet","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Change subtitles for ","SUBTITLES_CHANGE_NONE":"There are no other subtitles for this language, sorry.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Season","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"rating","SORT_WATCHED":"watched","SORT_YEAR":"year","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"Resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"Dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oscar Winners","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Continue with Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"or","I_ACCEPT":"I accept the","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terms and Conditions","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passwords don\'t match","SIGN_UP":"Sign up","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Log in","LOG_OUT":"Log out","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Guest login","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"click here","WRONG_PASSWORD":"Wrong email or password. In case you have forgotten your password, ","SET_A_PASS":"set a password","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"This email was used with a Facebook login.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Activate this addon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"What\'s new","BUTTON_CONTINUE":"Continue","BUTTON_ACTIVATE":"Activate","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Cancel","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Change password","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Contact support","SETTING_LANGUAGE":"Language","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Quit","CONNECTED":"Connected","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"January","February":"February","March":"March","April":"April","May":"May","June":"June","July":"July","August":"August","September":"September","October":"October","November":"November","December":"December","Monday":"Monday","Tuesday":"Tuesday","Wednesday":"Wednesday","Thursday":"Thursday","Friday":"Friday","Saturday":"Saturday","Sunday":"Sunday","Action":"Action","Comedy":"Comedy","War":"War","Family":"Family","Animation":"Animation","Adventure":"Adventure","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romance","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon collections","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Tonton Langsung","WEBSITE_SLOGAN_ALL":"Semua Konten Vidio yang Kamu Nikmati dalam Satu Tempat","WEBSITE_SLOGAN_NEW":"Semua Yang Kamu Tonton","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Tonton dari","WEBSITE_DOWNLOAD":"Unduh Sekarang","WEBSITE_DOWNLOAD_FOR":"Unduh Sekarang untuk","WEBSITE_IS_DESKTOP":"Stremio adalah aplikasi desktop, buka halaman ini dengan komputer kamu dan download","WEBSITE_DESKTOP_DEMO_VID":"Desmo Desktop","WEBSITE_PAGE_HOME":"Beranda","WEBSITE_PAGE_FEATURES":"Fitur","WEBSITE_PAGE_ADDONS":"Tambahan","WEBSITE_PAGE_TECH":"Teknologi","WEBSITE_PAGE_CREATE_ADDON":"Buat Tambahan","WEBSITE_PAGE_CONTACTS":"Kontak","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Film","WEBSITE_TYPE_series_PL":"Serial","WEBSITE_TYPE_tv":"TV Langsung","WEBSITE_TYPE_channel":"Saluran","WEBSITE_STREMIO_WHAT_IS":"Stremio adalah sebuah aplikasi yang membantu kamu mengatur and menonton vidio favorit, film, serial televisi dan saluran televisi kamu secara langsung","WEBSITE_FEATURES_WATCH":"Tonton HD secara langsung","WEBSITE_FEATURES_WATCH_DETAIL":"Klik dan mainkan film kesukaan, acara televisi, vidio dan saluran televisi kamu.","WEBSITE_FEATURES_SUBS":"Subjudul Otomatsi","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio secara otomatis memilih subjudul yang disinkronkan untuk bahasa kamu.","WEBSITE_FEATURES_SUBS_LABEL":"Langkahmu, Ketua.","WEBSITE_FEATURES_CAST":"Putar di Televisi & perangkat seluler","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Nikmati pustaka pribadi kamu yang tersinkronisasi pada seluruh perangkat kamu","WEBSITE_LIB_COLLECT":"Kumpulkan dari Stremio","WEBSITE_LIB_IMPORT":"Impor dari Facebook","WEBSITE_LIB_LOCAL":"Tambahkan dari perangkat lokal kamu","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Rekomendasi siaran televisi","WEBSITE_BOARD_TRENDING":"Film yang sedang tren","WEBSITE_BOARD_NEW":"Vidio baru","WEBSITE_BOARD_EPISODE":"Episode baru","WEBSITE_BOARD_1":"Sedang mencari sesuatu yang menarik untuk ditonton? Dapatkan rekomendasi berdasarkan selera kamu!","WEBSITE_BOARD_2":"Dapatkan pemberitahuan ketika episode baru dari siaran favorit televisi kamu atau siaran Youtube telah keluar!","WEBSITE_BOARD_YOUTUBE":"Vidio baru dari siaran Youtube","WEBSITE_BOARD_EPISODES":"Episode baru dari serial yang kamu ikuti","WEBSITE_ADDONS":"Konten Tambahan","WEBSITE_TECH_DETAIL":"Kita cinta teknologi, kita cinta sekali dengan ilmu pengetahuan!\\nStremio menggunakan teknologi open source berikut :","WEBSITE_TECH_WCJS":"WebChimera.js mengizinkan Stremio untuk memutar format vidio apapun dengan performa yang baik.","WEBSITE_TECH_WCJS_EXTRA":"Kita adalah penyumbang proyek inti","WEBSITE_TECH_ELECTRON":"Electron menyediakan sebuah platform inovatif untuk membangung Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Kita adalah penyumbang proyek","WEBSITE_TECH_LINVODB":"Sebuah teknologi basis data yang memastikan data kamu terorganisir dan tersedia dimanapun kamu masuk.","WEBSITE_TECH_LINVODB_EXTRA":"Teknolog Internal","WEBSITE_CREATE_ADDON":"Buat Addon kamu","WEBSITE_CREATE_ADDON_DETAIL":"Apakah kamu menyediakan sebuah jasa konten vidio? Kita akan membantu mendapatkan manfaat dari fitur dengan membuatkan Addon kamu.","WEBSITE_CREATE_ADDON_BENEFITS":"Manfaat dari membuat sebuah Addon untuk Stremio","WEBSITE_P2P_BEAUTY":"Keindahan straming Peer-To-Peer","WEBSITE_P2P_1":"Video full HD / 4K yang andal dan terjangkau sesuai permintaan atau streaming langsung","WEBSITE_P2P_2":"Platform distribusi memberikan pengalaman pengguna yang luar biasa","WEBSITE_P2P_3":"Kami akan membuat addon yang memenuhi kebutuhan Anda","WEBSITE_P2P_CONTACT":"Tertarik? Kamu dipersilahkan untuk menghubungi kami.","WEBSITE_P2P_CONTACT_EXTRA":"Kami akan dengan senang hati membantu Anda mengintegrasikan konten Anda dengan Stremio!","WEBSITE_P2P":"Sesekali, muncullah teknologi yang mengubah nama game tersebut. Kami menginvestasikan banyak waktu dan upaya dalam membangun mesin streaming video Peer-to-Peer (P2P) kami yang memberikan kinerja hebat dan keserbagunaan untuk beradaptasi dengan kasus penggunaan apa pun.\\nHubungi kami untuk video P2P berkemampuan DRM sesuai permintaan atau streaming langsung.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Oh, tidak! Halaman yang kamu cari tidak ada disini...","WEBSITE_GO_HOME":"Ke Beranda","WEBSITE_LINK_OTHER_DOWNLOADS":"Unduh lainnya","WEBSITE_FAQ_ABR":"Pertanyaan yang sering diajukan","WEBSITE_SUPPORT":"Bantuan","WEBSITE_DOWNLOAD_4_0_BETA":"Unduh Stremio 4 beta Sekarang","WEBSITE_GET_FOR_DESKTOP":"Dapatkan untuk Desktop","WEBSITE_LINK_ADDON_COMPETITION":"Kompetisi Addon","WEBSITE_LINK_ART_CONTEST":"Kontes Seni","WEBSITE_MY_ACCOUNT":"Akun Saya","WEBSITE_MAINPAGE_FAQ_001_H1":"Apa itu Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio adalah pusat media modern yang memberikan kamu kegemaran untuk menonton apapun yang kamu mau.","WEBSITE_MAINPAGE_FAQ_002_H1":"Bagaimana itu bekerja?","WEBSITE_MAINPAGE_FAQ_002_P1":"Setelah Anda menginstal Stremio di perangkat Anda dan membuat akun, yang harus Anda lakukan adalah mengunjungi katalog addon dan menginstal addon apa pun yang Anda inginkan, dan Anda siap melakukannya!","WEBSITE_MAINPAGE_FAQ_002_P2":"Setelah itu, Anda dapat pergi ke bagian Discover atau Board untuk mulai menjelajahi konten.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can access a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},2948:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"Canali TV","TYPE_channel":"Canali","TYPE_other":"Other","TYPE_movie_PL":"Film","TYPE_series_PL":"Serie","TYPE_tv_PL":"Canali TV","TYPE_channel_PL":"Canali","TYPE_other_PL":"Altri","TYPE_ALL":"All","VIDEO":"Video","BACK":"Indietro","MORE":"Di più","DONE":"Fatto","COPY":"Copia","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Scopri","Board":"Bacheca","Library":"Libreria","My Library":"La mia Libreria","Calendar":"Calendario","NOTIFICATION_ONLINE":"Ora sei online","NOTIFICATION_OFFLINE":"Attualmente sei offline","INTERNET_CONNECTION":"Connessione di rete","STORAGE_FULL_TITLE":"Avviso: Memoria piena!","STORAGE_FULL_TEXT":"Stremio non sarà in grado di salvare le tue impostazioni, i preferiti e le informazioni di login. Prova a riavviare o reinstallare Stremio.","SEARCH":"Ricerca","SEARCH_NO_RESULTS":"Non sono stati trovati risultati","SEARCH_EXPLANATION_CONTENT":"Ricerca film, serie, YouTube e canali TV","SEARCH_EXPLANATION_PEOPLE":"Ricerca per attori, direttori e scrittori","SEARCH_PASTE_LINKS":"Incolla HTTP e Magnet link","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Aggiungi alla libreria","REMOVE_FROM_LIB":"Rimuovi dalla libreria","ADDED_TO_LIB":"Aggiunto alla libreria","REMOVED_FROM_LIB":"Rimosso dalla libreria","TRAILER":"Trailer","WATCH_TRAILER":"Guarda Trailer","WATCH_NOW":"Guarda ora","SHOW":"Show","SHOW_MOVIE":"Mostra film","WATCH_RANDOM":"Guarda casuale","IMDB_RATING":"Voto IMDb","YEAR":"Anno","DIRECTOR":"Regista","WRITER":"Autore","LEAD_ACTORS":"Attori principali","CAST":"Cast","CREW":"Equipaggio","SHOW_MORE_CAST":"Mostra più cast »","AIRED":"Trasmesso","SEASONS":"Stagioni","GENRE":"Genere","CATALOG":"Catalogo","SUMMARY":"Trama","SHOW_MORE":"Mostra di più","SIMILAR":"Simile","UPCOMING":"Prossimamente","ENDED":"Finito","DURATION":"Durata","FEATURED":"In primo piano","METADATA":"Metadata","CATEGORY":"Categoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"ricerca video","SEARCH_PLACEHOLDER":"cerca o incolla un magnet link","ADDON":"Addon","ADDONS":"Addon","OFFICIAL":"ufficiale","ADDONS_OFFICIAL":"Addon ufficiali di Stremio","ADDONS_POPULAR":"Popolari nella tua zona","ADDON_FREE":"gratuito","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"ad abbonamento","ADDON_STREAM_GEORESTRICTED":"Non disponibile nella tua zona","ADDON_STREAM_OFFLINECACHE":"Cache Offline","ADDON_STREAM_LOCALFILE":"File locale","SHARE_ADDON":"Addon condiviso","AVAILABLE_STREAMS":"Stream Disponibili","NO_STREAM":"Nessuno stream disponibile","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Per vedere più stream, puoi installare altri addon","STREAM_NOT_SUPPORTED":"Lo stream selezionato non è disponibile su questa piattaforma.","ADDON_CATALOGUE":"Mostra tutti gli addon »","ADDON_CATALOGUE_MORE":"Più addon »","REPO_ADDED":"Repository aggiunta","ADDON_REPO_EXIST_ERR":"Queste repository addons esistono già","ADDON_REPO_ERR":"Si è verificato un errore durante l\'aggiunta della repository","ADDON_ADD_ERR":"Si è verificato un errore durante l\'aggiunta dell\'addon","ERR_ADDON_PROTECTED":"Addon protetto","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Qualcosa è andato storto - l’autenticazione potrebbe essere fallita","ERR_NOT_COLLECTION_URL":"Non è un url di una collezione","ERR_NOT_ADDON_URL":"Non è un url di un addon","ERR_DETECTFROMURL":"Non posso rillevarlo dall\'url","ADDON_DUPLICATE_WARNING":"Avviso: addon duplicato","ADDON_COLLECTION_SET_FAILED":"Impostazione della collezione addon fallita","SETTINGS_DATA_EXPORT":"Esporta dati","ADDON_PULL_FAILED":"Estrazione degli addon fallita","REFRESH_ON_CLICK":"Clicca per riprovare","STILL_IN_THEATER":"Film ancora al cinema","WATCH_IN_CINEMA":"Guardalo in un cinema vicino a te","IN_THEATER":"Al cinema","GET_TICKETS":"Compra biglietti","UPCOMING_EPISODE":"Episodio in arrivo","UPCOMING_EPISODE_MESSAGE":"Questo episodio sarà trasmesso il","MISSING_DATE_EPISODE":"Data episodio mancante","MISSING_DATE_EPISODE_MESSAGE":"Questo episodio potrebbe non essere ancora stato trasmesso","CHANNEL_NOT_SCRAPED":"Questo canale non è ancora disponibile.
Torna tra qualche minuto.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Aggiungilo alla tua libreria e ricevi una notifica quando sarà disponibile.","GET_NOTIFIED_WHEN_AVAILABLE":"Riceverai una notifica quando sarà disponibile.","WARNING_STREAMING_SERVER":"Attenzione: server di streaming locale non trovato. Lo streaming da YouTube e BitTorrent non sarà disponibile.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Attenzione: questo video potrebbe non essere supportato dal tuo hardware. Ricorda, la riproduzione potrebbe essere lenta.","PLAYER_ERROR":"Oops, Errore del Player","PLAYER_ERROR_LOOKSLIKE":"Sembra che","PLAYER_ORIENTATION":"Orientazione del player","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Bloccato","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensore","PLAYER_ORIENTATION_LANDSCAPE":"Orientazione del player bloccata in orizzontale","PLAYER_ORIENTATION_SENSOR":"Orientazione del player automatica (sensore)","PLAYER_PLAYBACK_SPEED":"Velocità di riproduzione","PLAYER_PLAYBACK_ERROR":"Errore di riproduzione, prova di nuovo","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Errore sconosciuto","PLAYER_PLAYBACK_ERROR_DEFAULT":"Ci dispiace, questo video non può essere riprodotto da {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Dal vivo","PLAYER_NEXT_VIDEO_TITLE":"Prossimo su","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Nascondi","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Guarda ora","STREAMING_FROM":"In streaming da","CASTING_TO":"Trasmesso su","NETWORK_STATUS":"Stato della rete","STREAM_SPEED":"Velocità dello stream:","STREAM_BUFFERED":"In buffer:","PEERS_INFO":"Informazioni sui peer","PEERS_ACTIVE":"Attivi:","PEERS_CONNECTED":"Connessi:","PEERS_WAITING":"In attesa:","TRANSCODING_WARNING":"Avvertimento: transcodifica video.","STREAM_LOADING":"in caricamento…","PLAYING_LOCAL":"riproduzione da file locale","PLAYING_CACHE":"riproduzione dalla cache","WRONG_SUBS":"Sottotitolo sbagliato?","ERR_SUBS_LOADING_TITLE":"Errore caricamento sottotitoli","ERR_SUBS_LOADING":"Caricamento sottotitoli fallito: potrebbe essere un problema dell\'addon che stai usando, oppure della connessione di rete","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Il seguente addon per sottotitoli non si è caricato","ERR_CASTING_UPDATE_TITLE":"Non è stato possibile aggiornare le info del dispositivo di riproduzione: il server di streaming potrebbe essere offline","CHOOSE_DEVICE":"Scegli un dispositivo su cui guardarlo","NO_CAST_DEVICES":"Nessun dispositivo per casting disponibile.","NO_SETTINGS":"Nessuna impostazione disponibile.","PHONE_TABLET":"Telefono / Tablet","SUBTITLES":"Sottotitoli","SUBTITLES_CHANGE":"Cambia i sottotitoli per ","SUBTITLES_CHANGE_NONE":"Non ci sono sottotitoli per questa lingua, ci dispiace","SUBTITLES_CHANGE_ACIVE":"In questo momento è attivo il sottotitolo #{{subtitlesDialog.activeIdx + 1}}. Clicca \\"Continua\\" per attivare il sottotitolo #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"In alternativa,","SUBTITLES_ADJUST_DELAY":"Aggiusta ritardo sottotitoli:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Oppure usa i tasti G / H durante la riproduzione per regolare.","SUBTITLES_ADJUST_DELAY_TIP":"SUGGERIMENTO: puoi usare G / H durante la riproduzione per regolare.","SUBTITLES_DELAY":"Ritardo sottotitoli:","SUBTITLES_LOADING":"Caricamento sottotitoli…","SUBTITLES_UNAVAILABLE":"Nessun sottotitolo esterno disponibile","SUBTITLES_DISABLED":"Disabilitati","AUDIO":"Audio","DEFAULT_LANGUAGE":"Lingua Predefinita","DEFAULT_SECONDARY_LANGUAGE":"Lingua Secondaria Predefinita","SEASON":"Stagione","EPISODE":"Episodio","SPECIAL":"Speciale","SORT":"ordina","SORT_BY":"Ordina per","FILTER":"filtro","SORT_TRENDING":"Popolari","SORT_RECENT":"Recenti","SORT_ALPHABET":"A-Z","SORT_RATING":"Voto","SORT_WATCHED":"Visto","SORT_YEAR":"Anno","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nuovi per te","New Episodes":"Nuovi Episodi","New Videos":"Nuovi Video","Recommendations":"Consigliati","LIBRARY_RESUME":"Riprendi","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Dettagli","LIBRARY_RESUME_DISMISS":"Scarta","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"In primo piano","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Vincitore di Oscar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Questo addon ha restituito un contenuto vuoto.","DISCOVER_ADULT_WARNING":"Questo contenuto è visibile solo agli adulti. Hai più di 18 anni?","DISCOVER_NOADDON_WARNING":"Attenzione: nessun addon di Stremio attivo per questo tipo. Questi sono gli elementi salvati, nulla verà aggiornato.","DISCOVER_LOAD_ERR":"Scopri: caricamento del catalogo dall\'addon fallito","DISCOVER_ADDON_UNINSTALLED":"Questo contenuto non è più disponibile, potresti aver disinstallato l\'addon.","UNINSTALL_THIS_ADDON":"Addon disinstallato","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Ricevi notifiche per i nuovi episodi","DETAIL_RECEIVE_NOTIF_VIDEOS":"Ricevi notifiche per i nuovi video","SIDEBAR_SHOW_STREAMS":"Mostra gli Stream","RELAUNCH":"Riavvia ora!","UPGRADE":"Aggiorna all\'ultima versione di Stremio","RELOAD_UI":"Ricarica l’interfaccia utente","MANUAL_UPDATE_TITLE":"Aggiorna la tua versione di Stremio","MANUAL_UPDATE_LINE1":"Stai urilizzando una versione obsoleta di Stremio, il che è altamente sconsigliato","MANUAL_UPDATE_LINE2":"Sei pregatə di aggiornare Stremio il prima possibile.","BUTTON_UPDATE_LATTER":"Non ora","BUTTON_UPDATE_NOW":"Aggiornamento","ANONYMOUS_USER":"Utente anonimo","DONT_HAVE_ACC":"Non hai un Account?","HAVE_ACC":"Hai già un Account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Conferma password","EMAIL":"E-mail","FB_LOGIN":"Collegati con Facebook","FB_NOTHINGSHARED":"Nulla è condiviso senza il tuo permesso","FB_NOPOST":"Non scriveremo nulla a tuo nome","OR":"o","I_ACCEPT":"Accetto","I_ACCEPT_BY_CLICKING":"Premendo il pulsante sopra confermo di accettare","TOS":"Termini e condizioni","MUST_ACCEPT_TERMS":"Devi accettare le condizioni","PASSWORDS_NOMATCH":"La password non corrisponde","SIGN_UP":"Registrati","SIGN_UP_EMAIL":"Registrati con l’email","CLICK_TO_SIGN_UP":"Premi qui per registrarti.","LOG_IN":"Entra","LOG_OUT":"Esci","EXIT_FULLSCREEN":"Esci dalla modalità fullscreen","ENTER_FULLSCREEN":"Entra in modalità fullscreen","PLAY_URL_MAGNET_LINK":"Riproduci URL/Magnet link","HELP_FEEDBACK":"Aiuto & Feedback","TERMS_OF_SERVICE":"Termini di Servizio","PRIVACY_POLICY":"Politica sulla riservatezza","ABOUT_STREMIO":"Info su Stremio","USER_PANEL":"Pannello utente","LOGIN_LABEL":"Accesso","GUEST_LOGIN":"Entra come ospite","GUEST_LOGIN_NOTICE":"Entrare come ospite non è consigliato. Entrando con un account permetti a Stremio di sincronizzare la tua libreria, ricevere notifiche per le tue serie/channels preferiti. Sei sicuro di voler procedere?","GUEST_LOGIN_NOTICE_2":"Entrare come ospite non è consigliato - non avrai la libreria e bacheca delle notifiche sincronizzate, che sono funzioni vitali di Stremio. Sei sicuro di voler procedere?","CLICK_HERE":"Clicca qui","WRONG_PASSWORD":"Password errata. Nel caso tu abbia dimenticato la password, ","SET_A_PASS":"imposta una password","RESET_PASSWORD":"Resetta password","FORGOT_PASSWORD":"Password dimenticata?","EMAIL_USED_WITH_FB":"Questa email è stata utilizzata con l\'accesso Facebook.","INVALID_EMAIL":"Per favore usa un indirizzo email valido","INVALID_PASSWORD":"Per favore inserisci una password valida","CONN_ERR":"Errore di connessione - riprova più darti per favore.\\n\\nSe persiste, disabilita il firewall/software anti-virus(specialmente Bitdefender).","IMPORT_FROM_GUEST":"Importa libreria dal tuo account ospite","RECEIVE_UPDATES_EMAIL":"Ricevi update alla tua email da Stremio","LOGIN_FAILED":"Autenticazione fallita.","SIGNUP_FAILED":"Registrazione fallita.","SEARCH_FAILED":"Ricerca fallita","EMAIL_USED":"Questa email è già in uso.","WAITING_FB_LOGIN":"Accesso con Facebook…","EXTERNAL_PLAYER_TITLE":"Riproduci in un player esterno","EXTERNAL_REMEMBER_PLAYER":"Vuoi la tua scelta sia ricordata?","EXTERNAL_ALWAYS_PLAY":"Sì","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Miglior adattamento","FIT_SCREEN":"Adatta allo schermo","FILL":"Riempi","16:9":"16:9","4:3":"4:3","Original":"Originale","INTRO_TASTE":"Facci sapere cosa ne pensi","INTRO_TASTE_LONG":"Facci sapere cosa ti piace vedere","INTRO_TASTE_PICK":"Seleziona {{interestsRemaining}} interessi","INTRO_TASTE_PICK_MORE":"Seleziona {{interestsRemaining}} più interessi","INTRO_TASTE_HELP_US":"Aiutaci a conoscerti.","INTRO_TASTE_CHOOSE_THESE":"Scegli alcuni di questi:","INTRO_TASTE_CHOOSE_MIN":"Scegli almeno 3 categorie","INTRO_TASTE_CHOOSE_MIN_ERR":"Devi scegliere almeno 3 categorie!","INTRO_TASTE_LIFESTYLE":"Stile di vita","INTRO_TASTE_SPORTS":"Sport","INTRO_TASTE_FOOD_HEALTH":"Cibo & Salute","INTRO_TASTE_BEAUTY_FASHION":"Bellezza & Fashion","INTRO_TASTE_NEWS":"Notizie","INTRO_TASTE_GAMING":"Videogiochi","INTRO_TASTE_SCIENCE_EDU":"Scienze & Educazione","INTRO_TASTE_MUSIC":"Musica","INTRO_TASTE_TRAVEL":"Viaggi","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Commedia","INTRO_TASTE_DIY":"Fai-da-te","INTRO_TASTE_TECH":"Tecnologia","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"L’addon selezionato non è supportato su questa piattaforma.","ADDON_DISCLAIMER":"Usare addon di terze parti sarà sempre soggetto alla tua responsabilità e alle leggi vigenti nella giurisdizione in cui ti trovi.","ADDON_ACTIVATE":"Attivare questo addon?","ADDON_REPO_ADD":"Url della repository dell’addon","ADDON_ADD":"Aggiungi","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Cosa c’è di nuovo","BUTTON_CONTINUE":"Continua","BUTTON_ACTIVATE":"Attiva","BUTTON_ACTIVATED":"Attivato","BUTTON_CANCEL":"Annulla","BUTTON_SUBMIT":"Invia","BUTTON_DISMISS_ALL":"Rimuovi tutto","BUTTON_VIEW_ALL":"vedi tutti","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"La tua libreria sembrerebbe vuota. Scopri quanto è utile :) ","HOW_START":"Puoi cominciare così:","LIB_EMPTY_CAL":"Il tuo calendario mostra le serie nella tua libreria.","HOW_START_CAL":"Puoi aggiungere delle serie così:","LIB_EMPTY_BOARD":"Palcoscenico mostra le notifiche e i consigli in merito alla tua libreria.","HOW_START_BOARD_WAIT":"Per favore, aggiungi alcune serie o canali alla tua libreria e dacci qualche minuto per elaborare il tutto :)","HOW_START_BOARD":"Puoi aggiungere serie e film così:","IMPORT_FB":"Importa quello che ti piace da Facebook","IMPORT_TRAKT":"Importa la tua libreria dei media da Trakt","IMPORT_DISCOVER":"Trova cose interessanti su Discover","IMPORT_DISK":"Importa film o show che hai sul tuo disco","PLEASE_CREATE_ACC":"Per favore crea un account per abilitare la sincronizzazione della libreria & bacheca.","IMPORT_DISCOVER_SIGNUP":"Registrati e scopri cose interessanti da Scopri","IMPORT_DISK_SIGNUP":"Autenticati e importa film o show che hai sul tuo disco locale","LIB_EMPTY_CLOUD":"Libreria cloud","LIB_EMPTY_CLOUD_DESC":"Libreria cloud personale sincronizzata su tutti i dispositivi","LIB_EMPTY_EARLY":"Primi arrivati","LIB_EMPTY_EARLY_DESC":"Ricevi notifiche per i nuovi episodi","LIB_EMPTY_PERSONAL":"Personale","LIB_EMPTY_PERSONAL_DESC":"Ottieni suggerimenti personalizzati","LIB_EMPTY_CALENDAR_DESC":"Organizza il tuo calendario personale","LIB_EMPTY_ALL":"Registrati per ottenere tutto questo:","LIB_EMPTY_BEST":"Registrati per ottenre il meglio da Stremio","LIB_EMPTY_OTHER":"Registrati per abilitare il Calendario & le altre fantastiche funzionalità","CALENDAR_ADDED":"Il calendario di Stremio è stato aggiunto al tuo calendario desktop di default.","CALENDAR_ADDED_MSG":"Se qeusto non funziona, per favore aggiungi manualmente questo URL alla tua applicazione calendario","TRAKT_EXPIRED":"Autenticazione a Trakt scaduta, per favore vai su impostazioni per autenticarti nuovamente","TRAKT_REQUIRES_LOGIN":"Errore di Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Devi fare login","SETTINGS_LABEL":"Impostazioni","SETTINGS_NAV_GENERAL":"Generale","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Scorciatoie","SETTINGS_SHORTCUT_RELOAD_APP":"Ricarica App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Apri le Impostazioni","SETTINGS_SHORTCUT_SWITCH_TABS":"Mostra le schede","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Scorri le schede in avanti","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Scorri le schede all\'indietro","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Esci / Torna indietro","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Passa a Schermo Intero","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Mostra Controlli","SETTINGS_SHORTCUT_PLAY_PAUSE":"Riproduci / Pausa","SETTINGS_SHORTCUT_VOLUME_UP":"Alza Volume","SETTINGS_SHORTCUT_VOLUME_DOWN":"Abbassa Volume","SETTINGS_SHORTCUT_SEEK_NEXT":"Scorri Prossimo","SETTINGS_SHORTCUT_SEEK_PREV":"Scorri Precedente","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Riproduci Prossimo","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Aumenta Dimensione Sottotitoli","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Riduci Dimensione Sottotitoli","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Aumenta Ritardo Sottotitoli","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Riduci Ritardo Sottotitoli","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Attiva/disattiva barra laterale","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Lancia all\'avvio","SETTINGS_VLC_DEFAULT":"Riproduci con VLC","SETTINGS_UI_LANGUAGE":"Lingua Interfaccia","SETTINGS_FULLSCREEN_EXIT":"Tasto Esc esce da schermo intero","SETTINGS_GAMEPAD":"Abilita supporto controller","SETTINGS_CLOSE_WINDOW":"Chiudi app quando la finestra è chiusa","SETTINGS_SUBTITLES_LANGUAGE":"Lingua Predefinita Sottotitoli","SETTINGS_SUBTITLES_SIZE":"Dimensione Predefinita Sottotitoli","SETTINGS_SUBTITLES_BACKGROUND":"Sfondo sottotitoli","SETTINGS_SUBTITLES_COLOR":"Colore sottotitoli","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Colore contorno sottotitoli","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Colore sfondo sottotitoli","SETTINGS_SEEK_KEY":"I tasti freccia scorrono il tempo","SETTINGS_SEEK_KEY_SHIFT":"I tasti freccia scorrono il tempo quando il tasto Maiusc è premuto","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Riproduci automaticamente il prossimo episodio","SETTINGS_NEXT_VIDEO":"Mostra notifica per far partire il prossimo episodio","SETTINGS_NEXT_VIDEO_TRIGGER":"Mostra notifica prossimo episodio per:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Ridimensiona automaticamente la finestra prima di riprodurre","SETTINGS_OVERRIDE_SERVER":"Sovrascrivi l\'URL del server di streaming (avvanzato)","SETTINGS_SERVER_URL":"URL server di streaming: ","SETTINGS_SERVER_AVAILABLE":"Server di streaming disponibile.","SETTINGS_SERVER_UNAVAILABLE":"Server di streaming non disponibile.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Endpoint HTTPS di streaming: ","SETTINGS_USE_BETA":"Usa sempre l\'ultima Beta","SETTINGS_IMPORT_FB":"Importa da Facebook","SETTINGS_IMPORT_DISK":"Importa da disco locale","SETTINGS_IMPORT_TRAKT":"Importa da Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Decodifica con accelerazione hardware","SETTINGS_BACKGROUND":"Riproduzione in sottofondo","SETTINGS_SUBSCRIBE_CALENDAR":"Iscrivi nel calendario","SETTINGS_REQ_EXPORT":"Richiedi estrazione dei dati","SETTINGS_ACC_DELETE":"Richiedi cancellazione account","SETTINGS_CHANGE_PASSWORD":"Cambia password","SETTINGS_TOS":"Termini di servizio","SETTINGS_SUPPORT":"Contatta il supporto","SETTING_LANGUAGE":"Lingua","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Esci da Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scannerizza il codice QR per aprire in remoto","SETTINGS_DESKTOP_NOTIFICATIONS":"Notifiche desktop","SETTINGS_DATA_SAVER":"Risparmio dati","SETTINGS_LANGUAGE_INTERFACE":"interfaccia","SETTINGS_LANGUAGE_SUBS":"sottotitoli predefiniti","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoseleziona Traccia Audio","SETTINGS_DEFAULT_AUDIO_TRACK":"Traccia Audio Predefinita","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"versione","SETTINGS_MPV_WINDOW":"Avvia il player in una finestra separata (avvanzato)","SETTINGS_PLAY_IN_EXTERNAL":"Apri sempre il video nel player esterno","SETTINGS_STORAGE_BUTTON":"Pulisci Memoria Locale","SETTINGS_STORAGE_MODAL_TITLE":"Sei sicuro ?","SETTINGS_STORAGE_MODAL_MESSAGE":"Questo pulirà la memoria locale e ti farà uscire dall\'account.","SETTINGS_HWDEC_PICKER":"Scegli impostazioni di decodifica con accelerazione hardware","SETTINGS_HW_AUTOMATIC":"Automatico","SETTINGS_HW_DISABLED":"Disabilitato","SETTINGS_HW_ACCELERATED":"Accelerazione di decodifica","SETTINGS_HW_FULL":"Accelerazione totale","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addon Sottotitoli","SUBSPICKER_BLACK_BACKGROUND":"Usa colore di sfondo nero","SUBSPICKER_VERTICAL_OFFSET":"Offset Verticale","SUBSPICKER_SIZE":"Dimensione","SUBSPICKER_DELAY":"Ritardo","SUBSPICKER_EMBEDDED_SUBS":"Sottotitoli Incorporati","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Segnalazione arresti","MOBILE_ZOOM_TO_FILL":"Fai Zoom per Riempire lo Schermo","MOBILE_PASSTHROUGH":"Uscita audio digitale (passante)","MOBILE_RUN_LOW_BATTERY":"Esegui a batteria scarica","MOBILE_RUN_FOREGROUND":"Esegui come servizio in primo piano","MOBILE_PERFORMANCE":"PRESTAZIONI E STABILITÀ","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"Il codice QR scade tra ","MOBILE_LOG_INTO":"Accedi al tuo account Stremio ","MOBILE_SCAN_QR":"Scansiona il codice QR sopra o vai a ","MOBILE_LINK_ACCOUNT":"Collega Account","MOBILE_SPEEDPICKER_CANCEL":"Cancella","MOBILE_SPEEDPICKER_LABEL":"Seleziona Velocità di Riproduzione","MOBILE_EMPTY_LIBRARY":"La tua libreria è vuota","MOBILE_NO_ADDON_ACTIVE":"Nessun addon Stremio attivo per questo tipo.","MOBILE_ORGANIZER_WARNING":"L\'app Stremio Organizer offre funzionalità limitate. Per un elenco di stream disponibili e l\'esperienza Stremio completa, utilizza Stremio sul desktop.","MOBILE_ADDON_LOADING":"sta ancora caricando","MOBILE_ADDONS_LOADING":"gli addons stanno ancora caricando","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configura il tuo addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configura Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"L\'app Stremio Organizer fornisce una selezione limitata di addon. Per l\'esperienza Stremio completa, usa Stremio sul desktop.","MOBILE_DISCONNECT":"Disconnesso","MOBILE_LOOKING_FOR_DEVICES":"Ricerca dispositivi...","MOBILE_CAST_TO":"Trasmetti a","NAVIGATION_ON":"Acceso","NAVIGATION_OFF":"Spento","MARKETING_AGREE":"Accetto di ricevere comunicazioni di marketing da Stremio","QUIT":"Chiudi","CONNECTED":"Connesso","AUTHENTICATE":"Autenticare","CACHING":"Salvataggio cache","SETTINGS_CACHING_DRIVE":"Seleziona il disco di cache","ENABLE_LOCAL_FILES_ADDON":"Abilita l\'addon dei file locali (richiede il riavvio)","LOCAL_ADDON_NOT_ENABLED":"L\'addon locale non è abilitato. Clicca qui per andare alle impostazioni e abilitarlo","ENABLE_REMOTE_HTTPS_CONN":"Abilita connessioni HTTPS remote","TORRENT_PROFILE":"Profilo Torrent","DATA_CACHING":"Salvataggio Dati Cache","MAGNET_PARSING":"Analisi del magnet link","January":"Gennaio","February":"Febbraio","March":"Marzo","April":"Aprile","May":"Maggio","June":"Giugno","July":"Luglio","August":"Agosto","September":"Settembre","October":"Ottobre","November":"Novembre","December":"Dicembre","Monday":"Lunedì","Tuesday":"Martedì","Wednesday":"Mercoledì","Thursday":"Giovedì","Friday":"Venerdì","Saturday":"Sabato","Sunday":"Domenica","Action":"Azione","Comedy":"Commedia","War":"Guerra","Family":"Famiglia","Animation":"Animazione","Adventure":"Avventura","Fantasy":"Fantasia","Crime":"Crimine","Mystery":"Mistero","Romance":"Romantico","Drama":"Dramma","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Fantascienza","Music":"Musica","Biography":"Biografia","Documentary":"Documentario","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"Notizie","History":"Storia","Game-Show":"Gioco a Premi","Reality-TV":"Reality-TV","Talk-Show":"Talk Show","Film & Entertainment":"Film & Spettacolo","Gaming":"Giochi","From TV":"Dalla TV","Lifestyle":"Stile di vita","Science & Education":"Scienza & Educazione","Cooking & Health":"Cucina & Salute","Beauty & Fashion":"Bellezza & Moda","Sports":"Sport","News & Politics":"Notizie & Politica","How-to & DIY":"Fai-da-te","Tech":"Tecnologia","Automotive":"Automobilismo","Causes & Non-Profits":"Cause Umanitarie & Non-Profit","Movies":"Film","Uk Live Tv":"UK Live Tv","Fashion":"Moda","Business News Radio":"Radio Notizie Business","Business Tv":"Business Tv","Cars & Auto":"Auto & Motori","Comedy Radio":"Comicità Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"Notizie Tv","Food And Wine":"Cibo & Vino","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religione","Kids":"Bambini","Body & Soul":"Corpo & Anima","Education":"Educativo","Indian Tv":"Indian Tv","Extreme Sports":"Sport Estremi","Middle Eastern Tv":"Medio Oriente Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Scienza Tv","Bikini babe":"Bikini babe","Outdoors":"Aria Aperta","German Tv":"Tv Tedesca","French Tv":"Tv Francese","Italian Tv":"Tv Italiana","Gamer Tv":"Gamer Tv","Travel":"Viaggi","Asian Tv":"Tv Asiatica","Entertainment":"Spettacolo","News Radio":"Notizie Radio","Music Radio":"Music Radio","Language Learning":"Imparare le Lingue","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Scienza & Tecnologia Vod","new video":"nuovo video","new episode":"nuovo episodio","new movie":"nuovo film","recommended":"consigliato","we recommend":"noi raccomandiamo","offer of the day":"offerta del giorno","news":"novità","music video":"video musicale","CTX_SHOW_HOTKEYS":"Mostra tasti di scelta rapida","CTX_DISMISS_NOTIF":"Chiudi notifica","CTX_DISMISS_ALL":"Chiudi tutto","CTX_SHARE":"Condividi","CTX_COPY_SHARE_LINK":"Copia condividi link","CTX_COPY_MAGNET_LINK":"Copia il collegamento magnetico","CTX_COPY_STREAM_LINK":"Copia il link dello stream","CTX_DOWNLOAD_VIDEO":"Scaricare questo video","CTX_DOWNLOAD_SUBS":"Scarica i sottotitoli","CTX_VIEW_ON_YOUTUBE":"Visualizza su YouTube","CTX_SHOW":"Mostra","CTX_PLAY":"Riproduci","CTX_PLAY_IN":"Riproduci in","CTX_PLAY_ON":"Riproduci su","CTX_WATCH_ON":"Guarda su","CTX_WATCH":"Guarda","CTX_WATCHED":"Visto","CTX_WATCH_BEGINNING":"Guarda dall\'inizio","CTX_WATCH_MOBILE":"Guarda su un dispositivo mobile","CTX_REWIND":"Riprendi dall\'inizio","CTX_MARK_WATCHED":"Segna come già visto","CTX_MARK_NON_WATCHED":"Segna come non visto","CTX_MARK_UNWATCHED":"Contrassegna come non guardato","CTX_MARK_REST":"Contrassegna i restanti come guardati","CTX_UNMARK_REST":"Contrassegna i restanti come non guardati","CTX_RECEIVE_NEW_NOTIF":"Ricevi nuove notifiche","CTX_REMOVE_CACHE":"Rimuovi dalla cache","CTX_REMOVE_CACHE_EP":"Rimuovi episodio dalla cache","CTX_OPEN_CONTAINING":"Apri cartella","CTX_REMOVE":"Rimuovi dalla libreria","CTX_AVAILABLE_OFFLINE":"Disponibile Offline","CTX_PAUSED":"In Pausa","CTX_ALWAYS_ON_TOP":"Sempre in cima","CTX_FULLSCREEN":"Schermo intero","CTX_WRONG_SUBS":"Sottotitolo sbagliato?","CTX_REPORT_ISSUES":"Segnala problema","CTX_COPY":"Copia","CTX_PASTE":"Incolla","CTX_CLEAR":"Cancella","CTX_CLEAR_RECENT_SEARCHES":"Cancella ricerche recenti","HELLO_THERE":"Hey ciao","HOPE_YOU_ENJOY":"Speriamo ti piaccia Stremio e che sia già una delle tue app preferite!","WHO_ARE_WE":"Chi siamo noi? Siamo il team che sta dietro - due ragazzi che hanno lavorato duramente ogni giorno negli ultimi 3 anni, con un unico obiettivo - rendere questo prodotto migliore sempre di più.","SUPPORT_US":"Se ti piace usare Stremio e pensi possa valere qualcosa - supportaci!","SPREAD_THE_WORD":"Condividi ora con i tuoi amici, spargi la voce su Stremio","MORE_PEOPLE":"Più persone usano Stremio, più migliorerà!","SEND_A_LINK":"Oppure invia un link al nostro sito web","TIP_LOCALFILES":"Suggerimento: puoi fare drag & drop dei video file locali in Stremio","ADDON_MY":"Miei Addon","ADDON_COMMUNITY":"Comunità Addon","ADDON_OFFICIAL":"Addon Ufficiali","ADDON_REPOS":"Cartelle Addon","ADDON_SEARCH":"Cerca addon","ADDON_INSTALL":"Installa","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Disinstalla","ADDON_UPGRADE":"Aggiorna","ADDON_INSTALLED":"Installato","ADDON_INSTALLED_MSG":"Addon installato!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Sconosciuto","ADDON_ERR":"Errore installazione Addon!","ADDON_DISCONNECTED":"Disconnesso","ADDON_APP_MISSING":"l\'app per questa fonte non è installata. Vuoi installarla ora?","ADDON_APP_INSTALL":"Installa Ora","ADDON_PAGE":"Pagina Addon","ADDON_TOP_CONTENT":"Il meglio di questo Addon","ADDON_PROVIDES":"fornisce","ADDON_WATCH":"Guarda #{types} ora!","ADDON_WATCH_FREE":"Guarda #{types} GRATIS ora!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Typi supportati","ADDON_SUPPORTED_CATALOGS":"Cataloghi supportati","ADDON_PROVIDES_DISCOVER":"Di più #{types} in Scopri","ADDON_PROVIDES_STREAMS":"Guarda #{types}","ADDON_PROVIDES_STREAMS_FREE":"Guarda #{types} GRATIS","ADDON_PROVIDES_SUBTITLES":"Sottotitoli per #{types}","ADDON_CANTDETECT":"Non siamo riusciti ad individuare alcun Stremio in esecuzione, perciò non siamo stati in grado di scoprire quali addon sono installati.","ERR_NO_META":"Nessun informazione trovata riguardo a questo","ERR_GETTING_META":"Errore nel recupero informazioni riguardo a questo.","ERR_CANT_PARSE_MAGNET":"Impossibile analizzare magnet","ERR_NO_MAGNET_INFOHASH":"Informazioni hash non valide per il magnet","ERR_NO_FILE_PATH":"Impossibile inviare richiesta senza percorso al file","ERR_NO_TORRENT":"Nessun torrent ritornato","ERR_NO_SUPPORTERD_FILES":"Non trovati file supportati","ERR_OPENING_FILES":"Impossibile aprire file esterni","ERR_INVALID_LINK":"Link non valido","ERR_REGISTERED_ONLY":"Questa funzione è disponibile solo per utenti registrati.","ERR_CLIPBOARD":"Impossibile riprodurre dagli appunti","ERR_CLIPBOARD_READ":"Impossibile leggere gli appunti su questa piattaforma","ERR_CLIPBOARD_GENERIC":"Nessun URL riproducibile trovato negli appunti. Copia un URL (ad es. un link magnetico) in un video.","BOARD_CONTINUE_WATCHING":"Continua a guardare","BOARD_EXPLANATION_RECOMMENDATIONS":"Film scelti solo per te.
Questo film è un esempio di suggerimento.","BOARD_EXPLANATION_EPISODES":"I nuovi episodi delle tue serie tv preferite arrivano qui.
Aggiungi serie tv che segui alla tua Libreria.","BOARD_EXPLANATION_VIDEOS":"I nuovi episodi dei tuo canali YouTube arrivano qui.
Aggiungi canali che segui alla tua Libreria.","WEBSITE_SLOGAN_WATCH":"Guarda subito","WEBSITE_SLOGAN_ALL":"Tutti I Contenuti Video Che Ami In Un\'Unica Raccola","WEBSITE_SLOGAN_NEW":"Tutto quello che puoi vedere","WEBSITE_SLOGAN_NEW_NEW":"Libertà di Streaming","WEBSITE_WATCH_FROM":"Guarda Da","WEBSITE_DOWNLOAD":"Scarica Ora","WEBSITE_DOWNLOAD_FOR":"Scarica Ora per","WEBSITE_IS_DESKTOP":"Stremio è un\'applicazione desktop, apri questa pagina sul tuo PC e scaricala","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Caratteristiche","WEBSITE_PAGE_ADDONS":"Addon","WEBSITE_PAGE_TECH":"Tecnologia","WEBSITE_PAGE_CREATE_ADDON":"Crea Addon","WEBSITE_PAGE_CONTACTS":"Contatti","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Film","WEBSITE_TYPE_series_PL":"Serie","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Canali","WEBSITE_STREMIO_WHAT_IS":"Stremio è un\'applicazione che ti aiuta ad organizzare e instantaneamente ti permette di guardare i tuoi video, film, serie TV e canali TV prefeti.","WEBSITE_FEATURES_WATCH":"Guarda subito in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Clicca e guarda i tuoi film, serie TV, video e canali TV preferiti.","WEBSITE_FEATURES_SUBS":"Sottotitoli Automatici","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio sceglie automaticamente i sottotitoli sincronizzati per la tua lingua.","WEBSITE_FEATURES_SUBS_LABEL":"Spetta a te la mossa, capitano.","WEBSITE_FEATURES_CAST":"Riproduci sulla TV e i dispositivi mobili","WEBSITE_FEATURES_CAST_DETAIL":"Trasmetti su AppleTV, Chromecast, Smart TV (DLNA/UPnP) e dispositivi mobili.","WEBSITE_LIB":"Goditi La Tua Libreria Personale Sincronizzata Su Tutti I Tuoi Dispositivi","WEBSITE_LIB_COLLECT":"Raccogli da Stremio","WEBSITE_LIB_IMPORT":"Importa da Facebook","WEBSITE_LIB_LOCAL":"Aggiungi dal tuo disco locale","WEBSITE_BOARD":"Il Tabellone - Il Tuo Unico Posto per le Notifiche e i Suggerimenti","WEBSITE_BOARD_RECOMMEND":"Serie TV Suggerite","WEBSITE_BOARD_TRENDING":"Film del Momento","WEBSITE_BOARD_NEW":"Nuovi Video","WEBSITE_BOARD_EPISODE":"Nuovi Episodi","WEBSITE_BOARD_1":"Cerchi qualcosa di interessante da guardare? Ricevi suggerimenti basati sulle tue preferenze!","WEBSITE_BOARD_2":"Ricevi una notifica quando c\'è un nuovo episodio della tua serie TV preferita o canale YouTube!","WEBSITE_BOARD_YOUTUBE":"Nuovi video dai canali YouTube","WEBSITE_BOARD_EPISODES":"Nuovi episodi dalle serie che stai seguendo","WEBSITE_ADDONS":"Contenuti Addon","WEBSITE_TECH_DETAIL":"Amiamo la tecnologia, amiamo la scienza pazza!\\nStremio usa le seguenti tecnologie open source:","WEBSITE_TECH_WCJS":"WebChimera.js permette a Stremio di riprodurre ogni formato video con ottime prestazioni.","WEBSITE_TECH_WCJS_EXTRA":"Siamo i contributori del progetto principale","WEBSITE_TECH_ELECTRON":"Electron fornisce una piattaforma innovativa con la quale sviluppare Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Siamo contributori del progetto","WEBSITE_TECH_LINVODB":"Un database che assicura che i tuoi dati siano organizzati e disponibili da ovunque accedi.","WEBSITE_TECH_LINVODB_EXTRA":"Tecnologia sviluppata in casa","WEBSITE_CREATE_ADDON":"Crea il tuo Addon","WEBSITE_CREATE_ADDON_DETAIL":"Hai un servizio he fornisce contenuti video? Ti aiuteremo a sfruttare le caratteristiche di Stremio creando il tuo Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefici dell\'avere un Addon per Stremio","WEBSITE_P2P_BEAUTY":"La Bellezza dello Streming Peer-to-Peer","WEBSITE_P2P_1":"Video full HD / 4K on demand o dirette streaming Affidabili e Sostenibili","WEBSITE_P2P_2":"Piattaforma di distribuzione che offre una fantastica esperienza utente","WEBSITE_P2P_3":"Svilupperemo il tuo addon che va in contro alle tue esatte necessità","WEBSITE_P2P_CONTACT":"Interessato? Sei il benvenuto contattaci.","WEBSITE_P2P_CONTACT_EXTRA":"Saremo felici di aiutarti ad integrare i tuoi contenuti con Stremio!","WEBSITE_P2P":"Una volta ogni tanto, arriva una tecnologia che cambia le regole del gioco. Abbiamo investito moltissimo tempo e impegno per costruire il nostro motore di streaming video Peer-to-Peer (P2P) che offre ottime prestazioni e versatilità nel addattarsi ad ogni caso d\'uso.\\nContattaci per i video con supporto DRM P2P on demand o dirette streaming.","WEBSITE_THOUGHTS":"I pensieri che condividiamo:","WEBSITE_SPREAD":"Passa parola riguardo a Stremio:","WEBSITE_CONTACT":"Se stai cercando di contattarci, fai pure qui","WEBSITE_OPENSOURCE":"Per i nostri progetti open source , vai al nostro","WEBSITE_BITCOIN":"Dona bitcoin:","WEBSITE_FAQ":"Domande Frequenti","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Domande","WEBSITE_TOS":"Condizioni d\'uso","WEBSITE_LEGAL":"Legale","WEBSITE_PAGE_ABOUT":"Riguardo","WEBSITE_PAGE_BECOME_PARTNER":"Diventa un partner","WEBSITE_ALL_YOU_CAN_WATCH":"Libertà di Guardare\\nTutto Quello che Vuoi.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Cos\'è Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio è un unico centro di raccolta per i contenuti video. Scopri, organizza e guarda video da qualsiasi fonte su ogni dispositivo in tuo possesso.","WEBSITE_WHAT_IS_STREMIO_P2":"Film, programmi TV, serie, dirette TV o canali web come YouTube e Twitch.tv: puoi trovare tutto questo su Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio è un media center moderno che rappresenta una soluzione completa per il tuo intrattenimento video. Scopri, guarda e organizza contenuti video con addon facili da installare.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Film, programmi TV, dirette TV o canali web: tutto questo su Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Divertiti su tutti i tuoi dispositivi multimediali","WEBSITE_DEVICES_COLLECT":"Prendi da Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importa da facebook","WEBSITE_DEVICES_LOCAL":"Aggiungi dal disco locale","WEBSITE_JOIN_THE_PARTY_NOW":"Unisciti alla festa ora","WEBSITE_DEVICES_ALL":"Facile da utilizzare su tutti i tuoi dispositivi;","WEBSITE_EXTENDABLE_CATALOG":"Catalogo video infinitamente espandibile;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Ottime funzionalità per organizzare i tuoi video;","WEBSITE_AS_SEEN_ON":"Come visto su","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Su di Noi","WEBSITE_LINK_TECHNOLOGY":"Tecnologia","WEBSITE_LINK_APPS":"App","WEBSITE_LINK_DOWNLOADS":"Download","WEBSITE_MORE":"Di più","WEBSITE_LINK_ADDONS":"Addon","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribuisci","WEBSITE_LINK_COMMUNITY":"Comunità","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & di più","WEBSITE_LINK_HELP":"Centro assistenza","WEBSITE_LINK_CONTACTS":"Contattaci","WEBSITE_LINK_TOS":"Termini & condizioni","WEBSITE_LINK_PRAVACY":"Politica sulla riservatezza","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Iscriviti alla nostra newsletter per cose fantastiche","WEBSITE_PLACEHOLDER_EMAIL":"La Tua Email","WEBSITE_COMMUNITY":"Comunità","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Perché lo facciamo","WEBSITE_WHY_P1":"Noi di Stremio, torniamo al lavoro ogni giorno perché vogliamo risolvere un importante problema dell\'industria dei video on-demand. Ci sono così tanti nuovi contenuti pubblicati ogni minuto che è praticamente impossibile orientarsi.","WEBSITE_WHY_P2":"Aiutiamo le persone a navigare nell\'enorme mondo dell\'intrattenimento video e scoprire nuovi contenuti con i quali divertirsi. Le nostre app riuniscono film, serie, dirette TV, canali web e altro ancora. Ci impegniamo a rendere molto facile per gli utenti trovare titoli ed emittenti che amano.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"Il team di Stremio è piccolo, ma potente: tra i dieci di noi programmiamo in X linguaggi e condividiamo competenze nello sviluppo di software, progettiamo UI e UX, marketing e pubblicità e business e startup.","WEBSITE_FEATURES":"Caratteristiche","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Scopri nuovi contenuti con facilità","WEBSITE_FEATURES_DISCOVER_P":"Scopri facilmente nuovi film, programmi TV, serie e canali da guardare. Sfoglia per categoria, genere, valutazione, attualità, ecc. Oppure digita semplicemente un nome da trovare. Stremio rende la ricerca di nuovi contenuti video un gioco da ragazzi.","WEBSITE_FEATURES_ALL_CONTENT":"Tutti i tuoi contenuti video su uno schermo","WEBSITE_FEATURES_ALL_CONTENT_P1":"Guarda quali film, serie o video non hai finito e continua a guardarli; ricevere notifiche per nuovi episodi e uscite; e sfoglia i consigli che otterrai in base alle tue abitudini di visualizzazione.","WEBSITE_FEATURES_LIBRARY":"Organizza la tua libreria","WEBSITE_FEATURES_LIBRARY_P1":"Aggiungi qualsiasi titolo alla tua libreria Stremio con un solo clic e trova la tua strada tra i contenuti, ordinati per tipo, attualità o ordine alfabetico.","WEBSITE_FEATURES_CALENDAR":"Tieni traccia di tutto ciò che guardi","WEBSITE_FEATURES_CALENDAR_P1":"Ottieni una visualizzazione del calendario di tutti i film e le serie che aggiungi alla tua libreria. Esporta il tuo calendario Stremio e sincronizzalo in modo da sapere sempre quando è previsto un nuovo episodio o una prima.","WEBSITE_FEATURES_BIG_SCREEN":"Goditi i tuoi contenuti video su uno schermo più grande","WEBSITE_FEATURES_BIG_SCREEN_P1":"Trasmetti tutto ciò che stai guardando su un altro dispositivo, che si tratti di un telefono, tablet o TV con un solo clic.","WEBSITE_FEATURES_SOURCES":"Guarda il video da fonti diverse","WEBSITE_FEATURES_SOURCES_P":"Installa addon ufficiali e della community per goderti video provenienti da provider diversi, il tutto in un\'unica app elegante e facile da usare.","WEBSITE_CREATE_AN_ADDON":"Crea un addon","WEBSITE_FEATURES_SYNC":"Sincronizza la tua libreria su diversi dispositivi e riprendi la riproduzione","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"INVIATO","WEBSITE_CONTACT_US_Q_1":"Come si installa?","WEBSITE_CONTACT_US_Q_2":"Come si disinstalla?","WEBSITE_CONTACT_US_Q_3":"(HTML) Come si fanno le lasagne?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Tecnologia","WEBSITE_TECHNOLOGY_P1":"Amiamo la tecnologia e la scienza folle.
Ecco ciò che fa girare Stremio (è tutto open-source).","WEBSITE_TECHNOLOGY_P_QT":"Sviluppo di software multi piattaforma al suo massimo splendore.","WEBSITE_TECHNOLOGY_P_MPV":"Un riproduttore multimediale gratuito, open source, e multi piattaforma.","WEBSITE_TECHNOLOGY_P_RN":"React Native ti permette di costruire applicazioni usando solo JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework incorporato nell\'applicazione per ottenere contenuti multimediali.","WEBSITE_TECHNOLOGY_P_REALM":"Realm è una piattaforma mobile e un sostituto di SQLite e Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js è un ambiente runtime per JavaScript, open-source e multi piattaforma.","WEBSITE_TECHNOLOGY_P_RUST":"Rust è un linguaggio di programmazione multi paradigma incentrato sulla sicurezza, specialmente sulla concorrenza sicura.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribuisci al progetto","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Ci sono due modi in cui puoi contribuire a Stremio e aiutarci a renderlo migliore.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Puoi donare le tue preziose competenze linguistiche traducendo la piattaforma...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"oppure","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... puoi sfruttare le tue capacità di scrittura del codice per creare addon per la comunità. ","WEBSITE_TRANSLATE_STREMIO":"Traduci Stremio","WEBSITE_404_OH_NO":"Uh-oh! La pagina che stavi cercando non si trova qui...","WEBSITE_GO_HOME":"Torna sulla home","WEBSITE_LINK_OTHER_DOWNLOADS":"Altri download","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Supporto","WEBSITE_DOWNLOAD_4_0_BETA":"Scarica Ora Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Ottieni per desktop","WEBSITE_LINK_ADDON_COMPETITION":"Competizione addon","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"Il mio account","WEBSITE_MAINPAGE_FAQ_001_H1":"Che cos\'è Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"Per altre domande, vai al nostro ${1}centro assistenza${2}.","HELP_LEARN_MORE":"Aiutaci a conoscerti meglio.","LIFESTYLE":"Stile di vita","SPORTS":"Sport","FOOD_HEALTH":"Cibo & salute","BEAUTY_FASHION":"Moda & bellezza","NEWS":"Notizie","GAMING":"Giochi","SCIENCE_EDUCATION":"Scienze & istruzione","MUSIC":"Musica","TRAVEL":"Viaggi","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Commedie","DIY":"Fai-da-te","TECH":"Tecnologia","CINEMA":"Cinema","CONTINUE":"Continua","SLOW_LOADING":"CARICAMENTO LENTO?","I_GIVE_UP":"RINUNCIO","LEARN_MORE":"Per saperne di più","POOR_SOURCE":"Questa fonte è scarsamente disponibile o la tua connessione Internet non è abbastanza veloce","PICK_CATEGORIES_ERR":"Devi scegliere almeno 3 categorie","ADJUST_TIMING":"Regola il tempo con ","ADJUST_SIZE":"Regola le dimensioni con ","SEARCH_ANYTHING":"Puoi cercare qualsiasi cosa...","ALL_CATEGORIES":"Tutte","SEARCH_CATEGORIES":"Film, Serie, YouTube & TV","SEARCH_PERSONS":"Attori, Registi & Scrittori","SEARCH_PROTOCOLS":"Link HTTP & Magnet","SEARCH_TYPES":"Link IMDB / TVDB","WATCHED":"Guardati","SHOW_LESS":"Mostra meno","LAST_SEARCHES":"Ultime ricerche","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"SCEGLI TRA QUESTI:","NO_WEB_REMOTE":"Impossibile caricare Telecomando Web","STREMIO_OFFLINE":"Stremio è offline","STREMIO_EXPENSIVE_CONNECTION":"La connessione di rete può comportare costosi","USE_DATA":"Usa dati","WARNING":"Attenzione","MORE_INFO":"Più informazioni ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Caricamento ...","STREMIO_TV_BACK_TO_LANGUAGES":"Torna alle lingue","STREMIO_TV_REMOTE":"Telecomando","STREMIO_TV_GO_TO":"Vai a:","STREMIO_TV_OR_SCAN":"o scansiona:","STREMIO_TV_ADDON_INSTRUCTIONS":"Per favore segui le istruzioni per installare i tuoi componenti aggiuntivi preferiti.","STREMIO_TV_LIVE_TV":"Diretta TV","STREMIO_TV_RESUME_WATCHING":"Riprendi a Guardare","STREMIO_TV_LOADING_BACKGROUND":"Caricamento Sfondo","STREMIO_TV_CHECKING_AUTHENTICATION":"Controllo Autenticazione","STREMIO_TV_LOADING_BOARD":"Scheda di Caricamento","STREMIO_TV_LOGIN_HEADER_LINE_1":"Vogliamo che i nostri utenti abbiano la migliore esperienza personalizzata possibile con il nostro software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"È per questo motivo che ti chiediamo gentilmente di creare e/o accedere al tuo account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Grazie per la comprensione,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Il Team Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Per utilizzare il Telecomando Web con il tuo Smartphone / Tablet / Computer:","STREMIO_TV_WIFI_SETUP":"Configurazione Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle non ha rilevato una connessione Internet.","STREMIO_TV_WIFI_DETAILS_1":"Connetti a:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Usa password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Apri un browser web con il link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Cambia dispositivo","REMOTE_VIDEOS":"Video","REMOTE_ADJUST_TIMING":"Regola tempi","REMOTE_ADJUST_SIZE":"Regola dimensioni","REMOTE_COULD_NOT_BE_LOADED":"Non è stato possibile caricare Telecomando Web","REMOTE_RETRY":"Riprova","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Cos\'è Stremio?","FAQ_001_P1":"Stremio è un software per media center progettato per l\'intrattenimento video pensando alla facilità d\'uso. Stremio ti consente di organizzare e guardare la tua raccolta di film, serie, canali e dirette TV.","FAQ_001_P2":"Stremio raccoglie i contenuti che ti mostra dal tuo disco locale e dal nostro sistema di addon.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Aggiungerete questo film / questa serie TV?","FAQ_06_P1":"No, ci dispiace :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Creerete addon per X?","FAQ_08_P1":"È assolutamente possibile.","FAQ_08_P2":"Se hai un\'idea per un addon, scrivi una riga a ${1}office@stremio.com${2}, ma assicurati che la tua idea per l\'addon non infranga nessun copyrights o condizione d\'uso.","FAQ_08_P3":"Al momento, le prossime cose sulla nostra tabella di marcia sono addon per FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Stremio fa uso di BitTorrent?","FAQ_09_P1":"Sì, Stremio supporta BitTorrent come protocollo di streaming. Puoi usarlo sia con un addon per torrent, oppure trascinando un file .torrent su Stremio, oppure incollando un magnet link nella barra di ricerca.","FAQ_09_P2":"Attenzione, da notare che l\'unico addon che usa BitTorrent è ${1}Vodo${2}, il quale fornisce contenuti indie, tutti autorizzati per essere distibuiti su BitTorrent.","FAQ_09_P3":"Noi non supportiamo l\'uso di un qualsiasi addon di terze parti che permetta l\'infrangimento del copyright.","FAQ_10_H1":"Cosa posso guardare su Stremio con gli addon ufficiali?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},9163:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Филм","TYPE_series":"Серија","TYPE_tv":"TV канал","TYPE_channel":"YouTube канал","TYPE_other":"Other","TYPE_movie_PL":"Филмови","TYPE_series_PL":"Серии","TYPE_tv_PL":"TV канали","TYPE_channel_PL":"YouTube канали","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Назад","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Најди","Board":"Известија","Library":"Библиотека","My Library":"My Library","Calendar":"Календар","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"бараj","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Додај","REMOVE_FROM_LIB":"Отстрани","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Треjлер","WATCH_TRAILER":"Треjлер","WATCH_NOW":"Гледај","SHOW":"Покажи","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb рејтинг","YEAR":"Година","DIRECTOR":"Режија","WRITER":"Автор","LEAD_ACTORS":"Во Главните улоги","CAST":"Глумат","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"емитувано","SEASONS":"Сезони","GENRE":"Жанр","CATALOG":"Catalog","SUMMARY":"Опис","SHOW_MORE":"Show More","SIMILAR":"Слични","UPCOMING":"Скоро","ENDED":"Прекинат","DURATION":"Времетраење","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"search videos","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"addon","ADDONS":"Addons","OFFICIAL":"официјални","ADDONS_OFFICIAL":"Официјални addon-и","ADDONS_POPULAR":"Популарни во регионот","ADDON_FREE":"бесплатно","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"subscription","ADDON_STREAM_GEORESTRICTED":"not available in your area","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Достапни извори","NO_STREAM":"Нема достапни извори","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Филмот е сеуште во кината","WATCH_IN_CINEMA":"Watch it in your local cinema","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Сеуште немаме информации за овој канал.
Вратете се по неколку минути.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Додадете го во библиотеката за да примите известување.","GET_NOTIFIED_WHEN_AVAILABLE":"Ќе примите известување кога ќе излезе.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"Стриминг од","CASTING_TO":"Репродукција на","NETWORK_STATUS":"Мрежа","STREAM_SPEED":"Брзина:","STREAM_BUFFERED":"Буфер:","PEERS_INFO":"Корисници","PEERS_ACTIVE":"Активни:","PEERS_CONNECTED":"Поврзани:","PEERS_WAITING":"Чекаат:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"Се вчитува...","PLAYING_LOCAL":"репродукција од локална датотека","PLAYING_CACHE":"репродукција од кеш","WRONG_SUBS":"Грешни преводи?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Изберете уред","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Телефон / таблет","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Смени превод на","SUBTITLES_CHANGE_NONE":"Нема други преводи за тој јазик.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alteratively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Сезона","EPISODE":"Епизода","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"популарни","SORT_RECENT":"последни","SORT_ALPHABET":"a-z","SORT_RATING":"рејтинг","SORT_WATCHED":"видени","SORT_YEAR":"година","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Топ","DISCOVER_OSCAR":"Добитници на Оскар","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Внимание: нема активен Stremio addon за овој тип содржина. Овде гледате зачувана информациjа, таа нема да се обновува.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Лансирање новата верзија!","UPGRADE":"Достапна е нова верзија","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Влегување со Фејсбук","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"или","I_ACCEPT":"Ги прочитав и ги прифаќам","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Општите услови","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Лозинките се разминуваат","SIGN_UP":"Регистрирај се","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Влез","LOG_OUT":"Излез","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Влегување како гостин","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"кликнете овде","WRONG_PASSWORD":"погрешна лозинка. Во случај дека сте ја заборавиле","SET_A_PASS":"ставете ваша лозинка","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"Овој email е употребен со Фејсбук најава.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Употребата на addon-и од трети лица е на ваша одговорност.","ADDON_ACTIVATE":"Активирај овој addon?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Што е ново?","BUTTON_CONTINUE":"Продолжи","BUTTON_ACTIVATE":"Активирај","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Откажи","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Библиотеката ви е празна. Откријте колку е корисна :)","HOW_START":"Започнете така:","LIB_EMPTY_CAL":"Календарот покажува епизоди од сериите во вашата Библиотека.","HOW_START_CAL":"Еве како да додадете серии:","LIB_EMPTY_BOARD":"Тука ќе видите известувања и препораки свързани со вашата Библиотеката.","HOW_START_BOARD_WAIT":"Ве молиме додадете неколку канали / серии и ни даjте неколку минути да собереме известувања :)","HOW_START_BOARD":"Еве како да додадете филмови и серии во библиотеката:","IMPORT_FB":"Додавање од Facebook ","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Најди интересни работи во Discover ","IMPORT_DISK":"Скенирајте за филмови и серии од вашиот локален диск ","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Промена на лозинка","SETTINGS_TOS":"Услови на употреба","SETTINGS_SUPPORT":"Поддршка","SETTING_LANGUAGE":"Јазик","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Стоп","CONNECTED":"Connected","AUTHENTICATE":"овластување","CACHING":"Кешира","SETTINGS_CACHING_DRIVE":"Изберете диск за кеш","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Jануари","February":"Февруари","March":"Март","April":"Април","May":"Мај","June":"Јуни","July":"Јули","August":"Август","September":"Септември","October":"Октомври","November":"Ноември","December":"Декември","Monday":"Понеделник","Tuesday":"Вторник","Wednesday":"Среда","Thursday":"Четврток","Friday":"Петок","Saturday":"Сабота","Sunday":"Недела","Action":"Акција","Comedy":"Комедија","War":"Воени","Family":"Семејни","Animation":"Анимација","Adventure":"Авантура","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romance","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years, with a single goal - to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - support us!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},6735:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Wayang","TYPE_series":"Siri","TYPE_tv":"Saluran TV","TYPE_channel":"Saluran","TYPE_other":"Other","TYPE_movie_PL":"Wayang","TYPE_series_PL":"Siri","TYPE_tv_PL":"Saluran TV","TYPE_channel_PL":"Saluran","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Kembali","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Teroka","Board":"Papan","Library":"Pustaka","My Library":"My Library","Calendar":"Takwim","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"cari","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Tambah dalam Pustaka","REMOVE_FROM_LIB":"Keluarkan dari Pustaka","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Watch Trailer","WATCH_NOW":"Tonton Sekarang","SHOW":"Tayang","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb","YEAR":"Tahun","DIRECTOR":"Pengarah","WRITER":"Penulis","LEAD_ACTORS":"Teraju Utama","CAST":"Pelakon","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Ke Udara","SEASONS":"Musim","GENRE":"Genre","CATALOG":"Catalog","SUMMARY":"Ringkasan","SHOW_MORE":"Show More","SIMILAR":"Yang Serupa","UPCOMING":"Akan Datang","ENDED":"Tamat","DURATION":"Tempoh","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"cari video","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"addon","ADDONS":"Addons","OFFICIAL":"rasmi","ADDONS_OFFICIAL":"Addons Stremio Rasmi","ADDONS_POPULAR":"Mahsyur di kawasan anda","ADDON_FREE":"Percuma","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"langganan","ADDON_STREAM_GEORESTRICTED":"tiada dalam kawasan anda","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Streams yang sedia ada","NO_STREAM":"Tiada streams buat masa ini","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Tunjukkan semua addons »","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Tayangan masih dalam teater","WATCH_IN_CINEMA":"Tonton di wayang berdekatan anda","IN_THEATER":"Dalam tayangan","GET_TICKETS":"Dapatkan Tiket","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Add it to your library to get notified once it is available.","GET_NOTIFIED_WHEN_AVAILABLE":"You will get notified once it is available.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Alamak, ralat pemain","PLAYER_ERROR_LOOKSLIKE":"Nampaknya seperti","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"streaming dari","CASTING_TO":"Tayangkan ke","NETWORK_STATUS":"Status capaian","STREAM_SPEED":"Kelajuan stream:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Maklumat peers","PEERS_ACTIVE":"Aktif:","PEERS_CONNECTED":"Sambungan:","PEERS_WAITING":"Menunggu:","TRANSCODING_WARNING":"Amaran: video transkoding.","STREAM_LOADING":"Memuatkan...","PLAYING_LOCAL":"main dari fail tempatan","PLAYING_CACHE":"playing from cache","WRONG_SUBS":"Wrong subtitles?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Pilih peranti untuk tayang","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Bimbit / Tablet","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Tukar sari kata untuk ","SUBTITLES_CHANGE_NONE":"There are no other subtitles for this language, sorry.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Sari kata lewat:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Musim","EPISODE":"Episod","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"baru","SORT_ALPHABET":"a-z","SORT_RATING":"rating","SORT_WATCHED":"ditonton","SORT_YEAR":"year","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"sambung","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Mahsyur","DISCOVER_OSCAR":"Pemenang Oscar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Masuk guna Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"atau","I_ACCEPT":"Saya akur","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terma dan Syarat","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Kata laluan tak sama","SIGN_UP":"Daftar","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Masuk","LOG_OUT":"Keluar","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Guest login","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"click here","WRONG_PASSWORD":"Katalaluan salah. Sekiranya terlupa, ","SET_A_PASS":"tetapkan satu kata laluan","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"Emel ini telah diguna This email was used with a Facebook login.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Aktifkan tambahan ini?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Apa yang terbaru","BUTTON_CONTINUE":"Teruskan","BUTTON_ACTIVATE":"Aktifkan","BUTTON_ACTIVATED":"Aktif","BUTTON_CANCEL":"Batal","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Cara bagaimana untuk mula:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Lancarkan bila mula","SETTINGS_VLC_DEFAULT":"Main guna VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Terus main episod seterusnya","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import dari Facebook","SETTINGS_IMPORT_DISK":"Import dari local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Masukkan ke kalendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Tukar katalaluan","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Contact support","SETTING_LANGUAGE":"Bahasa","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Keluar","CONNECTED":"Connected","AUTHENTICATE":"Pengesahan","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Select caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januari","February":"Februari","March":"Mac","April":"April","May":"Mei","June":"Jun","July":"Julai","August":"Ogos","September":"September","October":"Oktober","November":"November","December":"Disember","Monday":"Isnin","Tuesday":"Selasa","Wednesday":"Rabu","Thursday":"Khamis","Friday":"Jumaat","Saturday":"Sabtu","Sunday":"Ahad","Action":"Aksi","Comedy":"Komedi","War":"Perang","Family":"Kekeluargaan","Animation":"Animasi","Adventure":"Pengembaraan","Fantasy":"Khayalan","Crime":"Jenayah","Mystery":"Misteri","Romance":"Percintaan","Drama":"Drama","Horror":"Seram","Thriller":"Seram Sejuk","Sci-Fi":"Sains","Music":"Musik","Biography":"Biografi","Documentary":"Dokumentari","Sport":"Sukan","Musical":"Muzikal","Western":"Barat","Film-Noir":"Film-Noir","News":"Berita","History":"Sejarah","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Permainan","From TV":"Dari TV","Lifestyle":"Gaya Hidup","Science & Education":"Sains & Pendidikan","Cooking & Health":"Masakan & Kesihatan","Beauty & Fashion":"Kecantikan & Fesyen","Sports":"Olah raga","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Radio Akhbar Perniagaan","Business Tv":"Tv Niaga","Cars & Auto":"Kereta & Kenderaan","Comedy Radio":"Radio Jenaka","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Jasmani & Jiwa","Education":"Pendidikan","Indian Tv":"Tv India","Extreme Sports":"Sukan Lasak","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Tv Selebriti","Science Tv":"Tv Sains","Bikini babe":"Awek Bikini","Outdoors":"Outdoors","German Tv":"TV German","French Tv":"TV Perancis","Italian Tv":"Tv Itali","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"Radio Akhbar","Music Radio":"Radio Muzik","Language Learning":"Belajar Bahasa","Science Radio":"Radio Sains","Tech Radio":"Radio Tek","Science & Technology Vod":"Vod Sains & Teknologi","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"berita","music video":"video muzik","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Tayang","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Skrin Penuh","CTX_WRONG_SUBS":"Sari kata salah?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Salin","CTX_PASTE":"Paste","CTX_CLEAR":"Padam","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Damai Sana","HOPE_YOU_ENJOY":"Kami harap anda terhibur dengan Stremio dan menjadi salah satu apps kegemaran anda","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Muat Turun Sekarang","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Teknologi","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Saluran","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Rancangan TV yang disarankan","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"Video Baharu","WEBSITE_BOARD_EPISODE":"Episod Baharu","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},3778:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"TV kanal","TYPE_channel":"Kanal","TYPE_other":"Other","TYPE_movie_PL":"Filmer","TYPE_series_PL":"Serier","TYPE_tv_PL":"TV kanaler","TYPE_channel_PL":"Kanaler","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Tilbake","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Oppdag","Board":"Board","Library":"Bibliotek","My Library":"My Library","Calendar":"Kalender","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"Søk blant","SEARCH_NO_RESULTS":"Ingen resultater","SEARCH_EXPLANATION_CONTENT":"Søk etter filmer, serier, YouTubevideoer and TV-kanaler","SEARCH_EXPLANATION_PEOPLE":"Søk etter skuespillere, regissører and manusforfattere","SEARCH_PASTE_LINKS":"Lim inn HTTP og magnetlinker","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Legg til i bibliotek","REMOVE_FROM_LIB":"Fjern fra bibliotek","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Se Trailer","WATCH_NOW":"Se Nå","SHOW":"Vis","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Se tilfeldig","IMDB_RATING":"IMDb Rangering","YEAR":"År","DIRECTOR":"Regissør","WRITER":"Forfatter","LEAD_ACTORS":"Hovedskuespillere","CAST":"Skuespillere","CREW":"Crew","SHOW_MORE_CAST":"Vis mer »","AIRED":"Utgitt","SEASONS":"Sesonger","GENRE":"Sjanger","CATALOG":"Catalog","SUMMARY":"Sammendrag","SHOW_MORE":"Show More","SIMILAR":"Lignende","UPCOMING":"Kommer","ENDED":"Endte","DURATION":"Lengde","FEATURED":"Utvalgt","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"søk i videoer","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"Utvidelse","ADDONS":"Utvidelser","OFFICIAL":"Offisielle","ADDONS_OFFICIAL":"Offisielle Stremio Utvidelser","ADDONS_POPULAR":"Populært i ditt område","ADDON_FREE":"Gratis","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abonnering","ADDON_STREAM_GEORESTRICTED":"ikke tilgjengelig i ditt område","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Lokal fil","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Tilgjengelige Strømmninger","NO_STREAM":"Ingen strømmninger tilgjengelige","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Vis alle utvidelser »","ADDON_CATALOGUE_MORE":"Fler utvidelser »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Filmen er fortsatt på kino","WATCH_IN_CINEMA":"se den på din lokale kino","IN_THEATER":"På Kino","GET_TICKETS":"Få Biletter","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Denne kanalen er ikke ferdig enda.
Vennligst kom tilbake om noen få minutter.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Legg den til i ditt bibliotek for å bli varslet når den blir tilgjengelig.","GET_NOTIFIED_WHEN_AVAILABLE":"Du vil bli varslet med en gang den er tilgjengelig.","WARNING_STREAMING_SERVER":"Advarsel: lokal strømmeserver ble ikke funnet. Det vil ikke være tilgjengelig å strømme fra YouTube og BitTorrent.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, spiller feil","PLAYER_ERROR_LOOKSLIKE":"Det ser ut som","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"Strømmer fra","CASTING_TO":"Caster til","NETWORK_STATUS":"Nettverksstatus","STREAM_SPEED":"Fart på strømmen:","STREAM_BUFFERED":"Buffret:","PEERS_INFO":"Informasjon om peers","PEERS_ACTIVE":"Aktive:","PEERS_CONNECTED":"Tilkoblede:","PEERS_WAITING":"Venter:","TRANSCODING_WARNING":"Advarsel: transkoder videoen.","STREAM_LOADING":"Laster...","PLAYING_LOCAL":"Spiller fra lokal fil","PLAYING_CACHE":"Spiller fra cache","WRONG_SUBS":"Feil undertekster?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Velg en enhet å strømme fra","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Telefon / Nettbrett","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Endre undertekster for ","SUBTITLES_CHANGE_NONE":"Det er ingen andre undertekster for dette språket, beklager.","SUBTITLES_CHANGE_ACIVE":"Undertekst #{{subtitlesDialog.activeIdx + 1}} er aktivert. Klikk \\"Fortsett\\" for å aktivere undertekster #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativt,","SUBTITLES_ADJUST_DELAY":"Still inn undertekstsforsinkelse:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Eller bruk G / H tastene når du ser for å justere.","SUBTITLES_ADJUST_DELAY_TIP":"TIPS: du kan bruke G / H tastene når du ser for å justere.","SUBTITLES_DELAY":"Undertekstsforsinkelse:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sesong","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trender","SORT_RECENT":"nylig","SORT_ALPHABET":"a-z","SORT_RATING":"rangering","SORT_WATCHED":"sett","SORT_YEAR":"år","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"gjenoppta","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"avvis","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Utvalgt","DISCOVER_TOP":"Topp","DISCOVER_OSCAR":"Oscar vinnere","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Advarsel: ingen Stremio utvidelse aktiv for denne typen. Viser lagrede elementer, ingenting vil oppdatere.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Start på nytt nå!","UPGRADE":"Oppdater til den nyeste Stremio versjonen","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Har du ikke en bruker?","HAVE_ACC":"Already have an account?","PASSWORD":"Passord","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-post","FB_LOGIN":"Logg inn med Facebook","FB_NOTHINGSHARED":"Ingenting vil bli delt uten din tillatelse :)","FB_NOPOST":"We won’t post anything on your behalf","OR":"eller","I_ACCEPT":"Jeg godtar ","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Vilkårene og betingelsene","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passordene er ikke like","SIGN_UP":"Registrer","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Logg inn","LOG_OUT":"Logg ut","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Logg inn som gjest","GUEST_LOGIN_NOTICE":"Gjesteinnlogging er ikke anbefalt. Å bruke en vanlig inlogging gjør det lettere for Stremio å synkronisere biblioteket ditt og å motta varsler for dine favoritt serier/kanaler. Er su sikker på at du vil fortsette?","GUEST_LOGIN_NOTICE_2":"Gjesteinnlogging er ikke anbefalt - du vil ikke ha tilgang til et synkronisert bibliotek eller board, som er which are viktige Stremio funksjoner. ER du sikker på at du vil fortsette?","CLICK_HERE":"Klikk her","WRONG_PASSWORD":"Feil passord. I tilfelle du har glemt passordet, ","SET_A_PASS":"lag et passord","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Glemt passord?","EMAIL_USED_WITH_FB":"Denne eposten er i bruk av en Facebook innlogging.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Tilkoblingsfeil - venligst prøv igjen senere.\\n\\nHvis feilen fortsetter, deaktiver brannmuren/anti-virus program (spesielt Bitdefender).","IMPORT_FROM_GUEST":"Importer bibliotek fra en gjestebruker","RECEIVE_UPDATES_EMAIL":"Motta oppdateringer fra Stremio på epost","LOGIN_FAILED":"Innlogging feilet.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Bruk av tredjeparts-utvidelser vil alltid være ditt ansvar med hennsyn til den gjeldene loven der du befinner deg.","ADDON_ACTIVATE":"Aktivere denne utvidelsen?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Hva er nytt?","BUTTON_CONTINUE":"Fortsett","BUTTON_ACTIVATE":"Aktiver","BUTTON_ACTIVATED":"Aktivert","BUTTON_CANCEL":"Avbryt","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Biblioteket ditt ser tomt ut. Finn ut hvor nyttig det er :) ","HOW_START":"Kom i gang:","LIB_EMPTY_CAL":"Kalenderen din viser serier i biblioteket ditt.","HOW_START_CAL":"Her er hvordan du kan legge til serier:","LIB_EMPTY_BOARD":"Board viser varsler & anbefalinger relatert til biblioteket ditt.","HOW_START_BOARD_WAIT":"Legg til noen serier eller kanaler i biblioteket ditt og gi oss noen minutter til å behandle de :)","HOW_START_BOARD":"Her er hvordan du kan legge til serier & filmer til det:","IMPORT_FB":"Importer ting du liker fra Facebook","IMPORT_TRAKT":"Importer mediebiblioteket ditt fra Trakt","IMPORT_DISCOVER":"Finn interessante ting fra Oppdag","IMPORT_DISK":"Importer filmer eller serier fra din lokale Harddisk","PLEASE_CREATE_ACC":"Venligst opprett en bruker for å aktivere biblioteksynkronisering & Board.","IMPORT_DISCOVER_SIGNUP":"Registrer deg og finn interessante ting i Discover","IMPORT_DISK_SIGNUP":"Registrer deg for å importere filmer eller serier du har på din lokale disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Kjør ved oppstart","SETTINGS_VLC_DEFAULT":"Spill med VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Spill av neste episode automatisk","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Endre vindusstørrelse automatisk før avspilling","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Bruk alltid den nyeste betaversjonen","SETTINGS_IMPORT_FB":"Importer fra Facebook","SETTINGS_IMPORT_DISK":"Importer fra lokal disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Abonner på en kalender","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Endre passord","SETTINGS_TOS":"Vilkår for tjenesten","SETTINGS_SUPPORT":"Kontakt support","SETTING_LANGUAGE":"Språk","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Logg ut av Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR koden for å åpne eksternt","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Avslutt","CONNECTED":"Connected","AUTHENTICATE":"Verifiser","CACHING":"Bufrer","SETTINGS_CACHING_DRIVE":"Velg bufrings enhet","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januar","February":"Februar","March":"Mars","April":"April","May":"Mai","June":"Juni","July":"Juli","August":"August","September":"September","October":"Oktober","November":"November","December":"Desember","Monday":"Mandag","Tuesday":"Tirsdag","Wednesday":"Onsdag","Thursday":"Torsdag","Friday":"Fredag","Saturday":"Lørdag","Sunday":"Søndag","Action":"Action","Comedy":"Komedie","War":"Krig","Family":"Familie","Animation":"Animasjon","Adventure":"Eventyr","Fantasy":"Fantasy","Crime":"Krim","Mystery":"Mysterier","Romance":"Romantikk","Drama":"Drama","Horror":"Grøsser","Thriller":"Spenning","Sci-Fi":"Sci-Fi","Music":"Musikk","Biography":"Biografi","Documentary":"Dokumentar","Sport":"Sport","Musical":"Musikal","Western":"Western","Film-Noir":"Film-Noir","News":"Nyheter","History":"Historie","Game-Show":"Gameshow","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Underholdning","Gaming":"Gaming","From TV":"Fra TV","Lifestyle":"Livsstil","Science & Education":"Vitenskap & Utdanning","Cooking & Health":"Matlaging & Helse","Beauty & Fashion":"Skjønnhet & Mote","Sports":"Sport","News & Politics":"Nyheter & Politikk","How-to & DIY":"Gjør det selv","Tech":"Teknologi","Automotive":"Bilbransjen","Causes & Non-Profits":"Saker & ideelle organisasjoner","Movies":"Filmer","Uk Live Tv":"UK Direkte TV","Fashion":"Mote","Business News Radio":"Business Nyhetsradio","Business Tv":"Business TV","Cars & Auto":"Biler og Auto","Comedy Radio":"Komedieradio","Lifestyle Radio":"Livsstilsradio","News Tv":"Nyhets TV","Food And Wine":"Mat og Vin","Latino Tv":"Latino TV","Shopping Tv":"Shopping TV","Religion":"Religion","Kids":"Barn","Body & Soul":"Kropp og Sjel","Education":"Utdanning","Indian Tv":"Indisk TV","Extreme Sports":"Ekstremsport","Middle Eastern Tv":"TV fra Midtøsten","Celebrity Tv":"Kjendis TV","Science Tv":"Vitenskaps TV","Bikini babe":"Bikini babe","Outdoors":"Utendørs","German Tv":"Tysk TV","French Tv":"Fransk TV","Italian Tv":"Italiensk TV","Gamer Tv":"Spill TV","Travel":"ReiseTV","Asian Tv":"Asiatisk TV","Entertainment":"Underholdning","News Radio":"Nyhetsradio","Music Radio":"Musikkradio","Language Learning":"Språklæring","Science Radio":"Vitenskapsradio","Tech Radio":"Teknologiradio","Science & Technology Vod":"Vitenskap -og Teknologi VOD","new video":"ny video","new episode":"ny episode","new movie":"ny film","recommended":"anbefalt","we recommend":"vi anbefaler","offer of the day":"dagstilbud","news":"nyheter","music video":"musikkvideo","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Forkast varsler","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Del","CTX_COPY_SHARE_LINK":"Kopier link for deling","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Vis","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Se på","CTX_WATCH":"Se","CTX_WATCHED":"Sett","CTX_WATCH_BEGINNING":"Se fra starten","CTX_WATCH_MOBILE":"Se på en mobil enhet","CTX_REWIND":"Spol til start","CTX_MARK_WATCHED":"Merk som sett","CTX_MARK_NON_WATCHED":"Merk som ikke sett","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Få nye varsler","CTX_REMOVE_CACHE":"Fjern fra bruffren","CTX_REMOVE_CACHE_EP":"Fjern episode fra buffren","CTX_OPEN_CONTAINING":"Åpne mappen som inneholder filen","CTX_REMOVE":"Fjern fra bilbiotek","CTX_AVAILABLE_OFFLINE":"Tilgjengelig Offline","CTX_PAUSED":"Pauset","CTX_ALWAYS_ON_TOP":"Alltid på toppen","CTX_FULLSCREEN":"Fullskjem","CTX_WRONG_SUBS":"Feil undertekster?","CTX_REPORT_ISSUES":"Rapporter en feil","CTX_COPY":"Kopier","CTX_PASTE":"Lim inn","CTX_CLEAR":"Tøm","CTX_CLEAR_RECENT_SEARCHES":"Tøm nylige søk","HELLO_THERE":"Hei!","HOPE_YOU_ENJOY":"Vi håper du liker Stremio og at det er en av dine favoritt apper allerede!","WHO_ARE_WE":"Hvem er vi? Vi er teamet bak appen - to gutter som har jobbet hardt med appen hver dag i de siste 3 årene, med kun ett mål - å gjøre dette produkte bedre og bedre.","SUPPORT_US":"Hvis du liker Stremio, hvis Stremio er verdifull for deg - støtt oss!","SPREAD_THE_WORD":"Del med vennene dine og spred ordet om Stremio","MORE_PEOPLE":"Jo fler som bruker Stremio, jo bedre blir det!","SEND_A_LINK":"Eller send en link til websiden vår","TIP_LOCALFILES":"Tips: du kan dra og slippe lokale videoer inn i Stremio","ADDON_MY":"Mine utvidelser","ADDON_COMMUNITY":"Samfunnets utvidelser","ADDON_OFFICIAL":"Offisielle utvidelser","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Søk etter utvidelser","ADDON_INSTALL":"Installer","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Avinstaller","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installert","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Side for utvidelser","ADDON_TOP_CONTENT":"Det beste fra denne utvidelsen","ADDON_PROVIDES":"git","ADDON_WATCH":"Se #{types} nå!","ADDON_WATCH_FREE":"Se #{types} GRATIS nå!","ADDON_ADDON":"Utvidelse","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Mer #{types} i oppdag","ADDON_PROVIDES_STREAMS":"Se #{types}","ADDON_PROVIDES_STREAMS_FREE":"Se #{types} GRATIS","ADDON_PROVIDES_SUBTITLES":"Undertekster for #{types}","ADDON_CANTDETECT":"Vi kunne ikke oppdage en kjørende Stremio, så vi kunne ikke oppdage hvilke utvidelser du har installert.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Fortsett å se","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmer valgt spesielt for degg.
Denne filmen er en eksempel rekommandasjon","BOARD_EXPLANATION_EPISODES":"Nye episoder av favorittseriene dine kommer her.
Legg til serier du følger med på i biblioteket ditt.","BOARD_EXPLANATION_VIDEOS":"Nye episoder av dine favorittkanaler kommer her.
Legg til YouTubekanaler du følger med på i biblioteket ditt.","WEBSITE_SLOGAN_WATCH":"Se med en gang","WEBSITE_SLOGAN_ALL":"Alt videoinnholdet du liker på ett sted","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Last ned nå","WEBSITE_DOWNLOAD_FOR":"Last Ned For","WEBSITE_IS_DESKTOP":"Stremio er et skrivebordsprogram, åpne denne siden på PCen din og last ned nå!","WEBSITE_DESKTOP_DEMO_VID":"Skriveborddemo","WEBSITE_PAGE_HOME":"Hjem","WEBSITE_PAGE_FEATURES":"Funkjsoner","WEBSITE_PAGE_ADDONS":"Utvidelser","WEBSITE_PAGE_TECH":"Teknologi","WEBSITE_PAGE_CREATE_ADDON":"Lag utvidelse","WEBSITE_PAGE_CONTACTS":"Kontakter","WEBSITE_PAGE_BLOG":"Blogg","WEBSITE_TYPE_movie":"Filmer","WEBSITE_TYPE_series_PL":"Serier","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Kanaler","WEBSITE_STREMIO_WHAT_IS":"Stremio er en app som hjelper deg å organisere og umiddelbart se dine favoritt videoer, filmer, TV-serier og TV-kanaler.","WEBSITE_FEATURES_WATCH":"Se øyeblikkelig i HD","WEBSITE_FEATURES_WATCH_DETAIL":"Klikk og spill dine favoritt filmer, TV-programmer, videoer og TV-kanaler.","WEBSITE_FEATURES_SUBS":"Automatiske undertekster","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio velger automatisk synkroniserte undertekster for språket ditt.","WEBSITE_FEATURES_SUBS_LABEL":"Din tur, sjef.","WEBSITE_FEATURES_CAST":"Spill på TV og mobile enheter","WEBSITE_FEATURES_CAST_DETAIL":"Cast til AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile enheter.","WEBSITE_LIB":"Nyt ditt personlige bibliotek synkronisert på alle enhetene dine","WEBSITE_LIB_COLLECT":"Samle fra Stremio","WEBSITE_LIB_IMPORT":"Importer fra Facebook","WEBSITE_LIB_LOCAL":"Legg til fra din lokale harddisk","WEBSITE_BOARD":"Board - Ditt one-stop sted for varsler og anbefalinger","WEBSITE_BOARD_RECOMMEND":"Anbefalt TV Show","WEBSITE_BOARD_TRENDING":"Populær film","WEBSITE_BOARD_NEW":"Ny video","WEBSITE_BOARD_EPISODE":"Ny episode","WEBSITE_BOARD_1":"Leter du etter noe interessant å se på? Få anbefalinger basert på din smak!","WEBSITE_BOARD_2":"Bli varslet når en ny episode av ditt favoritt TV-program eller YouTube-kanal er ute!","WEBSITE_BOARD_YOUTUBE":"Nye episoder av YouTubekanaler","WEBSITE_BOARD_EPISODES":"Nye episoder av serier di følger.","WEBSITE_ADDONS":"Innholdsudvidelser","WEBSITE_TECH_DETAIL":"Vi elsker teknologi, vi elsker gal vitenskap!\\nStremio bruker følgende åpen kildekode-teknologier:","WEBSITE_TECH_WCJS":"WebChimera.js tillater Stremio å spille alle videoformater med god ytelse.","WEBSITE_TECH_WCJS_EXTRA":"Vi er kjerneprodukt bidragsytere","WEBSITE_TECH_ELECTRON":"Electron gir en innovativ plattform å bygge Stremio med.","WEBSITE_TECH_ELECTRON_EXTRA":"Vi er prosjekt bidragsytere","WEBSITE_TECH_LINVODB":"En databaseteknologi som sikrer dataene er organisert og tilgjengelig hvor som helst du har logger inn.","WEBSITE_TECH_LINVODB_EXTRA":"In-house teknologi","WEBSITE_CREATE_ADDON":"Lag din utvidelse","WEBSITE_CREATE_ADDON_DETAIL":"Har du en tjeneste som gir videoinnhold? Vi hjelper deg å dra nytte av Stremio funksjoner ved å lage utbidelsen din","WEBSITE_CREATE_ADDON_BENEFITS":"Fordeler med å lage en utvidelse for Stremio","WEBSITE_P2P_BEAUTY":"Skjønnheten av Peer-To-Peer strømming","WEBSITE_P2P_1":"Pålitelig og rimelig full HD / 4K video on demand eller direktestrømming","WEBSITE_P2P_2":"Distribusjonsplattform som gir god brukeropplevelse","WEBSITE_P2P_3":"Vi vil lage en utvidelse tilfredstiller dine behov","WEBSITE_P2P_CONTACT":"Interessert? Du er velkommen til å kontakte oss.","WEBSITE_P2P_CONTACT_EXTRA":"Vi vil gjerne hjelpe deg med å integrere innholdet ditt med Stremio!","WEBSITE_P2P":"En gang i blant, kommer det en teknologi som endrer spillereglene. Vi har investert tonnevis med tid og krefter på å bygge vår Peer-to-Peer (P2P) video streaming motor som gir god ytelse og allsidighet til å tilpasse enhver bruk.\\nKontakt oss for DRM-aktivert P2P video on demand eller live streaming.","WEBSITE_THOUGHTS":"Tanker vi deler:","WEBSITE_SPREAD":"Spre ordet om Stremio:","WEBSITE_CONTACT":"Hvis du ønsker å kontakte oss, kjør på","WEBSITE_OPENSOURCE":"For våre åpene kildekode-prosjekter, gå til vår","WEBSITE_BITCOIN":"Doner med bitcoin:","WEBSITE_FAQ":"Ofte stilte spørsmål","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Vilkår for bruk","WEBSITE_LEGAL":"Juridisk","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},8472:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Series","TYPE_tv":"TV-kanalen","TYPE_channel":"Kanaal","TYPE_other":"Other","TYPE_movie_PL":"Films","TYPE_series_PL":"Series","TYPE_tv_PL":"TV-kanalen","TYPE_channel_PL":"YouTube","TYPE_other_PL":"Andere","TYPE_ALL":"All","VIDEO":"Video","BACK":"Terug","MORE":"Meer","DONE":"Klaar","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Ontdekken","Board":"Dashboard","Library":"Bibliotheek","My Library":"Mijn Bibliotheek","Calendar":"Agenda","NOTIFICATION_ONLINE":"Je bent nu online","NOTIFICATION_OFFLINE":"Je bent nu offline","INTERNET_CONNECTION":"Netwerkverbinding","STORAGE_FULL_TITLE":"Waarschuwing: geheugen is vol!","STORAGE_FULL_TEXT":"Stremio kan uw instellingen, voorkeuren of inloggegevens niet opslaan. Probeer Stremio te herstarten of opnieuw te installeren.","SEARCH":"Zoek","SEARCH_NO_RESULTS":"Er zijn geen resultaten gevonden","SEARCH_EXPLANATION_CONTENT":"Zoek naar films, series, Youtube and TV series","SEARCH_EXPLANATION_PEOPLE":"Zoek naar acteurs, filmregisseurs en schrijvers","SEARCH_PASTE_LINKS":"Plak hier HTTP en Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Toevoegen aan bibliotheek","REMOVE_FROM_LIB":"Verwijderen uit bibliotheek","ADDED_TO_LIB":"Toegevoegd aan bibliotheek","REMOVED_FROM_LIB":"Verwijderd van uw bibliotheek","TRAILER":"Trailer","WATCH_TRAILER":"Trailer bekijken","WATCH_NOW":"Nu kijken","SHOW":"Toon","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Kijk willekeurig","IMDB_RATING":"IMDb beoordeling","YEAR":"Jaar","DIRECTOR":"Regisseur","WRITER":"Schrijver","LEAD_ACTORS":"Hoofdrolspelers","CAST":"Rolverdeling","CREW":"Crew","SHOW_MORE_CAST":"Laat meer zien »","AIRED":"Uitgezonden","SEASONS":"Seizoenen","GENRE":"Genre","CATALOG":"Catalogus","SUMMARY":"Samenvatting","SHOW_MORE":"Show More","SIMILAR":"Vergelijkbaar","UPCOMING":"Opkomend","ENDED":"Afgelopen","DURATION":"Tijdsduur","FEATURED":"Uitgelicht","METADATA":"Metadata","CATEGORY":"categorie","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Zoek video\'s","SEARCH_PLACEHOLDER":"zoek of plak magnet link","ADDON":"Addon","ADDONS":"Addons","OFFICIAL":"Officieel","ADDONS_OFFICIAL":"Officiële Stremio addon","ADDONS_POPULAR":"Populair in uw regio","ADDON_FREE":"Gratis","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abonnement","ADDON_STREAM_GEORESTRICTED":"Niet beschikbaar in uw regio","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Lokaal Bestand","SHARE_ADDON":"Deel addon","AVAILABLE_STREAMS":"Beschikbare streams","NO_STREAM":"Geen streams beschikbaar","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Voor meer streams, installeer meer addons","STREAM_NOT_SUPPORTED":"Geselecteerde stream is niet ondersteund op dit platform.","ADDON_CATALOGUE":"Toon alle addons »","ADDON_CATALOGUE_MORE":"Meer addons »","REPO_ADDED":"Repository toegevoegd","ADDON_REPO_EXIST_ERR":"Deze addons repository bestaat al","ADDON_REPO_ERR":"Foutmelding opgetreden tijdens het toevoegen van de repository","ADDON_ADD_ERR":"Foutmelding opgetreden tijdens het toevoegen van de addon","ERR_ADDON_PROTECTED":"Beschermde addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Er ging iets fout - authenticatie is mislukt","ERR_NOT_COLLECTION_URL":"Geen collectie URL","ERR_NOT_ADDON_URL":"Geen addon URL","ERR_DETECTFROMURL":"Niets beschikbaar in de URL","ADDON_DUPLICATE_WARNING":"Waarschuwing: gedupliceerde addon","ADDON_COLLECTION_SET_FAILED":"Addon collectieset mislukt","SETTINGS_DATA_EXPORT":"Exporteer data","ADDON_PULL_FAILED":"Addon ophalen mislukt","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Film nog in de bioscoop","WATCH_IN_CINEMA":"Bekijk de film in een bioscoop in uw buurt","IN_THEATER":"In de bioscoop","GET_TICKETS":"Tickets bemachtigen","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Dit kanaal is nog niet geschraapt.
Gelieve terug te komen in een paar minuten.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Voeg deze toe aan uw bibliotheek om een melding te krijgen zodra deze beschikbaar is.","GET_NOTIFIED_WHEN_AVAILABLE":"U krijgt een melding zodra deze beschikbaar is.","WARNING_STREAMING_SERVER":"Waarschuwing: lokale streaming server niet gevonden. Streamen van Youtube en BitTorrent is niet mogelijk","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Waarschuwing: de video is mogelijk niet ondersteund door uw hardware. De video zal mogelijks niet correct worden afspeeld.","PLAYER_ERROR":"Woeps, Videospeler fout","PLAYER_ERROR_LOOKSLIKE":"Het lijkt erop","PLAYER_ORIENTATION":"Videospeler orientatie","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Vergrendeld","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Videospeler vergrendeld op horizontale weergave","PLAYER_ORIENTATION_SENSOR":"Automatische orientatieweergave videospeler (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"Streamen van","CASTING_TO":"Casten naar","NETWORK_STATUS":"Netwerkstatus","STREAM_SPEED":"Snelheid:","STREAM_BUFFERED":"Gebufferd:","PEERS_INFO":"Peers informatie","PEERS_ACTIVE":"Actief:","PEERS_CONNECTED":"Verbonden:","PEERS_WAITING":"Wachten:","TRANSCODING_WARNING":"Waarschuwing: transcoderen van video.","STREAM_LOADING":"Laden...","PLAYING_LOCAL":"spelen van een lokaal bestand","PLAYING_CACHE":"spelen uit cache","WRONG_SUBS":"Verkeerde ondertiteling?","ERR_SUBS_LOADING_TITLE":"Fout tijdens laden ondertiteling","ERR_SUBS_LOADING":"Ondertiteling laden mislukt: Dit kan liggen aan de gebruikte addon, of uw internetverbinding","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Kon streamingsapparaat info niet vernieuwen: streamingserver is mogelijks offline","CHOOSE_DEVICE":"Kies een apparaat om op te kijken","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Mobiel/Tablet","SUBTITLES":"Ondertiteling","SUBTITLES_CHANGE":"Verander ondertiteling voor","SUBTITLES_CHANGE_NONE":"Voor deze taal zijn geen andere vertalingen beschikbaar, sorry.","SUBTITLES_CHANGE_ACIVE":"Momenteel is ondertiteling #{{subtitlesDialog.activeIdx + 1}} actief. Klik op \\"Verder\\" om ondertiteling #{{subtitlesDialog.pickedIdx + 1}} te gebruiken.","SUBTITLES_OR":"Als alternatief,","SUBTITLES_ADJUST_DELAY":"Ondertitelingsvertraging aanpassen:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Of gebruik de G / H toetsen om de ondertitels tijdens het afspelen aan te passen.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: je kan de toetsen G / H gebruiken tijdens het afspelen om aan te passen.","SUBTITLES_DELAY":"Ondertitelvertraging:","SUBTITLES_LOADING":"Ondertiteling laden...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Seizoen","EPISODE":"Aflevering","SPECIAL":"Special","SORT":"sorteer op","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"beoordeling","SORT_WATCHED":"gezien","SORT_YEAR":"jaar","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nieuw voor jou","New Episodes":"Nieuwe afleveringen","New Videos":"Nieuwe video\'s","Recommendations":"Aanbevelingen","LIBRARY_RESUME":"hervat","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"negeer","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Uitgelicht","DISCOVER_TOP":"Populair","DISCOVER_OSCAR":"Oscars","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Deze addon stuurde niks terug.","DISCOVER_ADULT_WARNING":"Deze inhoud is enkel toegankelijk voor volwassenen. Ben je 18+?","DISCOVER_NOADDON_WARNING":"Waarschuwing: geen Stremio addon actief voor dit type. Opgeslagen items worden weergegeven, hier komen geen updates.","DISCOVER_LOAD_ERR":"De inhoud werd niet geladen, er deed zich een fout voor.","DISCOVER_ADDON_UNINSTALLED":"Deze inhoud is niet meer beschikbaar, Het is mogelijk dat de addon is gedeinstalleerd.","UNINSTALL_THIS_ADDON":"Deinstalleer deze addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Ontvang notificaties bij nieuwe afleveringen","DETAIL_RECEIVE_NOTIF_VIDEOS":"Ontvang notificaties bij nieuwe video\'s","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Herstart Stremio","UPGRADE":"Updaten naar de laatste Stremio versie","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonieme gebruiker","DONT_HAVE_ACC":"Heeft u nog geen account?","HAVE_ACC":"Heeft u al een account?","PASSWORD":"Wachtwoord","PASSWORD_CONFIRM":"Bevestig wachtwoord","EMAIL":"E-mail","FB_LOGIN":"Inloggen met Facebook","FB_NOTHINGSHARED":"Niks wordt gedeeld zonder uw toestemming","FB_NOPOST":"Niks wordt gepost zonder uw toestemming","OR":"of","I_ACCEPT":"Ik accepteer de","I_ACCEPT_BY_CLICKING":"Door te klikken op de bovenstaande knop ga ik akkoord met de","TOS":"Algemene Voorwaarden","MUST_ACCEPT_TERMS":"U moet akkoord gaan met de voorwaarden","PASSWORDS_NOMATCH":"Wachtwoorden komen niet overeen","SIGN_UP":"Inschrijven","SIGN_UP_EMAIL":"Aanmelden met e-mail","CLICK_TO_SIGN_UP":"Klikt hier om aan te melden.","LOG_IN":"Inloggen","LOG_OUT":"Uitloggen","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gast-login","GUEST_LOGIN_NOTICE":"Gast-login is niet aangewezen. Een vaste login gebruiken zorgt ervoor dat Stremio je bibliotheek kan synchroniseren en je notificaties krijgt over je favoriete series/kanalen. Ben je zeker dat je wilt doorgaan?","GUEST_LOGIN_NOTICE_2":"Gast-login is niet aangewezen - je zal geen gesynchroniseerd bibliotheek hebben of dashboard notificaties krijgen, beiden belangrijke Stremio functies. Ben je zeker dat je wilt doorgaan?","CLICK_HERE":"Klik hier","WRONG_PASSWORD":"Verkeerd wachtwoord. In het geval dat u uw wachtwoord vergeten, ","SET_A_PASS":"Stel een wachtwoord in","RESET_PASSWORD":"Veranderd wachtwoord","FORGOT_PASSWORD":"Wachtwoord vergeten?","EMAIL_USED_WITH_FB":"Deze e-mail is al gebruikt met een Facebook login.","INVALID_EMAIL":"Voer een geldig e-mailadres in","INVALID_PASSWORD":"Voer een geldig wachtwoord in","CONN_ERR":"Connectiefout - probeer het later opnieuw.\\n\\nAls dit probleem zich aanhoudt, schakel dan uw firewall en/of anti-virus software uit (vooral Bitdefender).","IMPORT_FROM_GUEST":"Importeer bibliotheek van uw gast acccount","RECEIVE_UPDATES_EMAIL":"Ontvang updates via e-mail van Stremio","LOGIN_FAILED":"Login mislukt.","SIGNUP_FAILED":"Aanmelden mislukt.","SEARCH_FAILED":"Zoekopdracht mislukt","EMAIL_USED":"Dit e-mail is al in gebruik.","WAITING_FB_LOGIN":"Inloggen met Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Geef uw voorkeuren aan","INTRO_TASTE_LONG":"Vertel ons wat je wilt bekijken","INTRO_TASTE_PICK":"Kies {{interestsRemaining}} interesses","INTRO_TASTE_PICK_MORE":"Kies {{interestsRemaining}} meer interesses","INTRO_TASTE_HELP_US":"Help ons je beter te leren kennen.","INTRO_TASTE_CHOOSE_THESE":"Kies enkel van deze:","INTRO_TASTE_CHOOSE_MIN":"Kies minimum 3 categorieën","INTRO_TASTE_CHOOSE_MIN_ERR":"Je moet minimum 3 categorieën kiezen!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sport","INTRO_TASTE_FOOD_HEALTH":"Eten & Gezondheid","INTRO_TASTE_BEAUTY_FASHION":"Schoonheid & Mode","INTRO_TASTE_NEWS":"Nieuws","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Wetenschap & Onderwijs","INTRO_TASTE_MUSIC":"Muziek","INTRO_TASTE_TRAVEL":"Reizen","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Komedie","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"De geselecteerde addon is niet ondersteund op dit platform.","ADDON_DISCLAIMER":"Het gebruiken van addons van derden is altijd onderworpen aan uw eigen verantwoordelijkheid en het recht van de regio waar u zich bevindt.","ADDON_ACTIVATE":"Deze addon activeren?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Toevoegen","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Wat is er nieuw?","BUTTON_CONTINUE":"Doorgaan","BUTTON_ACTIVATE":"Activeer","BUTTON_ACTIVATED":"Geactiveerd","BUTTON_CANCEL":"Annuleer","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Negeer alles","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Uw bibliotheek ziet er leeg uit. Ontdek hoe nuttig het is :) ","HOW_START":"Hier is hoe je kunt beginnen:","LIB_EMPTY_CAL":"De agenda toont series in je bibliotheek.","HOW_START_CAL":"Hier is hoe je series kan toevoegen:","LIB_EMPTY_BOARD":"Het dashboard toont notificaties & aanbevelingen gebaseerd op uw bibliotheek.","HOW_START_BOARD_WAIT":"Voeg een paar series of kanalen toe aan uw bibliotheek en geef ons een paar minuten verwerktijd :)","HOW_START_BOARD":"Zo voeg je series & films toe:","IMPORT_FB":"Importeer dingen die je leuk vind van Facebook","IMPORT_TRAKT":"Importeer je media bibliotheek van Trakt","IMPORT_DISCOVER":"Ontdek interessante dingen","IMPORT_DISK":"Importeer films of series vanaf je lokale schijf","PLEASE_CREATE_ACC":"Registreer een account om van de bibliotheek & het dashboard gebruik te maken.","IMPORT_DISCOVER_SIGNUP":"Registreer en vind interessante dingen van Ontdekken","IMPORT_DISK_SIGNUP":"Registreer en importeer films en series van je lokale schijf","LIB_EMPTY_CLOUD":"Cloud bibliotheek","LIB_EMPTY_CLOUD_DESC":"Persoonlijke cloud bibliotheek gesynchroniseerd op alle toestellen","LIB_EMPTY_EARLY":"Vroege vogel","LIB_EMPTY_EARLY_DESC":"Ontvang notificaties bij nieuwe afleveringen","LIB_EMPTY_PERSONAL":"Persoonlijk","LIB_EMPTY_PERSONAL_DESC":"Ontvang persoonlijke aanbevelingen","LIB_EMPTY_CALENDAR_DESC":"Plan uw persoonlijke kijkkalender","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Registreer om deze allemaal te ontvangen","LIB_EMPTY_OTHER":"Registreer om Agenda en andere coole functies in te schakelen","CALENDAR_ADDED":"De Stremio-kalender is toegevoegd aan uw standaard desktopkalender.","CALENDAR_ADDED_MSG":"Indien dit niet werkt, voeg deze URL dan handmatig toe aan uw agendatoepassing","TRAKT_EXPIRED":"Trakt-authenticatie is verlopen, ga naar Instellingen en verifieer opnieuw","TRAKT_REQUIRES_LOGIN":"Trakt foutmelding","TRAKT_REQUIRES_LOGIN_MSG":"U moet inloggen","SETTINGS_LABEL":"Instellingen","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Openen bij opstarten","SETTINGS_VLC_DEFAULT":"Afspelen met VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Automatisch de volgende aflevering afspelen","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Het vensterformaat automatisch aanpassen voor afspelen","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Gebruik altijd de laatste Beta","SETTINGS_IMPORT_FB":"Importeren van Facebook","SETTINGS_IMPORT_DISK":"Importeren van lokale schijf","SETTINGS_IMPORT_TRAKT":"Importeren van Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Door hardware versnelde decodering","SETTINGS_BACKGROUND":"Achtergrondweergave","SETTINGS_SUBSCRIBE_CALENDAR":"Abonneer op agenda","SETTINGS_REQ_EXPORT":"Vraag gegevens export aan","SETTINGS_ACC_DELETE":"Verzoek om accountverwijdering","SETTINGS_CHANGE_PASSWORD":"Wachtwoord veranderen","SETTINGS_TOS":"Algemene voorwaarden","SETTINGS_SUPPORT":"Contact opnemen met ondersteuning","SETTING_LANGUAGE":"Taal","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Uitloggen van Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"QR code scanne om afstandsbediening te openen","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notificaties","SETTINGS_DATA_SAVER":"Gegevensbesparing","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"standaard ondertiteling","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"versie","SETTINGS_MPV_WINDOW":"Start videospeler in apart scherm (geadvanceerd)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Afsluiten","CONNECTED":"Verbonden","AUTHENTICATE":"Authenticeren","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Selecteer schijf voor caching","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Magnet link verwerken","January":"januari","February":"februari","March":"maart","April":"april","May":"mei","June":"juni","July":"juli","August":"augustus","September":"september","October":"oktober","November":"november","December":"december","Monday":"maandag","Tuesday":"dinsdag","Wednesday":"woensdag","Thursday":"donderdag","Friday":"vrijdag","Saturday":"zaterdag","Sunday":"zondag","Action":"Actie","Comedy":"Komedie","War":"Oorlog","Family":"Familie","Animation":"Animatie","Adventure":"Avontuur","Fantasy":"Fantasie","Crime":"Misdaad","Mystery":"Mysterie","Romance":"Romantiek","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Muziek","Biography":"Biografie","Documentary":"Documentaire","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-noir","News":"Nieuws","History":"Geschiedenis","Game-Show":"Spelprogramma","Reality-TV":"Reality-TV","Talk-Show":"Talkshow","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"Van TV","Lifestyle":"Lifestyle","Science & Education":"Wetenschap & Onderwijs","Cooking & Health":"Koken & Gezondheid","Beauty & Fashion":"Schoonheid & Mode","Sports":"Sport","News & Politics":"Nieuws & Politiek","How-to & DIY":"How-to & Klussen","Tech":"Technologie","Automotive":"Automotive","Causes & Non-Profits":"Goede doelen & Non-Profits","Movies":"Films","Uk Live Tv":"UK Live TV","Fashion":"Mode","Business News Radio":"Business News Radio","Business Tv":"Business","Cars & Auto":"Auto\'s","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"Nieuws","Food And Wine":"Eten & Wijn","Latino Tv":"Latino TV","Shopping Tv":"Shopping","Religion":"Godsdienst","Kids":"Kinderen","Body & Soul":"Lichaam & ziel","Education":"Onderwijs","Indian Tv":"Indische TV","Extreme Sports":"Extreme sporten","Middle Eastern Tv":"Midden-Oosten","Celebrity Tv":"Celebrity","Science Tv":"Wetenschap","Bikini babe":"Bikini babe","Outdoors":"Buitenleven","German Tv":"Duitse TV","French Tv":"Franse TV","Italian Tv":"Italiaanse TV","Gamer Tv":"Game","Travel":"Reizen","Asian Tv":"Aziatische TV","Entertainment":"Entertainment","News Radio":"Nieuws Radio","Music Radio":"Muziek Radio","Language Learning":"Taal leren","Science Radio":"Wetenschap Radio","Tech Radio":"Technologie Radio","Science & Technology Vod":"Wetenschap & Technologie Vod","new video":"nieuwe video","new episode":"nieuwe aflevering","new movie":"nieuwe film","recommended":"aanbevolen","we recommend":"onze aanbeveling","offer of the day":"aanbieding van de dag","news":"nieuws","music video":"muziekvideo","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Notificaties wissen","CTX_DISMISS_ALL":"Verwijder alles","CTX_SHARE":"Delen","CTX_COPY_SHARE_LINK":"Kopieer deelbare link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Kijken","CTX_PLAY":"Speel","CTX_PLAY_IN":"Speel in","CTX_PLAY_ON":"Speel op","CTX_WATCH_ON":"Kijk op","CTX_WATCH":"Kijken","CTX_WATCHED":"Gezien","CTX_WATCH_BEGINNING":"Vanaf het begin kijken","CTX_WATCH_MOBILE":"Op een mobiel apparaat kijken","CTX_REWIND":"Spoel terug naar begin","CTX_MARK_WATCHED":"Markeren als gezien","CTX_MARK_NON_WATCHED":"Markeren als niet gezien","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Markeer de rest als gezien","CTX_UNMARK_REST":"Markeer de rest als niet gezien","CTX_RECEIVE_NEW_NOTIF":"Nieuwe notificaties ontvangen","CTX_REMOVE_CACHE":"Van cache verwijderen","CTX_REMOVE_CACHE_EP":"Aflevering uit cache verwijderen","CTX_OPEN_CONTAINING":"Bijhorende map openen","CTX_REMOVE":"Verwijderen van bibliotheek","CTX_AVAILABLE_OFFLINE":"Offline beschikbaar","CTX_PAUSED":"Gepauzeerd","CTX_ALWAYS_ON_TOP":"Altijd op voorgrond","CTX_FULLSCREEN":"Volledig scherm","CTX_WRONG_SUBS":"Verkeerde ondertiteling?","CTX_REPORT_ISSUES":"Fout rapporteren","CTX_COPY":"Kopieren","CTX_PASTE":"Plakken","CTX_CLEAR":"Legen","CTX_CLEAR_RECENT_SEARCHES":"Recente zoekopdrachten verwijderen","HELLO_THERE":"Hallo daar","HOPE_YOU_ENJOY":"Wij hopen dat je Stremio leuk vindt en het al één van je favoriete programma\'s is!","WHO_ARE_WE":"Wie zijn wij? Wij zijn het team achter Stremio - twee jongens die de laatste 3 jaar erg hard hebben gewerkt, met één doel voor ogen - dit product beter en beter maken.","SUPPORT_US":"Als je Stremio met plezier gebruikt en/of het waardevol voor je is - steun ons!","SPREAD_THE_WORD":"Vertel je vrienden en de wereld over Stremio","MORE_PEOPLE":"Hoe meer mensen Stremio gebruiken, hoe beter het wordt!","SEND_A_LINK":"Of stuur een link naar onze website","TIP_LOCALFILES":"Tip: je kan lokale videobestanden in Stremio slepen om af te spelen","ADDON_MY":"Mijn Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Officiële Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Zoek addons","ADDON_INSTALL":"Installeer","ADDON_CONFIGURE":"Configureer","ADDON_UNINSTALL":"Deinstalleren","ADDON_UPGRADE":"Upgraden","ADDON_INSTALLED":"Geïnstalleerd","ADDON_INSTALLED_MSG":"Addon geinstalleerd!","ADDON_UPGRADED_MSG":"Addon ge-upgrade!","ADDON_UNKNOWN":"Onbekend","ADDON_ERR":"Addon installatie fout!","ADDON_DISCONNECTED":"Verbinding verbroken","ADDON_APP_MISSING":"De app voor deze bron is niet geinstalleerd. Wil je deze nu installeren?","ADDON_APP_INSTALL":"Installeer Nu","ADDON_PAGE":"Addon Pagina","ADDON_TOP_CONTENT":"Beste van deze Addon","ADDON_PROVIDES":"bied aan","ADDON_WATCH":"Kijk #{types} nu!","ADDON_WATCH_FREE":"Kijk #{types} nu GRATIS!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Meer #{types} in Ontdekken","ADDON_PROVIDES_STREAMS":"Kijk #{types}","ADDON_PROVIDES_STREAMS_FREE":"Kijk #{types} GRATIS","ADDON_PROVIDES_SUBTITLES":"Ondertiteling voor #{types}","ADDON_CANTDETECT":"We konden geen lopende instantie van Stremio detecteren, hierdoor konden we niet detecteren welke addons er zijn geinstalleerd.","ERR_NO_META":"Geen informatie over dit ","ERR_GETTING_META":"Fout tijdens het verkrijgen van informatie.","ERR_CANT_PARSE_MAGNET":"Kan magnet link niet verwerken","ERR_NO_MAGNET_INFOHASH":"Geen geldige infohash voor deze magnet link","ERR_NO_FILE_PATH":"Niet mogelijk een verzoek te versturen zonder Unable to send request zonder pad naar bestand","ERR_NO_TORRENT":"Geen torrent gevonden","ERR_NO_SUPPORTERD_FILES":"Geen ondersteunde bestanden gevonden","ERR_OPENING_FILES":"Kon externe bestanden niet openen","ERR_INVALID_LINK":"Ongeldige link","ERR_REGISTERED_ONLY":"Deze optie is alleen beschikbaar voor geregisteerde gebruikers.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Doorgaan met kijken","BOARD_EXPLANATION_RECOMMENDATIONS":"Films speciaal voor jou gekozen.
Deze film is een voorbeeld aanbeveling.","BOARD_EXPLANATION_EPISODES":"Nieuwe afleveringen van uw favoriete series komen hier.
Voeg series die je volgt toe aan je bibliotheek.","BOARD_EXPLANATION_VIDEOS":"Nieuwe afleveringen van uw favoriete kanalen komen hier.
Voeg Youtube Kanalen die je volgt toe aan je bibliotheek","WEBSITE_SLOGAN_WATCH":"Kijk direct","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Kijk van","WEBSITE_DOWNLOAD":"Download nu","WEBSITE_DOWNLOAD_FOR":"Download nu voor","WEBSITE_IS_DESKTOP":"Stremio is een desktop applicatie, open deze pagina op uw PC om Stremio te downloaden","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Functies","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technologie","WEBSITE_PAGE_CREATE_ADDON":"Maak een Addon","WEBSITE_PAGE_CONTACTS":"Contacten","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Films","WEBSITE_TYPE_series_PL":"Serie\'s","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Kanalen","WEBSITE_STREMIO_WHAT_IS":"Stremio is een app dat je helpt met het organizeren en onmiddellijk bekijken van je favoriete videos, filmss, TV series en TV-kanalen.","WEBSITE_FEATURES_WATCH":"Kijk direct in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Klik en bekijk je favoriete films, TV Shows, videos en TV-kanalen.","WEBSITE_FEATURES_SUBS":"Automatische Ondertiteling","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio kiest automatisch gesynchroniseerde ondertiteling voor jouw taal.","WEBSITE_FEATURES_SUBS_LABEL":"Jouw zet, baas.","WEBSITE_FEATURES_CAST":"Speel op TV en mobiele apparaten","WEBSITE_FEATURES_CAST_DETAIL":"Cast naar AppleTV, Chromecast, Smart TV (DLNA/UPnP) en mobiele apparaten.","WEBSITE_LIB":"Geniet van je persoonlijke bibliotheek gesynchroniseerd naar al je apparaten","WEBSITE_LIB_COLLECT":"Collecteer van Stremio","WEBSITE_LIB_IMPORT":"Importeer van Facebook","WEBSITE_LIB_LOCAL":"Voeg toe van je lokale schijf","WEBSITE_BOARD":"Het dashboard- Je one-stop plaats voor Notificaties en Aanbevelingen","WEBSITE_BOARD_RECOMMEND":"Aanbevolen TV Show","WEBSITE_BOARD_TRENDING":"Trending Film","WEBSITE_BOARD_NEW":"Nieuwe Video","WEBSITE_BOARD_EPISODE":"Nieuwe Aflevering","WEBSITE_BOARD_1":"Zoek je iets interessants? Krijg aanbevelingen gebaseerd op jouw smaak!","WEBSITE_BOARD_2":"krijg een notificatie wanneer een nieuwe aflevering van je favoriete TV show of Youtube kanaal uit is!","WEBSITE_BOARD_YOUTUBE":"Nieuwe video\'s van YouTube kanalen","WEBSITE_BOARD_EPISODES":"Nieuwe afleveringen van series die je volgd","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We houden van technologie, we houden van wetenschap!\\nStremio gebruikt de volgende open-source technologieën:","WEBSITE_TECH_WCJS":"WebChimera.js laat Stremio toe om alle videoformaten af te spelen.","WEBSITE_TECH_WCJS_EXTRA":"We dragen bij aan het kernproject","WEBSITE_TECH_ELECTRON":"Electron zorgt voor de innovatieve basis waarop Stremio gebouwd is.","WEBSITE_TECH_ELECTRON_EXTRA":"We dragen bij aan het project","WEBSITE_TECH_LINVODB":"Een database technologie dat je data organiseert en beschikbaar maakt waar en wanneer je ook inlogt.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technologie","WEBSITE_CREATE_ADDON":"Maak je eigen addon","WEBSITE_CREATE_ADDON_DETAIL":"Heb jij een videoservice? We helpen je graag voordeel te halen uit Stremio door een Addon voor je te maken.","WEBSITE_CREATE_ADDON_BENEFITS":"Voordelen aan het maken van een Addon voor Stremio","WEBSITE_P2P_BEAUTY":"De schoonheid van Peer-to-Peer streaming","WEBSITE_P2P_1":"Betrouwbare en betaalbare full HD / 4K-video op aanvraag of live streaming","WEBSITE_P2P_2":"Distributieplatform met een geweldige gebruikerservaring","WEBSITE_P2P_3":"We maken een addon naar jouw noden en wensen","WEBSITE_P2P_CONTACT":"Geïnteresseerd? Contacteer ons zeker.","WEBSITE_P2P_CONTACT_EXTRA":"We helpen je graag om je content te integreren in Stremio!","WEBSITE_P2P":"Af en toe komt er een technologie die de naam van het spel verandert. We hebben veel tijd en moeite geïnvesteerd in het bouwen van onze Peer-to-Peer (P2P) videostreamingmotor die geweldige prestaties en veelzijdigheid biedt voor elke toepassing. \\nNeem contact met ons op voor DRM-compatibele P2P-video op aanvraag of live streaming.","WEBSITE_THOUGHTS":"Gedachten die we willen delen:","WEBSITE_SPREAD":"Vertel iedereen over Stremio:","WEBSITE_CONTACT":"Wil je ons contacteren, doe gerust via","WEBSITE_OPENSOURCE":"Ga voor onze open source-projecten naar onze","WEBSITE_BITCOIN":"Doneer bitcoin:","WEBSITE_FAQ":"Veel Gestelde vragen","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Vragen","WEBSITE_TOS":"Gebruiksvoorwaarden","WEBSITE_LEGAL":"Wettelijk","WEBSITE_PAGE_ABOUT":"Over","WEBSITE_PAGE_BECOME_PARTNER":"Word een partner","WEBSITE_ALL_YOU_CAN_WATCH":"Vrijheid om te kijken \\nNaar alles wat je wilt.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Wat is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is een one-stop-hub voor het verzamelen van video-inhoud. Ontdek, organiseer en bekijk video van allerlei soorten bronnen op elk apparaat dat u bezit.","WEBSITE_WHAT_IS_STREMIO_P2":"Films, TV Shows, series, live TV of webkanalen zoals YouTube en Twitch.tv - je kunt dit allemaal vinden op Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is een modern mediacentrum dat een alles-in-een-oplossing is voor uw video-entertainment. U ontdekt, bekijkt en organiseert videocontent via eenvoudig te installeren addons..","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Films, TV Shows, live TV of webkanalen - je vindt het allemaal op Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Geniet op al uw media-apparaten","WEBSITE_DEVICES_COLLECT":"Verzamel van Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importeer van Facebook","WEBSITE_DEVICES_LOCAL":"Toevoegen van lokale schijf","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"Zoals gezien op","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Over ons","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Download\'s","WEBSITE_MORE":"Meer","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your E-mail","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid e-mail!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Doorgaan","SLOW_LOADING":"TRAAG AAN HET LADEN?","I_GIVE_UP":"IK GEEF OP","LEARN_MORE":"Meer info","POOR_SOURCE":"Deze bron is slecht beschikbaar of je internetverbinding is niet snel genoeg","PICK_CATEGORIES_ERR":"Je moet minimaal 3 categorieën kiezen","ADJUST_TIMING":"Pas de timing aan met ","ADJUST_SIZE":"Pas de grootte aan met ","SEARCH_ANYTHING":"Je kan dit alles zoeken...","ALL_CATEGORIES":"Alles","SEARCH_CATEGORIES":"Films, Series, YouTube & TV","SEARCH_PERSONS":"Acteurs, Regisseurs & Schrijvers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDb / TVDB links","WATCHED":"Gezien","SHOW_LESS":"Toon minder","LAST_SEARCHES":"Laatste zoekopdrachten","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Afstandsbediening kon niet worden geladen","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Gebruik data","WARNING":"Waarschuwing","MORE_INFO":"Meer Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Laden ...","STREMIO_TV_BACK_TO_LANGUAGES":"Terug naar talen","STREMIO_TV_REMOTE":"Afstandsbediening","STREMIO_TV_GO_TO":"Ga naar:","STREMIO_TV_OR_SCAN":"of scannen:","STREMIO_TV_ADDON_INSTRUCTIONS":"Volg de instructies om je addon keuze te installeren.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Verder kijken","STREMIO_TV_LOADING_BACKGROUND":"Achtergrond laden","STREMIO_TV_CHECKING_AUTHENTICATION":"Authenticeren","STREMIO_TV_LOADING_BOARD":"Dashboard laden","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio team","STREMIO_TV_REMOTE_INSTRUCTIONS":"om de Web Afstandsbediening met je smartphone / tablet / desktop te gebruiken:","STREMIO_TV_WIFI_SETUP":"Wifi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio-circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connecteer met:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremio-circle","STREMIO_TV_WIFI_DETAILS_5":"Open een webbrowser met de link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Verander apparaat","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Timing aanpassen","REMOTE_ADJUST_SIZE":"Grootte aanpassen","REMOTE_COULD_NOT_BE_LOADED":"Web Afstandsbediening kon niet worden geladen","REMOTE_RETRY":"Opnieuw proberen","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"Wat is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an e-mail to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Ga je een addon maken voor X?","FAQ_08_P1":"Dat is mogelijk.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Gebruikt Stremio het BitTorrent protocol?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie films met Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"Hoe kan ik een addon maken?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},8159:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"TV kanal","TYPE_channel":"Kanal","TYPE_other":"Other","TYPE_movie_PL":"Filmar","TYPE_series_PL":"Seriar","TYPE_tv_PL":"TV kanalar","TYPE_channel_PL":"Kanalar","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Tilbake","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Oppdag","Board":"Board","Library":"Bibliotek","My Library":"My Library","Calendar":"Kalender","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"Søk mellom","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Legg til i bibliotek","REMOVE_FROM_LIB":"Fjern frå bibliotek","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Sjå Trailer","WATCH_NOW":"Sjå No","SHOW":"Vis","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb Rangering","YEAR":"År","DIRECTOR":"Regissør","WRITER":"Forfattar","LEAD_ACTORS":"Hovudskodespelarar","CAST":"Skodespelarar","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Utgjeven","SEASONS":"Sesongar","GENRE":"Sjanger","CATALOG":"Catalog","SUMMARY":"Samandrag","SHOW_MORE":"Show More","SIMILAR":"Liknade","UPCOMING":"Kjem","ENDED":"Enda","DURATION":"Lengd","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"search videos","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"Utviding","ADDONS":"Utvidinger","OFFICIAL":"Offisielle","ADDONS_OFFICIAL":"Offisielle Stremio Utvidinger","ADDONS_POPULAR":"Populært i området ditt","ADDON_FREE":"Gratis","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Abonnering","ADDON_STREAM_GEORESTRICTED":"not available in your area","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Tilgjengelege Streams","NO_STREAM":"Ingen streams tilgjengelege","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Filmen er framleis på kino","WATCH_IN_CINEMA":"sjå han på din lokale kino","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Denne kanalen er ikkje ferdig enda.
Ver vennleg og kom tilbake om nokon få minutt.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Legg han til i ditt bibliotek for å bli varsla når han blir tilgjengeleg.","GET_NOTIFIED_WHEN_AVAILABLE":"Du vil bli varsla med ein gong han er tilgjengeleg.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"Streamer frå","CASTING_TO":"Caster til","NETWORK_STATUS":"Nettverks status","STREAM_SPEED":"Fart på streamen:","STREAM_BUFFERED":"Buffret:","PEERS_INFO":"Informasjon om peers","PEERS_ACTIVE":"Aktive:","PEERS_CONNECTED":"Tilkoblet:","PEERS_WAITING":"Ventar:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"Lastar...","PLAYING_LOCAL":"Spelar frå lokal fil","PLAYING_CACHE":"Spelar frå cache","WRONG_SUBS":"Feil undertekstar?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Vel ein eining å streame frå","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Telefon / Nettbrett","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Endre undertekstar for ","SUBTITLES_CHANGE_NONE":"Det fins ingen andre undertekstar for dette språket, beklagar.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alteratively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sesong","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"nyleg","SORT_ALPHABET":"a-z","SORT_RATING":"rangering","SORT_WATCHED":"sett","SORT_YEAR":"år","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Utvald","DISCOVER_TOP":"Topp","DISCOVER_OSCAR":"Oscar vinnarar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Åtvaring: ingen Stremio utviding aktiv for denne typen. Visar lagra element, ingenting vil oppdatere.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Start på nytt no!","UPGRADE":"Oppdater til den nyaste Stremio versjonen","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Logg på med Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"eller","I_ACCEPT":"Eg godtek ","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Vilkåra og føresetnadene","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passorda er ikkje like","SIGN_UP":"Registrer","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Logg på","LOG_OUT":"Logg ut","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gjestepålogging","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"Klikk her","WRONG_PASSWORD":"Feil passord. I tilfelle du har gløymd passordet, ","SET_A_PASS":"lag eit passord","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"Denne eposten er i bruk av ein Facebook pålogging.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Bruk av tredjeparts-utvidinger vil alltid vere ditt eige ansvar med omsyn til den gjeldane lova der du oppheld deg.","ADDON_ACTIVATE":"Aktivere denne utvidingen?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Kva er nytt?","BUTTON_CONTINUE":"Hald fram","BUTTON_ACTIVATE":"Aktiver","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Avbryt","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Biblioteket ditt ser tomt ut. Finn ut kvar nyttig det er :) ","HOW_START":"Kom i gang:","LIB_EMPTY_CAL":"Kalenderen din visar seriar i biblioteket ditt.","HOW_START_CAL":"Her er korleis du kan leggje til seriar:","LIB_EMPTY_BOARD":"Board viser varslar & anbefalingar relatert til biblioteket ditt.","HOW_START_BOARD_WAIT":"Legg til nokon seriar eller kanalar i biblioteket ditt og gi oss nokon minutt til å behandle dei :)","HOW_START_BOARD":"Her er korleis du kan leggje til seriar & filmar til det:","IMPORT_FB":"Importer ting du likar frå Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Finn interessante ting frå Oppdag","IMPORT_DISK":"Importer filmar eller seriar frå din lokale Harddisk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Køyr ved oppstart","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Importer frå Facebook","SETTINGS_IMPORT_DISK":"Importer frå lokal disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Abonner på ein kalender","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Endre passord","SETTINGS_TOS":"Vilkåra for tjenesta","SETTINGS_SUPPORT":"Kontakt support","SETTING_LANGUAGE":"Språk","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Avslutt","CONNECTED":"Connected","AUTHENTICATE":"Verifiser","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Velj caching eining","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januar","February":"Februar","March":"Mars","April":"April","May":"Mai","June":"Juni","July":"Juli","August":"August","September":"September","October":"Oktober","November":"November","December":"Desember","Monday":"Måndag","Tuesday":"Tysdag","Wednesday":"Onsdag","Thursday":"Torsdag","Friday":"Fredag","Saturday":"Laurdag","Sunday":"Søndag","Action":"Action","Comedy":"Komedie","War":"Krig","Family":"Familie","Animation":"Animasjon","Adventure":"Eventyr","Fantasy":"Fantasy","Crime":"Krim","Mystery":"Mysterium","Romance":"Romantikk","Drama":"Drama","Horror":"Grysjar","Thriller":"Spenning","Sci-Fi":"Sci-Fi","Music":"Musikk","Biography":"Biografi","Documentary":"Dokumentar","Sport":"Sport","Musical":"Musikal","Western":"Western","Film-Noir":"Film-Noir","News":"Nyheiter","History":"Historie","Game-Show":"Gameshow","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Underhalding","Gaming":"Gaming","From TV":"Frå TV","Lifestyle":"Livsstil","Science & Education":"Vitskap & Utdanning","Cooking & Health":"Matlaging & Helse","Beauty & Fashion":"Venleik & Mote","Sports":"Sport","News & Politics":"Nyheiter & Politikk","How-to & DIY":"Gjør det sjølv","Tech":"Teknologi","Automotive":"Bilbransjen","Causes & Non-Profits":"Saker & ideelle organisasjonar","Movies":"Filmar","Uk Live Tv":"UK Direkte TV","Fashion":"Mote","Business News Radio":"Business Nyheitsradio","Business Tv":"BusinessTV","Cars & Auto":"Bilar og Auto","Comedy Radio":"Komedieradio","Lifestyle Radio":"Livsstilsradio","News Tv":"NyheitsTV","Food And Wine":"Mat og Vin","Latino Tv":"Latino TV","Shopping Tv":"ShoppingTV","Religion":"Religion","Kids":"Barn","Body & Soul":"Kropp og Sjel","Education":"Utdanning","Indian Tv":"Indisk TV","Extreme Sports":"Ekstremsport","Middle Eastern Tv":"TV frå Midtøsten","Celebrity Tv":"KjendisTV","Science Tv":"VitskapsTV","Bikini babe":"Bikini babe","Outdoors":"Utandørs","German Tv":"Tysk TV","French Tv":"Fransk TV","Italian Tv":"Italiensk TV","Gamer Tv":"SpelTV","Travel":"ReiseTV","Asian Tv":"Asiatisk TV","Entertainment":"Underhalding","News Radio":"Nyheitsradio","Music Radio":"Musikkradio","Language Learning":"Språklæring","Science Radio":"Vitskapsradio","Tech Radio":"Teknologiradio","Science & Technology Vod":"Vitskap -og Teknologi VOD","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years, with a single goal - to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - support us!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},5517:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serial","TYPE_tv":"Program telewizyjny","TYPE_channel":"Kanał","TYPE_other":"Inne","TYPE_movie_PL":"Filmy","TYPE_series_PL":"Seriale","TYPE_tv_PL":"Programy telewizyjne","TYPE_channel_PL":"Kanały","TYPE_other_PL":"Inne","TYPE_ALL":"All","VIDEO":"Wideo","BACK":"Wstecz","MORE":"Więcej","DONE":"Gotowe","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Tryb rzutowania","CASTING_MODE_HLSV2":"Domyślny","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"Bez transkodowania","Discover":"Odkrywaj","Board":"Tablica","Library":"Biblioteka","My Library":"Moja biblioteka","Calendar":"Kalendarz","NOTIFICATION_ONLINE":"Jesteś teraz online","NOTIFICATION_OFFLINE":"Jesteś obecnie offline","INTERNET_CONNECTION":"Połączenie internetowe","STORAGE_FULL_TITLE":"Ostrzeżenie: pamięć pełna!","STORAGE_FULL_TEXT":"Stremio nie jest w stanie zapisać twoich ustawień lub danych logowania. Spróbuj ponownie uruchomić, lub ponownie zainstalować Stremio.","SEARCH":"szukaj","SEARCH_NO_RESULTS":"Nie znaleziono żadnych wyników","SEARCH_EXPLANATION_CONTENT":"Szukaj filmów, seriali, YouTube i kanałów telewizyjnych","SEARCH_EXPLANATION_PEOPLE":"Szukaj aktorów, reżyserów i scenarzystów","SEARCH_PASTE_LINKS":"Wklej adresy HTTP i Magnet","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Dodaj do biblioteki","REMOVE_FROM_LIB":"Usuń z biblioteki","ADDED_TO_LIB":"Dodano do biblioteki","REMOVED_FROM_LIB":"Usunięto z biblioteki","TRAILER":"Zwiastun","WATCH_TRAILER":"Zobacz zwiastun","WATCH_NOW":"Oglądaj","SHOW":"Pokaż","SHOW_MOVIE":"Pokaż film","WATCH_RANDOM":"Obejrzyj losowy","IMDB_RATING":"Ocena IMDb","YEAR":"Rok","DIRECTOR":"Reżyser","WRITER":"Scenarzysta","LEAD_ACTORS":"Główni aktorzy","CAST":"Obsada","CREW":"Ekipa","SHOW_MORE_CAST":"Pokaż więcej »","AIRED":"Wyemitowany","SEASONS":"Sezony","GENRE":"Gatunek","CATALOG":"Katalog","SUMMARY":"Podsumowanie","SHOW_MORE":"Pokaż więcej","SIMILAR":"Podobne","UPCOMING":"Nadchodzące","ENDED":"Zakończony","DURATION":"Czas trwania","FEATURED":"Wyróżnione","METADATA":"Metadane","CATEGORY":"kategoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"szukaj filmy","SEARCH_PLACEHOLDER":"szukaj lub wklej URL","ADDON":"dodatek","ADDONS":"Dodatki","OFFICIAL":"oficjalny","ADDONS_OFFICIAL":"Oficjalne dodatki Stremio","ADDONS_POPULAR":"Popularne w twojej okolicy","ADDON_FREE":"darmowe","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"subskrypcja","ADDON_STREAM_GEORESTRICTED":"niedostępne w twoim regionie","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Lokalny plik","SHARE_ADDON":"Udostępnij dodatek","AVAILABLE_STREAMS":"Dostępne źródła","NO_STREAM":"Nie ma dostępnych źródeł","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Dla większej ilości źródeł zainstaluj więcej dodatków","STREAM_NOT_SUPPORTED":"Wybrane źródło nie jest dostępne na tej platformie","ADDON_CATALOGUE":"Pokaż wszystkie dodatki »","ADDON_CATALOGUE_MORE":"Więcej dodatków »","REPO_ADDED":"Repozytorium dodane","ADDON_REPO_EXIST_ERR":"Repozytorium już istnieje","ADDON_REPO_ERR":"Wystąpił błąd podczas dodawania kolekcji","ADDON_ADD_ERR":"Wystąpił błąd podczas dodawania dodatku","ERR_ADDON_PROTECTED":"Nie można odinstalować dodatku, ponieważ jest chroniony","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Coś poszło nie tak - uwierzytelnianie mogło się nie powieść","ERR_NOT_COLLECTION_URL":"To nie jest URL kolekcji","ERR_NOT_ADDON_URL":"Nieprawidłowy URL dodatku","ERR_DETECTFROMURL":"Nie odnaleziono dodatku/kolekcji pod tym URL","ADDON_DUPLICATE_WARNING":"Ostrzeżenie: powielony dodatek","ADDON_COLLECTION_SET_FAILED":"Synchronizacja zainstalowanych dodatków do twojego konta nie powiodła się","SETTINGS_DATA_EXPORT":"Wyeksportuj dane użytkownika","ADDON_PULL_FAILED":"Synchronizacja zainstalowanych dodatków z twojego konta nie powiodła się","REFRESH_ON_CLICK":"Kliknij, aby ponowić","STILL_IN_THEATER":"Film obecnie w kinach","WATCH_IN_CINEMA":"Obejrzyj film w kinie","IN_THEATER":"W kinie","GET_TICKETS":"Kup bilety","UPCOMING_EPISODE":"Nadchodzący odcinek","UPCOMING_EPISODE_MESSAGE":"Ten odcinek zostanie nadany","MISSING_DATE_EPISODE":"Brak daty odcinka","MISSING_DATE_EPISODE_MESSAGE":"Ten odcinek mógł nie zostać jeszcze wyemitowany","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Zajrzyj z powrotem za kilka minut.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Dodaj do swojej biblioteki, aby zostać powiadomionym kiedy będzie dostępny.","GET_NOTIFIED_WHEN_AVAILABLE":"Zostaniesz powiadomiony kiedy będzie dostępny.","WARNING_STREAMING_SERVER":"Ostrzeżenie: lokalny serwer streamowania nie został znaleziony. Streamowanie lokalnych plików, YouTube i BitTorrent nie będzie dostępne.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Ostrzeżenie: ten film może nie być wspierany przez twój sprzęt. Miej na uwadze, że odtwarzanie może być wolne.","PLAYER_ERROR":"Ups, błąd odtwarzacza","PLAYER_ERROR_LOOKSLIKE":"Wygląda na to, że","PLAYER_ORIENTATION":"Orientacja odtwarzacza","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Zablokowana","PLAYER_ORIENTATION_SENSOR_SHORT":"Czujnik","PLAYER_ORIENTATION_LANDSCAPE":"Orientacja odtwarzacza zablokowana poziomo","PLAYER_ORIENTATION_SENSOR":"Orientacja odtwarzacza automatyczna (czujnik)","PLAYER_PLAYBACK_SPEED":"Prędkość odtwarzania","PLAYER_PLAYBACK_ERROR":"Błąd odtwarzania, spróbuj ponownie","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Nieznany błąd","PLAYER_PLAYBACK_ERROR_DEFAULT":"Przepraszamy, ten film nie może być odtworzony przez {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Na żywo","PLAYER_NEXT_VIDEO_TITLE":"Następnie w","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Odrzuć","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Oglądaj teraz","STREAMING_FROM":"streamuje z","CASTING_TO":"Rzutowanie do","NETWORK_STATUS":"Status połączenia","STREAM_SPEED":"Prędkość streama:","STREAM_BUFFERED":"Zbuforowane:","PEERS_INFO":"Informacje o peerach","PEERS_ACTIVE":"Aktywnych:","PEERS_CONNECTED":"Połączonych:","PEERS_WAITING":"Oczekujących:","TRANSCODING_WARNING":"Ostrzeżenie: transkodowanie filmu.","STREAM_LOADING":"ładowanie...","PLAYING_LOCAL":"odtwarzanie lokalnego pliku","PLAYING_CACHE":"odtwarzanie z pamięci podręcznej","WRONG_SUBS":"Złe napisy?","ERR_SUBS_LOADING_TITLE":"Błąd podczas ładowania napisów","ERR_SUBS_LOADING":"Nie udało się załadować napisów: to może być problem z dodatkiem, którego używasz, lub z twoim połączeniem sieciowym","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Te dodatki z napisami poległy","ERR_CASTING_UPDATE_TITLE":"Nie udało się zaktualizować info o urządzeniu zdalnym: serwer streamingowy może być niedostępny","CHOOSE_DEVICE":"Wybierz urządzenie, na którym chcesz oglądać","NO_CAST_DEVICES":"Brak zdalnych urządzeń.","NO_SETTINGS":"Brak dostępnych ustawień.","PHONE_TABLET":"Telefon / Tablet","SUBTITLES":"Napisy","SUBTITLES_CHANGE":"Zmień napisy na ","SUBTITLES_CHANGE_NONE":"Nie ma innych napisów dla tego języka, przepraszamy","SUBTITLES_CHANGE_ACIVE":"Obecnie napisy #{{subtitlesDialog.activeIdx + 1}} są aktywne. Kliknij \\"Kontynuuj\\", aby aktywować napisy #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatywnie,","SUBTITLES_ADJUST_DELAY":"Dopasuj opóźnienie napisów:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"lub użyj przycisków G / H podczas odtwarzania, aby dopasować.","SUBTITLES_ADJUST_DELAY_TIP":"PORADA: możesz używać przycisków G / H podczas odtwarzania, aby dopasować.","SUBTITLES_DELAY":"Opóźnienie napisów:","SUBTITLES_LOADING":"Ładowanie napisów...","SUBTITLES_UNAVAILABLE":"Brak dostępnych zewnętrznych napisów","SUBTITLES_DISABLED":"Wyłączone","AUDIO":"Dźwięk","DEFAULT_LANGUAGE":"Domyślny język","DEFAULT_SECONDARY_LANGUAGE":"Domyślny drugorzędny język","SEASON":"Sezon","EPISODE":"Odcinek","SPECIAL":"Bonus","SORT":"sortuj","SORT_BY":"Sortuj po","FILTER":"filtruj","SORT_TRENDING":"na czasie","SORT_RECENT":"ostatnie","SORT_ALPHABET":"a-z","SORT_RATING":"oceny","SORT_WATCHED":"obejrzane","SORT_YEAR":"rok","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Nowe dla ciebie","New Episodes":"Nowe odcinki","New Videos":"Nowe filmy","Recommendations":"Polecane","LIBRARY_RESUME":"Wznów","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Szczegóły","LIBRARY_RESUME_DISMISS":"Odrzuć","LIBRARY_CLEAR_PROGRESS":"Wyczyść postęp","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Wyróżnione","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Zwycięzcy Oscara","DISCOVER_WARNING_TITLE":"Ups!","DISCOVER_EMPTY_CATALOG":"Ten dodatek nie zwrócił zawartości.","DISCOVER_ADULT_WARNING":"Ta treść jest widoczna tylko dla dorosłych. Czy jesteś 18+?","DISCOVER_NOADDON_WARNING":"Ostrzeżenie: żaden dodatek Stremio nie jest aktywny dla tego typu. Pokazywanie zapisanych rzeczy, nic nie zostanie zaktualizowane","DISCOVER_LOAD_ERR":"Zawartość nie została załadowana, wystąpił błąd","DISCOVER_ADDON_UNINSTALLED":"Ta zawartość nie jest już dostępna, być może odinstalowano ten dodatek.","UNINSTALL_THIS_ADDON":"Odinstaluj ten dodatek","ERR_ADDON_NOT_INSTALLED":"Ten dodatek nie jest zainstalowany. Zainstalować teraz?","DETAIL_RECEIVE_NOTIF_SERIES":"Otrzymuj powiadomienia o nowych odcinkach","DETAIL_RECEIVE_NOTIF_VIDEOS":"Otrzymuj powiadomienia o nowych filmach","SIDEBAR_SHOW_STREAMS":"Pokaż źródła","RELAUNCH":"Uruchom ponownie teraz!","UPGRADE":"Nowa wersja jest dostępna! Zaktualizuj do najnowszej wersji Stremio","RELOAD_UI":"Przeładuj interface użytkownika","MANUAL_UPDATE_TITLE":"Zaktualizuj twoją wersję Stremio","MANUAL_UPDATE_LINE1":"Używasz przestarzałej wersji Stremio, co jest mocno niezalecane.","MANUAL_UPDATE_LINE2":"Proszę zaktualizować tak szybko, jak to możliwe.","BUTTON_UPDATE_LATTER":"Nie teraz","BUTTON_UPDATE_NOW":"Aktualizuj","ANONYMOUS_USER":"Anonimowy użytkownik","DONT_HAVE_ACC":"Nie masz konta?","HAVE_ACC":"Masz już konto?","PASSWORD":"Hasło","PASSWORD_CONFIRM":"Potwierdź hasło","EMAIL":"E-mail","FB_LOGIN":"Zaloguj z Facebook","FB_NOTHINGSHARED":"Nic nie jest udostępniane bez twojego zezwolenia","FB_NOPOST":"Nic nie napiszemy w twoim imieniu","OR":"lub","I_ACCEPT":"Akceptuję","I_ACCEPT_BY_CLICKING":"Poprzez kliknięcie powyższego przycisku świadczę, że akceptuję ","TOS":"Warunki Umowy","MUST_ACCEPT_TERMS":"Musisz zaakceptować regulamin","PASSWORDS_NOMATCH":"Hasła nie są takie same","SIGN_UP":"Zarejestruj się","SIGN_UP_EMAIL":"Zarejestruj się za pomocą email","CLICK_TO_SIGN_UP":"Kliknij tutaj, aby się zarejestrować.","LOG_IN":"Zaloguj się","LOG_OUT":"Wyloguj się","EXIT_FULLSCREEN":"Wyjdź z trybu pełnoekranowego","ENTER_FULLSCREEN":"Wejdź w tryb pełnoekranowy","PLAY_URL_MAGNET_LINK":"Odtwórz URL/Magnet link","HELP_FEEDBACK":"Pomoc i Feedback","TERMS_OF_SERVICE":"Warunki świadczenia usług","PRIVACY_POLICY":"Polityka prywatności","ABOUT_STREMIO":"O Stremio","USER_PANEL":"Panel użytkownika","LOGIN_LABEL":"Login","GUEST_LOGIN":"Zaloguj się jako gość","GUEST_LOGIN_NOTICE":"Logowanie się jako gość nie jest polecane. Używanie typowego logowania pozwala Stremio synchronizować twoją Bibliotekę, otrzymywać powiadomienia dla twoich ulubionych serialach/kanałach. Na pewno chcesz kontynuować?","GUEST_LOGIN_NOTICE_2":"Logowanie się jako gość nie jest polecane - nie będziesz miał możliwości synchronizacji Biblioteki i powiadomień na Tablicy, a to ważne funkcje Stremio. Na pewno chcesz kontynuować?","CLICK_HERE":"kliknij tutaj","WRONG_PASSWORD":"Zły email lub hasło. Jeżeli zapomniałeś swojego hasła, ","SET_A_PASS":"ustaw hasło","RESET_PASSWORD":"Zresetuj hasło","FORGOT_PASSWORD":"Zapomniałeś hasła?","EMAIL_USED_WITH_FB":"Ten email jest używany do logowania poprzez Facebook.","INVALID_EMAIL":"Wprowadź poprawny adres email","INVALID_PASSWORD":"Wprowadź poprawne hasło","CONN_ERR":"Błąd połączenia - proszę spróbować ponownie później.\\n\\nJeśli problem wciąż występuje, wyłącz zapory sieciowe/oprogramowanie antywirusowe (szczególnie Bitdefender).","IMPORT_FROM_GUEST":"Importuj Bibliotekę z twojego konta gościa","RECEIVE_UPDATES_EMAIL":"Otrzymuj aktualizacje na swój email od Stremio","LOGIN_FAILED":"Logowanie nieudane.","SIGNUP_FAILED":"Rejestracja nieudana.","SEARCH_FAILED":"Wyszukiwanie nieudane","EMAIL_USED":"Ten email jest już w użyciu.","WAITING_FB_LOGIN":"Logowanie za pomocą Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Powiedz nam co lubisz","INTRO_TASTE_LONG":"Powiedz nam co chcialbyś obejrzeć","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Pomóż nam dowiedzieć się więcej o Tobie.","INTRO_TASTE_CHOOSE_THESE":"Wybierz kilka z tych:","INTRO_TASTE_CHOOSE_MIN":"Wybierz przynajmniej 3 kategorie","INTRO_TASTE_CHOOSE_MIN_ERR":"Musisz wybrać przynajmniej 3 kategorie!","INTRO_TASTE_LIFESTYLE":"Styl życia","INTRO_TASTE_SPORTS":"Sport","INTRO_TASTE_FOOD_HEALTH":"Jedzenie i zdrowie","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Nauka i edukacja","INTRO_TASTE_MUSIC":"Muzyka","INTRO_TASTE_TRAVEL":"Podróże","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Wybrany addon nie jest wspierany na tej platformie.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Aktywować ten addon?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Dodaj","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Co nowego?","BUTTON_CONTINUE":"Kontynuuj","BUTTON_ACTIVATE":"Aktywuj","BUTTON_ACTIVATED":"Aktywowany","BUTTON_CANCEL":"Anuluj","BUTTON_SUBMIT":"Wyślij","BUTTON_DISMISS_ALL":"Odwołaj wszystko","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Twoja biblioteka wygląda na pustą. Dowiedz się jak bardzo ona jest przydatna :) ","HOW_START":"Oto jak zacząć:","LIB_EMPTY_CAL":"Twój Kalendarz pokazuje seriale w twojej bibliotece.","HOW_START_CAL":"Tak możesz dodawać seriale:","LIB_EMPTY_BOARD":"Board pokazuje powiadomienia & Polecane na podstawie twojej Biblioteki.","HOW_START_BOARD_WAIT":"Dodaj kilka seriali lub filmów to swojej Biblioteki i daj nam troche czasu na przetworzenie :)","HOW_START_BOARD":"Tak możesz dodawać seriale & filmy:","IMPORT_FB":"Importuj rzeczy z Facebook","IMPORT_TRAKT":"Importuj dane z Trakt","IMPORT_DISCOVER":"Znajdź interesujące rzeczy w Odkrywaj","IMPORT_DISK":"Importuj filmy lub seriale, które posiadasz na swoim lokalnym dysku","PLEASE_CREATE_ACC":"Załóż konto, aby aktywować synchronizacje Biblioteki & Board.","IMPORT_DISCOVER_SIGNUP":"Załóż konto i znajdź interesujące rzeczy w Odkrywaj","IMPORT_DISK_SIGNUP":"Załóż konto i importuj filmy lub seriale, które posiadasz na swoim lokalnym dysku","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Otrzymuj powiadomienia o nowych odcinkach","LIB_EMPTY_PERSONAL":"Osobiste","LIB_EMPTY_PERSONAL_DESC":"Otrzymuj osobiste rekomendacje","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"Kalendarz Stremio został dodany do twojego domyślnego systemowego kalendarza.","CALENDAR_ADDED_MSG":"Jeżeli to nie działa, dodaj ten URL do twojego kalendarza manualnie","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"Musisz się zalogować","SETTINGS_LABEL":"Ustawienia","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Odtwarzacz","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Przeładuj aplikację","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Otwórz ustawienia","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Wyjdź / Cofnij","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Zwiększ rozmiar napisów","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Zmniejsz rozmiar napisów","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Zwiększ opóźnienie napisów","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Zmniejsz opóźnienie napisów","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Odtwarzaj z VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Domyślny język napisów","SETTINGS_SUBTITLES_SIZE":"Domyślny rozmiar napisów","SETTINGS_SUBTITLES_BACKGROUND":"Tło napisów","SETTINGS_SUBTITLES_COLOR":"Kolor napisów","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Kolor tła napisów","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play następny odcinek","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Zawsze używaj najnowszej Bety","SETTINGS_IMPORT_FB":"Importuj z Facebook","SETTINGS_IMPORT_DISK":"Importuj z lokalnego dysku","SETTINGS_IMPORT_TRAKT":"Importuj z Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Odtwarzaj w tle","SETTINGS_SUBSCRIBE_CALENDAR":"Subskrybuj kalendarz","SETTINGS_REQ_EXPORT":"Zażądaj exportu danych","SETTINGS_ACC_DELETE":"Zażądaj usunięcia konta","SETTINGS_CHANGE_PASSWORD":"Zmień hasło","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Skontaktuj się ze wsparciem","SETTING_LANGUAGE":"Język","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Wyloguj z Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Oszczędzanie energii","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"domyślne napisy","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"konto","SETTINGS_VERSION":"wersja","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Rozmiar","SUBSPICKER_DELAY":"Opóźnienie","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Zamknij","CONNECTED":"Połączony","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Styczeń","February":"Luty","March":"Marzec","April":"Kwiecień","May":"Maj","June":"Czerwiec","July":"Lipiec","August":"Sierpień","September":"Wrzesień","October":"Październik","November":"Listopad","December":"Grudzień","Monday":"Poniedziałek","Tuesday":"Wtorek","Wednesday":"Środa","Thursday":"Czwartek","Friday":"Piątek","Saturday":"Sobota","Sunday":"Niedziela","Action":"Action","Comedy":"Komedia","War":"Wojna","Family":"Family","Animation":"Animation","Adventure":"Adventure","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romans","Drama":"Dramat","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Filmy","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"nowy film","new episode":"nowy odcinek","new movie":"nowy film","recommended":"polecane","we recommend":"polecamy","offer of the day":"offer of the day","news":"aktualności","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Odrzuć powiadominie","CTX_DISMISS_ALL":"Odrzuć wszystkie","CTX_SHARE":"Udostępnij","CTX_COPY_SHARE_LINK":"Kopiuj link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Pokaż","CTX_PLAY":"Odtwórz","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Oglądaj","CTX_WATCHED":"Obejrzane","CTX_WATCH_BEGINNING":"Obejrzyj od początku","CTX_WATCH_MOBILE":"Obejrzyj na urządzeniu mobilnym","CTX_REWIND":"Przewiń do początku","CTX_MARK_WATCHED":"Oznacz jako obejrzane","CTX_MARK_NON_WATCHED":"Oznacz jako nieobejrzane","CTX_MARK_UNWATCHED":"Oznacz jako nieoglądane","CTX_MARK_REST":"Oznacz resztę jako obejrzane","CTX_UNMARK_REST":"Oznacz resztę jako nieobejrzane","CTX_RECEIVE_NEW_NOTIF":"Otrzymuj nowe powiadomienia","CTX_REMOVE_CACHE":"Usuń z pamięci podręcznej","CTX_REMOVE_CACHE_EP":"Usuń odcinek z pamięci podręcznej","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Usuń z Biblioteki","CTX_AVAILABLE_OFFLINE":"Dostępne offline","CTX_PAUSED":"Zatrzymane","CTX_ALWAYS_ON_TOP":"Zawsze na wierzchu","CTX_FULLSCREEN":"Tryb pełnoekranowy","CTX_WRONG_SUBS":"Złe napisy?","CTX_REPORT_ISSUES":"Wyślij raport o błędzie","CTX_COPY":"Kopiuj","CTX_PASTE":"Wklej","CTX_CLEAR":"Wyczyść","CTX_CLEAR_RECENT_SEARCHES":"Wyczyść ostatnie wyszukania","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"Moje dodatki","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Wyszukaj dodatki","ADDON_INSTALL":"Zainstaluj","ADDON_CONFIGURE":"Konfiguruj","ADDON_UNINSTALL":"Odinstaluj","ADDON_UPGRADE":"Zaktualizuj","ADDON_INSTALLED":"Zainstalowany","ADDON_INSTALLED_MSG":"Dodatek zainstalowany!","ADDON_UPGRADED_MSG":"Dodatek zaktualizowany!","ADDON_UNKNOWN":"Nieznany","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Instaluj teraz","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You Can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Dodatki","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmy","WEBSITE_TYPE_series_PL":"Seriale","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Kanały","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Często zadawane pytania","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Pytania","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"O","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"O Nas","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"Więcej","WEBSITE_LINK_ADDONS":"Dodatki","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Społeczność","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Polityka prywatności","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Twój email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"Zespół","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Funkcjonalność","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Dodatki","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Stwórz dodatek","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Dodatki Stremio","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Tapety","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Kontakt","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Twój e-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Wiadomość","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"Wyślij","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Dodatki","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Styl życia","SPORTS":"Sporty","FOOD_HEALTH":"Jedzenie i zdrowie","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Muzyka","TRAVEL":"Podróż","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Komedia","DIY":"How to DIY","TECH":"Tech","CINEMA":"Kino","CONTINUE":"Kontynuuj","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Dowiedz się więcej","POOR_SOURCE":"To źródło jest słabo dostępne, albo twoje połączenie z internetem nie jest wystarczająco szybkie","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"Możesz wyszukać cokolwiek...","ALL_CATEGORIES":"Wszystkie","SEARCH_CATEGORIES":"Filmy, seriale, YouTube i TV","SEARCH_PERSONS":"Aktorzy, reżyserzy i scenarzyści","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Obejrzane","SHOW_LESS":"Pokaż mniej","LAST_SEARCHES":"Ostatnie wyszukiwania","CLEAR_HISTORY":"Wyczyść historię","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio jest offline","STREMIO_EXPENSIVE_CONNECTION":"Wykryliśmy, że korzystasz z połączenia mobilnego,czy chcesz kontynuować?","USE_DATA":"Use data","WARNING":"Ostrzeżenie","MORE_INFO":"Więcej informacji...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Ładowanie...","STREMIO_TV_BACK_TO_LANGUAGES":"Wróć do języków","STREMIO_TV_REMOTE":"Zdalny","STREMIO_TV_GO_TO":"Przejdź do:","STREMIO_TV_OR_SCAN":"lub zeskanuj:","STREMIO_TV_ADDON_INSTRUCTIONS":"Podążaj za instrukcjami w celu instalacji twoich preferowanych dodatków.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Wznów oglądanie","STREMIO_TV_LOADING_BACKGROUND":"Ładowanie tła","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Zespół Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Połącz z:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Domyślny","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Po ostatnio oglądanym","STREMIO_TV_LIBRARY_SORT_NAME":"Po nazwie","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Po ilości obejrzeń","STREMIO_TV_DETAILS_SEASON_NUMBER":"Sezon ${1}","STREMIO_TV_STREAMS_LOADING":"Załadowano ${1} z ${2} dodatków...","STREMIO_TV_STREAMS_STILL_LOADING":"Dodatek ${1} jeszcze się ładuje...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Notka: upewnij się, że używasz tego samego konta Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Zsynchronizuj dodatki","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Pomyślnie zsynchronizowano dodatki","STREMIO_TV_ADDONS_SYNC_FAILED":"Niepowodzenie synchronizacji dodatków","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Uaktualniono motyw","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Domyślny odtwarzacz","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"Zewnętrzny odtwarzacz","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferowany język","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Drugorzędny preferowany język","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"Bez pamięci podręcznej","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Domyślny","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Miękki","STREMIO_TV_SETTINGS_PROFILE_FAST":"Szybki","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra szybki","STREMIO_TV_SETTINGS_SERVER_URL":"URL serwera streamingowego","STREMIO_TV_SETTINGS_SERVER_VERSION":"Wersja Serwera","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Nieznany","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Wersja Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edytuj URL serwera","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Wyszukaj","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Biblioteka","STREMIO_TV_NAV_MOVIES":"Filmy","STREMIO_TV_NAV_SERIES":"Seriale","STREMIO_TV_NAV_CHANNELS":"Kanały","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Ustawienia","STREMIO_TV_NAV_ADDONS":"Dodatki","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Wygasa za","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Kod logowania odświerzony","STREMIO_TV_SEARCH_PLACEHOLDER":"Wpisz coś","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Szukaj","STREMIO_TV_SEARCH_KEY_DEL":"Usuń","STREMIO_TV_SEARCH_KEY_SPACE":"Spacja","STREMIO_TV_SEARCH_KEY_CLEAR":"Wyczyść","STREMIO_TV_SEARCH_HISTORY_TITLE":"Historia wyszukiwania","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Możesz wyszukać tytuł, aktora, kanał i więcej...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Wyczyść historię wyszukiwania","STREMIO_TV_FILTERS_DESCRIPTION":"Wybierz jeden z poniższych filtrów","FILTERS":"Filtry","SETTINGS":"Ustawienia","ACCOUNT":"Konto","LOGOUT":"Wyloguj","THEMES":"Motywy","PLAYBACK":"Odtwarzanie","PLAYBACK_SPEED":"Prędkość odtwarzania","AUDIO_TRACKS":"Ścieżki dźwiękowe","VIDEOS":"Filmy","SERVER":"Serwer","LINKS":"Linki","ABOUT":"O","INTERFACE":"Interface","ANIMATIONS":"Animacje","STATUS":"Status","LANGUAGE":"Język","SIZE":"Rozmiar","DELAY":"Opóźnienie","BOLD":"Pogrubienie","TEXT_COLOR":"Kolor tekstu","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Kolor tła","BACKGROUND_BLUR":"Rozmycie tła","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Automatycznie uruchom następny odcinek","PLAY_NOW":"Odtwórz teraz","MARK_AS_WATCHED":"Oznacz jako obejrzane","MARK_AS_UNWATCHED":"Oznacz jako nieobejrzane","REWIND_TO_BEGINNING":"Od początku","CONTINUE_WATCHING":"Kontynuuj oglądanie","ALL":"Wszystko","SECONDS":"sekundy","ON":"Wł.","OFF":"Wył.","RELOAD":"Przeładuj","EDIT_URL":"Edytuj URL","NONE":"Brak","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Filmy","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Dopasuj rozmiar","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Ponów","TORRENT_PROFILE_DEFAULT":"Domyślny","TORRENT_PROFILE_SOFT":"Miękki","TORRENT_PROFILE_FAST":"Szybki","TORRENT_PROFILE_ULTRA_FAST":"Ultra szybki","FAQ_001_H1":"Czym jest Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},2012:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filme","TYPE_series":"Série","TYPE_tv":"Canal de TV","TYPE_channel":"Canal","TYPE_other":"Outros","TYPE_movie_PL":"Filmes","TYPE_series_PL":"Séries","TYPE_tv_PL":"Canais de TV","TYPE_channel_PL":"Canais","TYPE_other_PL":"Outros","TYPE_ALL":"All","VIDEO":"Vídeo","BACK":"Voltar","MORE":"Mais","DONE":"Concluído","COPY":"Copiar","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Descubra","Board":"Painel","Library":"Biblioteca","My Library":"Minha Biblioteca","Calendar":"Calendário","NOTIFICATION_ONLINE":"Você está online","NOTIFICATION_OFFLINE":"Você está offline","INTERNET_CONNECTION":"Conexão de rede","STORAGE_FULL_TITLE":"Aviso: Disco cheio!","STORAGE_FULL_TEXT":"Stremio não será capaz de salvar suas configurações, preferências ou informações de login. Considere reiniciar ou reinstalar o Stremio.","SEARCH":"Buscar","SEARCH_NO_RESULTS":"Nenhum resultado encontrado","SEARCH_EXPLANATION_CONTENT":"Procure por filmes, séries, canais do YouTube e da TV","SEARCH_EXPLANATION_PEOPLE":"Procure por atores, diretores e escritores","SEARCH_PASTE_LINKS":"Cole links HTTP ou Magnéticos","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Adicionar à Biblioteca","REMOVE_FROM_LIB":"Remover da Biblioteca","ADDED_TO_LIB":"Adicionado à Biblioteca","REMOVED_FROM_LIB":"Removido da Biblioteca","TRAILER":"Trailer","WATCH_TRAILER":"Assistir ao Trailer","WATCH_NOW":"Assistir Agora","SHOW":"Mostrar","SHOW_MOVIE":"Exibir filme","WATCH_RANDOM":"Assistir Aleatoriamente","IMDB_RATING":"Avaliação IMDB","YEAR":"Ano","DIRECTOR":"Diretor","WRITER":"Escritor","LEAD_ACTORS":"Atores Principais","CAST":"Elenco","CREW":"Equipe técnica","SHOW_MORE_CAST":"Mostrar mais »","AIRED":"Foi ao ar em","SEASONS":"Temporadas","GENRE":"Gêneros","CATALOG":"Catálogo","SUMMARY":"Resumo","SHOW_MORE":"Mostrar mais","SIMILAR":"Parecidos","UPCOMING":"Próximos","ENDED":"Finalizados","DURATION":"Duração","FEATURED":"Destaque","METADATA":"Dados de Descrição","CATEGORY":"Categoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Pesquisar vídeos","SEARCH_PLACEHOLDER":"Buscar ou colar links","ADDON":"Addon","ADDONS":"Addons","OFFICIAL":"Oficial","ADDONS_OFFICIAL":"Addons Oficiais do Stremio","ADDONS_POPULAR":"Populares na sua região","ADDON_FREE":"Gratuito","ADDON_PEERED":"pareado","ADDON_SUBSCRIPTION":"assinatura","ADDON_STREAM_GEORESTRICTED":"indisponível na sua área","ADDON_STREAM_OFFLINECACHE":"Cache Offline","ADDON_STREAM_LOCALFILE":"Arquivo Local","SHARE_ADDON":"Compartilhar Addon","AVAILABLE_STREAMS":"Transmissões Disponíveis","NO_STREAM":"Nenhuma transmissão encontrada","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Para mais transmissões, por favor instale mais Addons","STREAM_NOT_SUPPORTED":"A transmissão selecionada não é suportada nesta plataforma.","ADDON_CATALOGUE":"Mostrar todas os Addons »","ADDON_CATALOGUE_MORE":"Instalar Addons","REPO_ADDED":"Repositório adicionado","ADDON_REPO_EXIST_ERR":"Este repositório de Addons já existe","ADDON_REPO_ERR":"Ocorreu um erro ao adicionar o repositório","ADDON_ADD_ERR":"Ocorreu um erro ao adicionar o Addon","ERR_ADDON_PROTECTED":"Não é possível desinstalar o Addon, ele está protegido","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Algo deu errado - a autenticação pode ter falhado","ERR_NOT_COLLECTION_URL":"Não é uma URL de coleção","ERR_NOT_ADDON_URL":"Não é uma URL de Addon válida","ERR_DETECTFROMURL":"Não foi possível encontrar um Addon/coleção para essa URL","ADDON_DUPLICATE_WARNING":"Aviso: Addon duplicado","ADDON_COLLECTION_SET_FAILED":"Falha ao sincronizar seus Addons instalados com sua conta","SETTINGS_DATA_EXPORT":"Exportar dados","ADDON_PULL_FAILED":"Falha ao sincronizar Addons instalados de sua conta","REFRESH_ON_CLICK":"Clique para tentar novamente","STILL_IN_THEATER":"Filme ainda em exibição","WATCH_IN_CINEMA":"Assista no cinema mais próximo","IN_THEATER":"No cinema","GET_TICKETS":"Obter ingressos","UPCOMING_EPISODE":"Próximo episódio","UPCOMING_EPISODE_MESSAGE":"Esse episódio irá ao ar em","MISSING_DATE_EPISODE":"Sem data do episódio","MISSING_DATE_EPISODE_MESSAGE":"Esse episódio pode não ter ido ao ar ainda","CHANNEL_NOT_SCRAPED":"Este canal ainda não foi extraído.
Por favor, retorne em alguns minutos.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Adicione à sua biblioteca para receber notificações quando estiver disponível.","GET_NOTIFIED_WHEN_AVAILABLE":"Você será notificado quando estiver disponível.","WARNING_STREAMING_SERVER":"Atenção: servidor local de transmissão não encontrado. Transmissões de arquivos locais, YouTube e BitTorrent não estarão disponíveis.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Aviso: este vídeo pode não ser suportado pelo seu hardware. Tenha em mente que a reprodução pode ser lenta.","PLAYER_ERROR":"Oops, ocorreu um erro no reprodutor de mídia","PLAYER_ERROR_LOOKSLIKE":"Parece que","PLAYER_ORIENTATION":"Orientação do reprodutor de mídia","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Travado","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Reprodutor de mídia travado para o modo paisagem","PLAYER_ORIENTATION_SENSOR":"Reprodutor de mídia automático (sensor)","PLAYER_PLAYBACK_SPEED":"Velocidade de reprodução","PLAYER_PLAYBACK_ERROR":"Erro de reprodução, tente novamente","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Erro desconhecido","PLAYER_PLAYBACK_ERROR_DEFAULT":"Desculpe, esse vídeo não poder ser reproduzido por {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Ao vivo","PLAYER_NEXT_VIDEO_TITLE":"A seguir","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dispensar","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Assistir agora","STREAMING_FROM":"Transmitindo de","CASTING_TO":"Transmitindo para","NETWORK_STATUS":"Estado da rede","STREAM_SPEED":"Velocidade da transmissão:","STREAM_BUFFERED":"Carregado:","PEERS_INFO":"Informações dos Pares","PEERS_ACTIVE":"Ativo:","PEERS_CONNECTED":"Conectado:","PEERS_WAITING":"Aguardando:","TRANSCODING_WARNING":"Atenção: transcodificando vídeo.","STREAM_LOADING":"Carregando...","PLAYING_LOCAL":"Reproduzir de um arquivo local","PLAYING_CACHE":"Reproduzir a partir do cache","WRONG_SUBS":"Legendas erradas?","ERR_SUBS_LOADING_TITLE":"Erro ao carregar a legenda","ERR_SUBS_LOADING":"Falha ao carregar as legendas: Isso pode ser um problema com seu Addon ou sua conexão de rede","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Os seguintes Addons de legenda falharam","ERR_CASTING_UPDATE_TITLE":"Não foi possível atualizar as informações do dispositivo de transmissão: o servidor de transmissão pode estar offline","CHOOSE_DEVICE":"Escolha um dispositivo para assistir","NO_CAST_DEVICES":"Sem dispositivos de transmissão disponíveis.","NO_SETTINGS":"Configurações não disponíveis.","PHONE_TABLET":"Smartphone / Tablet","SUBTITLES":"Legendas","SUBTITLES_CHANGE":"Modificar legendas para ","SUBTITLES_CHANGE_NONE":"Não há outra legenda para este idioma, desculpe.","SUBTITLES_CHANGE_ACIVE":"A legenda #{{subtitlesDialog.activeIdx + 1}} está ativada. Clique \\"Continuar\\" para ativar a legenda #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativamente,","SUBTITLES_ADJUST_DELAY":"Ajustar atraso da legenda:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Ou use as teclas G / H durante a reprodução para ajustar.","SUBTITLES_ADJUST_DELAY_TIP":"DICA: Você pode usar as teclas G / H durante a reprodução para ajustar.","SUBTITLES_DELAY":"Atraso das legendas:","SUBTITLES_LOADING":"Carregando legendas...","SUBTITLES_UNAVAILABLE":"Legendas externas não disponíveis","SUBTITLES_DISABLED":"Desativado","AUDIO":"Áudio","DEFAULT_LANGUAGE":"Idioma Padrão","DEFAULT_SECONDARY_LANGUAGE":"Idioma Padrão Secundário","SEASON":"Temporada","EPISODE":"Episódio","SPECIAL":"Especial","SORT":"ordenar","SORT_BY":"Ordenar por","FILTER":"Filtrar","SORT_TRENDING":"Em alta","SORT_RECENT":"Recente","SORT_ALPHABET":"a-z","SORT_RATING":"Classificação","SORT_WATCHED":"Assistido","SORT_YEAR":"Ano","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Novo para Você","New Episodes":"Novos Episódios","New Videos":"Novos Vídeos","Recommendations":"Recomendações","LIBRARY_RESUME":"Retomar","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detalhes","LIBRARY_RESUME_DISMISS":"Dispensar","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Destaque","DISCOVER_TOP":"Topo","DISCOVER_OSCAR":"Vencedores do Oscar","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"Este Addon não possui conteúdo.","DISCOVER_ADULT_WARNING":"Este conteúdo está disponível apenas para maiores de idade. Você tem mais de 18 anos?","DISCOVER_NOADDON_WARNING":"Atenção: nenhum Addon do Stremio ativa para este tipo. Mostrando itens salvos, nada aqui será atualizado.","DISCOVER_LOAD_ERR":"O conteúdo não foi carregado, ocorreu um erro.","DISCOVER_ADDON_UNINSTALLED":"Este conteúdo não está mais disponível, você deve ter desinstalado o Addon.","UNINSTALL_THIS_ADDON":"Remover este Addon","ERR_ADDON_NOT_INSTALLED":"Este Addon não está instalado. Instalar agora?","DETAIL_RECEIVE_NOTIF_SERIES":"Receber notificações de novos episódios","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receber notificações de novos vídeos","SIDEBAR_SHOW_STREAMS":"Exibir Streams","RELAUNCH":"Reinicie agora!","UPGRADE":"Nova versão disponível! Atualize para a versão mais recente do Stremio","RELOAD_UI":"Recarregar a interface do usuário","MANUAL_UPDATE_TITLE":"Atualize sua versão do Stremio","MANUAL_UPDATE_LINE1":"Você está executando uma versão desatualizada do Stremio, o que é altamente não recomendado.","MANUAL_UPDATE_LINE2":"Por favor, atualize o mais rápido possível.","BUTTON_UPDATE_LATTER":"Agora não","BUTTON_UPDATE_NOW":"Atualizar","ANONYMOUS_USER":"Usuário anônimo","DONT_HAVE_ACC":"Não possui uma conta?","HAVE_ACC":"Já possui uma conta?","PASSWORD":"Senha","PASSWORD_CONFIRM":"Confirmar senha","EMAIL":"E-mail","FB_LOGIN":"Conectar-se via Facebook","FB_NOTHINGSHARED":"Nada é compartilhado sem sua permissão","FB_NOPOST":"Não iremos postar nada em seu nome","OR":"ou","I_ACCEPT":"Eu aceito os","I_ACCEPT_BY_CLICKING":"Ao clicar no botão acima, comprovo que aceito o ","TOS":"Termos e Condições","MUST_ACCEPT_TERMS":"Você deve aceitar os termos","PASSWORDS_NOMATCH":"As senhas não coincidem","SIGN_UP":"Cadastrar","SIGN_UP_EMAIL":"Registre-se com email","CLICK_TO_SIGN_UP":"Clique aqui para se registrar","LOG_IN":"Conectar","LOG_OUT":"Desconectar","EXIT_FULLSCREEN":"Sair do modo de tela cheia","ENTER_FULLSCREEN":"Entrar em modo de tela cheia","PLAY_URL_MAGNET_LINK":"Reproduzir URL/Link Magnético","HELP_FEEDBACK":"Ajuda & Feedback","TERMS_OF_SERVICE":"Termos de serviço","PRIVACY_POLICY":"Política de Privacidade","ABOUT_STREMIO":"Sobre o Stremio","USER_PANEL":"Painel de Usuário","LOGIN_LABEL":"Login","GUEST_LOGIN":"Entrar como convidado","GUEST_LOGIN_NOTICE":"Entrar como convidado não é recomendado. Usar um conta padrão permite que o Stremio sincronize sua Biblioteca, receba notificações de séries/canais favoritos. Você tem certeza que deseja prosseguir?","GUEST_LOGIN_NOTICE_2":"Entrar como convidado não é recomendado - você não terá uma Biblioteca sincronizada e um Painel de notificações, que são características vitais do Stremio. Você tem certeza que deseja prosseguir?","CLICK_HERE":"clique aqui","WRONG_PASSWORD":"E-mail ou senha errada. Caso tenha esquecido sua senha, ","SET_A_PASS":"Defina uma senha","RESET_PASSWORD":"Redefinir a senha","FORGOT_PASSWORD":"Esqueceu a senha?","EMAIL_USED_WITH_FB":"Este e-mail foi utilizado com uma conta do Facebook.","INVALID_EMAIL":"Por favor, informe um e-mail válido","INVALID_PASSWORD":"Por favor, informe a senha correta","CONN_ERR":"Erro de conexão - por favor, tente novamente mais tarde.\\n\\nSe isso persistir, desabilite firewalls/antivírus (principalmente o Bitdefender).","IMPORT_FROM_GUEST":"Importar biblioteca da sua conta de convidado","RECEIVE_UPDATES_EMAIL":"Receber atualizações do Stremio no seu e-mail","LOGIN_FAILED":"Login falhou.","SIGNUP_FAILED":"Cadastro falhou.","SEARCH_FAILED":"Busca falhou","EMAIL_USED":"Este e-mail já está em uso.","WAITING_FB_LOGIN":"Entrando com a conta do Facebook...","EXTERNAL_PLAYER_TITLE":"Abrir com um reprodutor de vídeo externo","EXTERNAL_REMEMBER_PLAYER":"Você quer lembrar da sua escolha?","EXTERNAL_ALWAYS_PLAY":"Sim","EXTERNAL_ONLY_ONCE":"Não","BEST_FIT":"Melhor ajuste","FIT_SCREEN":"Tela de ajuste","FILL":"Preencher","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Conte-nos do que gosta","INTRO_TASTE_LONG":"Conte-nos o que gostaria de assistir","INTRO_TASTE_PICK":"Escolha {{interestsRemaining}} interesses","INTRO_TASTE_PICK_MORE":"Escolha {{interestsRemaining}} mais interesses","INTRO_TASTE_HELP_US":"Ajude-nos a saber mais sobre você.","INTRO_TASTE_CHOOSE_THESE":"Escolha alguns destes:","INTRO_TASTE_CHOOSE_MIN":"Escolha ao menos 3 categorias","INTRO_TASTE_CHOOSE_MIN_ERR":"Você precisa escolher ao menos 3 categorias!","INTRO_TASTE_LIFESTYLE":"Estilo de vida","INTRO_TASTE_SPORTS":"Esporte","INTRO_TASTE_FOOD_HEALTH":"Gastronomia e Saúde","INTRO_TASTE_BEAUTY_FASHION":"Moda e Beleza","INTRO_TASTE_NEWS":"Notícias","INTRO_TASTE_GAMING":"Jogos","INTRO_TASTE_SCIENCE_EDU":"Ciência e Educação","INTRO_TASTE_MUSIC":"Música","INTRO_TASTE_TRAVEL":"Viagens","INTRO_TASTE_LATE_NIGHT":"Programas noturnos","INTRO_TASTE_REALITY":"Realidade","INTRO_TASTE_COMEDY":"Comédia","INTRO_TASTE_DIY":"Faça você mesmo","INTRO_TASTE_TECH":"Tecnologia","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"O Addon selecionado não é suportada nesta plataforma.","ADDON_DISCLAIMER":"Usando um Addon de terceiros você estará se auto responsabilizando de acordo com as leis do governo de sua região.","ADDON_ACTIVATE":"Deseja ativar este Addon?","ADDON_REPO_ADD":"Endereço do repositório do Addon","ADDON_ADD":"Adicionar","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"O que há de novo","BUTTON_CONTINUE":"Continuar","BUTTON_ACTIVATE":"Ativar","BUTTON_ACTIVATED":"Ativado","BUTTON_CANCEL":"Cancelar","BUTTON_SUBMIT":"Enviar","BUTTON_DISMISS_ALL":"Dispensar tudo","BUTTON_VIEW_ALL":"ver tudo","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Sua biblioteca parece vazia. Descubra como ela é útil :) ","HOW_START":"Aqui está como você pode começar:","LIB_EMPTY_CAL":"Seu calendário mostra as séries na sua Biblioteca.","HOW_START_CAL":"Aqui está como você pode adicionar séries:","LIB_EMPTY_BOARD":"O Painel mostra notificações & recomendações relacionadas à sua Biblioteca.","HOW_START_BOARD_WAIT":"Por favor, adicione algumas séries ou canais à sua Biblioteca e nos dê um momento para processá-las :)","HOW_START_BOARD":"Aqui está como você pode adicionar séries & filmes nele:","IMPORT_FB":"Importe coisas que você gosta do Facebook","IMPORT_TRAKT":"Importe sua biblioteca de mídia do Trakt","IMPORT_DISCOVER":"Encontre coisas interessantes no Descubra","IMPORT_DISK":"Importe filmes ou shows que você tem no seu disco local","PLEASE_CREATE_ACC":"Por favor, crie uma conta para ativar a sincronização de Biblioteca & Painel.","IMPORT_DISCOVER_SIGNUP":"Registre-se e encontre coisas interessantes no Descubra","IMPORT_DISK_SIGNUP":"Cadastre-se e importe filmes ou shows que você tem em seu disco local","LIB_EMPTY_CLOUD":"Biblioteca na nuvem","LIB_EMPTY_CLOUD_DESC":"Biblioteca pessoal na nuvem sincronizada em todos os dispositivos","LIB_EMPTY_EARLY":"Madrugador","LIB_EMPTY_EARLY_DESC":"Receber notificações de novos episódios","LIB_EMPTY_PERSONAL":"Pessoal","LIB_EMPTY_PERSONAL_DESC":"Receber recomendações pessoais","LIB_EMPTY_CALENDAR_DESC":"Agende no seu calendário pessoal para assistir","LIB_EMPTY_ALL":"Registre-se para obter tudo isto:","LIB_EMPTY_BEST":"Cadastre-se para ter o melhor do Stremio","LIB_EMPTY_OTHER":"Registre-se para habilitar o calendário e outras funções fantásticas","CALENDAR_ADDED":"O calendário Stremio foi adicionado ao seu calendário padrão.","CALENDAR_ADDED_MSG":"Se isso não funcionar, por favor, adicione este endereço no seu calendário manualmente","TRAKT_EXPIRED":"A autenticação do Trakt expirou, vá até as Configurações e autentique novamente.","TRAKT_REQUIRES_LOGIN":"Erro no serviço Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Você precisa fazer login","SETTINGS_LABEL":"Configurações","SETTINGS_NAV_GENERAL":"Geral","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Atalhos","SETTINGS_SHORTCUT_RELOAD_APP":"Recarregar Aplicativo","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Abrir Configurações","SETTINGS_SHORTCUT_SWITCH_TABS":"Alternar Guias","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Percorrer as guias para a frente","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Percorrer abas para trás","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Sair / Voltar","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Alternar para o modo tela cheia","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Mostrar controles","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Aumentar o volume","SETTINGS_SHORTCUT_VOLUME_DOWN":"Abaixar o volume","SETTINGS_SHORTCUT_SEEK_NEXT":"Procurar próximo","SETTINGS_SHORTCUT_SEEK_PREV":"Procurar anterior","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Reproduzir próximo","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Aumentar o tamanho das legendas","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Diminuir o tamanho das legendas","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Aumentar o atraso das legendas","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Diminuir o atraso das legendas","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Alternar barra lateral","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Iniciar com o sistema","SETTINGS_VLC_DEFAULT":"Reproduzir no VLC","SETTINGS_UI_LANGUAGE":"Idioma da interface","SETTINGS_FULLSCREEN_EXIT":"Aperte ESC para sair da tela cheia","SETTINGS_GAMEPAD":"Ativar suporte a gamepad","SETTINGS_CLOSE_WINDOW":"Fechar aplicativo quando a janela for fechada","SETTINGS_SUBTITLES_LANGUAGE":"Idioma padrão de legendas","SETTINGS_SUBTITLES_SIZE":"Tamanho padrão de legendas","SETTINGS_SUBTITLES_BACKGROUND":"Fundo das legendas","SETTINGS_SUBTITLES_COLOR":"Cor das legendas","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Cor de contorno das legendas","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Cor de fundo das legendas","SETTINGS_SEEK_KEY":"As teclas de seta procuram o tempo","SETTINGS_SEEK_KEY_SHIFT":"As teclas de seta procuram o tempo quando a tecla Shift é pressionada","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Reproduzir automaticamente o próximo episódio","SETTINGS_NEXT_VIDEO":"Mostrar notificação para iniciar o próximo episódio.","SETTINGS_NEXT_VIDEO_TRIGGER":"Mostrar uma notificação ao iniciar o próximo episódio para:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Redimensionar automaticamente a janela antes de reproduzir","SETTINGS_OVERRIDE_SERVER":"Substituir a URL do servidor de streaming (avançado)","SETTINGS_SERVER_URL":"URL do servidor de Streaming: ","SETTINGS_SERVER_AVAILABLE":"O servidor de Streaming está disponível.","SETTINGS_SERVER_UNAVAILABLE":"O servidor de Streaming não está disponível.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Sempre usar a versão Beta mais recente","SETTINGS_IMPORT_FB":"Importar do Facebook","SETTINGS_IMPORT_DISK":"Importar do disco local","SETTINGS_IMPORT_TRAKT":"Importar do Trakt","SETTINGS_PAUSE_MINIMIZED":"Pausar reprodução quando minimizado","SETTINGS_HWDEC":"Decodificação acelerada por Hardware","SETTINGS_BACKGROUND":"Reprodução em segundo plano","SETTINGS_SUBSCRIBE_CALENDAR":"Inscrever-se no calendário","SETTINGS_REQ_EXPORT":"Exportar dados","SETTINGS_ACC_DELETE":"Solicitar exclusão de conta","SETTINGS_CHANGE_PASSWORD":"Alterar a senha","SETTINGS_TOS":"Termos de serviço","SETTINGS_SUPPORT":"Contate o suporte","SETTING_LANGUAGE":"Idioma","SETTINGS_TRAKT":"Recomendações do Trakt","SETTINGS_TRAKT_LOGOUT":"Sair do Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Escaneie o código QR para abrir remotamente","SETTINGS_DESKTOP_NOTIFICATIONS":"Notificações da área de trabalho","SETTINGS_DATA_SAVER":"Economizador de Dados","SETTINGS_LANGUAGE_INTERFACE":"Interface","SETTINGS_LANGUAGE_SUBS":"Legenda padrão","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Seleção automática de trilha de áudio","SETTINGS_DEFAULT_AUDIO_TRACK":"Trilha de áudio padrão","SETTINGS_ACCOUNT":"Conta","SETTINGS_VERSION":"Versão","SETTINGS_MPV_WINDOW":"Executar em uma janela separada (avançado)","SETTINGS_PLAY_IN_EXTERNAL":"Sempre iniciar vídeo em player externo","SETTINGS_STORAGE_BUTTON":"Limpar armazenamento local","SETTINGS_STORAGE_MODAL_TITLE":"Você tem certeza?","SETTINGS_STORAGE_MODAL_MESSAGE":"Isso limpará o armazenamento local e terminar a sua sessão.","SETTINGS_HWDEC_PICKER":"Escolha a configuração de decodificação acelerada por hardware","SETTINGS_HW_AUTOMATIC":"Automático","SETTINGS_HW_DISABLED":"Desativado","SETTINGS_HW_ACCELERATED":"Aceleração de decodificação","SETTINGS_HW_FULL":"Aceleração total","SETTINGS_HW_LEGACY":"Legado","SUBSPICKER_AUDIO":"Áudio","SUBSPICKER_SUBTITLES":"Addons de Legendas","SUBSPICKER_BLACK_BACKGROUND":"Usar cor de fundo preta","SUBSPICKER_VERTICAL_OFFSET":"Deslocamento Vertical","SUBSPICKER_SIZE":"Tamanho","SUBSPICKER_DELAY":"Atraso","SUBSPICKER_EMBEDDED_SUBS":"Legendas Embutidas","MOBILE_PRIVACY_POLICY":"Política de Privacidade","MOBILE_CRASH_REPORTING":"Relatório de falhas","MOBILE_ZOOM_TO_FILL":"Zoom para preencher a tela","MOBILE_PASSTHROUGH":"Saída de áudio digital (passthrough)","MOBILE_RUN_LOW_BATTERY":"Executar com bateria fraca","MOBILE_RUN_FOREGROUND":"Executar como serviço em primeiro plano","MOBILE_PERFORMANCE":"DESEMPENHO E ESTABILIDADE","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expira em ","MOBILE_LOG_INTO":"Faça login na sua conta Stremio ","MOBILE_SCAN_QR":"Escaneie o código QR acima ou acesse ","MOBILE_LINK_ACCOUNT":"Vincular conta","MOBILE_SPEEDPICKER_CANCEL":"Cancelar","MOBILE_SPEEDPICKER_LABEL":"Selecione a velocidade de reprodução","MOBILE_EMPTY_LIBRARY":"Sua biblioteca está vazia","MOBILE_NO_ADDON_ACTIVE":"Nenhum Addon Stremio ativo para este tipo.","MOBILE_ORGANIZER_WARNING":"O aplicativo Stremio Organizer oferece funcionalidade limitada. Para obter uma lista de streams reproduzíveis e a experiência completa do Stremio, use o Stremio no desktop.","MOBILE_ADDON_LOADING":"ainda está carregando","MOBILE_ADDONS_LOADING":"os Addons ainda estão carregando","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure seu Addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configurar Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"O aplicativo Stremio Organizer oferece funcionalidade limitada. Para obter uma lista de streams reproduzíveis e a experiência completa do Stremio, use o Stremio no desktop.","MOBILE_DISCONNECT":"Desconectar","MOBILE_LOOKING_FOR_DEVICES":"Procurando dispositivos...","MOBILE_CAST_TO":"Transmitir para","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"Concordo em receber comunicações de marketing do Stremio","QUIT":"Sair","CONNECTED":"Conectado","AUTHENTICATE":"Autenticar","CACHING":"Em Cache","SETTINGS_CACHING_DRIVE":"Selecione o drive para cache","ENABLE_LOCAL_FILES_ADDON":"Habilite o Addon de arquivos locais (requer reinicialização)","LOCAL_ADDON_NOT_ENABLED":"O Addon local não está ativado. Clique aqui para ir para as configurações e habilitá-lo","ENABLE_REMOTE_HTTPS_CONN":"Habilitar conexões HTTPS remotas","TORRENT_PROFILE":"Perfil de Torrent","DATA_CACHING":"Dados em cache","MAGNET_PARSING":"Analisando o link magnético","January":"Janeiro","February":"Fevereiro","March":"Março","April":"Abril","May":"Maio","June":"Junho","July":"Julho","August":"Agosto","September":"Setembro","October":"Outubro","November":"Novembro","December":"Dezembro","Monday":"Segunda","Tuesday":"Terça","Wednesday":"Quarta","Thursday":"Quinta","Friday":"Sexta","Saturday":"Sábado","Sunday":"Domingo","Action":"Ação","Comedy":"Comédia","War":"Guerra","Family":"Família","Animation":"Animação","Adventure":"Aventura","Fantasy":"Fantasia","Crime":"Policial","Mystery":"Mistério","Romance":"Romance","Drama":"Drama","Horror":"Terror","Thriller":"Suspense","Sci-Fi":"Ficção Científica","Music":"Música","Biography":"Biografia","Documentary":"Documentário","Sport":"Esporte","Musical":"Musical","Western":"Faroeste","Film-Noir":"Film-Noir","News":"Notícias","History":"História","Game-Show":"Show de Jogos","Reality-TV":"Show Real","Talk-Show":"Programa de Entrevista","Film & Entertainment":"Filmes e Entretenimento","Gaming":"Jogos","From TV":"Da TV","Lifestyle":"Estilo de Vida","Science & Education":"Ciência e Educação","Cooking & Health":"Culinária e Saúde","Beauty & Fashion":"Beleza e Moda","Sports":"Esportes","News & Politics":"Notícias e Política","How-to & DIY":"Faça Você Mesmo","Tech":"Tecnologia","Automotive":"Automotivo","Causes & Non-Profits":"Causas Humanitárias","Movies":"Filmes","Uk Live Tv":"TV Inglesa","Fashion":"Moda","Business News Radio":"Rádio de Negócios","Business Tv":"Negócios","Cars & Auto":"Carros","Comedy Radio":"Rádio de Comédia","Lifestyle Radio":"Rádio de Estilo de Vida","News Tv":"Noticiário","Food And Wine":"Comes e Bebes","Latino Tv":"TV Latina","Shopping Tv":"Compras","Religion":"Religião","Kids":"Infantil","Body & Soul":"Corpo e Alma","Education":"Educação","Indian Tv":"TV Indiana","Extreme Sports":"Esportes Extremos","Middle Eastern Tv":"TV do Oriente Médio","Celebrity Tv":"Celebridades","Science Tv":"Ciência","Bikini babe":"Biquíni","Outdoors":"Externas","German Tv":"TV Alemã","French Tv":"TV Francesa","Italian Tv":"TV Italiana","Gamer Tv":"TV Gamer","Travel":"Viagens","Asian Tv":"TV Asiática","Entertainment":"Entretenimento","News Radio":"Rádio de Notícias","Music Radio":"Rádio de Música","Language Learning":"Aprendendo Idiomas","Science Radio":"Rádio de Ciência","Tech Radio":"Rádio de Tecnologia","Science & Technology Vod":"Ciência e Tecnologia Video Sob Demanda","new video":"Novo video","new episode":"Novo episódio","new movie":"Filme novo","recommended":"Recomendado","we recommend":"Nós recomendamos","offer of the day":"Oferta do dia","news":"Notícias","music video":"video de música","CTX_SHOW_HOTKEYS":"Mostrar teclas de atalho","CTX_DISMISS_NOTIF":"Dispensar notificações","CTX_DISMISS_ALL":"Dispensar tudo","CTX_SHARE":"Compartilhar","CTX_COPY_SHARE_LINK":"Copiar link compartilhado","CTX_COPY_MAGNET_LINK":"Copiar link magnético","CTX_COPY_STREAM_LINK":"Copiar link da stream","CTX_DOWNLOAD_VIDEO":"Baixar esse vídeo","CTX_DOWNLOAD_SUBS":"Baixar Legendas","CTX_VIEW_ON_YOUTUBE":"Visualizar no YouTube","CTX_SHOW":"Mostrar","CTX_PLAY":"Reproduzir","CTX_PLAY_IN":"Reproduzir em","CTX_PLAY_ON":"Reproduzir em","CTX_WATCH_ON":"Assistir em","CTX_WATCH":"Assistir","CTX_WATCHED":"Assistido","CTX_WATCH_BEGINNING":"Assistir do inicio","CTX_WATCH_MOBILE":"Assistir em um aparelho móvel","CTX_REWIND":"Voltar para o início","CTX_MARK_WATCHED":"Marcar como assistido","CTX_MARK_NON_WATCHED":"Marcar como não assistido","CTX_MARK_UNWATCHED":"Marcar como não assistido","CTX_MARK_REST":"Marcar o resto como assistido","CTX_UNMARK_REST":"Marcar o resto como não assistido","CTX_RECEIVE_NEW_NOTIF":"Receber novas notificações","CTX_REMOVE_CACHE":"Remover do cache","CTX_REMOVE_CACHE_EP":"Remover episodio do cache","CTX_OPEN_CONTAINING":"Abrir pasta do arquivo","CTX_REMOVE":"Remover da biblioteca","CTX_AVAILABLE_OFFLINE":"Disponível Offline","CTX_PAUSED":"Pausado","CTX_ALWAYS_ON_TOP":"Manter em cima","CTX_FULLSCREEN":"Tela cheia","CTX_WRONG_SUBS":"Legendas incorretas?","CTX_REPORT_ISSUES":"Reportar um problema","CTX_COPY":"Copiar","CTX_PASTE":"Colar","CTX_CLEAR":"Limpar","CTX_CLEAR_RECENT_SEARCHES":"Limpar buscas recentes","HELLO_THERE":"Olá","HOPE_YOU_ENJOY":"Esperamos que aprecie o Stremio, que já é um dos seus aplicativos favoritos!","WHO_ARE_WE":"Quem somos? Somos a equipe por trás disso tudo. Dois caras que trabalham duro todos os dias nos últimos 3 anos, com o único objetivo de deixar este produto cada vez melhor","SUPPORT_US":"Se você gosta de usar o Stremio, se ele está sendo útil pra você, divulgue!","SPREAD_THE_WORD":"Compartilhe com seus amigos agora, divulgue o Stremio","MORE_PEOPLE":"Quanto mais pessoas usarem o Stremio, melhor ele vai ficar!","SEND_A_LINK":"Ou envie um link para nosso site","TIP_LOCALFILES":"Dica: você pode arrastar e soltar arquivos de vídeo diretamente no Stremio","ADDON_MY":"Meus Addons","ADDON_COMMUNITY":"Addons da comunidade","ADDON_OFFICIAL":"Addons oficiais","ADDON_REPOS":"Repositórios de Addons","ADDON_SEARCH":"Buscar Addons","ADDON_INSTALL":"Instalar","ADDON_CONFIGURE":"Configurar","ADDON_UNINSTALL":"Desinstalar","ADDON_UPGRADE":"Atualizar","ADDON_INSTALLED":"Instalado","ADDON_INSTALLED_MSG":"Addon instalado!","ADDON_UPGRADED_MSG":"Addon atualizado!","ADDON_UNKNOWN":"Desconhecido","ADDON_ERR":"Erro ao instalar o Addon!","ADDON_DISCONNECTED":"Desconectado","ADDON_APP_MISSING":"o aplicativo que suporta esta fonte não está instalado. Deseja instalar agora?","ADDON_APP_INSTALL":"Instalar agora","ADDON_PAGE":"Página de Addons","ADDON_TOP_CONTENT":"Melhor conteúdo deste Addon","ADDON_PROVIDES":"Este Addon lhe dará:","ADDON_WATCH":"Assista a #{types} agora!","ADDON_WATCH_FREE":"Assista a #{types} de GRAÇA agora!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Tipos suportados","ADDON_SUPPORTED_CATALOGS":"Catálogos suportados","ADDON_PROVIDES_DISCOVER":"Mais #{types} em Descubra","ADDON_PROVIDES_STREAMS":"Assista a #{types}","ADDON_PROVIDES_STREAMS_FREE":"Assista a #{types} de GRAÇA","ADDON_PROVIDES_SUBTITLES":"Legendas para #{types}","ADDON_CANTDETECT":"Nós não pudemos detectar se o Stremio está sendo executado, então não pudemos detectar quais Addons você tem instalado.","ERR_NO_META":"Nenhuma informação encontrada sobre isso ","ERR_GETTING_META":"Erro ao obter informação sobre isto.","ERR_CANT_PARSE_MAGNET":"Não foi possível analisar o link magnético","ERR_NO_MAGNET_INFOHASH":"Informação inválida no hash do link magnético","ERR_NO_FILE_PATH":"Impossível enviar uma requisição sem um caminho para o arquivo","ERR_NO_TORRENT":"Nenhum torrent retornado","ERR_NO_SUPPORTERD_FILES":"Nenhum arquivo suportado encontrado","ERR_OPENING_FILES":"Não foi possível abrir arquivos externos","ERR_INVALID_LINK":"Link inválido","ERR_REGISTERED_ONLY":"Esta opção está disponível apenas para usuários registrados.","ERR_CLIPBOARD":"Não é possível reproduzir da área de transferência","ERR_CLIPBOARD_READ":"Não é possível ler a área de transferência nesta plataforma","ERR_CLIPBOARD_GENERIC":"Nenhuma URL reproduzível encontrada na Área de Transferência. Por favor, copie uma URL (ex.: link magnético) para um vídeo.","BOARD_CONTINUE_WATCHING":"Continue assistindo","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmes escolhidos especialmente para você.
Este filme é uma recomendação de amostra.","BOARD_EXPLANATION_EPISODES":"Novos episódios de suas séries favoritas.
Adicione séries que você segue na sua Biblioteca.","BOARD_EXPLANATION_VIDEOS":"Novos episódios dos seus canais favoritos.
Adicione canais do YouTube que você segue na sua Biblioteca.","WEBSITE_SLOGAN_WATCH":"Assista instantaneamente","WEBSITE_SLOGAN_ALL":"Todo conteúdo em video que você adora em um único lugar","WEBSITE_SLOGAN_NEW":"Tudo o que você pode assistir","WEBSITE_SLOGAN_NEW_NEW":"Liberdade para o Stream","WEBSITE_WATCH_FROM":"Ver a partir","WEBSITE_DOWNLOAD":"Baixe agora","WEBSITE_DOWNLOAD_FOR":"Baixe agora para","WEBSITE_IS_DESKTOP":"Stremio é uma aplicação para desktop, abra esta página em seu computador e baixe","WEBSITE_DESKTOP_DEMO_VID":"Demonstração","WEBSITE_PAGE_HOME":"Inicio","WEBSITE_PAGE_FEATURES":"Funcionalidades","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Tecnologia","WEBSITE_PAGE_CREATE_ADDON":"Criar Addon","WEBSITE_PAGE_CONTACTS":"Contato","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmes","WEBSITE_TYPE_series_PL":"Séries","WEBSITE_TYPE_tv":"TV Ao vivo","WEBSITE_TYPE_channel":"Canais","WEBSITE_STREMIO_WHAT_IS":"Stremio é um aplicativo que lhe ajuda a organizar e assistir instantaneamente seus vídeos, filmes, séries de TV e canais de TV favoritos.","WEBSITE_FEATURES_WATCH":"Assista instantaneamente em HD","WEBSITE_FEATURES_WATCH_DETAIL":"Clique e assista seus filmes favoritos, Séries, vídeos e canais de TV.","WEBSITE_FEATURES_SUBS":"Legendas automáticas","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automaticamente seleciona legendas sincronizadas para o seu idioma.","WEBSITE_FEATURES_SUBS_LABEL":"Chefe, é a sua vez.","WEBSITE_FEATURES_CAST":"Exiba na TV & Celulares","WEBSITE_FEATURES_CAST_DETAIL":"Transmita para AppleTV, Chromecast, Smart TV (DLNA/UPnP) e dispositivos móveis.","WEBSITE_LIB":"Aprecie Sua Biblioteca Pessoal Sincronizada em Todos Seus Dispositivos","WEBSITE_LIB_COLLECT":"Recuperar da Stremio","WEBSITE_LIB_IMPORT":"Importe do Facebook","WEBSITE_LIB_LOCAL":"Adicione do seu dispositivo local","WEBSITE_BOARD":"Painel - Um lugar para Notificações e Recomendações","WEBSITE_BOARD_RECOMMEND":"Shows de TV Recomendados","WEBSITE_BOARD_TRENDING":"Filme em Alta","WEBSITE_BOARD_NEW":"Novo Vídeo","WEBSITE_BOARD_EPISODE":"Novo Episódio","WEBSITE_BOARD_1":"Procurando alguma coisa interessante para assistir? Obtenha recomendações baseadas no seu perfil!","WEBSITE_BOARD_2":"Seja avisado quando um novo episódio da sua série favorita ou canal do youtube sair!","WEBSITE_BOARD_YOUTUBE":"Novos videos de canais do YouTube","WEBSITE_BOARD_EPISODES":"Novos episódios de séries que você segue","WEBSITE_ADDONS":"Addons de Conteúdo","WEBSITE_TECH_DETAIL":"Nós amamos tecnologias, nós amamos ciência desruptiva!\\nA Stremio usa as seguintes tecnologias Open Source:","WEBSITE_TECH_WCJS":"WebChimera.js permite que o Stremio reproduza qualquer formato de vídeo com uma ótima qualidade.","WEBSITE_TECH_WCJS_EXTRA":"Nós somos os mantenedores do projeto","WEBSITE_TECH_ELECTRON":"Electron provê uma plataforma inovadora no qual o Stremio é construído.","WEBSITE_TECH_ELECTRON_EXTRA":"Nós somos os contribuidores do projeto","WEBSITE_TECH_LINVODB":"Uma tecnologia de Banco de Dados que garante que seus dados estarão organizados e disponíveis em qualquer lugar que você se conectar.","WEBSITE_TECH_LINVODB_EXTRA":"Tecnologia interna","WEBSITE_CREATE_ADDON":"Crie seu Addon","WEBSITE_CREATE_ADDON_DETAIL":"Você possui um serviço fornecendo conteúdo em vídeo? Nós vamos ajudar você a se beneficiar dos recursos do Stremio criando seu Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefícios de criar um Addon para o Stremio","WEBSITE_P2P_BEAUTY":"A Beleza do streaming ponto-a-ponto","WEBSITE_P2P_1":"Vídeos em Full HD / 4K sob demanda ou transmissões ao vivo confiáveis e acessíveis","WEBSITE_P2P_2":"Plataforma de distribuição providenciando uma ótima experiência ao usuário","WEBSITE_P2P_3":"Nós criaremos um Addon reunindo exatamente o que você precisa","WEBSITE_P2P_CONTACT":"Interessado? Sinta-se a vontade para entrar em contato conosco.","WEBSITE_P2P_CONTACT_EXTRA":"Será um prazer ajudar você a integrar seu conteúdo ao Stremio!","WEBSITE_P2P":"De vez em quando, aparece uma tecnologia que muda o jogo. Nós investimos muito tempo e esforço na construção do nosso mecanismo de transmissão de vídeo Peer-To-Peer (P2P) que fornece uma ótima performance e versatilidade para se adaptar a qualquer tipo de uso.\\nEntre em contato conosco para vídeos P2P sob demanda com gerenciamento de direitos autorais (DRM) habilitado ou transmissão ao vivo.","WEBSITE_THOUGHTS":"Pensamentos que compartilhamos:","WEBSITE_SPREAD":"Espalhe a palavra sobre o Stremio:","WEBSITE_CONTACT":"Contate-nos, teremos prazer em ouví-lo.","WEBSITE_OPENSOURCE":"Veja nossos projetos Open Souce em nosso ","WEBSITE_BITCOIN":"Doe Bitcoin:","WEBSITE_FAQ":"Perguntas frequentes","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Perguntas","WEBSITE_TOS":"Termos de uso","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"Sobre","WEBSITE_PAGE_BECOME_PARTNER":"Seja um parceiro","WEBSITE_ALL_YOU_CAN_WATCH":"Liberdade Para Assistir\\nTudo Que Você Deseja.","WEBSITE_FREEDOM_TO_STREAM":"Liberdade para o Stream","WEBSITE_WHAT_IS_STREMIO":"O que é Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"O Stremio é uma plataforma para agregação de conteúdo de vídeo. Descubra, organize e assista vídeos de todos os tipos de fontes em qualquer dispositivo que você possui.","WEBSITE_WHAT_IS_STREMIO_P2":"Filmes, séries, programas de TV, TV ao vivo ou canais da web como YouTube e Twitch.tv - você pode encontrar tudo isso no Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio é uma central de mídia moderna, uma solução integrada para todo seu entretenimento em vídeo. Você descobre, assiste e organiza conteúdo de vídeo a partir de Addons fáceis de instalar.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmes, shows de TV, TV ao vivo ou canais da web - encontre tudo isso no Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Desfrute em todos os seus dispositivos de mídia ","WEBSITE_DEVICES_COLLECT":"Recupere a partir do Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importe a partir do Facebook","WEBSITE_DEVICES_LOCAL":"Adicione a partir de unidade local","WEBSITE_JOIN_THE_PARTY_NOW":"Junte-se à festa agora","WEBSITE_DEVICES_ALL":"Fácil de usar em todos os seus dispositivos;","WEBSITE_EXTENDABLE_CATALOG":"Catálogo de vídeo infinitamente extensível;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Ótimas funcionalidades para organizar sua mídia;","WEBSITE_AS_SEEN_ON":"Como visto em","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Sobre nós","WEBSITE_LINK_TECHNOLOGY":"Tecnologia","WEBSITE_LINK_APPS":"Aplicativos","WEBSITE_LINK_DOWNLOADS":"Baixe","WEBSITE_MORE":"Mais","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Kit de Desenvolvimento","WEBSITE_LINK_CONTRIBUTE":"Contribuir","WEBSITE_LINK_COMMUNITY":"Comunidade","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & Mais","WEBSITE_LINK_HELP":"Central de Ajuda","WEBSITE_LINK_CONTACTS":"Inquérito de Negócios","WEBSITE_LINK_TOS":"Termos e Condições","WEBSITE_LINK_PRAVACY":"Politica de Privacidade","WEBSITE_SUBSCRIBE":"Inscreva-se","WEBSITE_NEWSLETTER":"Se increva no nosso newsletter para receber as novidades","WEBSITE_PLACEHOLDER_EMAIL":"Seu email","WEBSITE_COMMUNITY":"Comunidade","WEBSITE_LINK_PRAVACY_LEGAL":"Privacidade e Legal","WEBSITE_WHY":"Por que nós fazemos isso","WEBSITE_WHY_P1":"No Stremio, nós chegamos a trabalhar todos os dias porque queremos resolver um problema importante para o setor de vídeo sob demanda. Há tanto conteúdo novo publicado a cada minuto que é virtualmente impossível encontrar o caminho menos árduo.","WEBSITE_WHY_P2":"Ajudamos as pessoas a navegar neste mundo imenso de entretenimento de vídeo e a descobrir novos conteúdos para apreciar. Nossos aplicativos trazem consigo filmes, séries, TV ao vivo, canais da web e muito mais. Estamos focados em facilitar que nossos usuários possam encontrar facilmente títulos e canais que eles adoram. ","WEBSITE_WHY_P3":"Você pode usar nosso serviço em qualquer dispositivo e a qualquer hora, tornando o Stremio a única plataforma agregadora de entretenimento de vídeo que você precisará.","WEBSITE_TEAM":"Equipe","WEBSITE_TEAM_P":"A equipe do Stremio é pequena, mas poderosa: entre nós dez, codificamos em várias linguagens e compartilhamos experiência em desenvolvimento de software, design UI e UX, marketing e publicidade, e negócios e startups.","WEBSITE_FEATURES":"Recursos","WEBSITE_FEATURES_P1":"-","WEBSITE_FEATURES_DISCOVER":"Descubra novos conteúdos com facilidade","WEBSITE_FEATURES_DISCOVER_P":"Descubra facilmente novos filmes, séries, programas de TV e canais para assistir. Navegue por categoria, gênero, classificação, novidade, etc. ou simplesmente digite um nome para encontrar. Stremio faz achar conteúdo de vídeos ser uma moleza.","WEBSITE_FEATURES_ALL_CONTENT":"Todo seu conteúdo de vídeo em uma tela","WEBSITE_FEATURES_ALL_CONTENT_P1":"Veja quais filmes, séries ou vídeos você não terminou e continue assistindo. Seja notificado sobre novos episódios e lançamentos e navegue pelas recomendações que você obterá com base em seus hábitos de visualização","WEBSITE_FEATURES_LIBRARY":"Organize sua biblioteca de vídeos","WEBSITE_FEATURES_LIBRARY_P1":"Adicione qualquer título à sua biblioteca do Stremio com um único clique e encontre seu conteúdo, organizado por tipo, novidade ou ordem alfabética","WEBSITE_FEATURES_CALENDAR":"Acompanhe tudo o que você assiste","WEBSITE_FEATURES_CALENDAR_P1":"Visualize o calendário de todos os filmes e séries que você adiciona à sua biblioteca, e também saiba quando haverá um novo episódio ou uma estreia.","WEBSITE_FEATURES_BIG_SCREEN":"Aproveite o seu conteúdo de vídeo em uma tela maior ","WEBSITE_FEATURES_BIG_SCREEN_P1":"Projete o que você estiver assistindo para outro dispositivo - use o smartphone, tablet ou TV com um único clique","WEBSITE_FEATURES_SOURCES":"Assista o vídeo de várias fontes diferentes.","WEBSITE_FEATURES_SOURCES_P":"Instale os Addons oficiais e comunitárias para aproveitar o vídeo fornecido por vários fornecedores diferentes - tudo em um aplicativo elegante e fácil de usar.","WEBSITE_CREATE_AN_ADDON":"Crie um Addon.","WEBSITE_FEATURES_SYNC":"Sincronize sua biblioteca entre diferentes dispositivos e continue a reprodução","WEBSITE_FEATURES_SYNC_P1":"Entre com sua conta em todos os seus dispositivos e aproveite sua biblioteca, Addons, reprodução e calendário sincronizados.","WEBSITE_FEATURES_EXTENDABLE":"Catálogo de vídeo extensível por Addons","WEBSITE_FEATURES_EXTENDABLE_P1":"O catálogo de Addons do Stremio fornece vários Addons para instalar e assistir a uma variedade de conteúdos de vídeo. Isso inclui filmes, programas, TV ao vivo, esportes, notícias, podcasts, canais da web, videogames e muito mais.","WEBSITE_FEATURES_AUTO_SUBS":"Legendas automáticas","WEBSITE_FEATURES_AUTO_SUBS_P1":"Com nossos Addons para legenda, você obtém automaticamente as opções selecionadas para o seu idioma preferido.","WEBSITE_FEATURES_CHROMECAST":"Transmitir para Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Desfrute do conteúdo do vídeo em uma tela maior ou apenas transmita o que estiver assistindo para outro dispositivo.","WEBSITE_FEATURES_KEEP_TRACK":"Acompanhe seus programas de TV e canais da Web favoritos ","WEBSITE_FEATURES_KEEP_TRACK_P1":"Obtenha uma visualização do calendário e notificações para novos episódios de suas séries e canais da web favoritos.","WEBSITE_FEATURES_POWER_USER":"Recursos avançados para usuários","WEBSITE_FEATURES_POWER_USER_P1":"Reproduzir em um reprodutor externo","WEBSITE_FEATURES_POWER_USER_P2":"Reproduzir de um arquivo torrent ou link magnético","WEBSITE_FEATURES_POWER_USER_P3":"Importe para sua biblioteca do Facebook likes ou disco local","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"Todo o conteúdo de vídeo que o Stremio proporciona é proveniente de um sistema de Addons - nenhum fornecedor de conteúdo ou conteúdo foi incorporado no aplicativo.","WEBSITE_ADD_ONS_P2":"Existem dois grupos de Addons disponíveis: oficial e comunitária.","WEBSITE_ADD_ONS_P3":"As oficiais são desenvolvidas e hospedadas pela Stremio, enquanto os Addons comunitárias são criadas pelos membros de nossa comunidade, que também os hospedam.","WEBSITE_ADDONS_OFFICIAL":"Addons oficiais","WEBSITE_ADDONS_WATCHUB":"Transmite seus filmes, séries e shows favoritos de provedores como iTunes, Hulu, Amazon e outros serviços do Reino Unido / EUA.","WEBSITE_ADDONS_YOUTUBE":"Assista seus canais favoritos do YouTube livre de anúncios e receba notificações de novos vídeos dos canais que você segue.","WEBSITE_ADDONS_FILMON":"Assista TV ao vivo, filmes e canais interativos gratuitamente. 600 canais de TV, 45.000 filmes gratuitos, documentários e muito mais.","WEBSITE_ADDONS_OPENSUBTITLES":"Legendas de filmes e TV em vários idiomas. Milhares de legendas traduzidas e carregadas todos os dias.","WEBSITE_ADDONS_COMMUNITY":"Addons da comunidade","WEBSITE_ADDONS_FILMON_VOD":"Assista a vídeos sob demanda do Filmon.tv","WEBSITE_ADDONS_TWICH":"Assista transmissões ao vivo do Twitch.tv - a plataforma de streaming de vídeo para a indústria de e-sports.","WEBSITE_ADDONS_VODO":"Assista filmes independentes totalmente grátis.","WEBSITE_ADDONS_NETFLIX":"Assista filmes e séries da Netflix.","WEBSITE_ADDONS_CREATE":"Crie um Addon.","WEBSITE_ADDONS_CREATE_P1":"Se desejar, você pode desenvolver sua próprio Addon. Desta forma, você pode proporcianar a você e a nossa comunidade acesso a novos conteúdos de vídeo, e alcançar um novo público-alvo de milhões de usuários em todo o mundo.","WEBSITE_ADDONS_START_CREATE":"Para iniciar, visite a página do Kit de Desenvolvimento de Addons da Stremio:","WEBSITE_DOWNLOADS":"Baixar","WEBSITE_DOWNLOADS_P1":"Para um desempenho ideal, recomendamos que você use a versão mais recente disponível das aplicações Stremio. Se por algum motivo, no entanto, você prefira usar uma versão mais antiga, você pode baixá-la aqui.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio para Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio para MacOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio para Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio para Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio para Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio para Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio para Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio para iOS (versão limitada)","WEBSITE_CONTRIBUTE":"Colabore","WEBSITE_CONTRIBUTE_P1":"A plataforma Stremio é de código aberto e você pode criar facilmente um Addon para o conteúdo que atualmente não é fornecido.","WEBSITE_CONTRIBUTE_WHY":"Por que você deve criar um Addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Alcance novo público para o conteúdo do seu vídeo","WEBSITE_CONTRIBUTE_WHY_P2":"A base de usuários do Stremio está crescendo rapidamente - no primeiro ano de lançamento, o Stremio ganhou 1 milhão de usuários em todo o mundo e, no segundo ano de existência da plataforma, esse número cresceu para 2,5 milhões.","WEBSITE_CONTRIBUTE_WHY_P3":"Com a seu Addon, você pode alcançar facilmente esta audiência e distribuir o seu conteúdo em vídeo para eles.","WEBSITE_CONTRIBUTE_ALL":"Assista seus filmes, séries, vídeos e canais favoritos em um único lugar.","WEBSITE_CONTRIBUTE_ALL_P1":"Você é fã de um tipo de conteúdo que ainda não está disponível no Stremio? Crie um Addon para isso, e aprecie assistir seus vídeos favoritos em um dos maiores e mais fáceis de se usar hub de entretenimento do mercado.","WEBSITE_CONTRIBUTE_ALL_P2":"Além disso, você obterá a infinita gratidão de outros membros da comunidade Stremio com ideias semelhantes","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize seu Addon e ganhe dinheiro com a ajuda dela","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Uma vez que você desenvolve um novo Addon para o Stremio, você pode facilmente monetizá-lo através de várias maneiras diferentes. Se você está considerando isso, sinta-se à vontade para entrar em contato conosco no ","WEBSITE_CONTRIBUTE_MONETIZE_E":"Addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - nós ficaríamos felizes em lhe instruir e aconselhá-lo sobre as opções de monetização de seu Addon.","WEBSITE_CONTRIBUTE_TRANSLATE":"Torne-se um tradutor voluntário","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Se você deseja aproveitar as aplicações do Stremio em diferentes idiomas, você pode se juntar à nossa comunidade de tradutores voluntários. Eles nos ajudam a adicionar versões do Stremio em vários idiomas diferentes.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Você está ansioso para começar?","WEBSITE_TRANSALTE_STREMIO":"Traduza o Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Comunidades oficiais","WEBSITE_COMMUNITY_OFFICIALS_P1":"Torne-se parte da crescente comunidade Stremio. Siga-nos nas redes sociais e não se sinta intimidado em nos dizer um \\"Olá\\" - amamos saber de nossos fãs!","WEBSITE_COMMUNITY_UNOFFICIALS":"Comunidades Não Officiais","STREMIO_COMMUNITY_NL":"Stremio Nova Zelândia","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Alemanha","STREMIO_COMMUNITY_BELGIUM":"Stremio Bélgica","STREMIO_COMMUNITY_FRANCE":"Stremio França","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Itália","STREMIO_COMMUNITY_UK":"Stremio Reino Unido","STREMIO_COMMUNITY_USA":"Stremio EUA","STREMIO_COMMUNITY_MEXICO":"Stremio México","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Apoiadores e parceiros","WEBSITE_COMMUNITY_GOODIES":"Brindes Stremio","WEBSITE_COMMUNITY_WALLPAPERS":"Papéis de Parede","WEBSITE_COMMUNITY_ART":"Galeria de Arte Comunitária","WEBSITE_LINK_ART":"Galeria de arte comunitária","WEBSITE_CONTACT_US":"Fale conosco","WEBSITE_CONTACT_US_P1":"Caso tenha dúvidas, comentários ou sugestões, sinta-se à vontade para entrar em contato conosco através do formulário abaixo.","WEBSITE_CONTACT_US_P2":"Lembre-se de que estamos localizados na Bulgária, por isso, pode haver uma demora no atendimento da sua consulta devido às diferenças de fuso horário.","WEBSITE_CONTACT_US_SUCCESS":"Sua mensagem foi enviada. Nós entraremos em contato com você o mais breve possível.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Por favor, digite um e-mail válido!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Com o que sua pergunta está relacionada?","WEBSITE_CONTACT_US_Q_OS":"Qual o seu sistema operacional?","WEBSITE_CONTACT_US_PH_EMAIL":"Seu email","WEBSITE_CONTACT_US_PH_MESSAGE":"Mensagem","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ENVIAR","WEBSITE_CONTACT_US_Q_1":"Como instalar?","WEBSITE_CONTACT_US_Q_2":"Como desinstalar?","WEBSITE_CONTACT_US_Q_3":"(HTML) Como fazer lasanha?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"MacOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Tecnologia","WEBSITE_TECHNOLOGY_P1":"Nós amamos tecnologia e ciência maluca. Aqui estão os poderes do Stremio (tudo em código aberto).","WEBSITE_TECHNOLOGY_P_QT":"Desenvolvimento de software multiplataforma em seu melhor.","WEBSITE_TECHNOLOGY_P_MPV":"Um reprodutor de mídia gratuito, de código aberto e multiplataforma.","WEBSITE_TECHNOLOGY_P_RN":"O React Native permite que você crie aplicativos mobile usando apenas JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Framework de mídia embutido no aplicativo para recursos multimídia","WEBSITE_TECHNOLOGY_P_REALM":"Realm é uma plataforma mobile e um substituto para SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js é um ambiente em tempo de execução multiplataforma e de código aberto para JavaScript.","WEBSITE_TECHNOLOGY_P_RUST":"Rust é uma linguagem de programação multi-paradigma focada em segurança, especialmente concorrência segura.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribua com o projeto","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Há duas maneiras que você pode contribuir com o Stremio e nos ajudar a tornar o produto ainda melhor.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Você pode doar suas valiosas habilidades linguísticas para traduzir a plataforma...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"ou","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"...você pode usar suas habilidades de codificação para criar Addons comunitárias.","WEBSITE_TRANSLATE_STREMIO":"Traduza o Stremio","WEBSITE_404_OH_NO":"Oops! A página que você está procurando não está aqui...","WEBSITE_GO_HOME":"Principal","WEBSITE_LINK_OTHER_DOWNLOADS":"Outros downloads","WEBSITE_FAQ_ABR":"Dúvidas Frequentes","WEBSITE_SUPPORT":"Ajuda","WEBSITE_DOWNLOAD_4_0_BETA":"Baixe agora o Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Baixe para seu PC","WEBSITE_LINK_ADDON_COMPETITION":"Competição de Addon","WEBSITE_LINK_ART_CONTEST":"Concurso de arte","WEBSITE_MY_ACCOUNT":"Minha conta","WEBSITE_MAINPAGE_FAQ_001_H1":"O que é Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"O Stremio é um moderno centro de mídia que oferece a liberdade de assistir tudo o que você deseja.","WEBSITE_MAINPAGE_FAQ_002_H1":"Como funciona?","WEBSITE_MAINPAGE_FAQ_002_P1":"Depois de instalar o Stremio no seu dispositivo e criar uma conta, tudo o que você precisa fazer é visitar o catálogo de Addons e instalar qualquer Addon que desejar, e pronto!","WEBSITE_MAINPAGE_FAQ_002_P2":"Depois disso, você pode ir para as seções Descubra ou Painel para começar a explorar o conteúdo.","WEBSITE_MAINPAGE_FAQ_003_H1":"O que posso assistir aqui?","WEBSITE_MAINPAGE_FAQ_003_P1":"Diversos filmes, programas de TV, canais da Web, esportes, canais de TV, ouvir podcasts e muito mais. Graças ao nosso sistema de Addons, você pode acessar uma variedade de conteúdos.","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio é de código aberto?","WEBSITE_MAINPAGE_FAQ_004_P1":"Sim, você pode verificar os seguintes links: ${1}aplicativo de desktop${2} e ${3}organização GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio é seguro?","WEBSITE_MAINPAGE_FAQ_005_P1":"Sim. Por ser um software de código aberto, o código é auditável publicamente e você pode revisá-lo.","WEBSITE_MAINPAGE_FAQ_006_H1":"E a minha privacidade?","WEBSITE_MAINPAGE_FAQ_006_P1":"Respeitamos a privacidade dos usuários e não coletamos dados pessoais além do mínimo essencial para criar e sincronizar sua conta.","WEBSITE_MAINPAGE_FAQ_006_P2":"Há também um ${1}modo visitante ${2}na inscrição, que não requer dados: neste modo, nenhuma chamada é feita para o nossos servidores. No entanto, isso ocorre à custa de recursos úteis, como sincronizar sua biblioteca entre dispositivos.","WEBSITE_MAINPAGE_FAQ_007_H1":"Posso transmitir para minha TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Sim, suportamos o Chromecast e você pode transmitir a partir de aplicativos para computador e dispositivos móveis (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Quantos Addons o Stremio possui?","WEBSITE_MAINPAGE_FAQ_008_P1":"No final de 2019, acima de 50 - para obter mais informações, consulte nosso catálogo de Addons.","WEBSITE_MAINPAGE_FAQ_009_H1":"O Stremio pode ser estendido além do que está no catálogo de Addons?","WEBSITE_MAINPAGE_FAQ_009_P1":"Sim, você deve checar estes: ${1}PimpMyStremio${2}, ${3}Comunidades Reddit${4}, ${5}Downloader Stremio${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"Quais dispositivos o Stremio suporta?","WEBSITE_MAINPAGE_FAQ_010_P1":"Temos aplicativos de desktop para Windows, Mac e Linux. Para dispositivos móveis, suportamos Android e iOS, embora tenha em mente que a funcionalidade do iOS é limitada (não é compatível com a maioria das Addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"Existem muitos dispositivos baseados no Android nos quais você pode executar o Stremio, como NVIDIA Shield e Amazon Fire Stick, mas não os suportamos oficialmente.","WEBSITE_MAINPAGE_FAQ_011_H1":"Você pode adicionar determinado conteúdo ao Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Desculpe, mas nós não fornecemos conteúdo, porém quanto mais Addons do Stremio você instalar, mais conteúdo você poderá encontrar.","WEBSITE_MAINPAGE_FAQ_012_H1":"O Stremio pode reproduzir links magnéticos?","WEBSITE_MAINPAGE_FAQ_012_P1":"Sim, e também pode reproduzir links HTTP normais e arquivos torrent (arrastar e soltar).","WEBSITE_MAINPAGE_FAQ_013_H1":"Posso baixar um vídeo e assistir offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"O modo offline estará disponível futuramente, porém se você permitir que o Stremio faça cache no dispositivo (no painel de configurações), poderá assistir aos vídeos mais tarde, sem conexão.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nada funciona, me ajude!","WEBSITE_MAINPAGE_FAQ_014_P1":"Tem certeza de que instalou Addons? Se sim, verifique nossa ${1}central de ajuda${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Como o Stremio sustenta suas operações de desenvolvimento?","WEBSITE_MAINPAGE_FAQ_015_P1":"Executamos anúncios não invasivos por meio de ${1}AdEx${2}, que é uma empresa da mesma equipe fundadora que se concentra na preservação da privacidade e em anúncios transparentes.","WEBSITE_MAINPAGE_FAQ_015_P2":"Para mais dúvidas, visite nossa ${1}central de ajuda${2}.","HELP_LEARN_MORE":"Ajude-nos a aprender mais sobre você.","LIFESTYLE":"Estilo de vida","SPORTS":"Esportes","FOOD_HEALTH":"Gastronomia e Saúde","BEAUTY_FASHION":"Moda e Beleza","NEWS":"Notícias","GAMING":"Jogos","SCIENCE_EDUCATION":"Ciência e Educação","MUSIC":"Música","TRAVEL":"Viagens","LATE_NIGHT":"Tarde da Noite","REALITY":"Realidade","COMEDY":"Comédia","DIY":"Faça você mesmo","TECH":"Tecnologia","CINEMA":"Cinema","CONTINUE":"Continuar","SLOW_LOADING":"CARREGAMENTO LENTO?","I_GIVE_UP":"EU DESISTO","LEARN_MORE":"Saiba mais","POOR_SOURCE":"Esta fonte possui baixa disponibilidade ou a sua conexão à internet não é suficientemente rápida","PICK_CATEGORIES_ERR":"Você precisa escolher ao menos 3 categorias","ADJUST_TIMING":"Ajustar tempo com ","ADJUST_SIZE":"Ajustar tamanho com ","SEARCH_ANYTHING":"Você Pode Pesquisar Qualquer Coisa...","ALL_CATEGORIES":"Todas","SEARCH_CATEGORIES":"Filmes, Séries, YouTube & TV","SEARCH_PERSONS":"Atores, Diretores & Escritores","SEARCH_PROTOCOLS":"HTTP & Links Magnéticos","SEARCH_TYPES":"links IMDB / TVDB","WATCHED":"Visto","SHOW_LESS":"Mostrar menos","LAST_SEARCHES":"Últimas pesquisas","CLEAR_HISTORY":"Limpar histórico","CHOOSE_SOME":"ESCOLHA ALGUNS DESTES:","NO_WEB_REMOTE":"O Web Remote não pôde ser carregado","STREMIO_OFFLINE":"Stremio está offline","STREMIO_EXPENSIVE_CONNECTION":"A conexão de rede é custosa","USE_DATA":"Dados Móveis","WARNING":"Aviso","MORE_INFO":"Mais Informações ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Carregando ...","STREMIO_TV_BACK_TO_LANGUAGES":"Voltar para idiomas","STREMIO_TV_REMOTE":"Remoto","STREMIO_TV_GO_TO":"Ir Para:","STREMIO_TV_OR_SCAN":"ou buscar:","STREMIO_TV_ADDON_INSTRUCTIONS":"Por favor, siga as instruções a fim de instalar suas Addons favoritas.","STREMIO_TV_LIVE_TV":"TV Ao vivo","STREMIO_TV_RESUME_WATCHING":"Continuar assistindo","STREMIO_TV_LOADING_BACKGROUND":"Carregando Plano de Fundo","STREMIO_TV_CHECKING_AUTHENTICATION":"Checando Autenticação","STREMIO_TV_LOADING_BOARD":"Carregando Painel","STREMIO_TV_LOGIN_HEADER_LINE_1":"Queremos que nossos usuários tenham a melhor experiência personalizada possível com nosso programa.","STREMIO_TV_LOGIN_HEADER_LINE_2":"É por esta razão que nos gentilmente pedimos que faça e/ou logue em sua conta.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Obrigado por entender,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Equipe Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"A fim de usar o Web Remote com seu Smartphone / Tablet / PC:","STREMIO_TV_WIFI_SETUP":"Configurar Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle não detectou conexão com a internet.","STREMIO_TV_WIFI_DETAILS_1":"Conectar com:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Usar senha:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Abra o navegador com o link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Padrão","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Por Último Assistido","STREMIO_TV_LIBRARY_SORT_NAME":"Por Nome","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Por Vezes Assistido","STREMIO_TV_DETAILS_SEASON_NUMBER":"Temporada ${1}","STREMIO_TV_STREAMS_LOADING":"Carregando ${1} / ${2} Addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} o Addon ainda esta carregando...","STREMIO_TV_PLAYER_SETTINGS":"Configurações do player","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Atraso das legendas","STREMIO_TV_PLAYER_AUDIO_DELAY":"Atraso de áudio","STREMIO_TV_PLAYER_VIDEO_SCALING":"Dimensionamento de vídeo","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Fonte de stream não compatível","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Falha ao abrir link externo","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Tocar com ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Tocar com player libVLC","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Mudando para o player libVLC devido a um erro de reprodução","STREMIO_TV_ADDONS_TITLE":"Use o Stremio em seu telefone ou PC para instalar ou configurar Addons e pressione \\"Sincronizar Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Nota: verifique se você está usando a mesma conta Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sincronizar Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons sincronizados com sucesso","STREMIO_TV_ADDONS_SYNC_FAILED":"Falha ao sincronizar Addons","STREMIO_TV_META_LINK_FAILED":"Falha ao abrir o meta link","STREMIO_TV_CATALOG_LOADING":"Catálogo ainda carregando...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Idioma da interface atualizado","STREMIO_TV_SETTINGS_THEME_UPDATED":"Tema atualizado","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Idioma Preferido","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Idioma Secundário Preferido","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Reprodução em túnel","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possíveis problemas de reprodução em alguns dispositivos","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Alguns formatos de vídeo podem não funcionar","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Correspondência automática de taxa de quadros","STREMIO_TV_SETTINGS_NO_CACHING":"Sem cache","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Padrão","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Suave","STREMIO_TV_SETTINGS_PROFILE_FAST":"Rápido","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Rápido","STREMIO_TV_SETTINGS_SERVER_URL":"URL do servidor de streaming","STREMIO_TV_SETTINGS_SERVER_VERSION":"Versão do servidor","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Desconhecido","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Versão do Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Editar URL do servidor","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Insira um URL de servidor de streaming","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Para ler a Política de Privacidade do Stremio, visite:","STREMIO_TV_SETTINGS_TOS_TEXT":"Para ler os Termos e Condições do Stremio, visite:","STREMIO_TV_NAV_SEARCH":"Procurar","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Descobrir","STREMIO_TV_NAV_LIBRARY":"Biblioteca","STREMIO_TV_NAV_MOVIES":"Filmes","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Canais","STREMIO_TV_NAV_TV":"TV ao vivo","STREMIO_TV_NAV_SETTINGS":"Configurações","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Vincular Contas","STREMIO_TV_LOGIN_EXPIRES_IN":"Expira em","STREMIO_TV_LOGIN_STEP_ONE":"Escaneie o QR Code acima ou acesse","STREMIO_TV_LOGIN_STEP_TWO":"Faça login na sua conta Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Solicitar um novo link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Código de login atualizado","STREMIO_TV_SEARCH_PLACEHOLDER":"Digite algo","STREMIO_TV_SEARCH_NO_ADDONS":"Nenhum Addon foi solicitado para catálogos!","STREMIO_TV_SEARCH_BUTTON":"Procurar","STREMIO_TV_SEARCH_KEY_DEL":"Deletar","STREMIO_TV_SEARCH_KEY_SPACE":"Espaço","STREMIO_TV_SEARCH_KEY_CLEAR":"Limpar","STREMIO_TV_SEARCH_HISTORY_TITLE":"Histórico de pesquisa","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Você pode pesquisar por Títulos, Atores, Canais e muito mais...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Limpar histórico de pesquisa","STREMIO_TV_FILTERS_DESCRIPTION":"Escolha um dos filtros abaixo","FILTERS":"Filtros","SETTINGS":"Configurações","ACCOUNT":"Conta","LOGOUT":"Sair","THEMES":"Temas","PLAYBACK":"Reprodução","PLAYBACK_SPEED":"Velocidade de reprodução","AUDIO_TRACKS":"Faixas de áudio","VIDEOS":"Vídeos","SERVER":"Servidor","LINKS":"Links","ABOUT":"Sobre","INTERFACE":"Interface","ANIMATIONS":"Animações","STATUS":"Status","LANGUAGE":"Idioma","SIZE":"Tamanho","DELAY":"Atraso","BOLD":"Negrito","TEXT_COLOR":"Cor do texto","OUTLINE_COLOR":"Cor do contorno","BACKGROUND_COLOR":"Cor de fundo","BACKGROUND_BLUR":"Desfoque de fundo","SEEK_TIME_DURATION":"Duração do tempo de busca","AUTO_PLAY":"Reproduzir automaticamente o próximo episódio","PLAY_NOW":"Reproduzir agora","MARK_AS_WATCHED":"Marcar como assistido","MARK_AS_UNWATCHED":"Marcar como não assistido","REWIND_TO_BEGINNING":"Retornar ao início","CONTINUE_WATCHING":"Continuar assistindo","ALL":"Tudo","SECONDS":"segundos","ON":"ON","OFF":"OFF","RELOAD":"Recarregar","EDIT_URL":"Editar URL","NONE":"Nenhum","EMBEDDED":"Embutido","REMOTE_SWITCH_DEVICES":"Trocar aparelhos","REMOTE_VIDEOS":"Vídeos","REMOTE_ADJUST_TIMING":"Ajustar o tempo","REMOTE_ADJUST_SIZE":"Ajustar o tamanho","REMOTE_COULD_NOT_BE_LOADED":"Web Remote não pôde ser carregado","REMOTE_RETRY":"Tentar novamente","TORRENT_PROFILE_DEFAULT":"Padrão","TORRENT_PROFILE_SOFT":"Suave","TORRENT_PROFILE_FAST":"Rápido","TORRENT_PROFILE_ULTRA_FAST":"Ultra Rápido","FAQ_001_H1":"O que é Stremio?","FAQ_001_P1":"Stremio é um programa de midia centralizada desenhada para video entretenimento com facilidade de uso em mente. Stremio permite a você organizar & assistir sua própria coleção de vídeos, séries, canais e Tvs ao Vivo.","FAQ_001_P2":"Stremio cataloga o conteúdo e apresenta pra você de seu disco local e de nosso sistema de Addons.","FAQ_001_P3":"Também irá notificá-lo quando novos episódios/videos/filmes que você estiver interessado sair, e mostrará recomendações de filmes para você.","FAQ_02_H1":"Como Stremio se compara ao Kodi e Plex?","FAQ_02_P1":"Nós nos inspiramos nos dois programas, mas temos diferentes objetivos - Stremio é especificamente voltado para vídeo entretenimento. Batalhamos para sermos a solução padrão para isso, tendo em foco a facilidade de uso.","FAQ_02_P2":"Stremio nunca será tão customizável e com ricos recursos como Kodi e Plex, mas sendo significativamente mais fácil de usar. Simplesmente ${1} pegue isso e veja ${2} :)","FAQ_03_H1":"Como Stremio se compara ao Netflix?","FAQ_03_P1":"Novamente, Netflix é uma de nossas inspirações. Trabalharemos arduamente para atingir a experiência de uso proporcionada pelo Netflix, e mais um porção de melhorias. No entanto, o mais importante, nós estamos dando a você a liberdade de gerenciar sua própria biblioteca e adicionar novas fontes de conteúdos com o nosso sistema de Addons.","FAQ_03_P2":"Isso faz do Stremio infinitamente extensível, e então quando você usá-lo, você nunca ficará limitado ao conteúdo que o Netflix decida licenciar. Por exemplo, através do Stremio você pode assistir conteúdo de ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} e mesmo ${9}Netflix${10}!","FAQ_04_H1":"Como Stremio se compara ao Flipboard?","FAQ_04_P1":"Raramente recebemos esta questão, exceto quando falamos com pessoas iniciantes :)","FAQ_04_P2":"Stremio é desenhado como um agregador de conteúdo, ao qual essencialmente Flipboard o faz para vídeo. Isso é muito parecido em nosso painel, ao qual da a você catálogos e notificações de novos episódios/novos vídeos que você segue, tal qual Flipboard.","FAQ_05_H1":"Como Stremio se compara ao Popcorn Time?","FAQ_05_P1":"Stremio e Popcorn Time são similares em interface de uso, porque não há muitas maneiras de fazer catálogo de vídeo entretenimento, certo? :)","FAQ_05_P2":"Mas enquanto o Popcorn Time tem o foco em entrega de torrents de fontes específicas, Stremio não possui restrição e é meramente um agregador de conteúdo - não é travado em uma fonte de conteúdo específica.","FAQ_05_P3":"Além disso, nós não provemos nenhum Addon para torrent por padrão, então Stremio não cobre o caso de uso do Popcorn Time na sua funcionalidade oficial.","FAQ_05_P4":"Uma outra diferença notável é que o Popcorn Time é completamente de código aberto, enquanto Stremio é ${1} parcialmente de código aberto ${2}.","FAQ_06_H1":"Vocês que adicionam estes filmes/séries?","FAQ_06_P1":"Não, desculpe :(","FAQ_06_P2":"Como já mencionamos em muitas outras questões, Stremio não provê nenhum conteúdo por si próprio - tudo é adicionado diretamente pelo sistema de Addons. Caso queira solicitar algum conteúdo, você pode usar o botão “Reporte” no reprodutor, ao qual irá enviar um email para o autor do Addon ao qual está usando.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Vocês criarão Addons para X?","FAQ_08_P1":"Isso é inteiramente possível.","FAQ_08_P2":"Se você tem uma idéia para um Addon, escreva para ${1}office@stremio.com${2}, mas por favor, tenha certeza de que a idéia desse Addon não irá infringir nenhum direito de propriedade intelectual ou termos de uso.","FAQ_08_P3":"No momento, os próximos movimentos em nosso projeto são Addons para FandangoNOW, vídeo sob demanda no Filmon.tv e Crunchyroll.","FAQ_09_H1":"Stremio usa BitTorrent?","FAQ_09_P1":"Sim. Stremio suporta BitTorrent como um protocolo streaming. Você pode usá-lo com a Addon torrent ou por arrastar e soltar um arquivo .torrent dentro do Stremio, ou mesmo colando um link magnético dentro do campo de busca.","FAQ_09_P2":"Por favor, note que único Addon oficial que usa BitTorrent é ${1}Vodo${2}, ao qual provê produção independente, todos permitidos para serem distribuídos com BitTorrent.","FAQ_09_P3":"Nós não suportamos o uso de qualquer Addon de terceiro ao qual pode viabilizar o infringimento de leis de direitos.","FAQ_10_H1":"O que posso assistir no Stremio com as Addons oficiais?","FAQ_10_P1":"Por padrão, você pode assistir conteúdo do Filmon.tv, YouTube e Vodo dentro do Stremio com o reprodutor interno. Adicionalmente nós temos um Addon para Twitch.tv e alguns outros.","FAQ_10_P2":"Este combinado provê uma seleção de:","FAQ_10_L1":"Canais de TV populares, provido por Filmon.tv - por exemplo E4, BBC, Bollyworld TV","FAQ_10_L2":"Tudo do YouTube - por exemplo BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Filmes indepententes com Vodo","FAQ_10_L4":"Transmissão de jogos online com Twitch.tv","FAQ_10_P3":"Adicionalmente, há muitas fontes de conteúdo providas com Guidebox e Addons Netflix, ao qual não reproduzem inteiramente dentro do Stremio, mas pode redirecionar para o dado serviço. Por exemplo, o Addon Guidebox lhe dá uma seleção de filmes que você pode obter conteúdo streaming dentro dos Estados Unidos de graça de serviços como TubiTV e Crackle.","FAQ_11_H1":"Stremio não instala, o que devo fazer?","FAQ_11_P1":"Se você usa Windows, tente ${1}este instalador alternativo${2}.","FAQ_11_P2":"Pra quem usa Mac OS X, por favor esteja ciente que nós não suportamos versões inferiores a OS X Mavericks (10.9).","FAQ_11_P3":"Caso esteja usando Linux, fique avisado que nós damos suporte apenas para a versão 64 bits (x64) no momento.","FAQ_11_P4":"Se não ainda não conseguiu resolver seu problema, por favor nos mande uma mensagem no ${1}Grupo do Facebook${2}.","FAQ_12_H1":"Por que meu antivirus reclama? O Stremio é seguro?","FAQ_12_P1":"Nós lhe asseguramos que o Stremio é ${1}100% limpo${2}.","FAQ_12_P2":"Seu antivirus está reclamando porque nós incluimos propaganda em nosso instalador, e isso faz com que o Stremio seja classificado como um ad-ware.","FAQ_12_P3":"Se você não está seguro, você pode usar nosso ${1}instalador alternativo${2}.","FAQ_13_H1":"Como posso fazer um Addon?","FAQ_13_P1":"Para iniciantes, recomendados que leiam nosso ${1}módulo de sistema de Addon${2} no GitHub.","FAQ_13_P2":"Todavia, você pode seguir o ${1}Tutorial Olá Mundo${2}.","FAQ_13_P3":"Se você não tem nenhum conhecumento em programação, por favor poste sua idéia na ${1}comunidade Reddit${2} e nos contate com sua idéia de Addon no ${3}office@stremio.com${4}.","FAQ_14_H1":"Como as Addons são publicadas?","FAQ_14_P1":"Quando você cria um Addon e hospeda e coloca um campo endpoint no seu manifest, ao qual aponta para endereço de Addon ativo, o Addon irá automaticamente se auto-publicar em nosso ${1}Catálogo de Addons${2}.","FAQ_14_P2":"Isso acontece porque parte do servidor do módulo de Addon do Stremio automaticamente faz uma chamada para nossa API para publicar o Addon. Quando nossa API valida seu endpoint como um Addon válida, isso irá constar no catálogo.","FAQ_15_H1":"Eu posso executar o Stremio no navegador?","FAQ_15_P1":"No momento não, mas em breve !","FAQ_15_P2":"Se você está curioso para ver uma versão Alpha, você pode acessar aqui: ${1}alpha4.strem.io${2}. Tenha em mente que o streaming está disabilitado. Damos suporte para Chrome, Firefox, Opera e Edge.","FAQ_16_H1":"Transmissão para a TV não funciona / legendas não funcionam","FAQ_16_P1":"Transmissão para a TV usa a tecnologia DLNA que é muito inconsistente entre modelos de fabricantes diferentes. Por esta razão, nós não temos a habilidade de testar em cada caso, então estamos longe da perfeição. Estamos trabalhando em melhorar constantemente, mas nós não podemos lhe dar uma estimativa de tempo de quando a tecnologia DLNA funcionará corretamente em sua TV.","FAQ_16_P2":"Se você ainda não vê sua TV no menu de transmissão, por favor tente desabilitar sua conexão de rede e habilite novamente (no Windows, click com botão direito em Rede e click em Habilitar/Desabilitar), também reinicie seu roteador, TV e PC.","FAQ_16_P3":"Se você ainda está encontrando problemas, você pode nos ajudar enviando as informação de seu modelo de TV e fabricante para ${1}office@stremio.com${2}.","FAQ_16_P4":"Em quanto isso nós recomendamos o Chromecast, ao qual suportamos muito bem, ou simplesmente plugando sua TV no seu PC com um cabo HDMI.","FAQ_17_H1":"Stremio congela ou trava, o que posso fazer?","FAQ_17_P1":"Primeiro de tudo, se você está usando Windows 7 com o antivirus AVG: nós temos problema com essa combinação. O problema é o próprio AVG, e não há uma solução definitiva para corrigirmos isso. Infelizmente, exceções ou desabilitar o antivirus não funciona. A única maneira é trocar seu antivirus.","FAQ_17_P2":"Se isso não é o problema, mas você ainda usa Windows, por favor atualize seu o sistema incluindo os drivers da GPU, e tente novamente.","FAQ_17_P3":"Se o seu problema continua sem solução, ou utiliza Mac ou Linux, por favor nos escreva reportando em detalhes o problema em ${1}nosso grupo no Facebook${2}.","FAQ_18_H1":"Como posso fazer um Addon?","FAQ_18_P1":"Para iniciantes nós recomendamos que veja nosso ${1}módulo de sistema de Addon${2} no GitHub.","FAQ_18_P2":"No entanto, você pode seguir pelo nosso ${1}tutorial Olá Mundo!${2}.","FAQ_18_P3":"Se você não tem nenhuma habilidade em programação, por favor, poste sua idéia na ${1}comunidade do Reddit${2} e nos contate com sua idéia de Addon em ${3}office@stremio.com${4}.","FAQ_19_H1":"Por que o Stremio está ocupando espaço em disco?","FAQ_19_P1":"Stremio tem um cache local para temporariamente deixar os arquivos de vídeo descarregados.","FAQ_19_P2":"Isso tem dois benefícios: primeiro, permite ao Stremio pré carregar o vídeo para garantir uma transmissão suave. Segundo, isso deixa os vídeos no cache local para que você possa continuar assistindo off-line.","FAQ_19_P3":"Quanto o Stremio depende da configuração do Cache no painel de Configurações. Stremio pode manter uma quantidade (exemplo 2GB) no seu disco, a menos que o video descarregado seja maior que isso, no qual de have espaço suficiente para mantê-lo enquanto o descarrega.","FAQ_20_H1":"Onde está a pasta do cache?","FAQ_20_P1":"No Windows, o cache do Stremio fica no drive ao qual você selecionou nas configurações (exemplo \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"No MacOS, fica localizado em \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"No Linux, fica localizado em \\"~/.stremio/stremio-cache\\" ou \\"~/stremio-cache\\"","FAQ_21_H1":"Eu recebi a mensagem de erro \\"Servidor de streming não encontrado\\", o que posso fazer?","FAQ_21_P1":"Se você recebeu esta mensagem, isso implica em uma das possibilidades:","FAQ_21_P2":"1) Você está tentando usar um Addon suportada pelo código do YouTube/BitTorrent, através de nossa ${1}versão web${2}. Nesse caso, você deve instalar nossa versão para desktop de ${3}nosso website${4}.","FAQ_21_P3":"2) Há algo de errado com a instalação do Stremio. Neste caso, tente reinstalar nossa versão mais recente ${1}do website${2}. Se isso nao ajudar, tente desabilitar os programas de antivirus e firewal, reinicie seu PC e tente novamente. Se isso não funcionar, por favor nos contate pelo ${3}nosso grupo do Facebook${4}.","FAQ_22_H1":"Eu não posso ver/usar a maioria das Addons no iOS","FAQ_22_P1":"Devido a restrições nos termos e condições da loja da Apple, nós temos restringido somente aplicativos iOS de um grupo particular de Addons.","FAQ_22_P2":"Mas esteja avisado - haverão mais Addons para iOS no futuro, e nós poderemos também adicionar uma integração que permitirá o uso de todas Addons do Stremio graças a conexão do aplicativo iOS com o servidor de Streaming do Stremio."}')},5857:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filme","TYPE_series":"Série","TYPE_tv":"Canal de TV","TYPE_channel":"Canal","TYPE_other":"Outro","TYPE_movie_PL":"Filmes","TYPE_series_PL":"Séries","TYPE_tv_PL":"TV","TYPE_channel_PL":"YouTube","TYPE_other_PL":"Outros","TYPE_ALL":"Todos","VIDEO":"Vídeos","BACK":"Voltar","MORE":"Mais","DONE":"Concluído","COPY":"Copiar","SETTINGS_CASTING_MODE_PICKER":"Modo de casting","CASTING_MODE_HLSV2":"Predefinido","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"Sem transcodificação","Discover":"Explorar","Board":"Painel","Library":"Biblioteca","My Library":"A minha biblioteca","Calendar":"Calendário","NOTIFICATION_ONLINE":"Estás online","NOTIFICATION_OFFLINE":"Estás offline","INTERNET_CONNECTION":"Ligação à Internet","STORAGE_FULL_TITLE":"Aviso: Armazenamento cheio!","STORAGE_FULL_TEXT":"Não será possível guardar as definições ou informações de conta. Considera fechar o Stremio e voltar a abrir, caso este erro persista, poderás ter de reinstalar o Stremio.","SEARCH":"Pesquisar","SEARCH_NO_RESULTS":"Não foram encontrados resultados","SEARCH_EXPLANATION_CONTENT":"Pesquisa por filmes, séries, canais YouTube e de TV","SEARCH_EXPLANATION_PEOPLE":"Pesquisa por atores, realizadores e guionistas","SEARCH_PASTE_LINKS":"Colar links HTTP e Magnet","SEARCH_OR_PASTE_LINK":"Pesquisa ou cola o link","ADD_TO_LIB":"Adicionar à biblioteca","REMOVE_FROM_LIB":"Remover da biblioteca","ADDED_TO_LIB":"Adicionado à biblioteca","REMOVED_FROM_LIB":"Removido da biblioteca","TRAILER":"Trailer","WATCH_TRAILER":"Ver trailer","WATCH_NOW":"Ver agora","SHOW":"Mostrar","SHOW_MOVIE":"Mostrar filme","WATCH_RANDOM":"Ver aleatório","IMDB_RATING":"Classificação IMDb","YEAR":"Ano","DIRECTOR":"Realizador","WRITER":"Guionista","LEAD_ACTORS":"Elenco Principal","CAST":"Elenco","CREW":"Equipa Técnica","SHOW_MORE_CAST":"Mostrar mais »","AIRED":"Transmissão original","SEASONS":"Temporadas","GENRE":"Género","CATALOG":"Catálogo","SUMMARY":"Sinopse","SHOW_MORE":"Mostrar mais","SIMILAR":"Semelhante","UPCOMING":"Próximos","ENDED":"Finalizados","DURATION":"Duração","FEATURED":"Destaque","METADATA":"Metadados","CATEGORY":"categoria","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"pesquisar vídeos","SEARCH_PLACEHOLDER":"pesquisar ou colar link","ADDON":"Addon","ADDONS":"Addons","OFFICIAL":"oficial","ADDONS_OFFICIAL":"Addons Oficiais do Stremio","ADDONS_POPULAR":"Popular na tua área","ADDON_FREE":"gratuito","ADDON_PEERED":"partilhado","ADDON_SUBSCRIPTION":"subscrição","ADDON_STREAM_GEORESTRICTED":"indisponível no teu país","ADDON_STREAM_OFFLINECACHE":"Cache Offline","ADDON_STREAM_LOCALFILE":"Ficheiro local","SHARE_ADDON":"Partilhar addon","AVAILABLE_STREAMS":"Streams disponíveis","NO_STREAM":"Nenhuma stream disponível","ALL_ADDONS":"Todos","INSTALL_MORE_ADDONS":"Para mais streams, por favor, instala mais addons","STREAM_NOT_SUPPORTED":"A stream escolhida não é suportada nesta plataforma.","ADDON_CATALOGUE":"Mostrar todos os addons »","ADDON_CATALOGUE_MORE":"Instalar addons »","REPO_ADDED":"Repositório adicionado","ADDON_REPO_EXIST_ERR":"Esta coleção de addons já existe","ADDON_REPO_ERR":"Ocorreu um erro ao adicionar a coleção","ADDON_ADD_ERR":"Ocorreu um erro ao adicionar o addon","ERR_ADDON_PROTECTED":"Não é possível desinstalar o addon, é protegido","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Ocorreu um erro - a autenticação falhou.","ERR_NOT_COLLECTION_URL":"Não é um link de coleção","ERR_NOT_ADDON_URL":"Não é um link de addon válido","ERR_DETECTFROMURL":"Não foi possível detetar a extensão pelo link","ADDON_DUPLICATE_WARNING":"Aviso: extensão duplicada","ADDON_COLLECTION_SET_FAILED":"A sincronização dos addons instalados para a tua conta falhou","SETTINGS_DATA_EXPORT":"Exportar dados","ADDON_PULL_FAILED":"A sincronização dos addons instalados a partir da tua conta falhou","REFRESH_ON_CLICK":"Clica para tentar novamente","STILL_IN_THEATER":"Filme ainda nos cinemas","WATCH_IN_CINEMA":"Vê-o no cinema mais perto de ti","IN_THEATER":"Nos cinemas","GET_TICKETS":"Obter bilhetes","UPCOMING_EPISODE":"Próximo episódio","UPCOMING_EPISODE_MESSAGE":"Este episódio estará disponível brevemente","MISSING_DATE_EPISODE":"Data do episódio em falta","MISSING_DATE_EPISODE_MESSAGE":"Este episódio ainda não foi transmitido","CHANNEL_NOT_SCRAPED":"Este canal não está disponível.
Volta a tentar dentro de minutos.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Adiciona à biblioteca para receberes notificações quando estiver disponível.","GET_NOTIFIED_WHEN_AVAILABLE":"Serás notificado quando estiver disponível.","WARNING_STREAMING_SERVER":"Atenção: o servidor de transmissão local não foi encontrado. A transmissão através do YouTube e BitTorrent não estará disponível.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Atenção: provavelmente este vídeo não é compatível com o teu hardware. Tem em conta de que a reprodução poderá ser lenta.","PLAYER_ERROR":"Ups, ocorreu um erro na reprodução","PLAYER_ERROR_LOOKSLIKE":"Isto parece ser","PLAYER_ORIENTATION":"Orientação da reprodução","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Travado","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Reprodução travada no modo paisagem","PLAYER_ORIENTATION_SENSOR":"Reprodução automática (sensor)","PLAYER_PLAYBACK_SPEED":"Velocidade de reprodução","PLAYER_PLAYBACK_ERROR":"Erro de reprodução, tente novamente","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Erro desconhecido","PLAYER_PLAYBACK_ERROR_DEFAULT":"Pedimos desculpa, este vídeo não pode ser transmitido por {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Idioma das legendas","PLAYER_SUBTITLES_VARIANTS":"Variantes das legendas","PLAYER_SUBTITLES_SETTINGS":"Definições das legendas","PLAYER_SUBTITLES_DISABLED":"As legendas estão desativadas","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Posição vertical","PLAYER_PLAY":"Reproduzir","PLAYER_PAUSE":"Colocar em pausa","PLAYER_NEXT_VIDEO":"Próximo vídeo","PLAYER_MUTE":"Silenciar","PLAYER_UNMUTE":"Ativar som","PLAYER_LIVE":"Direto","PLAYER_NEXT_VIDEO_TITLE":"A seguir","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Fechar","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Ver agora","STREAMING_FROM":"A transmitir de","CASTING_TO":"A transmitir para","NETWORK_STATUS":"Estado da rede","STREAM_SPEED":"Velocidade de receção:","STREAM_BUFFERED":"Carregado:","PEERS_INFO":"Informação dos pares","PEERS_ACTIVE":"Ativo:","PEERS_CONNECTED":"Ligado:","PEERS_WAITING":"À espera:","TRANSCODING_WARNING":"Atenção: a transcodificar vídeo.","STREAM_LOADING":"a carregar...","PLAYING_LOCAL":"a reproduzir a partir de um ficheiro local","PLAYING_CACHE":"a reproduzir a partir da cache","WRONG_SUBS":"Legendas incorretas","ERR_SUBS_LOADING_TITLE":"Erro ao carregar as legendas","ERR_SUBS_LOADING":"Não foi possível carregar as legendas, poderá haver um erro no addon que estás a utilizar ou com a tua ligação à Internet","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Não foi possível carregar as seguintes legendas","ERR_CASTING_UPDATE_TITLE":"Não foi possível atualizar as informações do dispositivo de transmissão: o servidor de transmissão pode estar offline","CHOOSE_DEVICE":"Escolhe um dispositivo para transmitir","NO_CAST_DEVICES":"Sem dispositivos de transmissão disponíveis.","NO_SETTINGS":"Não há definições disponíveis.","PHONE_TABLET":"Telemóvel / Tablet","SUBTITLES":"Legendas","SUBTITLES_CHANGE":"Alterar legendas para ","SUBTITLES_CHANGE_NONE":"Desculpa, mas não existe mais legendas para este idioma","SUBTITLES_CHANGE_ACIVE":"As legendas #{{subtitlesDialog.activeIdx + 1}} estão ativas. clica \\"Continuar\\" para ativar as legendas #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativamente,","SUBTITLES_ADJUST_DELAY":"Ajusta o atraso das legendas:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Ou utiliza as teclas G / H para ajustar os tempos.","SUBTITLES_ADJUST_DELAY_TIP":"Dica: Podes utilizar as teclas G / H durante a reprodução para ajustar.","SUBTITLES_DELAY":"Atraso de legendas:","SUBTITLES_LOADING":"A carregar as legendas...","SUBTITLES_UNAVAILABLE":"Não há legendas externas disponíveis","SUBTITLES_DISABLED":"Desativado","AUDIO":"Áudio","DEFAULT_LANGUAGE":"Idioma predefinido","DEFAULT_SECONDARY_LANGUAGE":"Idioma secundário predefinido","SEASON":"Temporada","EPISODE":"Episódio","SPECIAL":"Especiais","SORT":"Ordenar","SORT_BY":"Ordenar por","FILTER":"Filtro","SORT_TRENDING":"tendência","SORT_RECENT":"Recentes","SORT_ALPHABET":"A-Z","SORT_RATING":"classificação","SORT_WATCHED":"vistos","SORT_YEAR":"Ano","SELECT_TYPE":"Selecionar tipo","SELECT_SORT":"Selecionar ordem","SELECT_CATALOG":"Selecionar catálogo","SELECT_GENRE":"Selecionar género","SORT_LASTWATCHED":"Por últimos vistos","SORT_NAME":"Pelo nome","SORT_TIMESWATCHED":"Por vezes vistas","New for You":"Novo para ti","New Episodes":"Novos episódios","New Videos":"Novos vídeos","Recommendations":"Recomendações","LIBRARY_RESUME":"Retomar","LIBRARY_PLAY":"Reproduzir","LIBRARY_DETAILS":"Detalhes","LIBRARY_RESUME_DISMISS":"Fechar","LIBRARY_CLEAR_PROGRESS":"Limpar progresso","LIBRARY_REMOVE":"Remover","DISCOVER_FEATURED":"Em destaque","DISCOVER_TOP":"Popular","DISCOVER_OSCAR":"Vencedores de Óscares","DISCOVER_WARNING_TITLE":"Ups!","DISCOVER_EMPTY_CATALOG":"Este addon não possui conteúdo.","DISCOVER_ADULT_WARNING":"Este conteúdo é apenas para adultos. Tens mais de 18 anos?","DISCOVER_NOADDON_WARNING":"Atenção: nenhum addon do Stremio ativo para este tipo. Ao exibir ficheiros guardados, nada será atualizado.","DISCOVER_LOAD_ERR":"Ocorreu um erro e não foi possível carregar o conteúdo.","DISCOVER_ADDON_UNINSTALLED":"Este conteúdo já não está disponível, poderás ter de reinstalar o addon.","UNINSTALL_THIS_ADDON":"Desinstalar este addon","ERR_ADDON_NOT_INSTALLED":"Este addon não está instalado. Instalar agora?","DETAIL_RECEIVE_NOTIF_SERIES":"Receber notificações para novos episódios.","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receber notificações para novos vídeos.","SIDEBAR_SHOW_STREAMS":"Mostrar Streams","RELAUNCH":"Reiniciar agora!","UPGRADE":"Está disponível uma nova versão! Atualiza para a versão mais recente do Stremio","RELOAD_UI":"Recarregar interface","MANUAL_UPDATE_TITLE":"Atualiza para uma versão do Stremio mais recente.","MANUAL_UPDATE_LINE1":"Estás a utilizar uma versão do Stremio que se encontra desatualizada, é recomendável que atualizes para a versão mais recente.","MANUAL_UPDATE_LINE2":"Atualiza assim que for possível.","BUTTON_UPDATE_LATTER":"Agora não","BUTTON_UPDATE_NOW":"Atualizar","ANONYMOUS_USER":"Utilizador anónimo","DONT_HAVE_ACC":"Não tens uma conta?","HAVE_ACC":"Já tens conta?","PASSWORD":"Palavra-passe","PASSWORD_CONFIRM":"Confirmar palavra-passe","EMAIL":"E-mail","FB_LOGIN":"Iniciar sessão com o Facebook","FB_NOTHINGSHARED":"Nada é partilhado sem a tua permissão","FB_NOPOST":"Não publicaremos nada na tua cronologia","OR":"ou","I_ACCEPT":"Aceito os","I_ACCEPT_BY_CLICKING":"Ao clicar no botão acima certifico-me de que aceito os ","TOS":"Termos e Condições","MUST_ACCEPT_TERMS":"Devez aceitar os termos e condições","PASSWORDS_NOMATCH":"As palavras-passe não coincidem","SIGN_UP":"Registar","SIGN_UP_EMAIL":"Regista-te com um e-mail","CLICK_TO_SIGN_UP":"Clica aqui para registares uma nova conta.","LOG_IN":"Iniciar sessão","LOG_OUT":"Terminar sessão","EXIT_FULLSCREEN":"Sair do modo de ecrã inteiro","ENTER_FULLSCREEN":"Abrir em modo de ecrã inteiro","PLAY_URL_MAGNET_LINK":"Abrir URL/Magnet link","HELP_FEEDBACK":"Ajuda e Opinião","TERMS_OF_SERVICE":"Termos de Utilização","PRIVACY_POLICY":"Política de Privacidade","ABOUT_STREMIO":"Sobre o Stremio","USER_PANEL":"Painel do utilizador","LOGIN_LABEL":"Iniciar sessão","GUEST_LOGIN":"Iniciar sessão como convidado","GUEST_LOGIN_NOTICE":"Não é recomendado que inicies sessão como convidado. Autentica-te para que o Stremio sincronize a tua biblioteca e te mostre notificações das tuas séries/canais. Tens a certeza de que queres continuar?","GUEST_LOGIN_NOTICE_2":"Não é recomendado que inicies sessão como convidado - não vai ter acesso à tua biblioteca e às notificações do painel, sendo estas funções vitais do Stremio. Tens a certeza de que queres continuar?","CLICK_HERE":"Clica aqui","WRONG_PASSWORD":"Palavra-passe incorreta. Caso te tenhas esquecido da tua palavra-passe, ","SET_A_PASS":"Introduz uma nova palavra-passe","RESET_PASSWORD":"Redefinir palavra-passe","FORGOT_PASSWORD":"Esqueceste-te da tua palavra-passe?","EMAIL_USED_WITH_FB":"Este e-mail foi utilizado com uma sessão do Facebook.","INVALID_EMAIL":"Introduzir um e-mail válido","INVALID_PASSWORD":"Introduzir uma palavra-passe válida","CONN_ERR":"Erro de ligação - Por favor, tenta novamente mais tarde.\\n\\nSe o problema persistir, desativa ou configura a tua firewall e/ou o teu anti-vírus (principalmente o Bitdefender).","IMPORT_FROM_GUEST":"Importar biblioteca a partir da conta de convidado","RECEIVE_UPDATES_EMAIL":"Receber notificações por e-mail do Stremio","LOGIN_FAILED":"A autenticação falhou.","SIGNUP_FAILED":"Ocorreu um erro ao criar a tua conta.","SEARCH_FAILED":"A pesquisa falhou","EMAIL_USED":"Este e-mail já está a ser utilizado.","WAITING_FB_LOGIN":"Iniciar sessão com o Facebook...","EXTERNAL_PLAYER_TITLE":"Abrir com um reprodutor de vídeo externo","EXTERNAL_REMEMBER_PLAYER":"Relembrar a tua escolha?","EXTERNAL_ALWAYS_PLAY":"Sim","EXTERNAL_ONLY_ONCE":"Não","BEST_FIT":"Melhor ajuste","FIT_SCREEN":"Ajustar ao ecrã","FILL":"Ajustar","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Diz-nos do que gostas","INTRO_TASTE_LONG":"Conta-nos sobre o que gostas de ver","INTRO_TASTE_PICK":"Seleciona {{interestsRemaining}} dos teus interesses","INTRO_TASTE_PICK_MORE":"Seleciona mais {{interestsRemaining}} dos teus interesses","INTRO_TASTE_HELP_US":"Ajuda-nos a saber mais sobre ti.","INTRO_TASTE_CHOOSE_THESE":"Escolhe alguns destes:","INTRO_TASTE_CHOOSE_MIN":"Escolhe pelo menos 3 categorias","INTRO_TASTE_CHOOSE_MIN_ERR":"Tens de escolher pelo menos 3 categorias!","INTRO_TASTE_LIFESTYLE":"Estilo de vida","INTRO_TASTE_SPORTS":"Desporto","INTRO_TASTE_FOOD_HEALTH":"Gastronomia e Saúde","INTRO_TASTE_BEAUTY_FASHION":"Moda e Beleza","INTRO_TASTE_NEWS":"Notícias","INTRO_TASTE_GAMING":"Videojogos","INTRO_TASTE_SCIENCE_EDU":"Ciência e Educação","INTRO_TASTE_MUSIC":"Música","INTRO_TASTE_TRAVEL":"Viagens","INTRO_TASTE_LATE_NIGHT":"Late Night Shows","INTRO_TASTE_REALITY":"Realidade","INTRO_TASTE_COMEDY":"Comédia","INTRO_TASTE_DIY":"Faz tu mesmo","INTRO_TASTE_TECH":"Tecnologia","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"O addon selecionado não é suportado nesta plataforma.","ADDON_DISCLAIMER":"Ao utilizar um addon de terceiros estarás sujeito à sua responsabilidade e às leis do governo onde está localizado.","ADDON_ACTIVATE":"Ativar este addon?","ADDON_REPO_ADD":"URL do repositório do addon","ADDON_ADD":"Adicionar","ADD_ADDON":"Adicionar addon","ADD_ADDON_DESCRIPTION":"Podes adicionar um addon através de um link externo, que aparecerá nos Addons instalados.","PASTE_ADDON_URL":"Cola o URL do addon","WHATS_NEW":"O que há de novo","BUTTON_CONTINUE":"Continuar","BUTTON_ACTIVATE":"Ativar","BUTTON_ACTIVATED":"Ativo","BUTTON_CANCEL":"Cancelar","BUTTON_SUBMIT":"Submeter","BUTTON_DISMISS_ALL":"Fechar tudo","BUTTON_VIEW_ALL":"Ver tudo","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"A tua biblioteca está vazia. Descobre o quão útil pode ser :) ","HOW_START":"Aqui está como podes começar:","LIB_EMPTY_CAL":"O teu calendário mostra as séries da biblioteca.","HOW_START_CAL":"Aqui está como podes adicionar uma série:","LIB_EMPTY_BOARD":"O painel mostra notificações e recomendações relacionadas com a tua biblioteca.","HOW_START_BOARD_WAIT":"Por favor, adiciona algumas séries ou canais à tua biblioteca e dá-nos uns instantes para as processar :)","HOW_START_BOARD":"Aqui está como podes adicionar séries e filmes:","IMPORT_FB":"Importa coisas de que gostas no Facebook","IMPORT_TRAKT":"Importa a tua biblioteca do Trakt","IMPORT_DISCOVER":"Encontra coisas interessantes em Explorar","IMPORT_DISK":"Importa filmes ou programas que tenhas no disco local","PLEASE_CREATE_ACC":"Por favor, cria uma conta para ativar a sincronização da biblioteca e do painel.","IMPORT_DISCOVER_SIGNUP":"Regista-te e encontra coisas interessantes em Explorar","IMPORT_DISK_SIGNUP":"Regista-te e importa filmes ou programas que tenhas no disco local","LIB_EMPTY_CLOUD":"Biblioteca na nuvem","LIB_EMPTY_CLOUD_DESC":"A biblioteca pessoal na nuvem sincroniza todos os teus dispositivos","LIB_EMPTY_EARLY":"Chegaste demasiado cedo","LIB_EMPTY_EARLY_DESC":"Receber notificações quando existirem episódios disponíveis","LIB_EMPTY_PERSONAL":"Privado","LIB_EMPTY_PERSONAL_DESC":"Receber recomendações pessoais","LIB_EMPTY_CALENDAR_DESC":"Agenda no teu calendário pessoal de visualização","LIB_EMPTY_ALL":"Inicia sessão para obteres tudo isto:","LIB_EMPTY_BEST":"Inicia sessão para obteres o melhor do Stremio","LIB_EMPTY_OTHER":"Inicia sessão para ativares o calendário e outras funcionalidades incríveis","CALENDAR_ADDED":"O calendário do Stremio foi adicionado ao calendário do teu computador.","CALENDAR_ADDED_MSG":"Se isto não funcionar, adiciona manualmente este link ao calendário","TRAKT_EXPIRED":"A autenticação do Trakt falhou, vai às definições e tenta novamente.","TRAKT_REQUIRES_LOGIN":"Erro ao iniciar sessão.","TRAKT_REQUIRES_LOGIN_MSG":"Precisas de iniciar sessão para avançar.","SETTINGS_LABEL":"Definições","SETTINGS_NAV_GENERAL":"Geral","SETTINGS_NAV_PLAYER":"Reprodutor","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Atalhos","SETTINGS_SHORTCUT_RELOAD_APP":"Recarregar app","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Abrir definições","SETTINGS_SHORTCUT_SWITCH_TABS":"Alternar separadores","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Avançar no ciclo de separadores","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Voltar atrás no ciclo de separadores","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navega entre menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Ir para a pesquisa","SETTINGS_SHORTCUT_EXIT_BACK":"Sair / Voltar atrás","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Alternar menu de velocidade de reprodução","SETTINGS_SHORTCUT_MENU_VIDEOS":"Alternar menu de vídeos","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Alternar menu das legendas","SETTINGS_SHORTCUT_MENU_INFO":"Alternar menu das informações","SETTINGS_SHORTCUT_FULLSCREEN":"Entrar / Sair do modo de ecrã inteiro","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Mostrar controlos","SETTINGS_SHORTCUT_PLAY_PAUSE":"Reproduzir / Colocar em pausa","SETTINGS_SHORTCUT_VOLUME_UP":"Aumentar o volume","SETTINGS_SHORTCUT_VOLUME_DOWN":"Diminuir o volume","SETTINGS_SHORTCUT_SEEK_NEXT":"Avançar na reprodução","SETTINGS_SHORTCUT_SEEK_PREV":"Recuar na reprodução","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Reproduzir próximo","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Aumentar o tamanho das legendas","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Diminuir o tamanho das legendas","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Aumentar o atraso das legendas","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Diminuir o atraso das legendas","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Mostrar / Ocultar barra lateral","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Autenticar","SETTINGS_FACEBOOK_IMPORT":"Importar","SETTINGS_CALENDAR_SUBSCRIBE":"Subscrever","SETTINGS_INTERFACE_LANGUAGE":"Idioma da interface","SETTINGS_LAUNCH_STARTUP":"Iniciar com o sistema","SETTINGS_VLC_DEFAULT":"Reproduzir com o VLC","SETTINGS_UI_LANGUAGE":"Idioma","SETTINGS_FULLSCREEN_EXIT":"Clica em ESC para sair do ecrã inteiro","SETTINGS_GAMEPAD":"Ativar o suporte de gamepad","SETTINGS_CLOSE_WINDOW":"Fechar o Stremio quando fechar a janela","SETTINGS_SUBTITLES_LANGUAGE":"Idioma predefinido das legendas","SETTINGS_SUBTITLES_SIZE":"Tamanho predefinido das legendas","SETTINGS_SUBTITLES_BACKGROUND":"Fundo das legendas","SETTINGS_SUBTITLES_COLOR":"Cor das legendas","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Cor de contorno das legendas","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Cor de fundo das legendas","SETTINGS_SEEK_KEY":"As teclas de seta avançam / retrocedem no tempo","SETTINGS_SEEK_KEY_SHIFT":"As teclas de seta avançam / retrocedem no tempo quando a tecla Shift é pressionada","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Reproduzir o próximo episódio automaticamente","SETTINGS_NEXT_VIDEO":"Mostrar uma notificação ao iniciar o próximo episódio.","SETTINGS_NEXT_VIDEO_TRIGGER":"Mostrar uma notificação ao iniciar o próximo episódio para:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Redimensionar automaticamente a janela antes de reproduzir","SETTINGS_OVERRIDE_SERVER":"Substituir o URL do servidor de streaming (avançado)","SETTINGS_SERVER_URL":"URL do servidor de Streaming: ","SETTINGS_SERVER_AVAILABLE":"O servidor de streaming está disponível.","SETTINGS_SERVER_UNAVAILABLE":"O servidor de Streaming não está disponível.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Utilizar sempre a última versão Beta","SETTINGS_IMPORT_FB":"Importar do Facebook","SETTINGS_IMPORT_DISK":"Importar do disco local","SETTINGS_IMPORT_TRAKT":"Importar do Trakt","SETTINGS_PAUSE_MINIMIZED":"Colocar a reprodução em pausa quando minimizado","SETTINGS_HWDEC":"Transcodificação acelerada por hardware","SETTINGS_BACKGROUND":"Reprodução em segundo plano","SETTINGS_SUBSCRIBE_CALENDAR":"Subscrever calendário","SETTINGS_REQ_EXPORT":"Exportar dados","SETTINGS_ACC_DELETE":"Pedir para eliminar conta","SETTINGS_CHANGE_PASSWORD":"Alterar palavra-passe","SETTINGS_TOS":"Termos do serviço","SETTINGS_SUPPORT":"Contactar o suporte","SETTING_LANGUAGE":"Idioma","SETTINGS_TRAKT":"Recomendações do Trakt","SETTINGS_TRAKT_LOGOUT":"Terminar sessão do Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Lê o código QR para abrir remotamente","SETTINGS_DESKTOP_NOTIFICATIONS":"Notificações no computador","SETTINGS_DATA_SAVER":"Economizador de Dados","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"Legendas predefinidas","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Selecionar automaticamente o ficheiro de áudio","SETTINGS_DEFAULT_AUDIO_TRACK":"Ficheiro de áudio predefinido","SETTINGS_ACCOUNT":"Conta","SETTINGS_VERSION":"versão","SETTINGS_MPV_WINDOW":"Abrir reprodutor numa janela em separado (avançado)","SETTINGS_PLAY_IN_EXTERNAL":"Abrir sempre num reprodutor externo","SETTINGS_STORAGE_BUTTON":"Limpar armanezamento local","SETTINGS_STORAGE_MODAL_TITLE":"Tens a certeza?","SETTINGS_STORAGE_MODAL_MESSAGE":"Esta ação fará com que o armazenamento seja limpo e termine a tua sessão.","SETTINGS_HWDEC_PICKER":"Escolhe a configuração de decodificação acelerada por hardware","SETTINGS_HW_AUTOMATIC":"Automático","SETTINGS_HW_DISABLED":"Desativado","SETTINGS_HW_ACCELERATED":"Aceleração de decodificação","SETTINGS_HW_FULL":"Aceleração total","SETTINGS_HW_LEGACY":"Legado","SUBSPICKER_AUDIO":"Áudio","SUBSPICKER_SUBTITLES":"Legendas de Addons","SUBSPICKER_BLACK_BACKGROUND":"Utilizar cor de fundo preta","SUBSPICKER_VERTICAL_OFFSET":"Compensação vertical","SUBSPICKER_SIZE":"Tamanho","SUBSPICKER_DELAY":"Atraso","SUBSPICKER_EMBEDDED_SUBS":"Legendas embutidas","MOBILE_PRIVACY_POLICY":"Política de Privacidade","MOBILE_CRASH_REPORTING":"Relatório de avarias","MOBILE_ZOOM_TO_FILL":"Zoom para preencher o ecrã","MOBILE_PASSTHROUGH":"Saída de áudio digital (passthrough)","MOBILE_RUN_LOW_BATTERY":"Executar com a bateria fraca","MOBILE_RUN_FOREGROUND":"Executar como serviço de primeiro plano","MOBILE_PERFORMANCE":"DESEMPENHO E ESTABILIDADE","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"O código QR expira em ","MOBILE_LOG_INTO":"Inicia sessão na tua conta Stremio ","MOBILE_SCAN_QR":"Lê o código QR acima ou vai para ","MOBILE_LINK_ACCOUNT":"Ligar conta","MOBILE_SPEEDPICKER_CANCEL":"Cancelar","MOBILE_SPEEDPICKER_LABEL":"Selecionar velocidade de reprodução","MOBILE_EMPTY_LIBRARY":"A tua biblioteca está vazia","MOBILE_NO_ADDON_ACTIVE":"Nenhum addon do Stremio ativo para este tipo.","MOBILE_ORGANIZER_WARNING":"A app Stremio Organizer dá-te apenas acesso a funcionalidades limitadas. Para uma lista de streams reproduzíveis e para teres a experiência Stremio completa, utiliza o Stremio no desktop.","MOBILE_ADDON_LOADING":"ainda está a carregar","MOBILE_ADDONS_LOADING":"os addons ainda estão a carregar","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configura o teu addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configurar addon","MOBILE_ORGANIZER_ADDONS_WARNING":"A app Stremio Organizer dá-te apenas acesso a uma seleção limitada de addons. Para teres a experiência Stremio completa, utiliza o Stremio no desktop.","MOBILE_DISCONNECT":"Desconectar","MOBILE_LOOKING_FOR_DEVICES":"À procura de dispositivos...","MOBILE_CAST_TO":"Transmitir para","NAVIGATION_ON":"Ligado","NAVIGATION_OFF":"Desligado","MARKETING_AGREE":"Concordo em receber comunicações de marketing do Stremio","QUIT":"Sair","CONNECTED":"Ligado","AUTHENTICATE":"Autenticado","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Seleciona a unidade para cache","ENABLE_LOCAL_FILES_ADDON":"Ativa o addon de ficheiros locais (requer reinicialização)","LOCAL_ADDON_NOT_ENABLED":"O addon local não está ativado. Clica aqui para o ir ativar às definições","ENABLE_REMOTE_HTTPS_CONN":"Ativar conexões HTTPS remotas","TORRENT_PROFILE":"Perfis de torrents","DATA_CACHING":"Caching de dados","MAGNET_PARSING":"A analisar o magnet link","January":"janeiro","February":"fevereiro","March":"março","April":"abril","May":"maio","June":"junho","July":"julho","August":"agosto","September":"setembro","October":"outubro","November":"novembro","December":"dezembro","Monday":"segunda-feira","Tuesday":"terça-feira","Wednesday":"quarta-feira","Thursday":"quinta-feira","Friday":"sexta-feira","Saturday":"sábado","Sunday":"domingo","Action":"Ação","Comedy":"Comédia","War":"Guerra","Family":"Família","Animation":"Animação","Adventure":"Aventura","Fantasy":"Fantasia","Crime":"Crime","Mystery":"Mistério","Romance":"Romance","Drama":"Drama","Horror":"Terror","Thriller":"Suspense","Sci-Fi":"Ficção Científica","Music":"Música","Biography":"Biografia","Documentary":"Documentário","Sport":"Desporto","Musical":"Musical","Western":"Faroeste","Film-Noir":"Filme negro","News":"Atualidade","History":"História","Game-Show":"Concursos","Reality-TV":"Reality Shows","Talk-Show":"Talk-Show","Film & Entertainment":"Filmes e Entretenimento","Gaming":"Videojogos","From TV":"Da TV","Lifestyle":"Estilo de vida","Science & Education":"Ciência e Educação","Cooking & Health":"Culinária e Saúde","Beauty & Fashion":"Beleza e Moda","Sports":"Desporto","News & Politics":"Notícias e Política","How-to & DIY":"Faz por ti mesmo","Tech":"Tecnologia","Automotive":"Automobilismo","Causes & Non-Profits":"Causas e Ações sem fins lucrativos","Movies":"Filmes","Uk Live Tv":"Reino Unido","Fashion":"Moda","Business News Radio":"Negócios (Rádio)","Business Tv":"Negócios","Cars & Auto":"Automobilismo","Comedy Radio":"Comédia (Rádio)","Lifestyle Radio":"Estilo de vida (Rádio)","News Tv":"Notícias","Food And Wine":"Gastronomia e Vinicultura","Latino Tv":"Latino","Shopping Tv":"Compras","Religion":"Religião","Kids":"Crianças","Body & Soul":"Corpo e Alma","Education":"Educação","Indian Tv":"Índia","Extreme Sports":"Desportos Radicais","Middle Eastern Tv":"Médio Oriente","Celebrity Tv":"Celebridades","Science Tv":"Ciência","Bikini babe":"Biquíni","Outdoors":"Ar livre","German Tv":"Alemanha","French Tv":"França","Italian Tv":"Itália","Gamer Tv":"Videojogos","Travel":"Viagens","Asian Tv":"Ásia","Entertainment":"Entretenimento","News Radio":"Notícias (Rádio)","Music Radio":"Música (Rádio)","Language Learning":"Aprender idiomas","Science Radio":"Ciência (Rádio)","Tech Radio":"Tecnologia (Rádio)","Science & Technology Vod":"Ciências e Tecnologias (VOD)","new video":"novo vídeo","new episode":"novo episódio","new movie":"novo filme","recommended":"recomendado","we recommend":"recomendamos","offer of the day":"oferta do dia","news":"notícias","music video":"musicais","CTX_SHOW_HOTKEYS":"Mostrar teclas de acesso rápido","CTX_DISMISS_NOTIF":"Descartar notificação","CTX_DISMISS_ALL":"Descartar todas","CTX_SHARE":"Partilhar","CTX_COPY_SHARE_LINK":"Copiar link de partilha","CTX_COPY_MAGNET_LINK":"Copiar o magnet link","CTX_COPY_STREAM_LINK":"Copiar link de transmissão","CTX_DOWNLOAD_VIDEO":"Transferir este vídeo","CTX_DOWNLOAD_SUBS":"Transferir as legendas","CTX_VIEW_ON_YOUTUBE":"Ver no YouTube","CTX_SHOW":"Mostrar","CTX_PLAY":"Reproduzir","CTX_PLAY_IN":"Reproduzir em","CTX_PLAY_ON":"Reproduzir no","CTX_WATCH_ON":"Ver em","CTX_WATCH":"Ver","CTX_WATCHED":"Visto","CTX_WATCH_BEGINNING":"Ver do início","CTX_WATCH_MOBILE":"Ver num dispositivo móvel","CTX_REWIND":"Retroceder para o início","CTX_MARK_WATCHED":"Marcar como visto","CTX_MARK_NON_WATCHED":"Marcar como não visto","CTX_MARK_UNWATCHED":"Marcar como não visto","CTX_MARK_REST":"Marcar o resto como visto.","CTX_UNMARK_REST":"Marcar o resto como não visto.","CTX_RECEIVE_NEW_NOTIF":"Receber novas notificações","CTX_REMOVE_CACHE":"Remover da cache","CTX_REMOVE_CACHE_EP":"Remover episódio da cache","CTX_OPEN_CONTAINING":"Abrir pasta com o conteúdo","CTX_REMOVE":"Remover da biblioteca","CTX_AVAILABLE_OFFLINE":"Disponível offline","CTX_PAUSED":"Em pausa","CTX_ALWAYS_ON_TOP":"Sempre visível","CTX_FULLSCREEN":"Ecrã inteiro","CTX_WRONG_SUBS":"Legendas incorretas?","CTX_REPORT_ISSUES":"Reportar problema","CTX_COPY":"Copiar","CTX_PASTE":"Colar","CTX_CLEAR":"Limpar","CTX_CLEAR_RECENT_SEARCHES":"Limpar pesquisas recentes","HELLO_THERE":"Olá!","HOPE_YOU_ENJOY":"Esperamos que gostes do Stremio e que seja uma das tuas aplicações favoritas!","WHO_ARE_WE":"Quem somos? Somos a equipa por detrás do projeto - dois rapazes que trabalham arduamente todos os dias durante os últimos 3 anos para melhorar cada vez mais este produto.","SUPPORT_US":"Se gostas de utilizar o Stremio e se o mesmo é importante para ti - divulga-o!","SPREAD_THE_WORD":"Partilha com os teus amigos, divulga-o","MORE_PEOPLE":"Quanto mais pessoas utilizarem o Stremio, melhor se tornará!","SEND_A_LINK":"Ou envia um link para o nosso site","TIP_LOCALFILES":"Dica: podes arrastar e largar os teus vídeos no Stremio","ADDON_MY":"Os meus addons","ADDON_COMMUNITY":"Addons da comunidade","ADDON_OFFICIAL":"Addons oficiais","ADDON_REPOS":"Repositórios de addons","ADDON_SEARCH":"Pesquisar addons","ADDON_INSTALL":"Instalar","ADDON_CONFIGURE":"Configurar","ADDON_UNINSTALL":"Desinstalar","ADDON_UPGRADE":"Atualizar","ADDON_INSTALLED":"Instalado","ADDON_INSTALLED_MSG":"Addon instalado!","ADDON_UPGRADED_MSG":"Addon atualizado!","ADDON_UNKNOWN":"Desconhecido","ADDON_ERR":"Erro ao instalar o addon!","ADDON_DISCONNECTED":"Desconectado","ADDON_APP_MISSING":"a aplicação que suporta este tipo de letra não está instalada. Desejas instalá-la agora?","ADDON_APP_INSTALL":"Instalar agora","ADDON_PAGE":"Página do addon","ADDON_TOP_CONTENT":"O melhor deste addon","ADDON_PROVIDES":"Este addon dar-te-á:","ADDON_WATCH":"Ver #{types} agora!","ADDON_WATCH_FREE":"Ver #{types} GRATUITAMENTE agora!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Tipos suportados","ADDON_SUPPORTED_CATALOGS":"Catálogos suportados","ADDON_PROVIDES_DISCOVER":"Mais #{types} em Explorar","ADDON_PROVIDES_STREAMS":"Ver #{types}","ADDON_PROVIDES_STREAMS_FREE":"Ver #{types} GRATUITAMENTE","ADDON_PROVIDES_SUBTITLES":"Legendas para #{types}","ADDON_CANTDETECT":"Não foi possível encontrar o Stremio em execução, assim sendo, não é possível determinar os addons que tens instalados.","ERR_NO_META":"Não encontrámos nenhuma informação sobre isto.","ERR_GETTING_META":"Erro ao obter informação sobre isto.","ERR_CANT_PARSE_MAGNET":"Impossível analisar o magnet link","ERR_NO_MAGNET_INFOHASH":"Sem informação válida para este magnet link","ERR_NO_FILE_PATH":"Impossível enviar o pedido sem um caminho para o ficheiro","ERR_NO_TORRENT":"Nenhum torrent recebido","ERR_NO_SUPPORTERD_FILES":"Nenhum ficheiro suportado encontrado","ERR_OPENING_FILES":"Não foi possível abrir ficheiros externos.","ERR_INVALID_LINK":"Link inválido","ERR_REGISTERED_ONLY":"Esta opção está apenas disponível para utilizadores com sessão iniciada.","ERR_CLIPBOARD":"Não é possível reproduzir da área de transferência","ERR_CLIPBOARD_READ":"Não é possível ler a área de transferência nesta plataforma","ERR_CLIPBOARD_GENERIC":"Nenhum URL reproduzível encontrada na área de transferência. Por favor, copia um URL (ex.: magnet link) para um vídeo.","BOARD_CONTINUE_WATCHING":"Continuar a ver","BOARD_EXPLANATION_RECOMMENDATIONS":"Os filmes escolhidos especialmente para ti.
Este filme é uma amostra de recomendação.","BOARD_EXPLANATION_EPISODES":"Os novos episódios das tuas séries favoritas aparecem aqui.
Adiciona as séries que segues à tua biblioteca.","BOARD_EXPLANATION_VIDEOS":"Os novos episódios dos teus canais favoritos aparecem aqui.
Adiciona os canais do YouTube que segues à tua biblioteca.","WEBSITE_SLOGAN_WATCH":"Vê instantaneamente","WEBSITE_SLOGAN_ALL":"Todo o conteúdo que adoras num único lugar","WEBSITE_SLOGAN_NEW":"Tudo o que podes ver","WEBSITE_SLOGAN_NEW_NEW":"Liberdade para fazeres streaming","WEBSITE_WATCH_FROM":"Ver a partir de","WEBSITE_DOWNLOAD":"Transferir","WEBSITE_DOWNLOAD_FOR":"Transferir para","WEBSITE_IS_DESKTOP":"O Stremio é uma aplicação desktop, abre esta página no teu computador e transfere-a","WEBSITE_DESKTOP_DEMO_VID":"Demonstração de ambiente de trabalho","WEBSITE_PAGE_HOME":"Início","WEBSITE_PAGE_FEATURES":"Funcionalidades","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Tecnologia","WEBSITE_PAGE_CREATE_ADDON":"Criar addon","WEBSITE_PAGE_CONTACTS":"Contactos","WEBSITE_PAGE_BLOG":"Blogue","WEBSITE_TYPE_movie":"Filmes","WEBSITE_TYPE_series_PL":"Séries","WEBSITE_TYPE_tv":"TV em Direto","WEBSITE_TYPE_channel":"Canais","WEBSITE_STREMIO_WHAT_IS":"O Stremio é uma aplicação que te ajuda a organizar e ver instantaneamente os teus vídeos, filmes, séries e canais favoritos.","WEBSITE_FEATURES_WATCH":"Vê instantaneamente em HD","WEBSITE_FEATURES_WATCH_DETAIL":"Clica e reproduz o teu conteúdo preferido, filmes, séries, vídeos e canais.","WEBSITE_FEATURES_SUBS":"Legendas automáticas","WEBSITE_FEATURES_SUBS_DETAIL":"O Stremio seleciona automaticamente as legendas sincronizadas para o teu idioma.","WEBSITE_FEATURES_SUBS_LABEL":"Agora é contigo, chefe.","WEBSITE_FEATURES_CAST":"Reproduz na TV & dispositivos móveis","WEBSITE_FEATURES_CAST_DETAIL":"Liga à AppleTV, Chromecast, Smart TV (DLNA/UPnP) e dispositivos móveis.","WEBSITE_LIB":"Desfruta da tua biblioteca pessoal sincronizada em todos os teus dispositivos","WEBSITE_LIB_COLLECT":"Recolhe através do Stremio","WEBSITE_LIB_IMPORT":"Importa do Facebook","WEBSITE_LIB_LOCAL":"Adiciona a partir do teu disco local","WEBSITE_BOARD":"O painel - O teu sítio para notificações e recomendações","WEBSITE_BOARD_RECOMMEND":"Série recomendada","WEBSITE_BOARD_TRENDING":"Filme em destaque","WEBSITE_BOARD_NEW":"Novo vídeo","WEBSITE_BOARD_EPISODE":"Novo episódio","WEBSITE_BOARD_1":"Procuras algo interessante para ver? Recebe recomendações baseadas nos teus gostos!","WEBSITE_BOARD_2":"Recebe uma notificação quando um novo episódio da tua série preferida ou de um canal do YouTube é lançado!","WEBSITE_BOARD_YOUTUBE":"Novos vídeos de canais do YouTube","WEBSITE_BOARD_EPISODES":"Novos episódios das séries que segues","WEBSITE_ADDONS":"Conteúdo do addon","WEBSITE_TECH_DETAIL":"Adoramos tecnologia e ciência maluca!\\nO Stremio utiliza as seguintes tecnologias de código aberto:","WEBSITE_TECH_WCJS":"O WebChimera.js permite que o Stremio reproduza qualquer formato de vídeo com boa performance.","WEBSITE_TECH_WCJS_EXTRA":"Somos os colaboradores principais do projeto","WEBSITE_TECH_ELECTRON":"O Electron oferece uma plataforma inovadora para construir o Stremio.","WEBSITE_TECH_ELECTRON_EXTRA":"Somos colaboradores do projeto","WEBSITE_TECH_LINVODB":"Uma tecnologia de base de dados que garante que os teus dados estão organizados e disponíveis em qualquer lugar.","WEBSITE_TECH_LINVODB_EXTRA":"Tecnologia interna","WEBSITE_CREATE_ADDON":"Cria o teu Addon","WEBSITE_CREATE_ADDON_DETAIL":"Tens um serviço que fornece conteúdo de vídeo? Vamos ajudar-te a beneficiar das funcionalidades do Stremio ao criar o teu addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefícios da criação de um addon para o Stremio","WEBSITE_P2P_BEAUTY":"A beleza do Streaming Ponto-a-Ponto","WEBSITE_P2P_1":"Vídeo full HD / 4K on demand ou streaming fiável e acessível","WEBSITE_P2P_2":"Plataforma de distribuição que proporciona uma grande experiência ao utilizador","WEBSITE_P2P_3":"Criaremos uma Extensão que corresponde exatamente às tuas necessidades","WEBSITE_P2P_CONTACT":"Interessado? Convidamos-te a nos contactares.","WEBSITE_P2P_CONTACT_EXTRA":"Ficaríamos felizes por te ajudar a integrar o teu contéudo com o Stremio!","WEBSITE_P2P":"De um momento para o outro, surge uma tecnologia que muda o sistema. Investimos muito tempo e esforço para construir o nosso motor de streaming de vídeo ponto-a-ponto que fornece grande performance e versatilidade para se adaptar a qualquer caso de utilização.\\nContacta-nos para gestão de direitos digitais de vídeo P2P on demand ou streaming.","WEBSITE_THOUGHTS":"Pensamentos que partilhamos:","WEBSITE_SPREAD":"Divulga o Stremio:","WEBSITE_CONTACT":"Contacta-nos, adoraríamos saber o que tens a dizer!","WEBSITE_OPENSOURCE":"Para os nosso projetos de código aberto, visita o nosso","WEBSITE_BITCOIN":"Doar Bitcoin:","WEBSITE_FAQ":"Perguntas frequentes","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Perguntas","WEBSITE_TOS":"Termos de utilização","WEBSITE_LEGAL":"Jurídico","WEBSITE_PAGE_ABOUT":"Acerca de","WEBSITE_PAGE_BECOME_PARTNER":"Torna-te num parceiro","WEBSITE_ALL_YOU_CAN_WATCH":"Liberdade para veres\\nTudo o que precisas.","WEBSITE_FREEDOM_TO_STREAM":"Liberdade para fazeres streaming","WEBSITE_WHAT_IS_STREMIO":"O que é o Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"O Stremio é uma plataforma única para agregação de conteúdo de vídeo. Descobre, organiza e vê vídeos de todos os tipos de fontes em qualquer dispositivo que tenhas.","WEBSITE_WHAT_IS_STREMIO_P2":"Filmes, séries, programas de TV, TV em Direto ou canais da web como YouTube e Twitch.tv - podes encontrar tudo isto no Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"O Stremio é uma central de multimédia moderna, uma solução integrada para todo o teu entretenimento em vídeo. Descobre, vê e organiza todo o conteúdo de vídeo a partir de addons fáceis de instalar.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmes, programas de TV, TV em direto ou canais da web - encontra tudo isto no Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Desfruta em todos os teus dispositivos multimédia","WEBSITE_DEVICES_COLLECT":"Recolhe através do Stremio","WEBSITE_DEVICES_IMPORT_FB":"Importar do facebook","WEBSITE_DEVICES_LOCAL":"Adiciona a partir do teu disco local","WEBSITE_JOIN_THE_PARTY_NOW":"Junta-te à festa agora","WEBSITE_DEVICES_ALL":"Fácil de utilizar em qualquer dispositivo;","WEBSITE_EXTENDABLE_CATALOG":"Catálogo de vídeo infinitamente extensível;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Ótimas funcionalidades para organizares o teu conteúdo multimédia;","WEBSITE_AS_SEEN_ON":"Visto(a) em","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Quem somos","WEBSITE_LINK_TECHNOLOGY":"Tecnologia","WEBSITE_LINK_APPS":"Aplicações","WEBSITE_LINK_DOWNLOADS":"Transferências","WEBSITE_MORE":"Mais","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribuir","WEBSITE_LINK_COMMUNITY":"Comunidade","WEBSITE_LINK_BLOG":"Blogue","WEBSITE_MORE_MORE":"... e mais","WEBSITE_LINK_HELP":"Centro de Ajuda","WEBSITE_LINK_CONTACTS":"Contacta-nos","WEBSITE_LINK_TOS":"Termos e Condições","WEBSITE_LINK_PRAVACY":"Política de Privacidade","WEBSITE_SUBSCRIBE":"Subscrever","WEBSITE_NEWSLETTER":"Subreve a nossa newsletter para receberes as novidades","WEBSITE_PLACEHOLDER_EMAIL":"O teu e-mail","WEBSITE_COMMUNITY":"Comunidade","WEBSITE_LINK_PRAVACY_LEGAL":"Privacidade e jurídico","WEBSITE_WHY":"Porque o fazemos","WEBSITE_WHY_P1":"No Stremio, chegamos a trabalhar todos os dias quando queremos resolver um problema importante para o setor de vídeo on demand. Há tanto conteúdo novo publicado a cada minuto, que é virtualmente impossível encontrar o caminho menos árduo.","WEBSITE_WHY_P2":"Ajudamos as pessoas a navegar neste mundo imenso de entretenimento de vídeo e a descobrir novos conteúdos para apreciar. As nossas aplicações trazem consigo filmes, séries, TV em direto, canais da web e muito mais. Estamos focados em facilitar para que os nossos utilizadores possam encontrar facilmente os títulos e os canais que adoram.","WEBSITE_WHY_P3":"Podes utilizar o nosso serviço em qualquer dispositivo e a qualquer hora tornando o Stremio a única plataforma agregadora de entretenimento de vídeo de que precisarás.","WEBSITE_TEAM":"Equipa","WEBSITE_TEAM_P":"A equipa do Stremio é pequena, mas poderosa: entre nós dez, programamos em várias linguagens e partilhamos experiência em desenvolvimento de software, design da IU e UX, marketing e publicidade, negócios e startups.","WEBSITE_FEATURES":"Funcionalidades","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Descobre facilmente novos conteúdos","WEBSITE_FEATURES_DISCOVER_P":"Descobre facilmente novos filmes, séries, programas de TV e canais para ver. Navega por categoria, género, classificação, novidade, etc. ou escreve simplesmente um nome para encontrar. O Stremio encontrará facilmente todo o conteúdo de vídeo.","WEBSITE_FEATURES_ALL_CONTENT":"Todo o teu conteúdo de vídeo num ecrâ","WEBSITE_FEATURES_ALL_CONTENT_P1":"Vê que filmes, séries ou vídeos não terminaste e continua a vê-los(as). Sê notificado sobre novos episódios e lançamentos e navega pelas recomendações que obterás com base nos teus hábitos de visualização","WEBSITE_FEATURES_LIBRARY":"Organiza a tua biblioteca de vídeos","WEBSITE_FEATURES_LIBRARY_P1":"Adiciona qualquer título à tua biblioteca do Stremio com um único clique e encontra o teu conteúdo organizado por tipo, recência ou ordem alfabética","WEBSITE_FEATURES_CALENDAR":"Acompanha tudo o que viste","WEBSITE_FEATURES_CALENDAR_P1":"Vê o calendário de todos os filmes e séries que adicionaste à tua biblioteca e sabe também quando haverá um novo episódio ou estreia.","WEBSITE_FEATURES_BIG_SCREEN":"Aproveita o teu conteúdo de vídeo num ecrã maior ","WEBSITE_FEATURES_BIG_SCREEN_P1":"Reproduz o que estiveres a ver noutro dispositivo - utiliza o smartphone, tablet ou TV com um único clique","WEBSITE_FEATURES_SOURCES":"Vê o vídeo de várias fontes diferentes.","WEBSITE_FEATURES_SOURCES_P":"Instala os addons oficiais e da comunidade para aproveitares o vídeo fornecido por vários fornecedores diferentes - tudo numa aplicação elegante e fácil de utilizar.","WEBSITE_CREATE_AN_ADDON":"Cria um addon.","WEBSITE_FEATURES_SYNC":"Sincroniza a tua biblioteca entre diferentes dispositivos e continua a reprodução","WEBSITE_FEATURES_SYNC_P1":"Entra com a tua conta em todos os teus dispositivos e aproveita a tua biblioteca, addons, reprodução e calendário sincronizados.","WEBSITE_FEATURES_EXTENDABLE":"Catálogo de vídeo extensível por addons","WEBSITE_FEATURES_EXTENDABLE_P1":"O catálogo de addons do Stremio fornece vários complementos para instalares e veres uma variedade imensa de conteúdos de vídeo. Isto inclui filmes, programas, TV em direto, desportos, notícias, podcasts, canais da web, jogos e muito mais.","WEBSITE_FEATURES_AUTO_SUBS":"Legendas automáticas","WEBSITE_FEATURES_AUTO_SUBS_P1":"Com os nossos addons de legendas obtens automaticamente as opções selecionadas para o teu idioma preferido.","WEBSITE_FEATURES_CHROMECAST":"Transmitir para Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Desfruta do conteúdo de vídeo num ecrã maior ou transmite apenas o que estiveres a ver para outro dispositivo.","WEBSITE_FEATURES_KEEP_TRACK":"Acompanha os teus programas de TV e canais da Web favoritos ","WEBSITE_FEATURES_KEEP_TRACK_P1":"Obtém uma visualização do calendário e notificações para novos episódios das tuas séries e canais da web favoritos.","WEBSITE_FEATURES_POWER_USER":"Funcionalidades avançadas para os utilizadores","WEBSITE_FEATURES_POWER_USER_P1":"Reproduzir num reprodutor externo","WEBSITE_FEATURES_POWER_USER_P2":"Reproduzir a partir de um ficheiro torrent ou magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Importa para a tua biblioteca a partir dos gostos do Facebook ou disco local","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"Todo o conteúdo de vídeo que o Stremio proporciona é proveniente de um sistema de addons - nenhum fornecedor de conteúdo ou conteúdo foi incorporado na aplicação.","WEBSITE_ADD_ONS_P2":"Existem dois grupos de addons disponíveis: oficiais e da comunidade.","WEBSITE_ADD_ONS_P3":"Os oficiais são desenvolvidas e hospedadas pelo Stremio enquanto que os addons da comunidade são criados por membros da nossa comunidade que também os hospedam.","WEBSITE_ADDONS_OFFICIAL":"Addons oficiais","WEBSITE_ADDONS_WATCHUB":"Transmite os teus filmes, séries e programas favoritos de serviços como iTunes, Hulu, Amazon e outros serviços do Reino Unido / EUA.","WEBSITE_ADDONS_YOUTUBE":"Vê os teus canais favoritos do YouTube livre de anúncios e recebe notificações de novos vídeos dos canais que segues.","WEBSITE_ADDONS_FILMON":"Vê TV em direto, filmes e canais interativos gratuitamente. 600 canais de TV, 45.000 filmes gratuitos, documentários e muito mais.","WEBSITE_ADDONS_OPENSUBTITLES":"Legendas de filmes e TV em vários idiomas. Milhares de legendas traduzidas e carregadas todos os dias.","WEBSITE_ADDONS_COMMUNITY":"Addons da comunidade","WEBSITE_ADDONS_FILMON_VOD":"Vê vídeos on demand do Filmon.tv","WEBSITE_ADDONS_TWICH":"Vê transmissões em direto da Twitch.tv - a plataforma de streaming de vídeo para a indústria de eSports.","WEBSITE_ADDONS_VODO":"Vê filmes independentes de forma totalmente gratuita.","WEBSITE_ADDONS_NETFLIX":"Vê filmes e séries da Netflix.","WEBSITE_ADDONS_CREATE":"Cria um addon.","WEBSITE_ADDONS_CREATE_P1":"Se desejares, podes desenvolver o teu próprio addon. Desta forma, podes proporcionar a ti mesmo e à nossa comunidade o acesso a novos conteúdos de vídeo e alcançar um novo público-alvo de milhões de utilizadores em todo o mundo.","WEBSITE_ADDONS_START_CREATE":"Para começares, visita a página do Kit de Desenvolvimento de Addons da Stremio:","WEBSITE_DOWNLOADS":"Transferências","WEBSITE_DOWNLOADS_P1":"Para um melhor desempenho recomendamos que utilizes a versão mais recente disponível das aplicações Stremio. No entanto, se por algum motivo preferires utilizar uma versão mais antiga, podes descarregá-la aqui.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio para Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio para macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio para Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio para Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio para Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio para telemóveis Android","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio para Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio para iOS (versão limitada)","WEBSITE_CONTRIBUTE":"Colaborar","WEBSITE_CONTRIBUTE_P1":"A plataforma Stremio é de código aberto e podes criar facilmente um addon para o conteúdo que não é atualmente fornecido.","WEBSITE_CONTRIBUTE_WHY":"Porque deves criar um?","WEBSITE_CONTRIBUTE_WHY_P1":"Alcança um novo público para o conteúdo do teu vídeo","WEBSITE_CONTRIBUTE_WHY_P2":"A base de utilizadores do Stremio está a crescer rapidamente - no primeiro ano de lançamento o Stremio ganhou 1 milhão de utilizadores em todo o mundo e no segundo ano de existência da plataforma, este número cresceu para 2,5 milhões.","WEBSITE_CONTRIBUTE_WHY_P3":"Com o teu addon podes facilmente alcançar esta audiência e distribuir o teu conteúdo de vídeo para todos os utilizadores.","WEBSITE_CONTRIBUTE_ALL":"Vê os teus filmes, séries, vídeos e canais favoritos num único lugar.","WEBSITE_CONTRIBUTE_ALL_P1":"És fã de um tipo de conteúdo que ainda não está disponível no Stremio? Cria um addon para isso e desfruta ao ver os teus vídeos favoritos numa das maiores e mais fáceis plataformas de entretenimento e de se utilizar do mercado.","WEBSITE_CONTRIBUTE_ALL_P2":"Além disso, obterás a infinita gratidão de outros membros da comunidade Stremio com ideias semelhantes","WEBSITE_CONTRIBUTE_MONETIZE":"Monetiza o teu addon e ganha dinheiro com ele","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Uma vez que desenvolvas um novo addons para o Stremio, podes facilmente monetizá-lo de várias maneiras diferentes. Se estás a considerá-lo, sente-te à vontade para entrar em contacto connosco através do ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - ficaríamos felizes por te orientar e aconselhar neste processo sobre as opções de monetização do teu addon.","WEBSITE_CONTRIBUTE_TRANSLATE":"Torna-te num tradutor voluntário","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Se desejas aproveitar as aplicações do Stremio em diferentes idiomas, podes juntar-te à nossa comunidade de tradutores voluntários. Eles ajudam-nos a adicionar versões do Stremio nos diferentes idiomas.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Estás ansioso para começar?","WEBSITE_TRANSALTE_STREMIO":"Traduzir o Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Comunidades oficiais","WEBSITE_COMMUNITY_OFFICIALS_P1":"Faz parte da crescente comunidade do Stremio. Segue-nos nas redes sociais e não te sintas intimidado por nos dizeres um \\"Olá\\" - gostamos de conhecer os nossos fãs!","WEBSITE_COMMUNITY_UNOFFICIALS":"Comunidades não-oficiais","STREMIO_COMMUNITY_NL":"Stremio Países Baixos","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Alemanha","STREMIO_COMMUNITY_BELGIUM":"Stremio Bélgica","STREMIO_COMMUNITY_FRANCE":"Stremio França","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Itália","STREMIO_COMMUNITY_UK":"Stremio Reino Unido","STREMIO_COMMUNITY_USA":"Stremio EUA","STREMIO_COMMUNITY_MEXICO":"Stremio México","STREMIO_COMMUNITY_ADDONS":"Extensões Stremio","STREMIO_COMMUNITY_AWESOME":"O melhor do Stremio","WEBSITE_COMMUNITY_PARTNERS":"Parceiros e apoiantes","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Papéis de parede","WEBSITE_COMMUNITY_ART":"Galeria de Artes da Comunidade","WEBSITE_LINK_ART":"Galeria de Artes da Comunidade","WEBSITE_CONTACT_US":"Contacta-nos","WEBSITE_CONTACT_US_P1":"Caso tenhas dúvidas, comentários ou sugestões, sente-te à vontade para entrares em contacto connosco através do formulário em baixo.","WEBSITE_CONTACT_US_P2":"Lembra-te de que estamos localizados na Bulgária, por isso, pode haver alguma demora no atendimento do teu contacto devido às diferenças de fuso horário.","WEBSITE_CONTACT_US_SUCCESS":"A tua mensagem foi enviada. Entraremos em contacto contigo o mais breve possível.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Por favor, escreve um e-mail válido!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Com que assunto está relacionada a tua pergunta?","WEBSITE_CONTACT_US_Q_OS":"Qual é o teu sistema operativo?","WEBSITE_CONTACT_US_PH_EMAIL":"O teu e-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Mensagem","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"ENVIAR","WEBSITE_CONTACT_US_Q_1":"Como instalar?","WEBSITE_CONTACT_US_Q_2":"Como desinstalar?","WEBSITE_CONTACT_US_Q_3":"(HTML) Como fazer lasanha?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"MacOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Tecnologia","WEBSITE_TECHNOLOGY_P1":"Adoramos tecnologia e ciência maluca. Aqui estão os poderes do Stremio (tudo em código aberto).","WEBSITE_TECHNOLOGY_P_QT":"Desenvolvimento de software multiplataforma no seu melhor.","WEBSITE_TECHNOLOGY_P_MPV":"Um reprodutor de multimédia gratuito, de código aberto e multiplataforma.","WEBSITE_TECHNOLOGY_P_RN":"O React Native permite que cries aplicações móveis utilizando apenas JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Framework de multimédia embutido na apicação para funcionalidades multimédia","WEBSITE_TECHNOLOGY_P_REALM":"A Realm é uma plataforma móvel e um substituto para o SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"O Node.js é um ambiente em tempo de execução multiplataforma e de código aberto para JavaScript.","WEBSITE_TECHNOLOGY_P_RUST":"O Rust é uma linguagem de programação multi-paradigma focada em segurança, especialmente em concorrência segura.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribuir para o projeto.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Há duas maneiras para poderes contribuir com o Stremio e ajudar-nos a tornar o produto ainda melhor.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Podes doar as tuas valiosas habilidades linguísticas para ajudar a traduzir a plataforma...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"ou","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"...podes utilizar as tuas habilidades de programação para criar addons da comunidade.","WEBSITE_TRANSLATE_STREMIO":"Traduzir o Stremio","WEBSITE_404_OH_NO":"Ups! A página que procuras não está aqui...","WEBSITE_GO_HOME":"Voltar ao início","WEBSITE_LINK_OTHER_DOWNLOADS":"Outras transferências","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Suporte","WEBSITE_DOWNLOAD_4_0_BETA":"Transferir o Stremio 4 beta agora","WEBSITE_GET_FOR_DESKTOP":"Transferir para o computador","WEBSITE_LINK_ADDON_COMPETITION":"Competições de addons","WEBSITE_LINK_ART_CONTEST":"Concurso de artes","WEBSITE_MY_ACCOUNT":"A minha conta","WEBSITE_MAINPAGE_FAQ_001_H1":"O que é o Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"O Stremio é um moderno centro de multimédia, que oferece a liberdade para veres tudo o que desejas.","WEBSITE_MAINPAGE_FAQ_002_H1":"Como funciona?","WEBSITE_MAINPAGE_FAQ_002_P1":"Depois de instalares o Stremio no teu dispositivo e criar uma conta tudo o que precisas de fazer é visitar o catálogo de addons e instalar qualquer complemento que desejares, e pronto!","WEBSITE_MAINPAGE_FAQ_002_P2":"Depois disso, podes ir às secções Explorar ou Painel para começar a explorar o conteúdo.","WEBSITE_MAINPAGE_FAQ_003_H1":"O que posso ver aqui?","WEBSITE_MAINPAGE_FAQ_003_P1":"Diversos filmes, programas de TV, canais da Web, desportos, canais de TV, ouvir podcasts e muito mais. Graças ao nosso sistema de addons podes aceder a uma variedade de conteúdos.","WEBSITE_MAINPAGE_FAQ_004_H1":"O Stremio é de código aberto?","WEBSITE_MAINPAGE_FAQ_004_P1":"Sim, podes verificar os seguintes links: ${1}aplicação desktop${2} e ${3}organização GitHub${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"O Stremio é seguro?","WEBSITE_MAINPAGE_FAQ_005_P1":"Sim. Por ser um software de código aberto o código é auditável publicamente e, podes revê-lo.","WEBSITE_MAINPAGE_FAQ_006_H1":"E a minha privacidade?","WEBSITE_MAINPAGE_FAQ_006_P1":"Respeitamos a privacidade dos utilizadores e não coletamos dados pessoais além do mínimo essencial para criar e sincronizar a tua conta.","WEBSITE_MAINPAGE_FAQ_006_P2":"Há também um ${1}modo convidado ${2}no registo que não requer dados: deste modo, nenhuma chamada é feita aos nossos servidores. No entanto, isto ocorre à custa de funcionalidades úteis, como sincronizar a tua biblioteca entre dispositivos.","WEBSITE_MAINPAGE_FAQ_007_H1":"Posso transmitir para a minha TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Sim, suportamos o Chromecast e podes transmitir através de aplicações para o computador e dispositivos móveis (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"Quantas extensões possui o Stremio?","WEBSITE_MAINPAGE_FAQ_008_P1":"No final de 2019, acima de 50 - para obter mais informações, consulte o nosso catálogo de extensões.","WEBSITE_MAINPAGE_FAQ_009_H1":"O Stremio pode ser expandido além do que se encontra no catálogo de extensões?","WEBSITE_MAINPAGE_FAQ_009_P1":"Sim, deves verificar estes: ${1}PimpMyStremio${2}, ${3}Comunidades Reddit${4}, ${5}Downloader Stremio${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"Que dispositivos o Stremio suporta?","WEBSITE_MAINPAGE_FAQ_010_P1":"Temos aplicações desktop para Windows, Mac e Linux. Para dispositivos móveis, suportamos Android e iOS, embora tem em conta que as funcionalidades do iOS são limitadas (não é compatível com a maioria dos addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"Existem muitos dispositivos com base no Android aos quais podes executar o Stremio, como NVIDIA Shield e Amazon Fire Stick, mas não os suportamos oficialmente.","WEBSITE_MAINPAGE_FAQ_011_H1":"Podem adicionar determinados conteúdos ao Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Desculpa, mas não fornecemos conteúdo. Porém, quanto mais addons do Stremio instalares mais conteúdo poderás encontrar.","WEBSITE_MAINPAGE_FAQ_012_H1":"O Stremio pode reproduzir magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Sim, e também pode reproduzir links HTTP normais e de ficheiros torrent (arrastar e soltar).","WEBSITE_MAINPAGE_FAQ_013_H1":"Posso descarregar um vídeo e vê-lo offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"O modo offline estará disponível futuramente, porém, se permitires que o Stremio faça cache no dispositivo (no painel de definições), poderás ver os teus vídeos mais tarde, mesmo sem ligação à Internet.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nada funciona, ajudem-me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Tens a certeza de que instalaste addons? Se sim, verifica a nossa ${1}central de ajuda${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"Como o Stremio sustenta as suas operações de desenvolvimento?","WEBSITE_MAINPAGE_FAQ_015_P1":"Executamos anúncios não invasivos por meio de ${1}AdEx${2}, que é uma empresa da mesma equipa fundadora e que se concentra na preservação da privacidade e anúncios transparentes.","WEBSITE_MAINPAGE_FAQ_015_P2":"Para mais dúvidas, visita a nossa ${1}central de ajuda${2}.","HELP_LEARN_MORE":"Ajuda-nos a aprender algo mais sobre ti.","LIFESTYLE":"Estilo de Vida","SPORTS":"Desporto","FOOD_HEALTH":"Comida e Bem-estar","BEAUTY_FASHION":"Beleza e Moda","NEWS":"Notícias","GAMING":"Jogos","SCIENCE_EDUCATION":"Ciência e educação","MUSIC":"Música","TRAVEL":"Viagens","LATE_NIGHT":"Late Night Shows","REALITY":"Realidade","COMEDY":"Comédia","DIY":"Faz tu mesmo","TECH":"Tecnologia","CINEMA":"Cinema","CONTINUE":"Continuar","SLOW_LOADING":"LENTO A CARREGAR?","I_GIVE_UP":"DESISTO","LEARN_MORE":"Aprender mais","POOR_SOURCE":"Esta fonte possui fraca disponibilidade ou a tua ligação à Internet não é suficientemente rápida","PICK_CATEGORIES_ERR":"Tens de escolher pelo menos 3 categorias","ADJUST_TIMING":"Ajustar tempos com ","ADJUST_SIZE":"Ajustar tamanho com ","SEARCH_ANYTHING":"Podes pesquisar qualquer coisa...","ALL_CATEGORIES":"Tudo","SEARCH_CATEGORIES":"Filmes, Séries, YouTube e TV","SEARCH_PERSONS":"Atores, Realizadores e Guionistas","SEARCH_PROTOCOLS":"Links HTTP e Magnet","SEARCH_TYPES":"Links IMDB / TVDB","WATCHED":"Visto","SHOW_LESS":"Mostrar menos","LAST_SEARCHES":"Pesquisas recentes","CLEAR_HISTORY":"Limpar histórico","CHOOSE_SOME":"ESCOLHE ALGUNS DESTES:","NO_WEB_REMOTE":"O controlo remoto via web não pôde ser carregado","STREMIO_OFFLINE":"O Stremio está offline","STREMIO_EXPENSIVE_CONNECTION":"Detetámos que estás a utilizar uma ligação por dados móveis. Desejas continuar?","USE_DATA":"Dados de Utilização","WARNING":"Aviso","MORE_INFO":"Mais informações ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"A carregar ...","STREMIO_TV_BACK_TO_LANGUAGES":"Voltar para os idiomas","STREMIO_TV_REMOTE":"Remoto","STREMIO_TV_GO_TO":"Ir para:","STREMIO_TV_OR_SCAN":"ou pesquisar:","STREMIO_TV_ADDON_INSTRUCTIONS":"Por favor, segue as instruções com o intuito de instalares os teus addons favoritos.","STREMIO_TV_LIVE_TV":"TV em Direto","STREMIO_TV_RESUME_WATCHING":"Continuar a ver","STREMIO_TV_LOADING_BACKGROUND":"A carregar o plano de fundo","STREMIO_TV_CHECKING_AUTHENTICATION":"A verificar autenticação","STREMIO_TV_LOADING_BOARD":"A carregar o painel","STREMIO_TV_LOGIN_HEADER_LINE_1":"Queremos que os nossos utilizadores tenham a melhor experiência personalizada possível com o nosso programa.","STREMIO_TV_LOGIN_HEADER_LINE_2":"É por esta razão que pedimos gentilmente que inicies sessão na tua conta.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Obrigado por entenderes,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Equipa Stremio","STREMIO_TV_REMOTE_INSTRUCTIONS":"Com o intuito de utilizares o Web Remote com teu Smartphone / Tablet / PC:","STREMIO_TV_WIFI_SETUP":"Configurar Wi-Fi","STREMIO_TV_WIFI_HEADER_LINE_1":"O Stremio Circle não detetou ligação à Internet.","STREMIO_TV_WIFI_DETAILS_1":"Ligar a:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Utilizar palavra-passe:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Abrir o navegador com o link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Predefinido","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Pela última vista","STREMIO_TV_LIBRARY_SORT_NAME":"Por nome","STREMIO_TV_LIBRARY_TIMES_WATCHED":"Por vezes vistas","STREMIO_TV_DETAILS_SEASON_NUMBER":"Temporada ${1}","STREMIO_TV_STREAMS_LOADING":"${1} / ${2} addons carregados...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} o addon está ainda a carregar...","STREMIO_TV_PLAYER_SETTINGS":"Definições de reprodução","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Atraso das legendas","STREMIO_TV_PLAYER_AUDIO_DELAY":"Atraso do áudio","STREMIO_TV_PLAYER_VIDEO_SCALING":"Escala do vídeo","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Fonte de streams não suportada","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Falha ao abrir o link externo","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Reproduzir com o ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Reproduzir com o libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"A mudar para o libVLC player devido a um erro de reprodução","STREMIO_TV_ADDONS_TITLE":"Utiliza o Stremio no teu telemóvel ou PC para instalares ou configurares addons e pressiona em \\"Sincronizar addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Nota: certifica-te de que estás a utilizar a mesma conta do Stremio","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sincronizar addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons sincronizados com sucesso","STREMIO_TV_ADDONS_SYNC_FAILED":"Falha ao sincronizar addons","STREMIO_TV_META_LINK_FAILED":"Falha ao abrir o link meta","STREMIO_TV_CATALOG_LOADING":"O catálogo ainda está a carregar...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Idioma da interface atualizado","STREMIO_TV_SETTINGS_THEME_UPDATED":"Tema atualizado","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Leitor predefinido","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"Leitor externo","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Idioma preferido","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Idioma secundário preferido","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Reprodução no modo tunnelled","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possíveis problemas de reprodução nalguns dispositivos","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Alguns formatos de vídeo podem não funcionar","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Correspondência da taxa de fotogramas automática","STREMIO_TV_SETTINGS_NO_CACHING":"Sem caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Predefinido","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Suave","STREMIO_TV_SETTINGS_PROFILE_FAST":"Rápido","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra rápido","STREMIO_TV_SETTINGS_SERVER_URL":"URL do servidor de streaming","STREMIO_TV_SETTINGS_SERVER_VERSION":"Versão do servidor","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Desconhecido","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Versão do Stremio","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Editar URL do servidor","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Introduz um URL do servidor de streaming","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Para leres a Política de Privacidade do Stremio, vai a:","STREMIO_TV_SETTINGS_TOS_TEXT":"Para leres os Termos e Condições do Stremio, vai a:","STREMIO_TV_NAV_SEARCH":"Pesquisar","STREMIO_TV_NAV_HOME":"Início","STREMIO_TV_NAV_DISCOVER":"Explorar","STREMIO_TV_NAV_LIBRARY":"Biblioteca","STREMIO_TV_NAV_MOVIES":"Filmes","STREMIO_TV_NAV_SERIES":"Séries","STREMIO_TV_NAV_CHANNELS":"Canais","STREMIO_TV_NAV_TV":"TV em Direto","STREMIO_TV_NAV_SETTINGS":"Definições","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Ligar conta","STREMIO_TV_LOGIN_EXPIRES_IN":"Expira em","STREMIO_TV_LOGIN_STEP_ONE":"Lê o código QR acima ou vai para","STREMIO_TV_LOGIN_STEP_TWO":"Inicia sessão na tua conta do Stremio","STREMIO_TV_LOGIN_NEW_LINK":"Pedir um novo link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Código de início de sessão atualizado","STREMIO_TV_SEARCH_PLACEHOLDER":"Escreve alguma coisa","STREMIO_TV_SEARCH_NO_ADDONS":"Não foram pedidos addons para catálogos!","STREMIO_TV_SEARCH_BUTTON":"Pesquisar","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Histórico de pesquisas","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Podes pesquisar por títulos, atores, canais e mais...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Limpar histórico de pesquisas","STREMIO_TV_FILTERS_DESCRIPTION":"Escolhe um dos filtros abaixo","FILTERS":"Filtros","SETTINGS":"Definições","ACCOUNT":"Conta","LOGOUT":"Terminar sessão","THEMES":"Temas","PLAYBACK":"Reprodução","PLAYBACK_SPEED":"Velocidade da reprodução","AUDIO_TRACKS":"Faixas áudio","VIDEOS":"Vídeos","SERVER":"Servidor","LINKS":"Links","ABOUT":"Acerca de","INTERFACE":"Interface","ANIMATIONS":"Animações","STATUS":"Estado","LANGUAGE":"Idioma","SIZE":"Tamanho","DELAY":"Atraso","BOLD":"Em negrito","TEXT_COLOR":"Cor do texto","OUTLINE_COLOR":"Cor do contorno","BACKGROUND_COLOR":"Cor do fundo","BACKGROUND_BLUR":"Desfocagem do fundo","SEEK_TIME_DURATION":"Duração do tempo para avançar / recuar","AUTO_PLAY":"Reproduzir o próximo episódio automaticamente","PLAY_NOW":"Reproduzir agora","MARK_AS_WATCHED":"Marcar como visto","MARK_AS_UNWATCHED":"Marcar como não visto","REWIND_TO_BEGINNING":"Ver do início","CONTINUE_WATCHING":"Continuar a ver","ALL":"Tudo","SECONDS":"segundos","ON":"LIGADO","OFF":"DESLIGADO","RELOAD":"Recarregar","EDIT_URL":"Editar URL","NONE":"Nenhum","EMBEDDED":"Embutido","REMOTE_SWITCH_DEVICES":"Trocar dispositivos","REMOTE_VIDEOS":"Vídeos","REMOTE_ADJUST_TIMING":"Ajustar o tempo","REMOTE_ADJUST_SIZE":"Ajustar o tamanho","REMOTE_COULD_NOT_BE_LOADED":"O Web Remote não pôde ser carregado","REMOTE_RETRY":"Tentar novamente","TORRENT_PROFILE_DEFAULT":"Predefinido","TORRENT_PROFILE_SOFT":"Suave","TORRENT_PROFILE_FAST":"Rápido","TORRENT_PROFILE_ULTRA_FAST":"Ultra rápido","FAQ_001_H1":"O que é o stremio?","FAQ_001_P1":"O Stremio é um programa de multimédia centralizado desenhado para video entretenimento com a facilidade de utilização em mente. O Stremio permite-te organizares e veres a tua própria coleção de vídeos, séries, canais e TV em Direto.","FAQ_001_P2":"O Stremio cataloga o teu conteúdo, seja através do teu disco local seja através do nosso sistema de addons.","FAQ_001_P3":"Também te notificaremos quando novos episódios/vídeos/filmes em que tenhas interesse sairem para o ar e mostrar-te-á recomendações de filmes.","FAQ_02_H1":"Como o Stremio se compara ao Kodi e Plex?","FAQ_02_P1":"Inspirámo-nos nos dois programas mas temos diferentes objetivos - o Stremio é especificamente voltado para o entretenimento de vídeo. Batalhámos para sermos a solução predefinida nesse sentido, tendo em foco a facilidade de utilização.","FAQ_02_P2":"Stremio nunca será tão customizável e nunca terá tantos recursos como Kodi e Plex. Mas será significativamente mais fácil de utilizar. Simplesmente ${1} obtém-no e comprova ${2} :)","FAQ_03_H1":"Como o Stremio se compara à Netflix?","FAQ_03_P1":"Novamente, a Netflix é uma das nossas inspirações. Trabalharemos arduamente para atingir a experiência de utilização proporcionada pela Netflix e mais uma quantidade de melhorias. No entanto, o mais importante é dar-vos a liberdade de organizarem a vossa própria biblioteca e adicionar novas fontes de conteúdos com o nosso sistema de addons.","FAQ_03_P2":"Isso faz do Stremio infinitamente extensível e assim que o utilizares nunca ficarás limitado ao conteúdo que a Netflix decida licenciar. Por exemplo, através do Stremio podes ver o conteúdo de ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} e mesmo da ${9}Netflix${10}!","FAQ_04_H1":"Como o Stremio se compara ao Flipboard?","FAQ_04_P1":"Raramente recebemos esta questão, excepto quando falamos com pessoas iniciantes :)","FAQ_04_P2":"O Stremio é desenhado como um agregador de conteúdo tal e qual o Flipboard o faz para vídeo. Isto é muito parecido no nosso painel, painel este que te mostrará catálogos e notificações de novos episódios/novos vídeos que sigas, tal e qual o Flipboard.","FAQ_05_H1":"Como o Stremio se compara ao Popcorn Time?","FAQ_05_P1":"O Stremio e o Popcorn Time são semelhantes na interface de utilização porque não há muitas formas de fazer catálogo de vídeo entretenimento, certo? :)","FAQ_05_P2":"Mas enquanto o Popcorn Time tem o foco numa entrega de torrents que provêm de fontes específicas, o Stremio não possui restrições e é meramente um agregador de conteúdo - não está bloqueado a uma fonte de conteúdo específica.","FAQ_05_P3":"Além disso, não fornecemos nenhuma extensão para torrent por padrão então o Stremio não cobre o caso de utilização do Popcorn Time na sua funcionalidade oficial.","FAQ_05_P4":"Uma outra diferença notável é que o Popcorn Time é completamente de código aberto enquanto o Stremio é ${1} parcialmente de código aberto ${2}.","FAQ_06_H1":"Vocês é que adicionam estes filmes/séries?","FAQ_06_P1":"Não, desculpa :(","FAQ_06_P2":"Como já mencionámos noutras questões, o Stremio não partilha nenhum conteúdo por si próprio - tudo é adicionado diretamente pelo sistema de addons. Caso queiras pedir algum conteúdo, pode utilizar o botão “Reportar” no reprodutor e assim enviar um e-mail para o autor do addons com que te encontras a utilizar.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Criarão addons para X?","FAQ_08_P1":"É inteiramente possível.","FAQ_08_P2":"Se tens alguma ideia para um addon, escreve para ${1}office@stremio.com${2}, mas por favor, tem a certeza de que a ideia desse addon não infringirá nenhum direito de propriedade intelectual ou termos de utilização.","FAQ_08_P3":"De momento, os próximos movimentos no nosso projeto são addons para FandangoNOW, vídeo on demand no Filmon.tv e no Crunchyroll.","FAQ_09_H1":"O Stremio utiliza o BitTorrent?","FAQ_09_P1":"Sim. O Stremio suporta o BitTorrent como um protocolo streaming. Podes utilizá-lo com a extensão torrent ou por arrastar e soltar um ficheiro .torrent dentro do Stremio ou até mesmo colando um magnet link dentro do campo de pesquisa.","FAQ_09_P2":"Por favor, nota que o único addon oficial que utiliza o BitTorrent é o ${1}Vodo${2}, ao qual fornece produção independente, todos com permissão para serem distribuídos com o BitTorrent.","FAQ_09_P3":"Não suportamos a utilização de qualquer addon de terceiros que possa viabilizar o infringimento de leis de direitos.","FAQ_10_H1":"O que posso ver no Stremio com os addons oficiais?","FAQ_10_P1":"Predefinidamente, podes ver conteúdo do Filmon.tv, YouTube e Vodo dentro do Stremio com o reprodutor interno. Temos adicionalmente um addon para a Twitch.tv e outros.","FAQ_10_P2":"Esta combinação fornece uma seleção de:","FAQ_10_L1":"Canais de TV populares, fornecido por Filmon.tv - por exemplo E4, BBC, Bollyworld TV","FAQ_10_L2":"Tudo do YouTube - por exemplo BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Filmes indepententes com Vodo","FAQ_10_L4":"Transmissões de jogos online com a Twitch.tv","FAQ_10_P3":"Adicionalmente, há muitas fontes de conteúdo fornecidas com Guidebox e addons Netflix, ao qual não reproduzem inteiramente dentro do Stremio, mas pode redirecionar para o dado serviço. Por exemplo, o addon Guidebox dá-te uma seleção de filmes que podes fazer stream gratuitamente dentro dos Estados Unidos através de serviços como o TubiTV e o Crackle.","FAQ_11_H1":"O Stremio não instala, o que devo fazer?","FAQ_11_P1":"Se utilizas Windows, tenta ${1}este instalador alternativo${2}.","FAQ_11_P2":"Se utilizas Mac OS X, por favor, tem em conta que não suportamos versões inferiores ao OS X Mavericks (10.9).","FAQ_11_P3":"Caso estejas a utilizar Linux, tem em conta que neste momento apenas damos suporte para a versão de 64 bits (x64).","FAQ_11_P4":"Se não ainda não conseguiste resolver o teu problema, por favor, envia-nos uma mensagem no ${1}Grupo do Facebook${2}.","FAQ_12_H1":"Porque é que o meu antivírus está a notificar-me? O Stremio é seguro?","FAQ_12_P1":"Asseguramos-te de que o Stremio é ${1}100% limpo${2}.","FAQ_12_P2":"O teu antivirus está a notificar-te, porque incluimos publicidade no nosso instalador e isso faz com que o Stremio seja classificado como um adware.","FAQ_12_P3":"Se não estás seguro, podes utilizar o nosso ${1}instalador alternativo${2}.","FAQ_13_H1":"Como posso fazer um addon?","FAQ_13_P1":"Para iniciantes, recomendados que leiam o nosso ${1}módulo de sistema de extensão${2} no GitHub.","FAQ_13_P2":"Todavia, podes seguir o ${1}Tutorial do Olá Mundo${2}.","FAQ_13_P3":"Se não tens nenhum conhecimento em programação, por favor, publica a tua ideia na ${1}comunidade Reddit${2} e partilha-a com ${3}office@stremio.com${4}.","FAQ_14_H1":"Como os addons são publicados?","FAQ_14_P1":"Quando crias um addon e hospedor, colocas um campo endpoint no teu manifest, ao qual aponta para um endereço de addon ativo. O addon ficará automaticamente publicado no nosso ${1}Catálogo de Addons{2}.","FAQ_14_P2":"Esta situação acontece porque parte do servidor do módulo de addons do Stremio, que faz automaticamente uma chamada para a nossa API para publicar o addon. Quando a nossa API o valida endpoint como um addon válido, ficará disponível no nosso catálogo.","FAQ_15_H1":"Posso executar o Stremio no navegador?","FAQ_15_P1":"De momento não, mas em breve!","FAQ_15_P2":"Se estás curioso para ver uma versão Alpha, podes aceder aqui: ${1}alpha4.strem.io${2}. Tem em conta que o streaming está inativo. Damos suporte para Chrome, Firefox, Opera e Edge.","FAQ_16_H1":"A transmissão para a TV não funciona / legendas não funcionam","FAQ_16_P1":"A transmissão para a TV utiliza a tecnologia DLNA que é muito inconsistente entre modelos de fabricantes diferentes. Por esta razão, nós não temos a habilidade de testar cada caso então estamos longe da perfeição. Continuamos a trabalhar no sentido de melhorar cada vez mais a aplicação mas não podemos dar uma estimativa de tempo de quando a tecnologia DLNA funcionará corretamente na tua TV.","FAQ_16_P2":"Se ainda não vês a tua TV no menu de transmissão, por favor, tenta desativar a tua conexão de rede e ativa-a novamente (no Windows, clica com o botão direito em Rede e clica em Ativar/Desativar), reinicia também o teu rooter, TV e PC.","FAQ_16_P3":"Se estás ainda a encontrar problemas, podes ajudar-nos ao enviares a informação do teu modelo de TV e fabricante para ${1}office@stremio.com${2}.","FAQ_16_P4":"Entretanto, recomendamos o Chromecast, ao qual suportamos muito bem ou até simplesmente conectando a tua TV ao teu PC com um cabo HDMI.","FAQ_17_H1":"O Stremio congela ou trava, o que posso fazer?","FAQ_17_P1":"Primeiro de tudo, se estás a utilizar o Windows 7 com o antivirus AVG: temos problemas com essa combinação. O problema é o próprio AVG e não há uma solução definitiva para corrigirmos isso. Infelizmente, exceções ou desativar o antivirus não funciona. A única forma é trocares o teu antivirus.","FAQ_17_P2":"Se isso não é o problema, mas usa Windows, por favor atualize seu o sistema, incluíndo os drivers da GPU e tente novamente.","FAQ_17_P3":"Se o teu problema continua sem solução ou utilizas Mac ou Linux, por favor escreve-nos reportando em detalhe o problema no ${1}nosso grupo do Facebook${2}.","FAQ_18_H1":"Como posso fazer uma extensão?","FAQ_18_P1":"Para iniciantes recomendamos que vejas o nosso ${1}módulo de sistema de addons{2} no GitHub.","FAQ_18_P2":"No entanto, podes guiar-te pelo nosso ${1}tutorial do Olá Mundo!${2}.","FAQ_18_P3":"Se não tens nenhuma habilidade em programação, por favor, publica a tua ideia na ${1}comunidade do Reddit${2} e contacta-nos com a tua ideia de addon para ${3}office@stremio.com${4}.","FAQ_19_H1":"Porque é que o Stremio está a ocupar espaço em disco?","FAQ_19_P1":"O Stremio tem um cache local para temporariamente deixar os ficheiros de vídeo descarregados.","FAQ_19_P2":"Esta situação tem dois benefícios: primeiro, permite ao Stremio pré-carregar o vídeo para garantir uma transmissão suave. Segundo, isto deixa os vídeos na cache local para que possas continuar a ver offline.","FAQ_19_P3":"Quanto depende o Stremio da configuração do Cache no painel das Definições. O Stremio pode manter uma quantidade (exemplo 2GB) no teu disco, a menos que o video descarregado seja maior que isso e nesse caso pode necessitar de mais espaço para mantê-lo enquanto o descarrega.","FAQ_20_H1":"Onde está a pasta da cache?","FAQ_20_P1":"No Windows, a cache do Stremio fica no caminho que selecionaste nas definições (exemplo \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"No MacOS, fica em \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"No Linux, fica em \\"~/.stremio/stremio-cache\\" ou \\"~/stremio-cache\\"","FAQ_21_H1":"Recebi a mensagem de erro \\"Servidor de streming não encontrado\\", o que posso fazer?","FAQ_21_P1":"Se recebeste esta mensagem implica uma das possibilidades:","FAQ_21_P2":"1) Estás a tentar utilizar um addon suportado pelo código do YouTube/BitTorrent através da nossa ${1}versão web${2}. Nesse caso, deves instalar a nossa versão para desktop através do ${3}nosso site${4}.","FAQ_21_P3":"2) Há algo de errado com a instalação do Stremio. Neste caso, tenta reinstalar a nossa versão mais recente através ${1}do site${2}. Se isto não ajudar, tenta desativar os programas de antivírus e firewal, reinicia o teu PC e tenta novamente. Se isto não funcionar, por favor, entra em contacto pelo ${3}nosso grupo do Facebook${4}.","FAQ_22_H1":"Eu não posso ver/utilizar a maioria dos addons no iOS","FAQ_22_P1":"Devido a restrições nos termos e condições da loja da Apple, temos restringido apenas a aplicação iOS de um grupo particular de addons.","FAQ_22_P2":"Mas fica atento - existirão mais addons para iOS no futuro e poderemos também adicionar uma integração que permitirá a utilização de todos os addons do Stremio graças à conexão da aplicação iOS com o servidor de Streaming do Stremio."}')},6687:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Кино","TYPE_series":"Сериал","TYPE_tv":"ТВ-канал","TYPE_channel":"Канал","TYPE_other":"Прочее","TYPE_movie_PL":"Кино","TYPE_series_PL":"Сериалы","TYPE_tv_PL":"ТВ-каналы","TYPE_channel_PL":"Каналы","TYPE_other_PL":"Прочее","TYPE_ALL":"All","VIDEO":"Видео","BACK":"Назад","MORE":"Ещё","DONE":"Готово","COPY":"Копировать","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Открытия","Board":"Доска","Library":"Библиотека","My Library":"Моя библиотека","Calendar":"Календарь","NOTIFICATION_ONLINE":"Вы в сети","NOTIFICATION_OFFLINE":"Вы вне сети","INTERNET_CONNECTION":"Сетевое подключение","STORAGE_FULL_TITLE":"Внимание: хранилище заполнено!","STORAGE_FULL_TEXT":"Stremio не может сохранить ваши настройки, предпочтения или данные для входа. Попробуйте перезапустить или переустановить Stremio.","SEARCH":"поиск","SEARCH_NO_RESULTS":"Ничего не найдено","SEARCH_EXPLANATION_CONTENT":"Поиск фильмов, сериалов, YouTube и ТВ-каналов","SEARCH_EXPLANATION_PEOPLE":"Поиск актёров, режиссёров и авторов","SEARCH_PASTE_LINKS":"Вставьте HTTP и Magnet-ссылки","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Добавить в библиотеку","REMOVE_FROM_LIB":"Удалить из библиотеки","ADDED_TO_LIB":"Добавлено в библиотеку","REMOVED_FROM_LIB":"Удалено из библиотеки","TRAILER":"Трейлер","WATCH_TRAILER":"Смотреть трейлер","WATCH_NOW":"Смотреть","SHOW":"Показать","SHOW_MOVIE":"Показать фильм","WATCH_RANDOM":"Смотреть в случайном порядке","IMDB_RATING":"Рейтинг IMDb","YEAR":"Год","DIRECTOR":"Режиссёр","WRITER":"Писатель","LEAD_ACTORS":"Основные актёры","CAST":"Актёры","CREW":"Команда","SHOW_MORE_CAST":"Показать больше »","AIRED":"Выпуск","SEASONS":"Сезоны","GENRE":"Жанр","CATALOG":"Каталог","SUMMARY":"Описание","SHOW_MORE":"Показать больше","SIMILAR":"Похожее","UPCOMING":"Скоро","ENDED":"Закончилось","DURATION":"Продолжительность","FEATURED":"Представлено","METADATA":"Метаданные","CATEGORY":"категория","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"поиск видео","SEARCH_PLACEHOLDER":"поиск или вставка магнитной ссылки","ADDON":"Дополнение","ADDONS":"Дополнения","OFFICIAL":"Официальный","ADDONS_OFFICIAL":"Официальные дополнения Stremio","ADDONS_POPULAR":"Популярно в вашем районе","ADDON_FREE":"Бесплатно","ADDON_PEERED":"Попробовать","ADDON_SUBSCRIPTION":"Подписка","ADDON_STREAM_GEORESTRICTED":"недоступно в вашем регионе","ADDON_STREAM_OFFLINECACHE":"Офлайн-кэш","ADDON_STREAM_LOCALFILE":"Локальный файл","SHARE_ADDON":"Поделиться дополнением","AVAILABLE_STREAMS":"Доступные стримы","NO_STREAM":"Нет стримов","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Для большего количества стримов установите больше дополнений","STREAM_NOT_SUPPORTED":"Выбранные стримы не поддерживаются на этой платформе.","ADDON_CATALOGUE":"Показать все дополнения »","ADDON_CATALOGUE_MORE":"Больше дополнений »","REPO_ADDED":"Репозиторий добавлен","ADDON_REPO_EXIST_ERR":"Этот репозиторий дополнений уже существует","ADDON_REPO_ERR":"Ошибка при добавлении репозитория","ADDON_ADD_ERR":"Ошибка при добавлении дополнения","ERR_ADDON_PROTECTED":"Защищенное дополнение","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Что-то пошло не так — возможно, аутентификация не удалась","ERR_NOT_COLLECTION_URL":"Не URL-адрес коллекции","ERR_NOT_ADDON_URL":"Не URL-адрес дополнения","ERR_DETECTFROMURL":"Не удается обнаружить по URL-адресу","ADDON_DUPLICATE_WARNING":"Внимание: дублирующееся дополнение","ADDON_COLLECTION_SET_FAILED":"Не удалось установить коллекцию дополнений","SETTINGS_DATA_EXPORT":"Экпорт данных","ADDON_PULL_FAILED":"Синхронизация установленных дополнений из вашей учетной записи не удалась","REFRESH_ON_CLICK":"Нажмите, чтобы повторить","STILL_IN_THEATER":"Фильм все еще показывают в кинотеатрах","WATCH_IN_CINEMA":"Смотрите его в местном кинотеатре","IN_THEATER":"В кино","GET_TICKETS":"Купить билеты","UPCOMING_EPISODE":"Предстоящий эпизод","UPCOMING_EPISODE_MESSAGE":"Этот эпизод выйдет в эфир","MISSING_DATE_EPISODE":"Дата отсутсвует","MISSING_DATE_EPISODE_MESSAGE":"Возможно, этот эпизод еще не выпущен","CHANNEL_NOT_SCRAPED":"Этот канал ещё не просканирован.
Пожалуйста, вернитесь через несколько минут.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Добавьте в библиотеку, чтобы получить уведомление, как только станет доступно.","GET_NOTIFIED_WHEN_AVAILABLE":"Вы получите уведомление, как только станет доступно.","WARNING_STREAMING_SERVER":"Внимание: локальный стриминговый сервер не найден. Стриминг из локальных файлов, YouTube и BitTorrent будет недоступен.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Внимание: это видео может не поддерживаться вашим оборудованием. Имейте в виду, что воспроизведение может быть замедленным.","PLAYER_ERROR":"Упс, ошибка воспроизведения","PLAYER_ERROR_LOOKSLIKE":"Выглядит как","PLAYER_ORIENTATION":"Ориентация плеера","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Заблокировано","PLAYER_ORIENTATION_SENSOR_SHORT":"По датчику наклона","PLAYER_ORIENTATION_LANDSCAPE":"Ориентация плеера заблокирована в альбомной ориентации","PLAYER_ORIENTATION_SENSOR":"Автоматическая ориентация плеера (датчик)","PLAYER_PLAYBACK_SPEED":"Скорость воспроизведения","PLAYER_PLAYBACK_ERROR":"Ошибка воспроизведения, пожалуйста, попробуйте снова","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Неизвестная ошибка","PLAYER_PLAYBACK_ERROR_DEFAULT":"Извините, это видео не может быть воспроизведено {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Смотрите далее","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Отклонить","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Смотреть","STREAMING_FROM":"Стрим от","CASTING_TO":"Стим для","NETWORK_STATUS":"Состояние сети","STREAM_SPEED":"Скорость:","STREAM_BUFFERED":"Загружено:","PEERS_INFO":"Информация о пирах","PEERS_ACTIVE":"Активны:","PEERS_CONNECTED":"Подключены:","PEERS_WAITING":"Ждут:","TRANSCODING_WARNING":"Внимание: перекодирование видео.","STREAM_LOADING":"Загрузка...","PLAYING_LOCAL":"Из локального файла","PLAYING_CACHE":"Из кэша","WRONG_SUBS":"Некорректные субтитры?","ERR_SUBS_LOADING_TITLE":"Ошибка загрузки субтитров","ERR_SUBS_LOADING":"Не удалось загрузить субтитры: это может быть связано с используемым вами дополнением или с сетевым подключением","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Не удалось выполнить следующие дополнения субтитров","ERR_CASTING_UPDATE_TITLE":"Не удалось обновить информацию об устройстве трансляции: стриминг-сервер, возможно, отключен","CHOOSE_DEVICE":"Выберите устройство для просмотра","NO_CAST_DEVICES":"Нет доступных устройств.","NO_SETTINGS":"Настройки недоступны.","PHONE_TABLET":"Телефон/планшет","SUBTITLES":"Субтитры","SUBTITLES_CHANGE":"Изменить субтитры для ","SUBTITLES_CHANGE_NONE":"К сожалению, нет других субтитров для этого языка","SUBTITLES_CHANGE_ACIVE":"Сейчас выбраны субтитры #{{subtitlesDialog.activeIdx + 1}}. Нажмите \\"Продолжить\\", чтобы выбрать субтитры #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Как вариант,","SUBTITLES_ADJUST_DELAY":"Настроить задержку субтитров:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Или использовать клавиши G/H во время вопроизведения для настройки.","SUBTITLES_ADJUST_DELAY_TIP":"Совет: вы можете использовать клавиши G/H во время вопроизведения для настройки.","SUBTITLES_DELAY":"Задержка субтитров:","SUBTITLES_LOADING":"Загрузка субтитров...","SUBTITLES_UNAVAILABLE":"Нет доступных внешних субтитров","SUBTITLES_DISABLED":"Отключено","AUDIO":"Аудио","DEFAULT_LANGUAGE":"Язык по умолчанию","DEFAULT_SECONDARY_LANGUAGE":"Дополнительный язык по умолчанию","SEASON":"Сезон","EPISODE":"Эпизод","SPECIAL":"Особый","SORT":"Сортировать","SORT_BY":"Сортировать по","FILTER":"Фильтровать","SORT_TRENDING":"Лидеры","SORT_RECENT":"Недавние","SORT_ALPHABET":"А-я","SORT_RATING":"Рейтинг","SORT_WATCHED":"Просмотрено","SORT_YEAR":"Год","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Новые для вас","New Episodes":"Новые эпизоды","New Videos":"Новые видео","Recommendations":"Рекомендации","LIBRARY_RESUME":"Продолжить","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Подробности","LIBRARY_RESUME_DISMISS":"Сбросить","LIBRARY_CLEAR_PROGRESS":"Очистить прогресс","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Рекомендуемые","DISCOVER_TOP":"Топ","DISCOVER_OSCAR":"Победители Оскара","DISCOVER_WARNING_TITLE":"Ой!","DISCOVER_EMPTY_CATALOG":"Это дополнение вернуло пустой контент.","DISCOVER_ADULT_WARNING":"Контент доступен только взрослым. Вам 18+?","DISCOVER_NOADDON_WARNING":"Внимание: не было найдено активного дополнения для этого типа. Показаны только сохранённые элементы, обновления не могут быть выполнены.","DISCOVER_LOAD_ERR":"Контент не загрузился, произошла ошибка.","DISCOVER_ADDON_UNINSTALLED":"Этот контент больше не доступен, возможно, вы удалили дополнение.","UNINSTALL_THIS_ADDON":"Удалить дополнение","ERR_ADDON_NOT_INSTALLED":"Это дополнение не установлено. Установить?","DETAIL_RECEIVE_NOTIF_SERIES":"Получать уведомления о новых эпизодах","DETAIL_RECEIVE_NOTIF_VIDEOS":"Получать уведомления о новых видео","SIDEBAR_SHOW_STREAMS":"Показать стримы","RELAUNCH":"Перезапустить!","UPGRADE":"Доступная новая версия! Обновите Stremio до последней версии","RELOAD_UI":"Перезагрузить пользовательский интерфейс","MANUAL_UPDATE_TITLE":"Обновите версию Stremio","MANUAL_UPDATE_LINE1":"Вы используете устаревшую версию Stremio, которая крайне не рекомендуется.","MANUAL_UPDATE_LINE2":"Пожалуйста, обновите как только получится.","BUTTON_UPDATE_LATTER":"Не сейчас","BUTTON_UPDATE_NOW":"Обновить","ANONYMOUS_USER":"Анонимный пользователь","DONT_HAVE_ACC":"Нет аккаунта?","HAVE_ACC":"Уже есть аккаунт?","PASSWORD":"Пароль","PASSWORD_CONFIRM":"Подтвердить пароль","EMAIL":"Эл. почта","FB_LOGIN":"Войти с Facebook","FB_NOTHINGSHARED":"Мы не будем ничем делиться без вашего согласия","FB_NOPOST":"Мы не будем ничего публиковать без вашего согласия","OR":"или","I_ACCEPT":"Я принимаю","I_ACCEPT_BY_CLICKING":"Нажимая кнопку выше, я подтверждаю, что принимаю ","TOS":"Условия и положения","MUST_ACCEPT_TERMS":"Вы должны принять условия","PASSWORDS_NOMATCH":"Пароли не совпадают","SIGN_UP":"Регистрация","SIGN_UP_EMAIL":"Зарегистроваться с эл. почтой","CLICK_TO_SIGN_UP":"Нажмите здесь, чтобы зарегистрироваться.","LOG_IN":"Войти","LOG_OUT":"Выйти","EXIT_FULLSCREEN":"Выйти из полноэкранного режима","ENTER_FULLSCREEN":"Войти в полноэкранный режим","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Помощь и обратная связь","TERMS_OF_SERVICE":"Условия обслуживания","PRIVACY_POLICY":"Политика конфиденциальности","ABOUT_STREMIO":"О Stremio","USER_PANEL":"Панель пользователя","LOGIN_LABEL":"Войти","GUEST_LOGIN":"Войти как гость","GUEST_LOGIN_NOTICE":"Гостевой вход не рекомендуется. Использование обычного входа позволяет Stremio синхронизировать вашу библиотеку, получать уведомления о любимых сериалах/каналах. Вы уверены, что хотите продолжить?","GUEST_LOGIN_NOTICE_2":"Гостевой вход не рекомендуется. У вас не будет синхронизированной библиотеки и доски уведомлений, которые являются очень важными функциями Stremio. Вы уверены, что хотите продолжить?","CLICK_HERE":"нажмите здесь","WRONG_PASSWORD":"Неправильный пароль. Если вы забыли свой пароль, ","SET_A_PASS":"установить пароль","RESET_PASSWORD":"Сброс пароля","FORGOT_PASSWORD":"Забыли пароль?","EMAIL_USED_WITH_FB":"Эта эл. почта была использована с логином Facebook.","INVALID_EMAIL":"Пожалуйста, введите действительный адрес эл. почты","INVALID_PASSWORD":"Пожалуйста, введите действительный пароль","CONN_ERR":"Ошибка подключения. Повторите попытку позже.\\n\\nЕсли проблема не устранится, отключите брандмауэры/антивирусное ПО (особенно Bitdefender).","IMPORT_FROM_GUEST":"Импорт библиотеки из гостевой учетной записи","RECEIVE_UPDATES_EMAIL":"Получайте обновления от Stremio на свою эл. почту","LOGIN_FAILED":"Ошибка входа.","SIGNUP_FAILED":"Регистрация не удалась.","SEARCH_FAILED":"Поиск не удался","EMAIL_USED":"Эта эл. почта уже используется.","WAITING_FB_LOGIN":"Вход через Facebook...","EXTERNAL_PLAYER_TITLE":"Воспроизвести во внешнем плеере","EXTERNAL_REMEMBER_PLAYER":"Хотите запомнить свой выбор","EXTERNAL_ALWAYS_PLAY":"Да","EXTERNAL_ONLY_ONCE":"Нет","BEST_FIT":"Наиболее подходящее","FIT_SCREEN":"По размеру экрана","FILL":"Заполнить","16:9":"16:9","4:3":"4:3","Original":"Оригинал","INTRO_TASTE":"Расскажите, что вам нравится","INTRO_TASTE_LONG":"Расскажите нам о том, что вы хотели бы посмотреть","INTRO_TASTE_PICK":"Выберите {{interestsRemaining}} интересов","INTRO_TASTE_PICK_MORE":"Выберите больше интересов {{interestsRemaining}}","INTRO_TASTE_HELP_US":"Помогите нам лучше узнать вас.","INTRO_TASTE_CHOOSE_THESE":"Выберите некоторые из них:","INTRO_TASTE_CHOOSE_MIN":"Выберите не менее 3 категорий","INTRO_TASTE_CHOOSE_MIN_ERR":"Вы должны выбрать минимум 3 категории!","INTRO_TASTE_LIFESTYLE":"Образ жизни","INTRO_TASTE_SPORTS":"Спорт","INTRO_TASTE_FOOD_HEALTH":"Еда и здоровье","INTRO_TASTE_BEAUTY_FASHION":"Красота и мода","INTRO_TASTE_NEWS":"Новости","INTRO_TASTE_GAMING":"Игры","INTRO_TASTE_SCIENCE_EDU":"Наука и образование","INTRO_TASTE_MUSIC":"Музыка","INTRO_TASTE_TRAVEL":"Путешествия","INTRO_TASTE_LATE_NIGHT":"Ночное шоу","INTRO_TASTE_REALITY":"Реалити","INTRO_TASTE_COMEDY":"Комедия","INTRO_TASTE_DIY":"Сделать своими руками","INTRO_TASTE_TECH":"Технологии","INTRO_TASTE_CINEMA":"Кино","ADDON_NOT_SUPPORTED":"Выбранное дополнение не поддерживается на этой платформе.","ADDON_DISCLAIMER":"Использование посторонних дополнений всегда будет предметом вашей личной ответственности и попадает под регулирующее законодательство той юрисдикции в которой вы находитесь.","ADDON_ACTIVATE":"активировать это дополнение?","ADDON_REPO_ADD":"URL-адрес репозитория дополнения","ADDON_ADD":"Добавить","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Что нового","BUTTON_CONTINUE":"Продолжить","BUTTON_ACTIVATE":"Активировать","BUTTON_ACTIVATED":"Активировано","BUTTON_CANCEL":"Отмена","BUTTON_SUBMIT":"Отправить","BUTTON_DISMISS_ALL":"Отклонить все","BUTTON_VIEW_ALL":"Посмотреть все","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Ваша библиотека пуста. Узнайте, насколько она полезна :)","HOW_START":"Как начать:","LIB_EMPTY_CAL":"Ваш календарь показывает сериалы в библиотеке.","HOW_START_CAL":"Как вы можете добавить сериал:","LIB_EMPTY_BOARD":"Таблица показывает уведомления и рекомендации, относящиеся к вашей библиотеке.","HOW_START_BOARD_WAIT":"Пожалуйста, добавьте несколько серий или каналов к вашей библиотеке и дайте нам несколько минут для обработки :)","HOW_START_BOARD":"Вот как вы можете добавить сериалы и фильмы:","IMPORT_FB":"Импорт понравившегося материала из Facebook","IMPORT_TRAKT":"Импорт медиатеки из Trakt","IMPORT_DISCOVER":"Найти интересный материал в Открытиях","IMPORT_DISK":"Импорт видео из локального диска","PLEASE_CREATE_ACC":"Пожалуйста, создайте аккаунт, чтобы включить синхронизацию библиотеки и доски.","IMPORT_DISCOVER_SIGNUP":"Зарегистрируйтесь и находите интересные материалы в Открытиях","IMPORT_DISK_SIGNUP":"Зарегистрируйтесь и импортируйте фильмы или шоу из вашего локального диска","LIB_EMPTY_CLOUD":"Облачная бибилиотека","LIB_EMPTY_CLOUD_DESC":"Личная облачная библиотека синхронизируется на всех устройствах","LIB_EMPTY_EARLY":"Ранняя птичка","LIB_EMPTY_EARLY_DESC":"Получайте уведомления о новых эпизодах","LIB_EMPTY_PERSONAL":"Личное","LIB_EMPTY_PERSONAL_DESC":"Получите личные рекомендации","LIB_EMPTY_CALENDAR_DESC":"Запланируйте свой личный календарь просмотра","LIB_EMPTY_ALL":"Зарегистрируйтесь, чтобы получить всё это:","LIB_EMPTY_BEST":"Зарегистрируйтесь, чтобы получить всё лучшее от Stremio","LIB_EMPTY_OTHER":"Зарегистрируйтесь, чтобы включить календарь и другие крутые функции","CALENDAR_ADDED":"Календарь Stremio был добавлен в ваш настольный календарь по умолчанию.","CALENDAR_ADDED_MSG":"Если не сработало, добавьте этот URL-адрес в приложение календаря вручную","TRAKT_EXPIRED":"Срок действия аутентификации Trakt истек, перейдите в настройки и повторите аутентификацию.","TRAKT_REQUIRES_LOGIN":"Ошибка Trakt","TRAKT_REQUIRES_LOGIN_MSG":"Необходимо войти","SETTINGS_LABEL":"Настройки","SETTINGS_NAV_GENERAL":"Общее","SETTINGS_NAV_PLAYER":"Плеер","SETTINGS_NAV_STREAMING":"Стриминг","SETTINGS_NAV_SHORTCUTS":"Ярлыки","SETTINGS_SHORTCUT_RELOAD_APP":"Перезагрузить приложение","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Открыть настройки","SETTINGS_SHORTCUT_SWITCH_TABS":"Переключить вкладки","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Перелистывать вкладки вперёд","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Перелистывать вкладки назад","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Выйти/Вернуться","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Переключить полноэкранный режим","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Показать элементы управления","SETTINGS_SHORTCUT_PLAY_PAUSE":"Воспроизведение/Пауза","SETTINGS_SHORTCUT_VOLUME_UP":"Громче","SETTINGS_SHORTCUT_VOLUME_DOWN":"Тише","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Увеличить размер субтитров","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Уменьшить размер субтитров","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"величить задержку субтитров","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Уменьшить задержку субтитров","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Переключить боковую панель","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Запуск при старте","SETTINGS_VLC_DEFAULT":"Воспроизвести в VLC","SETTINGS_UI_LANGUAGE":"Язык интерфейса","SETTINGS_FULLSCREEN_EXIT":"Выход из полноэкранного режима клавишей Escape","SETTINGS_GAMEPAD":"Включить поддержку геймпада","SETTINGS_CLOSE_WINDOW":"Закрывать приложение, когда окно закрыто","SETTINGS_SUBTITLES_LANGUAGE":"Язык субтитров по умолчанию","SETTINGS_SUBTITLES_SIZE":"Размер субтитров по умолчанию","SETTINGS_SUBTITLES_BACKGROUND":"Фон субтитров","SETTINGS_SUBTITLES_COLOR":"Цвет субтитров","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Цвет контура субтитров","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Цвет фона субтитров","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Автовоспроизведение следующего эпизода","SETTINGS_NEXT_VIDEO":"Показывать уведомление перед началом следующего эпизода","SETTINGS_NEXT_VIDEO_TRIGGER":"Показывать уведомление о следующем эпизоде для:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Автоизменение размера окна перед вопроизведением","SETTINGS_OVERRIDE_SERVER":"Переопределить URL-адрес сервера стриминга (дополнительно)","SETTINGS_SERVER_URL":"URL-адрес стримингового сервера: ","SETTINGS_SERVER_AVAILABLE":"Стриминговый сервер доступен.","SETTINGS_SERVER_UNAVAILABLE":"Стриминговый сервер недоступен.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Конечная точка HTTPS-стриминга: ","SETTINGS_USE_BETA":"Всегда использовать последнюю бета-версию","SETTINGS_IMPORT_FB":"Импорт из Facebook","SETTINGS_IMPORT_DISK":"Импорт из локального диска","SETTINGS_IMPORT_TRAKT":"Импорт из Trakt","SETTINGS_PAUSE_MINIMIZED":"Приостановить воспроизведение при сворачивании","SETTINGS_HWDEC":"Декодирование с аппаратным ускорением","SETTINGS_BACKGROUND":"Фоновое воспроизведение","SETTINGS_SUBSCRIBE_CALENDAR":"Подписаться на календарь","SETTINGS_REQ_EXPORT":"Запросить экспорт данных","SETTINGS_ACC_DELETE":"Запросить удаление аккаунта","SETTINGS_CHANGE_PASSWORD":"Изменить пароль","SETTINGS_TOS":"Условия использования","SETTINGS_SUPPORT":"Связаться с поддержкой","SETTING_LANGUAGE":"Язык","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Выйти из Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Отсканируйте QR-код, чтобы открыть удалённо","SETTINGS_DESKTOP_NOTIFICATIONS":"Уведомления на рабочем столе","SETTINGS_DATA_SAVER":"Экономия трафика","SETTINGS_LANGUAGE_INTERFACE":"интерфейс","SETTINGS_LANGUAGE_SUBS":"субтитры по умолчанию","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Автовыбор аудиодорожки","SETTINGS_DEFAULT_AUDIO_TRACK":"Аудиодорожка по умолчанию","SETTINGS_ACCOUNT":"аккаунт","SETTINGS_VERSION":"версия","SETTINGS_MPV_WINDOW":"Запускать плеер в отдельном окне (дополнительно)","SETTINGS_PLAY_IN_EXTERNAL":"Всегда запускать видео во внешнем плеере","SETTINGS_STORAGE_BUTTON":"Очистить локальное хранилище","SETTINGS_STORAGE_MODAL_TITLE":"Вы уверены?","SETTINGS_STORAGE_MODAL_MESSAGE":"Это очистит локальное хранилище и вы выйдете из приложения.","SETTINGS_HWDEC_PICKER":"Выберите настройку декодирования с аппаратным ускорением","SETTINGS_HW_AUTOMATIC":"Автоматически","SETTINGS_HW_DISABLED":"Отключено","SETTINGS_HW_ACCELERATED":"Ускорение декодирования","SETTINGS_HW_FULL":"Полное ускорение","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Аудио","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Использовать чёрный цвет фона","SUBSPICKER_VERTICAL_OFFSET":"Вертикальное смещение","SUBSPICKER_SIZE":"Размер","SUBSPICKER_DELAY":"Задержка","SUBSPICKER_EMBEDDED_SUBS":"Встроенные субтитры","MOBILE_PRIVACY_POLICY":"Политика конфиденциальности","MOBILE_CRASH_REPORTING":"Сообщение о сбоях","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"ПРОИЗВОДИТЕЛЬНОСТЬ И СТАБИЛЬНОСТЬ","MOBILE_SERVER_ONLINE":"Онлайн","MOBILE_SERVER_OFFLINE":"Офлайн","MOBILE_QR_EXPIRES":"Действие QR-кода истекает через ","MOBILE_LOG_INTO":"Войдите в ваш аккаунт Stremio ","MOBILE_SCAN_QR":"Отсканируйте QR-код выше или перейдите на ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Отмена","MOBILE_SPEEDPICKER_LABEL":"Выберите скорость воспроизведения","MOBILE_EMPTY_LIBRARY":"Ваша библиотека пуста","MOBILE_NO_ADDON_ACTIVE":"Дополнение Stremio не активно для этого типа.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"ещё загружается","MOBILE_ADDONS_LOADING":"дополнения ещё загружаются","MOBILE_ADDON":"Дополнение","MOBILE_CONFIGURE_ADDON":"Настройте ваше дополнение","MOBILE_CONFIGURE_ADDON_LABEL":"Настроить дополнение","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Отключить","MOBILE_LOOKING_FOR_DEVICES":"Поиск устройства...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"Вкл.","NAVIGATION_OFF":"Выкл.","MARKETING_AGREE":"Я согласен получать маркетинговые сообщения от Stremio","QUIT":"Выход!","CONNECTED":"Подключено","AUTHENTICATE":"Проверять подлинность","CACHING":"Кэширование","SETTINGS_CACHING_DRIVE":"Выберите диск кэширования","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Включить удалённые HTTPS-соединения","TORRENT_PROFILE":"Торрент-профиль","DATA_CACHING":"Кэширование данных","MAGNET_PARSING":"Парсинг магнет-ссылки","January":"Января","February":"Февраль","March":"Март","April":"Апрель","May":"Май","June":"Июнь","July":"Июль","August":"Август","September":"Сентябрь","October":"Октября","November":"Ноября","December":"Декабрь","Monday":"Понедельник","Tuesday":"Вторник","Wednesday":"Среда","Thursday":"Четверг","Friday":"Пятница","Saturday":"Суббота","Sunday":"Воскресенье","Action":"Боевик","Comedy":"Комедия","War":"Война","Family":"Семья","Animation":"Анимация","Adventure":"Приключения","Fantasy":"Фантазия","Crime":"Криминал","Mystery":"Таинственность","Romance":"Романтика","Drama":"Драма","Horror":"Ужасы","Thriller":"Триллеры","Sci-Fi":"Научная фантастика","Music":"Музыка","Biography":"Биография","Documentary":"Документальный","Sport":"Спорт","Musical":"Музыкальный","Western":"Вестерн","Film-Noir":"Нуар","News":"Новости","History":"История","Game-Show":"Игровое шоу","Reality-TV":"Реалити шоу","Talk-Show":"Ток-шоу","Film & Entertainment":"Кино и развлечения","Gaming":"Игры","From TV":"Из ТВ","Lifestyle":"Стиль жизни","Science & Education":"Наука и образование","Cooking & Health":"Готовка и здоровье","Beauty & Fashion":"Красота и мода","Sports":"Спорт","News & Politics":"Новости и политика","How-to & DIY":"Сделай сам","Tech":"Технологии","Automotive":"Автомобильный","Causes & Non-Profits":"Коммерческое и некоммерческое","Movies":"Кино","Uk Live Tv":"Прямой эфир в Великобритании","Fashion":"Мода","Business News Radio":"Радио о бизнес-новостях","Business Tv":"Бизнес ТВ","Cars & Auto":"Автомобили и авто","Comedy Radio":"Комедийное радио","Lifestyle Radio":"Радио об образе жизни","News Tv":"Новости ТВ","Food And Wine":"Еда и вино","Latino Tv":"Латинское ТВ","Shopping Tv":"Покупки ТВ","Religion":"Религия","Kids":"Дети","Body & Soul":"Тело и душа","Education":"Образование","Indian Tv":"Индийское ТВ","Extreme Sports":"Экстремальный спорт","Middle Eastern Tv":"Ближневосточное ТВ","Celebrity Tv":"Знаменитость ТВ","Science Tv":"Наука ТВ","Bikini babe":"Попки в бикини","Outdoors":"На открытом воздухе","German Tv":"Немецкое ТВ","French Tv":"Французское ТВ","Italian Tv":"Итальянское ТВ","Gamer Tv":"Геймерское ТВ","Travel":"Путешествия","Asian Tv":"Азиатское ТВ","Entertainment":"Развлечения","News Radio":"Новостное радио","Music Radio":"Музыкальное радио","Language Learning":"Изучение языков","Science Radio":"Научное радио","Tech Radio":"Техническое радио","Science & Technology Vod":"Наука и технологии VoD","new video":"новое видео","new episode":"новый эпизод","new movie":"новый фильм","recommended":"рекомендуемое","we recommend":"мы рекомендуем","offer of the day":"предложение дня","news":"новости","music video":"мызкальное видео","CTX_SHOW_HOTKEYS":"Показать горячие клавиши","CTX_DISMISS_NOTIF":"Игнорировать уведомления","CTX_DISMISS_ALL":"Отклонить все","CTX_SHARE":"Поделиться","CTX_COPY_SHARE_LINK":"Скопировать ссылку","CTX_COPY_MAGNET_LINK":"Скопировать магнитную ссылку","CTX_COPY_STREAM_LINK":"Скопировать ссылку на стрим","CTX_DOWNLOAD_VIDEO":"Скачать видео","CTX_DOWNLOAD_SUBS":"Скачать субтитры","CTX_VIEW_ON_YOUTUBE":"Смотреть на YouTube","CTX_SHOW":"Показать","CTX_PLAY":"Вопроизвести","CTX_PLAY_IN":"Воспроизвести в","CTX_PLAY_ON":"Воспроизвести на","CTX_WATCH_ON":"Смотреть на","CTX_WATCH":"Смотреть","CTX_WATCHED":"Просмотрено","CTX_WATCH_BEGINNING":"Смотреть с начала","CTX_WATCH_MOBILE":"Смотреть на мобильном устройсте","CTX_REWIND":"Перемотать на начало","CTX_MARK_WATCHED":"Отметить как просмотренное","CTX_MARK_NON_WATCHED":"Отметить как непросмотренное","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Получать новые уведомления","CTX_REMOVE_CACHE":"Удалить из кэша","CTX_REMOVE_CACHE_EP":"Удалить эпизод из кэша","CTX_OPEN_CONTAINING":"Открыть папку с файлом","CTX_REMOVE":"Удалить из библиотеки","CTX_AVAILABLE_OFFLINE":"Доступно без интернета","CTX_PAUSED":"Остановлено","CTX_ALWAYS_ON_TOP":"Закреплено","CTX_FULLSCREEN":"Полный экран","CTX_WRONG_SUBS":"Некорректные субтитры","CTX_REPORT_ISSUES":"Сообщить о проблеме","CTX_COPY":"Копировать","CTX_PASTE":"Вставить","CTX_CLEAR":"Очистить","CTX_CLEAR_RECENT_SEARCHES":"Очистить историю поисковых запросов","HELLO_THERE":"Привет","HOPE_YOU_ENJOY":"Надеемся, что вам нравится Stremio и это одно из ваших любимых приложений!","WHO_ARE_WE":"Кто мы? Мы — команда, стоящая за этим, — два парня, которые усердно работают каждый день в течение последних 3 лет с одной целью — делать этот продукт всё лучше и лучше.","SUPPORT_US":"Если вам нравится Stremio, если Stremio ценен для вас — расскажите об этом!","SPREAD_THE_WORD":"Поделитесь с друзьями прямо сейчас, расскажите о Streamio","MORE_PEOPLE":"Чем больше людей пользуются Streamio, тем лучше он становится","SEND_A_LINK":"Или отправьте ссылку на наш сайт","TIP_LOCALFILES":"Совет: вы можете перетаскивать локальные видеофайлы в Stremio.","ADDON_MY":"Мои дополнения","ADDON_COMMUNITY":"Дополнения от сообщества","ADDON_OFFICIAL":"Официальные дополнения","ADDON_REPOS":"Репозитории дополнений","ADDON_SEARCH":"Искать плагины","ADDON_INSTALL":"Установить","ADDON_CONFIGURE":"Настроить","ADDON_UNINSTALL":"Удалить","ADDON_UPGRADE":"Обновить","ADDON_INSTALLED":"Установлено","ADDON_INSTALLED_MSG":"Дополнение установлено!","ADDON_UPGRADED_MSG":"Дополнение обновлено!","ADDON_UNKNOWN":"Неизвестно","ADDON_ERR":"Ошибка установки дополнения!","ADDON_DISCONNECTED":"Отключено","ADDON_APP_MISSING":"приложение для этого источника не установлено. Вы хотите установить его сейчас?","ADDON_APP_INSTALL":"Установить","ADDON_PAGE":"Страница дополнения","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Дополнение","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Скачать сейчас","WEBSITE_DOWNLOAD_FOR":"Скачать сейчас для","WEBSITE_IS_DESKTOP":"Stremio — это настольное приложение, откройте эту страницу на своем ПК и скачайте его","WEBSITE_DESKTOP_DEMO_VID":"Демо","WEBSITE_PAGE_HOME":"Главная","WEBSITE_PAGE_FEATURES":"Возможности","WEBSITE_PAGE_ADDONS":"Дополнения","WEBSITE_PAGE_TECH":"Технологии","WEBSITE_PAGE_CREATE_ADDON":"Создать дополнение","WEBSITE_PAGE_CONTACTS":"Контакты","WEBSITE_PAGE_BLOG":"Блог","WEBSITE_TYPE_movie":"Фильмы","WEBSITE_TYPE_series_PL":"Сериалы","WEBSITE_TYPE_tv":"В эфире","WEBSITE_TYPE_channel":"Каналы","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Нажмите и смотрите свои любимые фильмы, ТВ-шоу, видео и телеканалы.","WEBSITE_FEATURES_SUBS":"Автоматические субтитры","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio автоматически выбирает синхронизированные субтитры для вашего языка.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Импорт из Facebook","WEBSITE_LIB_LOCAL":"Добавить с локального диска","WEBSITE_BOARD":"Доска — ваше универсальное место для уведомлений и рекомендаций","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Популярный фильм","WEBSITE_BOARD_NEW":"Новое видео","WEBSITE_BOARD_EPISODE":"Новый эпизод","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"Новые видео из каналов YouTube","WEBSITE_BOARD_EPISODES":"Новые серии из сериалов, за которыми вы следите","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"Мы основные участники проекта","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"Мы участники проекта","WEBSITE_TECH_LINVODB":"Технология базы данных, гарантирующая что ваши данные организованы и доступны везде, где вы входите в приложение.","WEBSITE_TECH_LINVODB_EXTRA":"Собственная технология","WEBSITE_CREATE_ADDON":"Создайте свое дополнение","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Расскажите о Stremio:","WEBSITE_CONTACT":"Если вы хотите связаться с нами, перейдите по адресу","WEBSITE_OPENSOURCE":"Чтобы посмотреть наши проекты с открытым кодом, перейдите на","WEBSITE_BITCOIN":"Пожертвовать Bitcoin:","WEBSITE_FAQ":"Часто задаваемые вопросы","WEBSITE_FAQ_SHORT":"ЧЗВ","WEBSITE_QUESTIONS":"Вопросы","WEBSITE_TOS":"Условия использования","WEBSITE_LEGAL":"Юридическое","WEBSITE_PAGE_ABOUT":"О проекте","WEBSITE_PAGE_BECOME_PARTNER":"Стать партнером","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"Что такое Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio — это универсальный центр видеоконтента. Находите, упорядочивайте и просматривайте видео из любых источников на любом устройстве, которое у вас есть.","WEBSITE_WHAT_IS_STREMIO_P2":"Фильмы, ТВ-шоу, сериалы, прямое телевидение или веб-каналы, такие как YouTube и Twitch.tv — все это вы можете найти на Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Фильмы, ТВ-передачи, прямые телепередачи или веб-каналы — все это можно найти на Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Наслаждайтесь этим на любых мультимедийных устройствах","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Импорт из Facebook","WEBSITE_DEVICES_LOCAL":"Добавить с локального диска","WEBSITE_JOIN_THE_PARTY_NOW":"Присоединяйтесь к тусовке","WEBSITE_DEVICES_ALL":"Легко использовать на всех ваших устройствах;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"О нас","WEBSITE_LINK_TECHNOLOGY":"Технологии","WEBSITE_LINK_APPS":"Приложения","WEBSITE_LINK_DOWNLOADS":"Скачать","WEBSITE_MORE":"Больше","WEBSITE_LINK_ADDONS":"Дополнения","WEBSITE_LINK_ADDON_SDK":"SDK дополнения","WEBSITE_LINK_CONTRIBUTE":"Участвовать","WEBSITE_LINK_COMMUNITY":"Сообщество","WEBSITE_LINK_BLOG":"Блог","WEBSITE_MORE_MORE":"...и ещё","WEBSITE_LINK_HELP":"Центр помощи","WEBSITE_LINK_CONTACTS":"Контакты","WEBSITE_LINK_TOS":"Условия и положения","WEBSITE_LINK_PRAVACY":"Политика конфиденциальности","WEBSITE_SUBSCRIBE":"Подписаться","WEBSITE_NEWSLETTER":"Подпишитесь на нашу рассылку и получайте удивительные вещи","WEBSITE_PLACEHOLDER_EMAIL":"Ваша эл. почта","WEBSITE_COMMUNITY":"Сообщество","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Зачем нам это","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},6650:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filmi","TYPE_series":"Serije","TYPE_tv":"TV kanali","TYPE_channel":"Kanali","TYPE_other":"Ostalo","TYPE_movie_PL":"Filmi","TYPE_series_PL":"Serije","TYPE_tv_PL":"TV kanali","TYPE_channel_PL":"Kanali","TYPE_other_PL":"Ostalo","TYPE_ALL":"All","VIDEO":"Video","BACK":"Nazaj","MORE":"Več","DONE":"Done","COPY":"Kopiraj","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Razišči","Board":"Plošča","Library":"Knjižnica","My Library":"Moja Knjižnica","Calendar":"Koledar","NOTIFICATION_ONLINE":"Sedaj si povezan","NOTIFICATION_OFFLINE":"Si trenutno nepovezan","INTERNET_CONNECTION":"Mrežna povezava","STORAGE_FULL_TITLE":"Opozorilo: Prostor je poln!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"iskanje","SEARCH_NO_RESULTS":"Ni rezultatov iskanja","SEARCH_EXPLANATION_CONTENT":"Išči filme, serije, YouTube in TV kanale","SEARCH_EXPLANATION_PEOPLE":"Išči igralce, režiserje in avtorje","SEARCH_PASTE_LINKS":"Kopiraj HTTP in Magnet linke","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Dodaj v knjižnico","REMOVE_FROM_LIB":"Odstrani iz knjižnice","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Napovednik","WATCH_TRAILER":"Predvajaj Napovednik","WATCH_NOW":"Glej sedaj","SHOW":"Show","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb Rating","YEAR":"Leto","DIRECTOR":"Režiser","WRITER":"Avtor","LEAD_ACTORS":"Glavni igralci","CAST":"Postava","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Objavljeno","SEASONS":"Sezone","GENRE":"Žanr","CATALOG":"Catalog","SUMMARY":"Povzetek","SHOW_MORE":"Show More","SIMILAR":"Podobno","UPCOMING":"Prihajajoče","ENDED":"Končano","DURATION":"Trajanje","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"išči video","SEARCH_PLACEHOLDER":"search or paste URL","ADDON":"dodatek","ADDONS":"Dodatki","OFFICIAL":"Glavni","ADDONS_OFFICIAL":"Glavni Stremio Dodatki","ADDONS_POPULAR":"Popularno v vašem področju","ADDON_FREE":"prosto","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"naročnina","ADDON_STREAM_GEORESTRICTED":"ni dostopno v vašem področju","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Dostopni Stream-i","NO_STREAM":"Ni dostopnih stream-ov","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Prikaži vse dodatke »","ADDON_CATALOGUE_MORE":"Več dodatkov »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons collection already exist","ADDON_REPO_ERR":"Error occurred while adding collection","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Cannot uninstall addon, it is protected","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection URL","ERR_NOT_ADDON_URL":"Not a valid addon URL","ERR_DETECTFROMURL":"Cannot find addon/collection from this URL","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Syncing installed addons to your account failed","SETTINGS_DATA_EXPORT":"Export user data","ADDON_PULL_FAILED":"Syncing installed addons from your account failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Movie still in theaters","WATCH_IN_CINEMA":"Watch it in your local cinema","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Add it to your library to get notified once it is available.","GET_NOTIFIED_WHEN_AVAILABLE":"You will get notified once it is available.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from local files, YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"streaming from","CASTING_TO":"Casting to","NETWORK_STATUS":"Network status","STREAM_SPEED":"Stream speed:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Active:","PEERS_CONNECTED":"Connected:","PEERS_WAITING":"Waiting:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"loading...","PLAYING_LOCAL":"playing from local file","PLAYING_CACHE":"playing from cache","WRONG_SUBS":"Wrong subtitles?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Choose a device to watch on","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Telefon / Tablica","SUBTITLES":"Podnapisi","SUBTITLES_CHANGE":"Change subtitles for ","SUBTITLES_CHANGE_NONE":"There are no other subtitles for this language, sorry.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Onemogočeno","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sezone","EPISODE":"Nanizanke","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"rating","SORT_WATCHED":"watched","SORT_YEAR":"year","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Novo Za Vas","New Episodes":"Nove Nanizanke","New Videos":"New Videos","Recommendations":"Priporočila","LIBRARY_RESUME":"Nadaljuj","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Podrobnosti","LIBRARY_RESUME_DISMISS":"Opusti","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oscar Winners","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonimni uporabnik","DONT_HAVE_ACC":"Nimate še računa?","HAVE_ACC":"Že imate račun?","PASSWORD":"Geslo","PASSWORD_CONFIRM":"Potrdi geslo","EMAIL":"E-mail","FB_LOGIN":"Nadaljuj z Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"or","I_ACCEPT":"Se strinjam z","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terms and Conditions","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Geslo se ne ujema","SIGN_UP":"Registracija","SIGN_UP_EMAIL":"Registracija z email naslovom","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Prijava","LOG_OUT":"Odjava","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"O Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Guest login","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"click here","WRONG_PASSWORD":"Wrong email or password. In case you have forgotten your password, ","SET_A_PASS":"set a password","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"This email was used with a Facebook login.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Activate this addon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Kaj je novega","BUTTON_CONTINUE":"Nadaljuj","BUTTON_ACTIVATE":"Aktiviraj","BUTTON_ACTIVATED":"Aktivirano","BUTTON_CANCEL":"Prekliči","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Opusti vse","BUTTON_VIEW_ALL":"pregled vseh","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Nastavitve","SETTINGS_NAV_GENERAL":"Osnovno","SETTINGS_NAV_PLAYER":"Predvajalnik","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Zaženi ob zagon","SETTINGS_VLC_DEFAULT":"Predvajaj z VLC","SETTINGS_UI_LANGUAGE":"UI Jezik","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Change password","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Contact support","SETTING_LANGUAGE":"Jezik","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Quit","CONNECTED":"Connected","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januar","February":"Februar","March":"Marec","April":"April","May":"Maj","June":"Junij","July":"Julij","August":"Avgust","September":"September","October":"Oktober","November":"November","December":"December","Monday":"Ponedeljek","Tuesday":"Torek","Wednesday":"Sreda","Thursday":"Četrtek","Friday":"Petek","Saturday":"Sobota","Sunday":"Nedelja","Action":"Akcije","Comedy":"Komedije","War":"Vojni","Family":"Družinski","Animation":"Animirani","Adventure":"Pustolovski","Fantasy":"Fantazijski","Crime":"Kriminalni","Mystery":"Mistični","Romance":"Romantični","Drama":"Drame","Horror":"Grozljivke","Thriller":"Trilerji","Sci-Fi":"Sci-Fi","Music":"Glazbeni","Biography":"Biografski","Documentary":"Dokumentarni","Sport":"Športni","Musical":"Mjuzikli","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Add-ons","ADDON_COMMUNITY":"Community Add-ons","ADDON_OFFICIAL":"Official Add-ons","ADDON_REPOS":"Addon collections","ADDON_SEARCH":"Search add-ons","ADDON_INSTALL":"Naloži","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Odstrani","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Naloženo","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You Can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Stremio 4 beta Now","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can access a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},2963:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Filmovi","TYPE_series":"Serije","TYPE_tv":"TV kanal","TYPE_channel":"Kanal","TYPE_other":"Drugo","TYPE_movie_PL":"Filmovi","TYPE_series_PL":"Serije","TYPE_tv_PL":"TV kanali","TYPE_channel_PL":"Kanali","TYPE_other_PL":"Drugo","TYPE_ALL":"All","VIDEO":"Video","BACK":"Nazad","MORE":"Više","DONE":"Gotovo","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Otkrij","Board":"Tabla","Library":"Biblioteka","My Library":"Moja Biblioteka","Calendar":"Kalendar","NOTIFICATION_ONLINE":"Sada ste povezani","NOTIFICATION_OFFLINE":"Trenutno ste bez konekcije","INTERNET_CONNECTION":"Mrežna greška","STORAGE_FULL_TITLE":"Upozorenje: nemate slobodnog prostora!","STORAGE_FULL_TEXT":"Stremio neće moći da sačuva podešavanja, prednosti ili informacije za login. Razmislite o restartovanja ili reinstalacije Stremio-a.","SEARCH":"Pretraži...","SEARCH_NO_RESULTS":"Nema pronađenih rezultata","SEARCH_EXPLANATION_CONTENT":"Pretražite filmove, serije, YouTube i TV kanale","SEARCH_EXPLANATION_PEOPLE":"Pretražite glumce, režisere i scenografe","SEARCH_PASTE_LINKS":"Nalepi HTTP i Magnet linkove","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Dodaj u Biblioteku","REMOVE_FROM_LIB":"Ukloni iz Biblioteke","ADDED_TO_LIB":"Dodato u Biblioteku","REMOVED_FROM_LIB":"Uklonjeno iz Biblioteke","TRAILER":"Najava","WATCH_TRAILER":"Pogledajte najavu","WATCH_NOW":"Gledaj sada","SHOW":"Prikaži","SHOW_MOVIE":"Prikaži film","WATCH_RANDOM":"Pusti nasumično","IMDB_RATING":"IMDb Ocena","YEAR":"Godina","DIRECTOR":"Režiser","WRITER":"Scenograf","LEAD_ACTORS":"Glavne Uloge","CAST":"Uloge","CREW":"Ekipa","SHOW_MORE_CAST":"Prikaži više »","AIRED":"Emitovano","SEASONS":"Sezona","GENRE":"Žanr","CATALOG":"Catalog","SUMMARY":"Opis","SHOW_MORE":"Pokaži više","SIMILAR":"Slično","UPCOMING":"Nadolazeće","ENDED":"Završeno","DURATION":"Trajanje","FEATURED":"Istaknuto","METADATA":"Metadata","CATEGORY":"Kategorija","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Pretraži video","SEARCH_PLACEHOLDER":"Pretraži ili nalepi magnet linkove","ADDON":"Dodatak","ADDONS":"Dodaci","OFFICIAL":"Zvanični","ADDONS_OFFICIAL":"Zvanični Stremio dodaci","ADDONS_POPULAR":"Popularno u vašem području","ADDON_FREE":"besplatno","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"pretplata","ADDON_STREAM_GEORESTRICTED":"nije dostupno u vašem području","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Lokalni fajl","SHARE_ADDON":"Podeli dodatak","AVAILABLE_STREAMS":"Dostpuni strimovi","NO_STREAM":"Nema dostupnih strimova","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Za više strimova molimo vas da instalirate više dodataka","STREAM_NOT_SUPPORTED":"Odabrani prenos nije podržan na ovoj platformi.","ADDON_CATALOGUE":"Prikaži sve dodatke »","ADDON_CATALOGUE_MORE":"Više dodataka »","REPO_ADDED":"Dodat je repository","ADDON_REPO_EXIST_ERR":"Repository ovog dodatka već postoji","ADDON_REPO_ERR":"Greška uz dodavanje repository-a","ADDON_ADD_ERR":"Greška uz dodavanje dodatka","ERR_ADDON_PROTECTED":"Zaštićeni dodatak","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Greška - Autentifikacija može da je neuspešna","ERR_NOT_COLLECTION_URL":"Nije url kolekcije","ERR_NOT_ADDON_URL":"Nije url dodatka","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Upozorenje: dupli dodatak","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Film je i dalje u bioskopu","WATCH_IN_CINEMA":"Pogledajte ga u lokalnom bioskopu","IN_THEATER":"U Bioskopu","GET_TICKETS":"Nabaviti karte","UPCOMING_EPISODE":"Sledeća epizoda","UPCOMING_EPISODE_MESSAGE":"Ova epizoda će biti emitovana","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"Ova epizoda možda još nije emitovana","CHANNEL_NOT_SCRAPED":"Ovaj kanal još nije sačuvan.
Molimo vas pokušajte za par minuta.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Dodajte u svoju biblioteku da budete obavešteni kada bude dostupno.","GET_NOTIFIED_WHEN_AVAILABLE":"Bićete obavešteni kada bude dostupno.","WARNING_STREAMING_SERVER":"Upozorenje: lokalni server za strimovanje nije pronađen. Streaming sa YouTube-a i BitTorrent-a neće biti dostupan.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Upozorenje: ovaj video možda ne podržava vaš hardver. Imajte na umu da reprodukcija može biti spora.","PLAYER_ERROR":"Ups, greška plejera","PLAYER_ERROR_LOOKSLIKE":"Izgleda kao","PLAYER_ORIENTATION":"Orijentacija plejera","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Fiksno","PLAYER_ORIENTATION_SENSOR_SHORT":"Senzor","PLAYER_ORIENTATION_LANDSCAPE":"Orijentacija plejera je fiksirana na vodoravno","PLAYER_ORIENTATION_SENSOR":"Orijentacija plejera je automatska (senzor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Izvinite, ovaj video ne može biti prikazan sa {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Uživo","PLAYER_NEXT_VIDEO_TITLE":"Sledeći na","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Gledati sada","STREAMING_FROM":"Puštanje iz","CASTING_TO":"Prikazivanje na","NETWORK_STATUS":"Mrežni status","STREAM_SPEED":"Brzina strimovanja:","STREAM_BUFFERED":"Preuzeto:","PEERS_INFO":"Peer Informacije","PEERS_ACTIVE":"Aktivno:","PEERS_CONNECTED":"Konektovano:","PEERS_WAITING":"Čekanje:","TRANSCODING_WARNING":"Upozorenje: konvertovanje videa.","STREAM_LOADING":"učitavanje...","PLAYING_LOCAL":"puštanje iz lokale datoteke","PLAYING_CACHE":"puštanje iz privremenog skladišta","WRONG_SUBS":"Pogrešan prevod?","ERR_SUBS_LOADING_TITLE":"Greška pri učitavanju titlova","ERR_SUBS_LOADING":"Greška pri učitavanju titlova: može biti do dodatka kog koristite, ili do internet konekcije","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Izaberi uređaj za gledanje","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"Podešavanja nisu dostupna.","PHONE_TABLET":"Telefon / Tablet","SUBTITLES":"Titlovi","SUBTITLES_CHANGE":"Promeni titl za ","SUBTITLES_CHANGE_NONE":"Nažalost nema drugih titlova za odabrani jezik","SUBTITLES_CHANGE_ACIVE":"Trenutno titl #{{subtitlesDialog.activeIdx + 1}} je aktivan. Klikni \\"Nastavi\\" da aktiviraš titl #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternativno,","SUBTITLES_ADJUST_DELAY":"Podešavanje odlaganja titla:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Ili koristite G / H dugmad dok puštate da podesite titlove.","SUBTITLES_ADJUST_DELAY_TIP":"Savet: možete koristiti G / H dugmad dok puštate da podesite titlove.","SUBTITLES_DELAY":"Odlaganje titlova:","SUBTITLES_LOADING":"Učitavanje titlova...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Isključeno","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sezona","EPISODE":"Epizoda","SPECIAL":"Special","SORT":"sortiraj","SORT_BY":"Sortiraj po","FILTER":"filter","SORT_TRENDING":"popularno","SORT_RECENT":"nedavno","SORT_ALPHABET":"a-z","SORT_RATING":"ocena","SORT_WATCHED":"gledano","SORT_YEAR":"godina","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Novo za vas","New Episodes":"Nove Epizode","New Videos":"Novi Video","Recommendations":"Preporuke","LIBRARY_RESUME":"nastavi","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"odbaci","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Istaktnut","DISCOVER_TOP":"Najbolji","DISCOVER_OSCAR":"Dobitnici Oskara","DISCOVER_WARNING_TITLE":"Ups!","DISCOVER_EMPTY_CATALOG":"Ovaj dodatak je uzvratio prazan sadržaj.","DISCOVER_ADULT_WARNING":"Ovaj sadržaj je dostupan samo odraslima. Imaš li 18+?","DISCOVER_NOADDON_WARNING":"Upozorenje: nema aktivnog Stremio dodatka za ovaj tip. Prikazujemo sačuvane stvari, ništa se neće nadograditi.","DISCOVER_LOAD_ERR":"Greška, sadržaj nije mogao biti učitan.","DISCOVER_ADDON_UNINSTALLED":"Ovaj sadržaj nije više dostupan, možda ste deinstalirali dodatak.","UNINSTALL_THIS_ADDON":"Deinstaliraj dodatak","ERR_ADDON_NOT_INSTALLED":"Ovaj dodatak nije instaliran. Sada instalirati?","DETAIL_RECEIVE_NOTIF_SERIES":"Dobijajte obaveštenja o novim epizodama","DETAIL_RECEIVE_NOTIF_VIDEOS":"Dobijajte obaveštenja o novim videima","SIDEBAR_SHOW_STREAMS":"Pokaži strimove","RELAUNCH":"Ponovo pokreni sada!","UPGRADE":"Nova verzija je dostupna! Ažurirajte se na poslednju Stremio verziju","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Ažurirajte vašu verziju Stremio-a","MANUAL_UPDATE_LINE1":"Trenunto koristite zastarelu verziju Stremio-a, što nije preporučeno.","MANUAL_UPDATE_LINE2":"Molimo vas da ažurirate verziju što pre.","BUTTON_UPDATE_LATTER":"Ne sada","BUTTON_UPDATE_NOW":"Ažurirati","ANONYMOUS_USER":"Anonimni korisnik","DONT_HAVE_ACC":"Nemate nalog?","HAVE_ACC":"Već imate nalog?","PASSWORD":"Lozinka","PASSWORD_CONFIRM":"Potvrdite lozinku","EMAIL":"E-mail","FB_LOGIN":"Prijavite se preko Facebook-a","FB_NOTHINGSHARED":"Ništa se ne deli bez vaše dozvole","FB_NOPOST":"Nećemo objavljivati ništa u Vaše ime","OR":"ili","I_ACCEPT":"Prihvatam","I_ACCEPT_BY_CLICKING":"Klikom na gornje dugme svedočim da prihvatam","TOS":"Uslove i Odredbe","MUST_ACCEPT_TERMS":"Morate prihvatiti uslove","PASSWORDS_NOMATCH":"Lozinke se ne podudaraju","SIGN_UP":"Registracija","SIGN_UP_EMAIL":"Prijavite se putem e-pošte","CLICK_TO_SIGN_UP":"Pritisnite ovde za registraciju.","LOG_IN":"Prijavite se","LOG_OUT":"Odjavite se","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Pomoć & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"O Stremio-u","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Prijavite se kao gost","GUEST_LOGIN_NOTICE":"Prijava kao gost nije preporučena. Koristeći redovnu prijavu Stremio omogućava sinhronizaciju svojih biblioteke i primanje obaveštenja o omiljenim serijama / kanalima. Jeste li sigurni da želite nastaviti?","GUEST_LOGIN_NOTICE_2":"Prijava kao gosti nije preporučena - nećete imati sinhronizaciju i obaveštenja Biblioteke i Table, koje su od vitalne važnosti za Stremio. Jeste li sigurni da želite nastaviti?","CLICK_HERE":"klikni ovde","WRONG_PASSWORD":"Pogrešna lozinka. U slučaju da ste zaboravili lozinku, ","SET_A_PASS":"postavite lozinku","RESET_PASSWORD":"Resetuj lozinku","FORGOT_PASSWORD":"Zaboravili ste lozinku?","EMAIL_USED_WITH_FB":"Ovaj email je korišten sa Facebook prijavom.","INVALID_EMAIL":"Unesite ispravnu e-mail adresu","INVALID_PASSWORD":"Molimo Vas da unesete ispravnu lozinku","CONN_ERR":"Greška pri povezivanju - molimo Vas pokušajte kasnije.\\n\\nAko se ovo nastavi, onemogućite zaštitni zid/antivirus (naročito Bitdefender).","IMPORT_FROM_GUEST":"Uvezite Biblioteku iz Vašeg gost naloga","RECEIVE_UPDATES_EMAIL":"Primite vesti od Stremio-a na Vaš e-mail","LOGIN_FAILED":"Neuspešna prijava.","SIGNUP_FAILED":"Prijava nije uspela.","SEARCH_FAILED":"Neuspešna istraga","EMAIL_USED":"Ovaj email je već u upotrebi.","WAITING_FB_LOGIN":"Prijavljivanje preko Facebook-a...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Hoćete li da zapamtite Vaš izbor?","EXTERNAL_ALWAYS_PLAY":"Da","EXTERNAL_ONLY_ONCE":"Ne","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Recite nam šta volite","INTRO_TASTE_LONG":"Recite nam šta biste hteli da gledate","INTRO_TASTE_PICK":"Izaberite {{interestsRemaining}} interesovanja","INTRO_TASTE_PICK_MORE":"Izaberite još {{interestsRemaining}} interesovanja","INTRO_TASTE_HELP_US":"Pomozite nam da naučimo o Vama.","INTRO_TASTE_CHOOSE_THESE":"Izaberite neke od ovih:","INTRO_TASTE_CHOOSE_MIN":"Izaberite makar tri kategorije","INTRO_TASTE_CHOOSE_MIN_ERR":"Morate izabrati makar tri kategorije!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Izabrani dodatak nije podržan na ovoj platformi.","ADDON_DISCLAIMER":"Korištenje trećih dodataka uvek će biti predmet lične odgovornosti i zakonom zemlje u kojoj se nalazite.","ADDON_ACTIVATE":"Aktiviraj ovaj dodatak?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Dodaj","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Šta je novo","BUTTON_CONTINUE":"Nastavi","BUTTON_ACTIVATE":"Aktiviraj","BUTTON_ACTIVATED":"Aktivirano","BUTTON_CANCEL":"Prekini","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Poništi sve","BUTTON_VIEW_ALL":"Vidi sve","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Vaša Biblioteka izlgeda prazna. Saznajte koliko je zapravo korisna :) ","HOW_START":"Ovako možete početi:","LIB_EMPTY_CAL":"Vaš Kalendar prikazuje serije iz Vaše Biblioteke.","HOW_START_CAL":"Ovako možete dodati serije:","LIB_EMPTY_BOARD":"Tabla prikazuje notifikacije & preporuke slične tvojoj biblioteci.","HOW_START_BOARD_WAIT":"Molimo Vas da dodate par serija ili kanala u Vašu Biblioteku i dozvolite nam par minuta da procesuiramo :)","HOW_START_BOARD":"Evo kako možete da dodate serije & flmove na nju:","IMPORT_FB":"Uvoz stvari koje Vam se sviđaju na Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Nađite zanimljive stvari u Otkrij","IMPORT_DISK":"Uvoz filmova ili serija koje imate na Vašem lokalnom disku","PLEASE_CREATE_ACC":"Molimo Vas napravite nalog da omogućite sinhronizaciju Biblioteke & Table.","IMPORT_DISCOVER_SIGNUP":"Registrujte se i otkrijte zanimljive stvari u Otkrij","IMPORT_DISK_SIGNUP":"Registrujte se i importujte filmove i serije sa vašeg lokalnog diska","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Primaj obaveštenja o novim epizodama","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Prijavite se da dobijete sve ovo:","LIB_EMPTY_BEST":"Prijavite se da dobijete najbolje of Stremio-a","LIB_EMPTY_OTHER":"Prijavite se da biste mogli da aktivirate kalendar i druge dobre funkcije","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt greška","TRAKT_REQUIRES_LOGIN_MSG":"Morate biti ulogovani","SETTINGS_LABEL":"Podešavanja","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Pokreni na pokretanju","SETTINGS_VLC_DEFAULT":"Pusti sa VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Zatvoriti aplikaciju kada je zatvoren prozor","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Automatski pusti sledeću epizodu","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Automatski promeni veličinu prozora pre puštanja","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Uvek koristi najnoviju BETA","SETTINGS_IMPORT_FB":"Uvezi sa Facebooka","SETTINGS_IMPORT_DISK":"Uvezi sa lokalnog diska","SETTINGS_IMPORT_TRAKT":"Uvezi sa Trakt-a","SETTINGS_PAUSE_MINIMIZED":"Pauziraj plejback kada je minimiran","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Pozadinsko puštanje","SETTINGS_SUBSCRIBE_CALENDAR":"Pretplati se na Kalendar","SETTINGS_REQ_EXPORT":"Zatraži izvoz podataka","SETTINGS_ACC_DELETE":"Zatraži brisanje naloga","SETTINGS_CHANGE_PASSWORD":"Promeni lozinku","SETTINGS_TOS":"Uslovi korišćenja","SETTINGS_SUPPORT":"Kontaktiraj podršku","SETTING_LANGUAGE":"Jezik","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Odjavi se sa Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"podrazumevani titlovi","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Pokreni u zasebnom prozoru (napredno)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Izađi","CONNECTED":"Povezan","AUTHENTICATE":"Prijavi se","CACHING":"Keširanje","SETTINGS_CACHING_DRIVE":"Izaberi disk za keširanje","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januar","February":"Februar","March":"Mart","April":"April","May":"Maj","June":"Jun","July":"Jul","August":"Avgust","September":"Septembar","October":"Oktobar","November":"Novembar","December":"Decembar","Monday":"Ponedeljak","Tuesday":"Utorak","Wednesday":"Sreda","Thursday":"Četvrtak","Friday":"Petak","Saturday":"Subota","Sunday":"Nedelja","Action":"Akcija","Comedy":"Komedija","War":"Ratni","Family":"Porodični","Animation":"Animacija","Adventure":"Avanturistički","Fantasy":"Fantazija","Crime":"Krimi","Mystery":"Misterija","Romance":"Ljubavni","Drama":"Drama","Horror":"Horor","Thriller":"Triler","Sci-Fi":"Naučna Fantastika","Music":"Mjuzikl","Biography":"Biografija","Documentary":"Dokumentarni","Sport":"Sport","Musical":"Mujuzikl","Western":"Western","Film-Noir":"Film-Noir","News":"Novosti","History":"Istorijski","Game-Show":"Game-Show","Reality-TV":"Rijaliti","Talk-Show":"Tok Šou","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Filmovi","Uk Live Tv":"UK Uživo Tv","Fashion":"Moda","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"novi video","new episode":"nova epizoda","new movie":"novi film","recommended":"preporučeno","we recommend":"preporučujemo","offer of the day":"ponuda dana","news":"vesti","music video":"spot","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Odbaci obaveštenja","CTX_DISMISS_ALL":"Odustani","CTX_SHARE":"Podeli","CTX_COPY_SHARE_LINK":"Kopiraj link za deljenje","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Prikaži","CTX_PLAY":"Pusti","CTX_PLAY_IN":"Pusti u","CTX_PLAY_ON":"Pusti na","CTX_WATCH_ON":"Gledajte na","CTX_WATCH":"Gledajte","CTX_WATCHED":"Odlgedano","CTX_WATCH_BEGINNING":"Gledajte od početka","CTX_WATCH_MOBILE":"Gledajte na mobilnom uređaju","CTX_REWIND":"Premotaj na početak","CTX_MARK_WATCHED":"Označi kao odgledano","CTX_MARK_NON_WATCHED":"Označi kao neodgledano","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Označi ostatak kao odgledano","CTX_UNMARK_REST":"Označi ostatak kao neodgledano","CTX_RECEIVE_NEW_NOTIF":"Primajte nova obaveštenja","CTX_REMOVE_CACHE":"Obriši iz keša","CTX_REMOVE_CACHE_EP":"Ukloni epizodu iz keša","CTX_OPEN_CONTAINING":"Otvori folder sadržaja","CTX_REMOVE":"Ukloni iz Biblioteke","CTX_AVAILABLE_OFFLINE":"Dostupno Offline","CTX_PAUSED":"Pauzirano","CTX_ALWAYS_ON_TOP":"Uvek na vrhu","CTX_FULLSCREEN":"Ceo ekran","CTX_WRONG_SUBS":"Pogrešan prevod?","CTX_REPORT_ISSUES":"Prijavi problem","CTX_COPY":"Kopiraj","CTX_PASTE":"Nalepi","CTX_CLEAR":"Očisti","CTX_CLEAR_RECENT_SEARCHES":"Obriši skorašnje pretrage","HELLO_THERE":"Hej zdravo","HOPE_YOU_ENJOY":"Nadamo se da uživate uz Stremio i da je već jedna od vaših omiljenih aplikacija!","WHO_ARE_WE":"Ko smo mi? Mi smo tim iza njega - dva momka koja rade teško svaki dan već skoro 3 godine da bismo napravili ovaj proizvod sve boljim i boljim.","SUPPORT_US":"Ako uživate koristeći Stremio, ako je Stremio vredan za vas - širite reč!","SPREAD_THE_WORD":"Podelite sada sa svojim prijateljima, širite reči o Stremio","MORE_PEOPLE":"Što više ljudi koriste Stremio, to će biti bolji!","SEND_A_LINK":"Ili podelite link ka našem sajtu","TIP_LOCALFILES":"Savet: možete prevući i ubaciti lokalne video datoteke u Stremio","ADDON_MY":"Moji Dodaci","ADDON_COMMUNITY":"Dodaci zajednice","ADDON_OFFICIAL":"Zvanični dodaci","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Pretraži dodatke","ADDON_INSTALL":"Instaliraj","ADDON_CONFIGURE":"Podesi","ADDON_UNINSTALL":"Deinstaliraj","ADDON_UPGRADE":"Nadogradi","ADDON_INSTALLED":"Instalirano","ADDON_INSTALLED_MSG":"Dodatak instaliran!","ADDON_UPGRADED_MSG":"Dodatak nadograđen!","ADDON_UNKNOWN":"Nepoznato","ADDON_ERR":"Greška pri instaliranju dodatka!","ADDON_DISCONNECTED":"Diskonektovan","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Instaliraj Sada","ADDON_PAGE":"Stranica dodataka","ADDON_TOP_CONTENT":"Najbolje do ovog dodatka","ADDON_PROVIDES":"Ovaj dodatak će vam dati:","ADDON_WATCH":"Pogledaj #{types} sada!","ADDON_WATCH_FREE":"Pogledaj #{types} BESPLATNO sada !","ADDON_ADDON":"Dodatak","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"Više #{types} u Otkrivanju","ADDON_PROVIDES_STREAMS":"Gledaj #{types}","ADDON_PROVIDES_STREAMS_FREE":"Gledaj #{types} BESPLATNO","ADDON_PROVIDES_SUBTITLES":"Prevodi za #{types}","ADDON_CANTDETECT":"Nismo uspeli pronaći pokrenuti Stremio, tako da nismo uspeli detektovati koje dodatke imate instaliarne.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Neuspešno otvaranje fajla","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"Ova mogućnost je dostupna samo registrovanim korisnicima.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Nastavi gledanje","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmovi izabrani isključivo za vas.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Gledaj Odmah","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Gledati od","WEBSITE_DOWNLOAD":"Skinite sada","WEBSITE_DOWNLOAD_FOR":"Skinite sada za","WEBSITE_IS_DESKTOP":"Stremio je desktop aplikacija, otvori ovu stranicu na svom PC i skini ga","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Glavna","WEBSITE_PAGE_FEATURES":"Karakteristike","WEBSITE_PAGE_ADDONS":"Dodaci","WEBSITE_PAGE_TECH":"Tehnologija","WEBSITE_PAGE_CREATE_ADDON":"Kreiraj dodatak","WEBSITE_PAGE_CONTACTS":"Kontakti","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmovi","WEBSITE_TYPE_series_PL":"Serije","WEBSITE_TYPE_tv":"Uživo TV","WEBSITE_TYPE_channel":"Kanali","WEBSITE_STREMIO_WHAT_IS":"Stremio je aplikacija koja Vam pomaže da organizujete i odmah gledate vaše omiljene video, filmove, TV serije i TV kanale.","WEBSITE_FEATURES_WATCH":"Gledajte odmah u HD","WEBSITE_FEATURES_WATCH_DETAIL":"Kliknite i pustite svoje omiljene filmove, TV Emisije, video i TV kanale.","WEBSITE_FEATURES_SUBS":"Automatski Prevodi","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatski odabire sinhronizovane prevode za vaš jezik.","WEBSITE_FEATURES_SUBS_LABEL":"Vaš potez, šefe.","WEBSITE_FEATURES_CAST":"Pustite na TV & mobilnim uređajima","WEBSITE_FEATURES_CAST_DETAIL":"Emitovanje na AppleTV, Chromecast, Smart TV (DLNA/UPnP) i mobilne uređaje.","WEBSITE_LIB":"Uživajte u Svojoj ličnoj Biblioteci sinhronizovanoj na sve Vaše uređaje","WEBSITE_LIB_COLLECT":"Prikupite sa Stremio","WEBSITE_LIB_IMPORT":"Uvezite sa Facebook-a","WEBSITE_LIB_LOCAL":"Dodajte sa vašeg lokalnog diska","WEBSITE_BOARD":"Tabla - Vaše one-stop mesto za obaveštenja i preporuke","WEBSITE_BOARD_RECOMMEND":"Preporučena TV Emisija","WEBSITE_BOARD_TRENDING":"Traženi Film","WEBSITE_BOARD_NEW":"Novi Video","WEBSITE_BOARD_EPISODE":"Nova Epizoda","WEBSITE_BOARD_1":"Tražite nešto interesantno da gledate? Dobijajte preporuke na osnovu vašeg ukusa!","WEBSITE_BOARD_2":"Primite obaveštenja kada nova epizoda vaš omiljene TV emisije ili YouTube kanala izadje!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Dodaci za sadržaj","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Kreiraj svoj dodatak","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Zainteresovani? Dobrodošli ste da nas kontaktirate.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Misljenja koja delimo:","WEBSITE_SPREAD":"Delite reč o Stremio-u:","WEBSITE_CONTACT":"Ako hoćete da nas kontaktirate, to možete ovde uraditi","WEBSITE_OPENSOURCE":"Za naše open-source projekate, idite na naš","WEBSITE_BITCOIN":"Donirajte bitcoin:","WEBSITE_FAQ":"Često postavljena pitanja","WEBSITE_FAQ_SHORT":"ČPP","WEBSITE_QUESTIONS":"Pitanja","WEBSITE_TOS":"Uslovi korišćenja","WEBSITE_LEGAL":"Zakoni","WEBSITE_PAGE_ABOUT":"O","WEBSITE_PAGE_BECOME_PARTNER":"Postanite partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! Stranica koju tražite nije ovde...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"Ovaj izvor je slabo dostupan ili je Vaša internet konekcija prespora","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Podesi vreme sa ","ADJUST_SIZE":"Podesi veličinu sa ","SEARCH_ANYTHING":"Moćeš Pretraživati Bilo Šta...","ALL_CATEGORIES":"Sve","SEARCH_CATEGORIES":"Filmove, Serije, YouTube & TV","SEARCH_PERSONS":"Glumce, Režisere i Scenografe","SEARCH_PROTOCOLS":"HTTP i Magnet Linkove","SEARCH_TYPES":"IMDB / TVDB linkove","WATCHED":"Odgledano","SHOW_LESS":"Prikaži manje","LAST_SEARCHES":"Poslednje pretrage","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"Prenos podataka je skup","USE_DATA":"Use data","WARNING":"Upozorenje","MORE_INFO":"Više Informacija ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Učitavanje ...","STREMIO_TV_BACK_TO_LANGUAGES":"Nazad na jezike","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Idi na:","STREMIO_TV_OR_SCAN":"ili skeniraj:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Nastavi Gledanje","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Namesti vreme","REMOTE_ADJUST_SIZE":"Namesti veličinu","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Pokušaj ponovo","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},4662:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Serie","TYPE_tv":"TV-kanal","TYPE_channel":"Kanal","TYPE_other":"Other","TYPE_movie_PL":"Filmer","TYPE_series_PL":"Serier","TYPE_tv_PL":"TV-kanaler","TYPE_channel_PL":"Kanaler","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Tillbaka","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Upptäck","Board":"Vägg","Library":"Bibliotek","My Library":"My Library","Calendar":"Kalender","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"Sök","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Lägg till i biblioteket","REMOVE_FROM_LIB":"Ta bort från biblioteket","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Titta på trailer","WATCH_NOW":"Titta nu","SHOW":"Visa","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"Betyg på IMDB","YEAR":"År","DIRECTOR":"Regissör","WRITER":"Manusförfattare","LEAD_ACTORS":"Huvudskådespelare","CAST":"Rollista","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Utgiven","SEASONS":"Säsonger","GENRE":"Genre","CATALOG":"Catalog","SUMMARY":"Sammanfattning","SHOW_MORE":"Show More","SIMILAR":"Liknande","UPCOMING":"Kommande","ENDED":"Avslutad","DURATION":"Speltid","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"Sök efter video","SEARCH_PLACEHOLDER":"search or paste magnet link","ADDON":"Tillägg","ADDONS":"Tilläggen","OFFICIAL":"Officiella","ADDONS_OFFICIAL":"Officiella Stremio-tillägg","ADDONS_POPULAR":"Populärt i ditt område","ADDON_FREE":"Gratis tillägg","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"Prenumeration på tillägg","ADDON_STREAM_GEORESTRICTED":"not available in your area","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Tillgängliga strömmar","NO_STREAM":"Ingen ström","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Katalog för tillägg","ADDON_CATALOGUE_MORE":"More addons »","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons repository already exist","ADDON_REPO_ERR":"Error occurred while adding repository","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Protected addon","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection url","ERR_NOT_ADDON_URL":"Not an addon url","ERR_DETECTFROMURL":"Cannot detect from url","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Addon collection set failed","SETTINGS_DATA_EXPORT":"Export data","ADDON_PULL_FAILED":"Addon pulling failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Visas fortfarande på bio","WATCH_IN_CINEMA":"Se den på din lokala bio","IN_THEATER":"På bio","GET_TICKETS":"Skaffa biljetter","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"Den här kanalen är inte skrapad än.
Kom tillbaka om några minuter.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Lägg till den till ditt bibliotek för att bli meddelad när den blir tillgänglig.","GET_NOTIFIED_WHEN_AVAILABLE":"Du kommer att bli meddelad när den blir tillgänglig.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Hoppsan, fel på spelaren","PLAYER_ERROR_LOOKSLIKE":"Det tycks vara ett fel på spelaren","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"Strömmar från","CASTING_TO":"Castar till","NETWORK_STATUS":"Nätverksstatus","STREAM_SPEED":"Nedladdningshastighet:","STREAM_BUFFERED":"Buffrat:","PEERS_INFO":"Information om peers","PEERS_ACTIVE":"Aktiv:","PEERS_CONNECTED":"Ansluten:","PEERS_WAITING":"Väntar:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"Laddar strömmen...","PLAYING_LOCAL":"Spelar upp en lokal fil","PLAYING_CACHE":"Spelar upp från cache","WRONG_SUBS":"Felaktiga undertexter","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Välj en enhet att titta på","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Telefon / Platta","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Ändra undertexter för ","SUBTITLES_CHANGE_NONE":"Det finns inga andra undertexter för detta språk, beklagar.","SUBTITLES_CHANGE_ACIVE":"För närvarande är undertexter #{{subtitlesDialog.activeIdx + 1}} aktiverade. Klicka på \\"Fortsätt\\" för att aktiverar undertexter #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Undertexter eller","SUBTITLES_ADJUST_DELAY":"Justera fördröjning av undertexter:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Eller använd tangenterna G / H när du tittar.","SUBTITLES_ADJUST_DELAY_TIP":"TIPS: du kan använda tangenterna G / H när du tittar för att justera.","SUBTITLES_DELAY":"Fördröjning av undertexter:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Säsong","EPISODE":"Avsnitt","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"Sortera trender","SORT_RECENT":"Sortera efter senaste","SORT_ALPHABET":"Sortera efter alfabetet","SORT_RATING":"betyg","SORT_WATCHED":"sett","SORT_YEAR":"År","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"Återuppta","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Detaljer","LIBRARY_RESUME_DISMISS":"dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Utvalda","DISCOVER_TOP":"Topp","DISCOVER_OSCAR":"Oscarsvinnare","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Varning: inget Stremio-tillägg aktivt för denna typ. Visar sparade objekt, ingenting kommer att uppdateras.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Starta om nu!","UPGRADE":"Uppgradera till den senaste versionen av Stremio","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Logga in med Facebook","FB_NOTHINGSHARED":"Ingenting delas utan din tillåtelse ","FB_NOPOST":"We won’t post anything on your behalf","OR":"eller","I_ACCEPT":"Jag accepterar","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Användarvillkoren","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Lösenorden matchar inte","SIGN_UP":"Registrera","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Logga in","LOG_OUT":"Logga ut","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Gästinloggning","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"klicka här","WRONG_PASSWORD":"Fel lösenord. Om du har glömt ditt lösenord, ","SET_A_PASS":"ange ett lösenord","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"Denna e-postadress användes med en Facebook-inloggning.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Anslutningsfel - var vänlig och försök igen senare.\\n\\nOm problemet kvarstår, inaktivera brandväggar/antivirusprogram (speciellt Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Användandet av tredjeparts-tillägg kommer alltid att vara ditt eget ansvar och faller under lagstiftningen i det område du befinner dig i.","ADDON_ACTIVATE":"Aktivera detta tillägg?","ADDON_REPO_ADD":"Addon repository url","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Nyheter","BUTTON_CONTINUE":"Fortsätt","BUTTON_ACTIVATE":"Aktivera","BUTTON_ACTIVATED":"Aktiverad","BUTTON_CANCEL":"Avbryt","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Ditt bibliotek ser tomt ut. Ta reda på hur användbart det kan vara :)","HOW_START":"Så här kan du börja:","LIB_EMPTY_CAL":"Din Kalender visar serier från ditt bibliotek.","HOW_START_CAL":"Så här kan du lägga till en serie:","LIB_EMPTY_BOARD":"Väggen visar notifikationer & rekommendationer med anknytning till ditt bibliotek.","HOW_START_BOARD_WAIT":"Lägg gärna till några serier eller kanaler till Bibliotek och ge oss några minuter att behandla dem :)","HOW_START_BOARD":"Så här kan du lägga till serier & filmer till den:","IMPORT_FB":"Importera saker du tycker om från Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Hitta intressanta saker från Upptäck","IMPORT_DISK":"Importera filmer eller serier som du har på din lokala hårddisk","PLEASE_CREATE_ACC":"Vänligen skapa ett konto för att aktivera synkronisering av Biblioteket & Vägg.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sigm up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"Du behöver logga in","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Starta vid uppstart","SETTINGS_VLC_DEFAULT":"Spela upp med VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Spela automatiskt upp nästa avsnitt","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Importera från Facebook","SETTINGS_IMPORT_DISK":"Importera från lokal hårddisk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Prenumerera på kalender","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Ändra lösenord","SETTINGS_TOS":"Användarvillkor","SETTINGS_SUPPORT":"Kontakta supporten","SETTING_LANGUAGE":"Språk","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Logga ut från Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Avsluta","CONNECTED":"Connected","AUTHENTICATE":"Autentisera","CACHING":"Cachear","SETTINGS_CACHING_DRIVE":"Inställningar för cacheenhet","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"Januari","February":"Februari","March":"Mars","April":"April","May":"Maj","June":"Juni","July":"Juli","August":"Augusti","September":"September","October":"Oktober","November":"November","December":"December","Monday":"Måndag","Tuesday":"Tisdag","Wednesday":"Onsdag","Thursday":"Torsdag","Friday":"Fredag","Saturday":"Lördag","Sunday":"Söndag","Action":"Action","Comedy":"Komedi","War":"Krig","Family":"Familj","Animation":"Animerat","Adventure":"Äventyr","Fantasy":"Fantasy","Crime":"Deckare","Mystery":"Mysterium","Romance":"Romantik","Drama":"Drama","Horror":"Skräck","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Musik","Biography":"Biografi","Documentary":"Dokumentär","Sport":"Sport","Musical":"Musikal","Western":"Western","Film-Noir":"Film-Noir","News":"Nyheter","History":"Historia","Game-Show":"Spel-program","Reality-TV":"Reality-TV","Talk-Show":"Pratprogram","Film & Entertainment":"Film & Underhållning","Gaming":"Gaming","From TV":"Från TV","Lifestyle":"Livsstil","Science & Education":"Vetenskap & Utbildning","Cooking & Health":"Matlagning & Hälsa","Beauty & Fashion":"Skönhet & Mode","Sports":"Sport","News & Politics":"Nyheter & Politik","How-to & DIY":"Gör det själv","Tech":"Teknik","Automotive":"Fordon","Causes & Non-Profits":"Bra saker & Ideella organisationer","Movies":"Filmer","Uk Live Tv":"UK Direkt Tv","Fashion":"Mode","Business News Radio":"Nyhetsradio för företag","Business Tv":"Företags-TV","Cars & Auto":"Bilar & Fordon","Comedy Radio":"Komediradio","Lifestyle Radio":"Livsstilsradio","News Tv":"Nyheter Tv","Food And Wine":"Mat Och Vin","Latino Tv":"Latinsk Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Barn","Body & Soul":"Kropp & Själ","Education":"Utbildning","Indian Tv":"Indisk Tv","Extreme Sports":"Extremsport","Middle Eastern Tv":"Mellanöstern Tv","Celebrity Tv":"Kändis Tv","Science Tv":"Vetenskap Tv","Bikini babe":"Bikini brud","Outdoors":"Utomhus","German Tv":"Tysk Tv","French Tv":"Fransk Tv","Italian Tv":"Italiensk Tv","Gamer Tv":"Gamer Tv","Travel":"Resor","Asian Tv":"Asiatisk Tv","Entertainment":"Underhållning","News Radio":"Nyheter Radio","Music Radio":"Musik Radio","Language Learning":"Språkinlärning","Science Radio":"Vetenskaplig Radio","Tech Radio":"Teknik Radio","Science & Technology Vod":"Vetenskap & Teknik Vod","new video":"nytt videoklipp","new episode":"nytt avsnitt","new movie":"ny film","recommended":"rekommenderad","we recommend":"vi rekommenderar","offer of the day":"dagens erbjudande","news":"nyheter","music video":"musikvideo","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Avisa notifikationer","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Dela","CTX_COPY_SHARE_LINK":"Kopiera delningslänk","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Visa","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Titta på","CTX_WATCH":"Titta","CTX_WATCHED":"Sedd","CTX_WATCH_BEGINNING":"Se från början","CTX_WATCH_MOBILE":"Se på mobilen","CTX_REWIND":"Spola tillbaka till början","CTX_MARK_WATCHED":"Markera som sedd","CTX_MARK_NON_WATCHED":"Markera som osedd","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Ta emot nya notifikationer","CTX_REMOVE_CACHE":"Ta bort från cache","CTX_REMOVE_CACHE_EP":"Ta bort avsnitt från cache","CTX_OPEN_CONTAINING":"Öppna innehållande mapp","CTX_REMOVE":"Ta bort från bibliotek","CTX_AVAILABLE_OFFLINE":"Tillgänglig Offline","CTX_PAUSED":"Pausad","CTX_ALWAYS_ON_TOP":"Alltid överst","CTX_FULLSCREEN":"Fullskärm","CTX_WRONG_SUBS":"Fel undertexter?","CTX_REPORT_ISSUES":"Rapportera problem","CTX_COPY":"Kopiera","CTX_PASTE":"Klistra in","CTX_CLEAR":"Rensa","CTX_CLEAR_RECENT_SEARCHES":"Rensa senaste sökningar","HELLO_THERE":"Hejsan","HOPE_YOU_ENJOY":"Vi hoppas att ni uppskattar Stremio och det redan är ett av dina favoritprogram!","WHO_ARE_WE":"Vilka är vi? Vi är teamet bakom det - två killar som arbetat hårt varje dag under de senaste 3 åren, med ett enda mål - att göra produkten bättre och bättre.","SUPPORT_US":"Om du tycker om att använda Stremio, om Stremio är värdefullt för dig - stöd oss!","SPREAD_THE_WORD":"Dela med dina vänner nu, sprid ordet om Stremio.","MORE_PEOPLE":"Ju fler människor som använder Stremio, desto bättre kommer det att bli!","SEND_A_LINK":"Eller skicka en länk till vår hemsida","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"Mina tillägg","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Officiella tillägg","ADDON_REPOS":"Addon repositories","ADDON_SEARCH":"Sök efter tillägg","ADDON_INSTALL":"Installera","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Avinstallera","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installerad","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"provides","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Tillägg","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Fortsätt titta","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Ladda ner nu","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Skrivbordsdemo","WEBSITE_PAGE_HOME":"Hem","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Tillägg","WEBSITE_PAGE_TECH":"Teknologi","WEBSITE_PAGE_CREATE_ADDON":"Skapa ett tillägg","WEBSITE_PAGE_CONTACTS":"Kontakter","WEBSITE_PAGE_BLOG":"Blogg","WEBSITE_TYPE_movie":"Filmer","WEBSITE_TYPE_series_PL":"Serier","WEBSITE_TYPE_tv":"Live-TV","WEBSITE_TYPE_channel":"Kanaler","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatiska undertexter","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio väljer automatiskt synkade undertexter för ditt språk.","WEBSITE_FEATURES_SUBS_LABEL":"Ditt drag, chefen.","WEBSITE_FEATURES_CAST":"Spela upp på TV:n & mobila enheter","WEBSITE_FEATURES_CAST_DETAIL":"Castea till AppleTV, Chromecast, Smart TV (DLNA/UPnP) och mobila enheter.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Samla från Stremio","WEBSITE_LIB_IMPORT":"Importera från Facebook","WEBSITE_LIB_LOCAL":"Lägg till från din lokala hårddisk","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Rekommenderat TV-program","WEBSITE_BOARD_TRENDING":"Filmtrend","WEBSITE_BOARD_NEW":"Ny video","WEBSITE_BOARD_EPISODE":"Nytt avsnitt","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"Vi älskar teknologi, vi älskar galen forskning!\\nStremio använder följande öppen källkodsteknologier:","WEBSITE_TECH_WCJS":"WebChimera.js tillåter Stremio att spela upp alla videoformat med bra prestanda.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Skapa ditt tillägg","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Fördelar med att skapa ett tillägg till Stremio","WEBSITE_P2P_BEAUTY":"Det sköna med strömmande via Peer-to-Peer","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"Vi kommer att skapa ett tillägg som möter dina specifika behov","WEBSITE_P2P_CONTACT":"Intresserad? Du är välkommen att kontakta oss.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Nu och då kommer det en teknologi som förändrar situationen. Vi investerade massor av tid och ansträngning för att bygga vår Peer-to-Peer (P2P) strömningsmotor för video som erbjuder bra prestanda and mångsidighet att anpassa sig med alla användningsområden.\\nKontakta oss för DRM-aktiverad P2P-video on demand eller live-sändning.","WEBSITE_THOUGHTS":"Tankar som vi delar:","WEBSITE_SPREAD":"Sprid ordet om Stremio:","WEBSITE_CONTACT":"If you are looking to contact us, go ahead at","WEBSITE_OPENSOURCE":"För våra projekt med öppen källod, går till vår","WEBSITE_BITCOIN":"Donera bitcoin:","WEBSITE_FAQ":"Frekvent ställda frågor","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Användningsvillkor","WEBSITE_LEGAL":"Lagligt","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Contacts us","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Sibscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Now Stremio 4 beta","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can accss a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},9892:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"సినిమా","TYPE_series":"సిరీస్","TYPE_tv":"టీవీ ఛానల్","TYPE_channel":"ఛానల్","TYPE_other":"మరిన్ని","TYPE_movie_PL":"Movies","TYPE_series_PL":"Series","TYPE_tv_PL":"TV channels","TYPE_channel_PL":"Channels","TYPE_other_PL":"Others","TYPE_ALL":"All","VIDEO":"Video","BACK":"Back","MORE":"More","DONE":"Done","COPY":"Copy","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Discover","Board":"Board","Library":"Library","My Library":"My Library","Calendar":"Calendar","NOTIFICATION_ONLINE":"You are now online","NOTIFICATION_OFFLINE":"You are currently offline","INTERNET_CONNECTION":"Network connection","STORAGE_FULL_TITLE":"Warning: Storage full!","STORAGE_FULL_TEXT":"Stremio will not be able to save your settings, preferences or login information. Consider re-starting or re-installing Stremio.","SEARCH":"search","SEARCH_NO_RESULTS":"No results were found","SEARCH_EXPLANATION_CONTENT":"Search for movies, series, YouTube and TV channels","SEARCH_EXPLANATION_PEOPLE":"Search for actors, directors and writers","SEARCH_PASTE_LINKS":"Paste HTTP and Magnet links","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Add to Library","REMOVE_FROM_LIB":"Remove from Library","ADDED_TO_LIB":"Added to Library","REMOVED_FROM_LIB":"Removed from Library","TRAILER":"Trailer","WATCH_TRAILER":"Watch Trailer","WATCH_NOW":"Watch Now","SHOW":"Show","SHOW_MOVIE":"Show Movie","WATCH_RANDOM":"Watch Random","IMDB_RATING":"IMDb Rating","YEAR":"Year","DIRECTOR":"Director","WRITER":"Writer","LEAD_ACTORS":"Lead Actors","CAST":"Cast","CREW":"Crew","SHOW_MORE_CAST":"Show more »","AIRED":"Aired","SEASONS":"Seasons","GENRE":"Genre","CATALOG":"Catalog","SUMMARY":"Summary","SHOW_MORE":"Show More","SIMILAR":"Similar","UPCOMING":"Upcoming","ENDED":"Ended","DURATION":"Duration","FEATURED":"Featured","METADATA":"Metadata","CATEGORY":"category","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"search videos","SEARCH_PLACEHOLDER":"search or paste URL","ADDON":"addon","ADDONS":"Addons","OFFICIAL":"official","ADDONS_OFFICIAL":"Official Stremio Addons","ADDONS_POPULAR":"Popular in your area","ADDON_FREE":"free","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"subscription","ADDON_STREAM_GEORESTRICTED":"not available in your area","ADDON_STREAM_OFFLINECACHE":"Offline Cache","ADDON_STREAM_LOCALFILE":"Local File","SHARE_ADDON":"Share addon","AVAILABLE_STREAMS":"Available Streams","NO_STREAM":"No streams were found","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"For more streams, please install more addons","STREAM_NOT_SUPPORTED":"Selected stream is not supported on this platform.","ADDON_CATALOGUE":"Show all addons »","ADDON_CATALOGUE_MORE":"Install addons","REPO_ADDED":"Repository added","ADDON_REPO_EXIST_ERR":"This addons collection already exist","ADDON_REPO_ERR":"Error occurred while adding collection","ADDON_ADD_ERR":"Error occurred while adding addon","ERR_ADDON_PROTECTED":"Cannot uninstall addon, it is protected","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Something went wrong - authentication may have failed","ERR_NOT_COLLECTION_URL":"Not a collection URL","ERR_NOT_ADDON_URL":"Not a valid addon URL","ERR_DETECTFROMURL":"Cannot find addon/collection from this URL","ADDON_DUPLICATE_WARNING":"Warning: duplicated addon","ADDON_COLLECTION_SET_FAILED":"Syncing installed addons to your account failed","SETTINGS_DATA_EXPORT":"Export user data","ADDON_PULL_FAILED":"Syncing installed addons from your account failed","REFRESH_ON_CLICK":"Click to retry","STILL_IN_THEATER":"Movie still in theaters","WATCH_IN_CINEMA":"Watch it in your local cinema","IN_THEATER":"In cinema","GET_TICKETS":"Get tickets","UPCOMING_EPISODE":"Upcoming episode","UPCOMING_EPISODE_MESSAGE":"This episode will be aired on","MISSING_DATE_EPISODE":"Missing episode date","MISSING_DATE_EPISODE_MESSAGE":"This episode might not have aired yet","CHANNEL_NOT_SCRAPED":"This channel is not scraped yet.
Please come back in a few minutes.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Add it to your library to get notified once it is available.","GET_NOTIFIED_WHEN_AVAILABLE":"You will get notified once it is available.","WARNING_STREAMING_SERVER":"Warning: local streaming server not found. Streaming from local files, YouTube and BitTorrent will not be available.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Warning: this video may not be supported by your hardware. Keep in mind, playback may be slow.","PLAYER_ERROR":"Oops, Player Error","PLAYER_ERROR_LOOKSLIKE":"It looks like","PLAYER_ORIENTATION":"Player orientation","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Locked","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensor","PLAYER_ORIENTATION_LANDSCAPE":"Player orientation locked at landscape","PLAYER_ORIENTATION_SENSOR":"Player orientation automatic (sensor)","PLAYER_PLAYBACK_SPEED":"Playback Speed","PLAYER_PLAYBACK_ERROR":"Playback error, please try again","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Unknown error","PLAYER_PLAYBACK_ERROR_DEFAULT":"Sorry, this video cannot be played by {{productName}}.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Live","PLAYER_NEXT_VIDEO_TITLE":"Coming up next on","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Dismiss","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Watch now","STREAMING_FROM":"streaming from","CASTING_TO":"Casting to","NETWORK_STATUS":"Network status","STREAM_SPEED":"Stream speed:","STREAM_BUFFERED":"Buffered:","PEERS_INFO":"Peers Information","PEERS_ACTIVE":"Active:","PEERS_CONNECTED":"Connected:","PEERS_WAITING":"Waiting:","TRANSCODING_WARNING":"Warning: transcoding video.","STREAM_LOADING":"loading...","PLAYING_LOCAL":"playing from local file","PLAYING_CACHE":"playing from cache","WRONG_SUBS":"Wrong subtitles?","ERR_SUBS_LOADING_TITLE":"Error loading subtitles","ERR_SUBS_LOADING":"Failed loading subtitles: this could be an issue with the addon you are using, or with your network connection","WARN_FOLLOWING_SUB_ADDONS_FAILED":"The following subtitle addons failed","ERR_CASTING_UPDATE_TITLE":"Could not update casting device info: streaming server might be offline","CHOOSE_DEVICE":"Choose a device to watch on","NO_CAST_DEVICES":"No casting devices available.","NO_SETTINGS":"No settings available.","PHONE_TABLET":"Phone / Tablet","SUBTITLES":"Subtitles","SUBTITLES_CHANGE":"Change subtitles for ","SUBTITLES_CHANGE_NONE":"There are no other subtitles for this language, sorry.","SUBTITLES_CHANGE_ACIVE":"Currently subtitles #{{subtitlesDialog.activeIdx + 1}} are activated. Click \\"Continue\\" to activate subtitles #{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"Alternatively,","SUBTITLES_ADJUST_DELAY":"Adjust subtitle delay:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Or use G / H keys while playing to adjust.","SUBTITLES_ADJUST_DELAY_TIP":"TIP: you can use G / H keys while playing to adjust.","SUBTITLES_DELAY":"Subtitles delay:","SUBTITLES_LOADING":"Loading subtitles...","SUBTITLES_UNAVAILABLE":"No external subtitles available","SUBTITLES_DISABLED":"Disabled","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Season","EPISODE":"Episode","SPECIAL":"Special","SORT":"sort","SORT_BY":"Sort by","FILTER":"filter","SORT_TRENDING":"trending","SORT_RECENT":"recent","SORT_ALPHABET":"a-z","SORT_RATING":"rating","SORT_WATCHED":"watched","SORT_YEAR":"year","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"New for You","New Episodes":"New Episodes","New Videos":"New Videos","Recommendations":"Recommendations","LIBRARY_RESUME":"Resume","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Details","LIBRARY_RESUME_DISMISS":"Dismiss","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Featured","DISCOVER_TOP":"Top","DISCOVER_OSCAR":"Oscar Winners","DISCOVER_WARNING_TITLE":"Oops!","DISCOVER_EMPTY_CATALOG":"This addon returned empty content.","DISCOVER_ADULT_WARNING":"The content is visible only for adults. Are you 18+?","DISCOVER_NOADDON_WARNING":"Warning: no Stremio addon active for this type. Showing saved items, nothing here will update.","DISCOVER_LOAD_ERR":"The content did not load, error occured.","DISCOVER_ADDON_UNINSTALLED":"This content is no longer available, you may have un-installed the addon.","UNINSTALL_THIS_ADDON":"Uninstall this addon","ERR_ADDON_NOT_INSTALLED":"This addon is not installed. Install now?","DETAIL_RECEIVE_NOTIF_SERIES":"Receive notifications for new episodes","DETAIL_RECEIVE_NOTIF_VIDEOS":"Receive notifications for new videos","SIDEBAR_SHOW_STREAMS":"Show Streams","RELAUNCH":"Re-launch now!","UPGRADE":"New version is available! Upgrade to the latest Stremio version","RELOAD_UI":"Reload the user interface","MANUAL_UPDATE_TITLE":"Update your Stremio version","MANUAL_UPDATE_LINE1":"You are running an outdated version of Stremio which is highly unrecommended.","MANUAL_UPDATE_LINE2":"Please update as soon as possible.","BUTTON_UPDATE_LATTER":"Not now","BUTTON_UPDATE_NOW":"Update","ANONYMOUS_USER":"Anonymous user","DONT_HAVE_ACC":"Don\'t have an account?","HAVE_ACC":"Already have an account?","PASSWORD":"Password","PASSWORD_CONFIRM":"Confirm password","EMAIL":"E-mail","FB_LOGIN":"Continue with Facebook","FB_NOTHINGSHARED":"Nothing is shared without your permission","FB_NOPOST":"We won’t post anything on your behalf","OR":"or","I_ACCEPT":"I accept the","I_ACCEPT_BY_CLICKING":"By clicking the above button I testify that I accept the ","TOS":"Terms and Conditions","MUST_ACCEPT_TERMS":"You must accept terms","PASSWORDS_NOMATCH":"Passwords don\'t match","SIGN_UP":"Sign up","SIGN_UP_EMAIL":"Sign up with email","CLICK_TO_SIGN_UP":"Click here to sign up.","LOG_IN":"Log in","LOG_OUT":"Log out","EXIT_FULLSCREEN":"Exit fullscreen mode","ENTER_FULLSCREEN":"Enter fullscreen mode","PLAY_URL_MAGNET_LINK":"Play URL/Magnet link","HELP_FEEDBACK":"Help & Feedback","TERMS_OF_SERVICE":"Terms of Service","PRIVACY_POLICY":"Privacy Policy","ABOUT_STREMIO":"About Stremio","USER_PANEL":"User Panel","LOGIN_LABEL":"Login","GUEST_LOGIN":"Guest login","GUEST_LOGIN_NOTICE":"Guest Login is not recommended. Using a regular login allows Stremio to sync your Library, receive notifications for favourite series/channels. Are you sure you want to proceed?","GUEST_LOGIN_NOTICE_2":"Guest Login is not recommended - you won\'t have synced Library and Board notifications, which are vital Stremio features. Are you sure you want to proceed?","CLICK_HERE":"click here","WRONG_PASSWORD":"Wrong email or password. In case you have forgotten your password, ","SET_A_PASS":"set a password","RESET_PASSWORD":"Reset password","FORGOT_PASSWORD":"Forgot password?","EMAIL_USED_WITH_FB":"This email was used with a Facebook login.","INVALID_EMAIL":"Please enter a valid email address","INVALID_PASSWORD":"Please enter a valid password","CONN_ERR":"Connection error - please try again later.\\n\\nIf this persists, disable firewalls/anti-virus software (especially Bitdefender).","IMPORT_FROM_GUEST":"Import Library from your guest account","RECEIVE_UPDATES_EMAIL":"Receive updates to your email from Stremio","LOGIN_FAILED":"Login failed.","SIGNUP_FAILED":"Signup failed.","SEARCH_FAILED":"Search failed","EMAIL_USED":"This email is already in use.","WAITING_FB_LOGIN":"Logging in with Facebook...","EXTERNAL_PLAYER_TITLE":"Play in external player","EXTERNAL_REMEMBER_PLAYER":"Do you want to remember your choice","EXTERNAL_ALWAYS_PLAY":"Yes","EXTERNAL_ONLY_ONCE":"No","BEST_FIT":"Best Fit","FIT_SCREEN":"Fit Screen","FILL":"Fill","16:9":"16:9","4:3":"4:3","Original":"Original","INTRO_TASTE":"Tell us about what you like","INTRO_TASTE_LONG":"Tell us about what you\'d like to watch","INTRO_TASTE_PICK":"Pick {{interestsRemaining}} interests","INTRO_TASTE_PICK_MORE":"Pick {{interestsRemaining}} more interests","INTRO_TASTE_HELP_US":"Help us learn more about you.","INTRO_TASTE_CHOOSE_THESE":"Choose some of these:","INTRO_TASTE_CHOOSE_MIN":"Choose at least 3 categories","INTRO_TASTE_CHOOSE_MIN_ERR":"You have to pick at least 3 categories!","INTRO_TASTE_LIFESTYLE":"Lifestyle","INTRO_TASTE_SPORTS":"Sports","INTRO_TASTE_FOOD_HEALTH":"Food & Health","INTRO_TASTE_BEAUTY_FASHION":"Beauty & Fashion","INTRO_TASTE_NEWS":"News","INTRO_TASTE_GAMING":"Gaming","INTRO_TASTE_SCIENCE_EDU":"Science & Education","INTRO_TASTE_MUSIC":"Music","INTRO_TASTE_TRAVEL":"Travel","INTRO_TASTE_LATE_NIGHT":"Late Night Show","INTRO_TASTE_REALITY":"Reality","INTRO_TASTE_COMEDY":"Comedy","INTRO_TASTE_DIY":"How to DIY","INTRO_TASTE_TECH":"Tech","INTRO_TASTE_CINEMA":"Cinema","ADDON_NOT_SUPPORTED":"Selected addon is not supported on this platform.","ADDON_DISCLAIMER":"Using third-party addons will always be subject to your responsibility and the governing law of the jurisdiction you are located.","ADDON_ACTIVATE":"Activate this addon?","ADDON_REPO_ADD":"Addon collection URL","ADDON_ADD":"Add","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"What\'s new","BUTTON_CONTINUE":"Continue","BUTTON_ACTIVATE":"Activate","BUTTON_ACTIVATED":"Activated","BUTTON_CANCEL":"Cancel","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"Dismiss All","BUTTON_VIEW_ALL":"view all","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Your library looks empty. Find out how useful it is :) ","HOW_START":"Here is how you can start:","LIB_EMPTY_CAL":"Your Calendar shows series in your Library.","HOW_START_CAL":"Here is how you can add series:","LIB_EMPTY_BOARD":"Board shows notifications & recommendations related to your Library.","HOW_START_BOARD_WAIT":"Please, add a few series or channels to your Library give us a few minutes to process :)","HOW_START_BOARD":"Here is how you can add series & movies to it:","IMPORT_FB":"Import things you like from Facebook","IMPORT_TRAKT":"Import your media library from Trakt","IMPORT_DISCOVER":"Find interesting stuff from Discover","IMPORT_DISK":"Import movies or shows you have on your local disk","PLEASE_CREATE_ACC":"Please create an account to enable Library sync & Board.","IMPORT_DISCOVER_SIGNUP":"Sign up and find interesting stuff from Discover","IMPORT_DISK_SIGNUP":"Sign up and import movies or shows you have on your local disk","LIB_EMPTY_CLOUD":"Cloud library","LIB_EMPTY_CLOUD_DESC":"Personal cloud library synced on all devices","LIB_EMPTY_EARLY":"Early bird","LIB_EMPTY_EARLY_DESC":"Receive notifications for new episodes","LIB_EMPTY_PERSONAL":"Personal","LIB_EMPTY_PERSONAL_DESC":"Get personal recommendations","LIB_EMPTY_CALENDAR_DESC":"Schedule your personal watching calendar","LIB_EMPTY_ALL":"Sign up to get all of these:","LIB_EMPTY_BEST":"Sign up to get best of Stremio","LIB_EMPTY_OTHER":"Sign up to enable Calendar & other cool features","CALENDAR_ADDED":"The Stremio calendar has been added to your default desktop calendar.","CALENDAR_ADDED_MSG":"If this does not work, please add this URL to your calendar application manually","TRAKT_EXPIRED":"Trakt authentication expired, please go to Settings and re-authenticate","TRAKT_REQUIRES_LOGIN":"Trakt error","TRAKT_REQUIRES_LOGIN_MSG":"You need to login","SETTINGS_LABEL":"Settings","SETTINGS_NAV_GENERAL":"General","SETTINGS_NAV_PLAYER":"Player","SETTINGS_NAV_STREAMING":"Streaming","SETTINGS_NAV_SHORTCUTS":"Shortcuts","SETTINGS_SHORTCUT_RELOAD_APP":"Reload App","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Open Settings","SETTINGS_SHORTCUT_SWITCH_TABS":"Switch Tabs","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Cycle Through Tabs Forward","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Cycle Through Tabs Backward","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Exit / Go Back","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Toggle Fullscreen","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Show Controls","SETTINGS_SHORTCUT_PLAY_PAUSE":"Play / Pause","SETTINGS_SHORTCUT_VOLUME_UP":"Volume Up","SETTINGS_SHORTCUT_VOLUME_DOWN":"Volume Down","SETTINGS_SHORTCUT_SEEK_NEXT":"Seek Next","SETTINGS_SHORTCUT_SEEK_PREV":"Seek Prev","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Play Next","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Increase Subtitles Size","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Decrease Subtitles Size","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Increase Subtitles Delay","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Decrease Subtitles Delay","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Toggle Sidebar","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Launch on start-up","SETTINGS_VLC_DEFAULT":"Play with VLC","SETTINGS_UI_LANGUAGE":"UI Language","SETTINGS_FULLSCREEN_EXIT":"Escape key exit full screen","SETTINGS_GAMEPAD":"Enable gamepad support","SETTINGS_CLOSE_WINDOW":"Close app when window is closed","SETTINGS_SUBTITLES_LANGUAGE":"Default Subtitles Language","SETTINGS_SUBTITLES_SIZE":"Default Subtitles Size","SETTINGS_SUBTITLES_BACKGROUND":"Subtitles background","SETTINGS_SUBTITLES_COLOR":"Subtitles color","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Subtitles outline color","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Subtitles background color","SETTINGS_SEEK_KEY":"Arrow keys seek time","SETTINGS_SEEK_KEY_SHIFT":"Arrow keys seek time when Shift key is held","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Auto-play next episode","SETTINGS_NEXT_VIDEO":"Show notification to start next episode","SETTINGS_NEXT_VIDEO_TRIGGER":"Show next episode notification for:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Auto-resize window before playing","SETTINGS_OVERRIDE_SERVER":"Override the streaming server URL (advanced)","SETTINGS_SERVER_URL":"Streaming server URL: ","SETTINGS_SERVER_AVAILABLE":"Streaming server is available.","SETTINGS_SERVER_UNAVAILABLE":"Streaming server is not available.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Streaming HTTPS endpoint: ","SETTINGS_USE_BETA":"Always use latest Beta","SETTINGS_IMPORT_FB":"Import from Facebook","SETTINGS_IMPORT_DISK":"Import from local disk","SETTINGS_IMPORT_TRAKT":"Import from Trakt","SETTINGS_PAUSE_MINIMIZED":"Pause playback when minimized","SETTINGS_HWDEC":"Hardware-accelerated decoding","SETTINGS_BACKGROUND":"Background playback","SETTINGS_SUBSCRIBE_CALENDAR":"Subscribe to calendar","SETTINGS_REQ_EXPORT":"Request data export","SETTINGS_ACC_DELETE":"Request account deletion","SETTINGS_CHANGE_PASSWORD":"Change password","SETTINGS_TOS":"Terms of service","SETTINGS_SUPPORT":"Contact support","SETTING_LANGUAGE":"Language","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Log out of Trakt.tv","SETTINGS_SCAN_FOR_REMOTE":"Scan QR code to open remote","SETTINGS_DESKTOP_NOTIFICATIONS":"Desktop notifications","SETTINGS_DATA_SAVER":"Data saver","SETTINGS_LANGUAGE_INTERFACE":"interface","SETTINGS_LANGUAGE_SUBS":"default subtitles","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Autoselect Audio Track","SETTINGS_DEFAULT_AUDIO_TRACK":"Default Audio Track","SETTINGS_ACCOUNT":"account","SETTINGS_VERSION":"version","SETTINGS_MPV_WINDOW":"Launch player in a separate window (advanced)","SETTINGS_PLAY_IN_EXTERNAL":"Always start video in external player","SETTINGS_STORAGE_BUTTON":"Clear Local Storage","SETTINGS_STORAGE_MODAL_TITLE":"Are you sure ?","SETTINGS_STORAGE_MODAL_MESSAGE":"This will clear the local storage and log you out.","SETTINGS_HWDEC_PICKER":"Pick hardware-accelerated decoding setting","SETTINGS_HW_AUTOMATIC":"Automatic","SETTINGS_HW_DISABLED":"Disabled","SETTINGS_HW_ACCELERATED":"Decoding acceleration","SETTINGS_HW_FULL":"Full acceleration","SETTINGS_HW_LEGACY":"Legacy","SUBSPICKER_AUDIO":"Audio","SUBSPICKER_SUBTITLES":"Addons Subtitles","SUBSPICKER_BLACK_BACKGROUND":"Use black background color","SUBSPICKER_VERTICAL_OFFSET":"Vertical Offset","SUBSPICKER_SIZE":"Size","SUBSPICKER_DELAY":"Delay","SUBSPICKER_EMBEDDED_SUBS":"Embedded Subtitles","MOBILE_PRIVACY_POLICY":"Privacy Policy","MOBILE_CRASH_REPORTING":"Crash Reporting","MOBILE_ZOOM_TO_FILL":"Zoom To Fill Screen","MOBILE_PASSTHROUGH":"Digital audio output (passthrough)","MOBILE_RUN_LOW_BATTERY":"Run on low battery","MOBILE_RUN_FOREGROUND":"Run as Foreground Service","MOBILE_PERFORMANCE":"PERFORMANCE & STABILITY","MOBILE_SERVER_ONLINE":"Online","MOBILE_SERVER_OFFLINE":"Offline","MOBILE_QR_EXPIRES":"QR Code expires in ","MOBILE_LOG_INTO":"Log in to your Stremio account ","MOBILE_SCAN_QR":"Scan QR code above or go to ","MOBILE_LINK_ACCOUNT":"Link Account","MOBILE_SPEEDPICKER_CANCEL":"Cancel","MOBILE_SPEEDPICKER_LABEL":"Select Playback Speed","MOBILE_EMPTY_LIBRARY":"Your library is empty","MOBILE_NO_ADDON_ACTIVE":"No Stremio addon active for this type.","MOBILE_ORGANIZER_WARNING":"The Stremio Organizer app provides limited functionality. For a list of playable streams and the full Stremio experience, use Stremio on desktop.","MOBILE_ADDON_LOADING":"is still loading","MOBILE_ADDONS_LOADING":"addons are still loading","MOBILE_ADDON":"Addon","MOBILE_CONFIGURE_ADDON":"Configure your addon","MOBILE_CONFIGURE_ADDON_LABEL":"Configure Addon","MOBILE_ORGANIZER_ADDONS_WARNING":"The Stremio Organizer app provides a limited selection of addons. For the full Stremio experience, use Stremio on desktop.","MOBILE_DISCONNECT":"Disconnect","MOBILE_LOOKING_FOR_DEVICES":"Looking for devices...","MOBILE_CAST_TO":"Cast to","NAVIGATION_ON":"On","NAVIGATION_OFF":"Off","MARKETING_AGREE":"I agree to receive marketing communications from Stremio","QUIT":"Quit","CONNECTED":"Connected","AUTHENTICATE":"Authenticate","CACHING":"Caching","SETTINGS_CACHING_DRIVE":"Caching drive","ENABLE_LOCAL_FILES_ADDON":"Enable the local files addon (requires restart)","LOCAL_ADDON_NOT_ENABLED":"Local addon is not enabled. Click here to go to the settings and enable it","ENABLE_REMOTE_HTTPS_CONN":"Enable remote HTTPS connections","TORRENT_PROFILE":"Torrent Profile","DATA_CACHING":"Data Caching","MAGNET_PARSING":"Parsing a magnet link","January":"January","February":"February","March":"March","April":"April","May":"May","June":"June","July":"July","August":"August","September":"September","October":"October","November":"November","December":"December","Monday":"Monday","Tuesday":"Tuesday","Wednesday":"Wednesday","Thursday":"Thursday","Friday":"Friday","Saturday":"Saturday","Sunday":"Sunday","Action":"Action","Comedy":"Comedy","War":"War","Family":"Family","Animation":"Animation","Adventure":"Adventure","Fantasy":"Fantasy","Crime":"Crime","Mystery":"Mystery","Romance":"Romance","Drama":"Drama","Horror":"Horror","Thriller":"Thriller","Sci-Fi":"Sci-Fi","Music":"Music","Biography":"Biography","Documentary":"Documentary","Sport":"Sport","Musical":"Musical","Western":"Western","Film-Noir":"Film-Noir","News":"News","History":"History","Game-Show":"Game-Show","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film & Entertainment","Gaming":"Gaming","From TV":"From TV","Lifestyle":"Lifestyle","Science & Education":"Science & Education","Cooking & Health":"Cooking & Health","Beauty & Fashion":"Beauty & Fashion","Sports":"Sports","News & Politics":"News & Politics","How-to & DIY":"How-to & DIY","Tech":"Tech","Automotive":"Automotive","Causes & Non-Profits":"Causes & Non-Profits","Movies":"Movies","Uk Live Tv":"Uk Live Tv","Fashion":"Fashion","Business News Radio":"Business News Radio","Business Tv":"Business Tv","Cars & Auto":"Cars & Auto","Comedy Radio":"Comedy Radio","Lifestyle Radio":"Lifestyle Radio","News Tv":"News Tv","Food And Wine":"Food And Wine","Latino Tv":"Latino Tv","Shopping Tv":"Shopping Tv","Religion":"Religion","Kids":"Kids","Body & Soul":"Body & Soul","Education":"Education","Indian Tv":"Indian Tv","Extreme Sports":"Extreme Sports","Middle Eastern Tv":"Middle Eastern Tv","Celebrity Tv":"Celebrity Tv","Science Tv":"Science Tv","Bikini babe":"Bikini babe","Outdoors":"Outdoors","German Tv":"German Tv","French Tv":"French Tv","Italian Tv":"Italian Tv","Gamer Tv":"Gamer Tv","Travel":"Travel","Asian Tv":"Asian Tv","Entertainment":"Entertainment","News Radio":"News Radio","Music Radio":"Music Radio","Language Learning":"Language Learning","Science Radio":"Science Radio","Tech Radio":"Tech Radio","Science & Technology Vod":"Science & Technology Vod","new video":"new video","new episode":"new episode","new movie":"new movie","recommended":"recommended","we recommend":"we recommend","offer of the day":"offer of the day","news":"news","music video":"music video","CTX_SHOW_HOTKEYS":"Show hotkeys","CTX_DISMISS_NOTIF":"Dismiss notifications","CTX_DISMISS_ALL":"Dismiss all","CTX_SHARE":"Share","CTX_COPY_SHARE_LINK":"Copy share link","CTX_COPY_MAGNET_LINK":"Copy magnet link","CTX_COPY_STREAM_LINK":"Copy stream link","CTX_DOWNLOAD_VIDEO":"Download this video","CTX_DOWNLOAD_SUBS":"Download subtitles","CTX_VIEW_ON_YOUTUBE":"View on YouTube","CTX_SHOW":"Show","CTX_PLAY":"Play","CTX_PLAY_IN":"Play in","CTX_PLAY_ON":"Play on","CTX_WATCH_ON":"Watch on","CTX_WATCH":"Watch","CTX_WATCHED":"Watched","CTX_WATCH_BEGINNING":"Watch from the beginning","CTX_WATCH_MOBILE":"Watch on a mobile device","CTX_REWIND":"Rewind to beginning","CTX_MARK_WATCHED":"Mark as watched","CTX_MARK_NON_WATCHED":"Mark as non-watched","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Mark rest as watched","CTX_UNMARK_REST":"Mark rest as non-watched","CTX_RECEIVE_NEW_NOTIF":"Receive new notifications","CTX_REMOVE_CACHE":"Remove from cache","CTX_REMOVE_CACHE_EP":"Remove episode from cache","CTX_OPEN_CONTAINING":"Open containing folder","CTX_REMOVE":"Remove from library","CTX_AVAILABLE_OFFLINE":"Available Offline","CTX_PAUSED":"Paused","CTX_ALWAYS_ON_TOP":"Always on top","CTX_FULLSCREEN":"Fullscreen","CTX_WRONG_SUBS":"Wrong subtitles?","CTX_REPORT_ISSUES":"Report issue","CTX_COPY":"Copy","CTX_PASTE":"Paste","CTX_CLEAR":"Clear","CTX_CLEAR_RECENT_SEARCHES":"Clear recent searches","HELLO_THERE":"Hello There","HOPE_YOU_ENJOY":"We hope you enjoy Stremio and it\'s one of your favourite apps already!","WHO_ARE_WE":"Who are we? We are the team behind it - two guys who work hard every day for the last 3 years to make this product better and better.","SUPPORT_US":"If you enjoy using Stremio, if Stremio is valuable for you - spread the word!","SPREAD_THE_WORD":"Share with your friends now, spread the word about Stremio","MORE_PEOPLE":"The more people use Stremio, the better it will get!","SEND_A_LINK":"Or send a link to our website","TIP_LOCALFILES":"Tip: you can drag & drop local video files into Stremio","ADDON_MY":"My Addons","ADDON_COMMUNITY":"Community Addons","ADDON_OFFICIAL":"Official Addons","ADDON_REPOS":"Addon collections","ADDON_SEARCH":"Search addons","ADDON_INSTALL":"Install","ADDON_CONFIGURE":"Configure","ADDON_UNINSTALL":"Uninstall","ADDON_UPGRADE":"Upgrade","ADDON_INSTALLED":"Installed","ADDON_INSTALLED_MSG":"Addon installed!","ADDON_UPGRADED_MSG":"Addon upgraded!","ADDON_UNKNOWN":"Unknown","ADDON_ERR":"Addon install error!","ADDON_DISCONNECTED":"Disconnected","ADDON_APP_MISSING":"the app for this source is not installed. Do you want to install it now?","ADDON_APP_INSTALL":"Install Now","ADDON_PAGE":"Addon Page","ADDON_TOP_CONTENT":"Best from this Addon","ADDON_PROVIDES":"This addon will give you:","ADDON_WATCH":"Watch #{types} now!","ADDON_WATCH_FREE":"Watch #{types} for FREE now!","ADDON_ADDON":"Addon","ADDON_SUPPORTED_TYPES":"Supported types","ADDON_SUPPORTED_CATALOGS":"Supported catalogs","ADDON_PROVIDES_DISCOVER":"More #{types} in Discover","ADDON_PROVIDES_STREAMS":"Watch #{types}","ADDON_PROVIDES_STREAMS_FREE":"Watch #{types} for FREE","ADDON_PROVIDES_SUBTITLES":"Subtitles for #{types}","ADDON_CANTDETECT":"We couldn\'t detect a running Stremio, so we couldn\'t detect what addons you have installed.","ERR_NO_META":"No information found about this ","ERR_GETTING_META":"Error retrieving information about this.","ERR_CANT_PARSE_MAGNET":"Unable to parse magnet","ERR_NO_MAGNET_INFOHASH":"No valid info hash for magnet","ERR_NO_FILE_PATH":"Unable to send request without a path to file","ERR_NO_TORRENT":"No torrent returned","ERR_NO_SUPPORTERD_FILES":"No supported files found","ERR_OPENING_FILES":"Could not open external files","ERR_INVALID_LINK":"Invalid link","ERR_REGISTERED_ONLY":"This option is available for registred users only.","ERR_CLIPBOARD":"Can not play from clipboard","ERR_CLIPBOARD_READ":"Can not read the clipboard on this platform","ERR_CLIPBOARD_GENERIC":"No playable URL found in the clipboard. Please copy a URL (e.g. a magnet link) to a video.","BOARD_CONTINUE_WATCHING":"Continue watching","BOARD_EXPLANATION_RECOMMENDATIONS":"Movies picked specially for you.
This movie is a sample recommendation.","BOARD_EXPLANATION_EPISODES":"New episodes of your favorite Series come here.
Add series you follow to your Library.","BOARD_EXPLANATION_VIDEOS":"New episodes of your favorite Channels come here.
Add YouTube channels you follow to your Library.","WEBSITE_SLOGAN_WATCH":"Watch Instantly","WEBSITE_SLOGAN_ALL":"All the Video Content You Enjoy in One Place","WEBSITE_SLOGAN_NEW":"All You Can Watch","WEBSITE_SLOGAN_NEW_NEW":"Freedom to Stream","WEBSITE_WATCH_FROM":"Watch from","WEBSITE_DOWNLOAD":"Download Now","WEBSITE_DOWNLOAD_FOR":"Download Now For","WEBSITE_IS_DESKTOP":"Stremio is a desktop application, open this page on your PC and download it","WEBSITE_DESKTOP_DEMO_VID":"Desktop demo","WEBSITE_PAGE_HOME":"Home","WEBSITE_PAGE_FEATURES":"Features","WEBSITE_PAGE_ADDONS":"Addons","WEBSITE_PAGE_TECH":"Technology","WEBSITE_PAGE_CREATE_ADDON":"Create Addon","WEBSITE_PAGE_CONTACTS":"Contacts","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Movies","WEBSITE_TYPE_series_PL":"Series","WEBSITE_TYPE_tv":"Live TV","WEBSITE_TYPE_channel":"Channels","WEBSITE_STREMIO_WHAT_IS":"Stremio is an app that helps you organize and instantly watch your favorite videos, movies, TV series and TV channels.","WEBSITE_FEATURES_WATCH":"Watch Instantly in HD","WEBSITE_FEATURES_WATCH_DETAIL":"Click and play your favourite movies, TV Shows, videos and TV channels.","WEBSITE_FEATURES_SUBS":"Automatic Subtitles","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio automatically picks synced subtitles for your language.","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"Play on TV & mobile devices","WEBSITE_FEATURES_CAST_DETAIL":"Cast to AppleTV, Chromecast, Smart TV (DLNA/UPnP) and mobile devices.","WEBSITE_LIB":"Enjoy Your Personal Library Synced on All Your Devices","WEBSITE_LIB_COLLECT":"Collect from Stremio","WEBSITE_LIB_IMPORT":"Import from Facebook","WEBSITE_LIB_LOCAL":"Add from your local drive","WEBSITE_BOARD":"The Board - Your one-stop place for Notifications and Recommendations","WEBSITE_BOARD_RECOMMEND":"Recommended TV Show","WEBSITE_BOARD_TRENDING":"Trending Movie","WEBSITE_BOARD_NEW":"New Video","WEBSITE_BOARD_EPISODE":"New Episode","WEBSITE_BOARD_1":"Looking for something interesting to watch? Get recommendations based on your taste!","WEBSITE_BOARD_2":"Get notified when a new episode of your favourite TV show or YouTube channel is out!","WEBSITE_BOARD_YOUTUBE":"New videos of YouTube channels","WEBSITE_BOARD_EPISODES":"New episodes of series you follow","WEBSITE_ADDONS":"Content Addons","WEBSITE_TECH_DETAIL":"We love technology, we love mad science!\\nStremio is using the following open source technologies:","WEBSITE_TECH_WCJS":"WebChimera.js allows Stremio to play any video format with good performance.","WEBSITE_TECH_WCJS_EXTRA":"We are core project contributors","WEBSITE_TECH_ELECTRON":"Electron provides an innovative platform to build Stremio with.","WEBSITE_TECH_ELECTRON_EXTRA":"We are project contributors","WEBSITE_TECH_LINVODB":"A database technology that ensures your data is organized and available anywhere you login.","WEBSITE_TECH_LINVODB_EXTRA":"In-house technology","WEBSITE_CREATE_ADDON":"Create your addon","WEBSITE_CREATE_ADDON_DETAIL":"Do you have a service providing video content? We\'ll help you benefit from Stremio\'s features by creating your Addon.","WEBSITE_CREATE_ADDON_BENEFITS":"Benefits of Creating an Addon for Stremio","WEBSITE_P2P_BEAUTY":"The Beauty of Peer-to-Peer Streaming","WEBSITE_P2P_1":"Reliable and affordable full HD / 4K video on demand or live streaming","WEBSITE_P2P_2":"Distribution platform providing great user experience","WEBSITE_P2P_3":"We will create an addon meeting your exact needs","WEBSITE_P2P_CONTACT":"Interested? You are welcome to contact us.","WEBSITE_P2P_CONTACT_EXTRA":"We will be happy to help you integrate your content with Stremio!","WEBSITE_P2P":"Once in a while, there comes a technology that changes the name of the game. We invested tons of time and effort in building our Peer-to-Peer (P2P) video streaming engine that provides great performance and versatility to adapt with any use case.\\nContact us for DRM-enabled P2P video on demand or live streaming.","WEBSITE_THOUGHTS":"Thoughts we share:","WEBSITE_SPREAD":"Spread the word about Stremio:","WEBSITE_CONTACT":"Contact us, we\'ll be happy to hear from you!","WEBSITE_OPENSOURCE":"For our open source projects, go to our","WEBSITE_BITCOIN":"Donate bitcoin:","WEBSITE_FAQ":"Frequently asked questions","WEBSITE_FAQ_SHORT":"FAQ","WEBSITE_QUESTIONS":"Questions","WEBSITE_TOS":"Terms of use","WEBSITE_LEGAL":"Legal","WEBSITE_PAGE_ABOUT":"About","WEBSITE_PAGE_BECOME_PARTNER":"Become a partner","WEBSITE_ALL_YOU_CAN_WATCH":"Freedom To Watch\\nEverything You Want.","WEBSITE_FREEDOM_TO_STREAM":"Freedom to Stream","WEBSITE_WHAT_IS_STREMIO":"What is stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio is a one-stop hub for video content aggregation. Discover, organize and watch video from all kind of sources on any device that you own.","WEBSITE_WHAT_IS_STREMIO_P2":"Movies, TV shows, series, live television or web channels like YouTube and Twitch.tv - you can find all this on Stremio.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio is a modern media center that\'s a one-stop solution for your video entertainment. You discover, watch and organize video content from easy to install addons.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Movies, TV shows, live TV or web channels - find all this on Stremio.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Enjoy on all your Media devices","WEBSITE_DEVICES_COLLECT":"Collect from Stremio","WEBSITE_DEVICES_IMPORT_FB":"Import from facebook","WEBSITE_DEVICES_LOCAL":"Add from local drive","WEBSITE_JOIN_THE_PARTY_NOW":"Join the party now","WEBSITE_DEVICES_ALL":"Easy to use on all your devices;","WEBSITE_EXTENDABLE_CATALOG":"Infinitelly extendable video catalog;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Great features to organize your media;","WEBSITE_AS_SEEN_ON":"As seen on","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"About us","WEBSITE_LINK_TECHNOLOGY":"Technology","WEBSITE_LINK_APPS":"Apps","WEBSITE_LINK_DOWNLOADS":"Downloads","WEBSITE_MORE":"More","WEBSITE_LINK_ADDONS":"Addons","WEBSITE_LINK_ADDON_SDK":"Addon SDK","WEBSITE_LINK_CONTRIBUTE":"Contribute","WEBSITE_LINK_COMMUNITY":"Community","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"... & More","WEBSITE_LINK_HELP":"Help center","WEBSITE_LINK_CONTACTS":"Business inquiries","WEBSITE_LINK_TOS":"Terms & conditions","WEBSITE_LINK_PRAVACY":"Privacy policy","WEBSITE_SUBSCRIBE":"Subscribe","WEBSITE_NEWSLETTER":"Join Our Newsletter for amazing stuff","WEBSITE_PLACEHOLDER_EMAIL":"Your Email","WEBSITE_COMMUNITY":"Community","WEBSITE_LINK_PRAVACY_LEGAL":"Privacy & legal","WEBSITE_WHY":"Why we do it","WEBSITE_WHY_P1":"At Stremio, we come to work every day because we want to solve an important problem for the video-on-demand industry. There’s so much new content published every minute that it’s virtually impossible to find your way around it.","WEBSITE_WHY_P2":"We help people navigate that huge world of video entertainment and discover new content to enjoy. Our apps bring together movies, series, live TV, web channels, and more. We are dedicated to making it incredibly easy for users to find titles and broadcasters that they love.","WEBSITE_WHY_P3":"You can use our service on any device and at any time, making Stremio the only video entertainment hub you’ll ever need.","WEBSITE_TEAM":"TEAM","WEBSITE_TEAM_P":"The Stremio team is small but powerful: between the ten of us, we code in X languages, and share expertise in software development, UI and UX design, marketing and advertising, and business and startups.","WEBSITE_FEATURES":"Features","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Discover new content with ease","WEBSITE_FEATURES_DISCOVER_P":"Easily discover new movies, TV shows, series and channels to watch. Browse by category, genre, rating, recency, etc. or simply type a name to find. Stremio makes finding new video content a piece of cake.","WEBSITE_FEATURES_ALL_CONTENT":"All of your video content on one screen","WEBSITE_FEATURES_ALL_CONTENT_P1":"See what movies, series or videos you didn’t finish and continue watching them; get notified for new episodes and releases; and browse through the recommendations you will get based on your viewing habits.","WEBSITE_FEATURES_LIBRARY":"Organize your video library","WEBSITE_FEATURES_LIBRARY_P1":"Add any title to your Stremio library with a single click and find your way around your content, neatly arranged by type, recency, or alphabetical order.","WEBSITE_FEATURES_CALENDAR":"Keep track of everything you watch","WEBSITE_FEATURES_CALENDAR_P1":"Get a calendar visualization of all the movies and series you add to your library. Export your Stremio calendar and sync it so you always know when a new episode or a premier is due.","WEBSITE_FEATURES_BIG_SCREEN":"Enjoy your video content on a bigger screen","WEBSITE_FEATURES_BIG_SCREEN_P1":"Cast whatever you are watching to another device - be it a phone, tablet or a TV with a single click.","WEBSITE_FEATURES_SOURCES":"Watch video from many different sources","WEBSITE_FEATURES_SOURCES_P":"Install official and community addons to enjoy video sourced from many different providers - all in one sleek, easy to use app.","WEBSITE_CREATE_AN_ADDON":"Create an addon","WEBSITE_FEATURES_SYNC":"Sync your library across different devices and resume your playback","WEBSITE_FEATURES_SYNC_P1":"Login with your account across all your devices and enjoy your library, addons, playback and calendar synchronized.","WEBSITE_FEATURES_EXTENDABLE":"Extendable video catalog by addons","WEBSITE_FEATURES_EXTENDABLE_P1":"The Stremio addon catalog provides a number of addons to install and watch a variety of video content from. This includes movies, shows, live TV, sport, news, podcasts, web channels, video games and more.","WEBSITE_FEATURES_AUTO_SUBS":"Automatic subtitles","WEBSITE_FEATURES_AUTO_SUBS_P1":"With our subtitle addons you get automatically selected options for your preferred language.","WEBSITE_FEATURES_CHROMECAST":"Casting to Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"Enjoy your video content on a bigger screen or just cast whatever you are watching to another device.","WEBSITE_FEATURES_KEEP_TRACK":"Keep track of your favorite TV shows and Web channels","WEBSITE_FEATURES_KEEP_TRACK_P1":"Get a calendar visualization and notifications for new episodes of your favorite series and web channels.","WEBSITE_FEATURES_POWER_USER":"Power user features","WEBSITE_FEATURES_POWER_USER_P1":"Play in external player","WEBSITE_FEATURES_POWER_USER_P2":"Play from a torrent file or magnet link","WEBSITE_FEATURES_POWER_USER_P3":"Import to your library from Facebook likes or local disk","WEBSITE_ADD_ONS":"Addons","WEBSITE_ADD_ONS_P1":"All of the video content Stremio provides get sourced through an addon system - no content or content provider has been built into the app.","WEBSITE_ADD_ONS_P2":"There are two groups of addons available: official and community addons.","WEBSITE_ADD_ONS_P3":"The official ones are developed and hosted by Stremio, whereas community addons are created by our community members, who also host them.","WEBSITE_ADDONS_OFFICIAL":"Official addons","WEBSITE_ADDONS_WATCHUB":"Stream your favourite movies, series and shows from providers like iTunes, Hulu, Amazon and other UK/US services.","WEBSITE_ADDONS_YOUTUBE":"Watch your favourite YouTube channels ad-free and get notifications for new uploads from the contributors you follow.","WEBSITE_ADDONS_FILMON":"Watch live TV, movies and social television for free. 600 TV channels, 45,000 free movies, documentaries and more.","WEBSITE_ADDONS_OPENSUBTITLES":"Movie and TV subtitles in multiple languages, thousands of translated subtitles uploaded every day.","WEBSITE_ADDONS_COMMUNITY":"Community addons","WEBSITE_ADDONS_FILMON_VOD":"Watch video on demand from Filmon.tv","WEBSITE_ADDONS_TWICH":"Watch live streams from Twitch.tv - a video streaming platform for the e-sports industry.","WEBSITE_ADDONS_VODO":"Watch indie movies absolutely free of charge.","WEBSITE_ADDONS_NETFLIX":"Watch Netflix movies and web series.","WEBSITE_ADDONS_CREATE":"Create an addon","WEBSITE_ADDONS_CREATE_P1":"If you wish, you can develop your own addon. This way, you can give yourself and our community access to new video content, and reach a new, targeted audience of millions of users around the world.","WEBSITE_ADDONS_START_CREATE":"To get started, visit the Stremio Addon SDK page:","WEBSITE_DOWNLOADS":"Downloads","WEBSITE_DOWNLOADS_P1":"For optimal performance, we recommend that you use the latest available version of the Stremio apps. If for some reason, however, you would like to use an older version, you can download it here.","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS (limited version)","WEBSITE_CONTRIBUTE":"Contribute","WEBSITE_CONTRIBUTE_P1":"The Stremio platform is open source and you can easily create an addon for content that is currently not sourced.","WEBSITE_CONTRIBUTE_WHY":"Why should you create an addon?","WEBSITE_CONTRIBUTE_WHY_P1":"Reach new audience for your video content","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio’s user base is growing rapidly - within the first year of the launch, Stremio had gained 1 million users around the world, and in the second year of the platform’s existence this number grew to 2.5 million.","WEBSITE_CONTRIBUTE_WHY_P3":"With your addon, you can easily reach this audience and distribute your video content to them.","WEBSITE_CONTRIBUTE_ALL":"Watch your favourite movies, videos, series and channels in one single place.","WEBSITE_CONTRIBUTE_ALL_P1":"You’re a fan of a particular type of content not available on Stremio yet? Create an addon for it and enjoy watching your favourite videos in one of the largest and easiest to use entertainment hubs on the market.","WEBSITE_CONTRIBUTE_ALL_P2":"On top of that, you’ll get the endless gratitude of other like-minded Stremio community members.","WEBSITE_CONTRIBUTE_MONETIZE":"Monetize your addon and earn money with its help","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Once you develop a new addon for Stremio, you can easily monetize it through a number of different ways. If you are considering this, feel free to get in touch with us at ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" - we would be happy to consult and advise you about addon monetization options.","WEBSITE_CONTRIBUTE_TRANSLATE":"Become a volunteer translator","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"If you want to enjoy the Stremio apps in different languages, you can join our community of volunteer translators. They help us add versions of the Stremio in many different languages.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Are you eager to get started?","WEBSITE_TRANSALTE_STREMIO":"Translate Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Official communities","WEBSITE_COMMUNITY_OFFICIALS_P1":"Become a part of the growing Stremio community. Follow us on social media and don’t be shy to say hello - we love hearing from our fans! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Unofficial communities","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Partners and supporters","WEBSITE_COMMUNITY_GOODIES":"Stremio goodies","WEBSITE_COMMUNITY_WALLPAPERS":"Wallpapers","WEBSITE_COMMUNITY_ART":"Community Art Gallery","WEBSITE_LINK_ART":"Community art gallery","WEBSITE_CONTACT_US":"Contact us","WEBSITE_CONTACT_US_P1":"If you have any questions, comments or suggestions, feel free to get in touch with us through the contact form below.","WEBSITE_CONTACT_US_P2":"Keep in mind that we are located in Bulgaria so there may be a delay in addressing your query due to time zone differences.","WEBSITE_CONTACT_US_SUCCESS":"Your message has been sent. We will get back to you at our earliest convenience.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Please enter a valid email!","WEBSITE_CONTACT_US_Q_RELATED_TO":"What is your question related to?","WEBSITE_CONTACT_US_Q_OS":"What is your Operation System?","WEBSITE_CONTACT_US_PH_EMAIL":"Your E-mail","WEBSITE_CONTACT_US_PH_MESSAGE":"Message","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"SEND","WEBSITE_CONTACT_US_Q_1":"How to install?","WEBSITE_CONTACT_US_Q_2":"How to uninstall?","WEBSITE_CONTACT_US_Q_3":"(HTML) How to make lasagna?","WEBSITE_CONTACT_US_Q_4":"Addons","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Technology","WEBSITE_TECHNOLOGY_P1":"We love technology and mad science.
Here is what powers Stremio (it’s all open-source).","WEBSITE_TECHNOLOGY_P_QT":"Cross-platform software development at its best.","WEBSITE_TECHNOLOGY_P_MPV":"A free, open source, and cross-platform media player.","WEBSITE_TECHNOLOGY_P_RN":"React Native lets you build mobile apps using only JavaScript.","WEBSITE_TECHNOLOGY_P_VLC":"Media framework embedded into application to get multimedia.","WEBSITE_TECHNOLOGY_P_REALM":"Realm is a mobile platform and a replacement for SQLite & Core Data.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js is an open-source, cross-platform, JavaScript runtime environment.","WEBSITE_TECHNOLOGY_P_RUST":"Rust is a multi-paradigm system programming language focused on safety, especially safe concurrency.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Contribute to the project","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"There are two ways you can contribute to Stremio and help us make the product even better.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"You can donate your valuable language skills by translating the platform...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"or","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... you can employ your coding skills for creating community addons. ","WEBSITE_TRANSLATE_STREMIO":"Translate Stremio","WEBSITE_404_OH_NO":"Uh-oh! The page you’re looking for is not here...","WEBSITE_GO_HOME":"Go home","WEBSITE_LINK_OTHER_DOWNLOADS":"Other downloads","WEBSITE_FAQ_ABR":"FAQ","WEBSITE_SUPPORT":"Support","WEBSITE_DOWNLOAD_4_0_BETA":"Download Stremio 4 beta Now","WEBSITE_GET_FOR_DESKTOP":"Get for desktop","WEBSITE_LINK_ADDON_COMPETITION":"Addon competition","WEBSITE_LINK_ART_CONTEST":"Art contest","WEBSITE_MY_ACCOUNT":"My account","WEBSITE_MAINPAGE_FAQ_001_H1":"What is Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio is a modern media center that gives you the freedom to watch everything you want.","WEBSITE_MAINPAGE_FAQ_002_H1":"How does it work?","WEBSITE_MAINPAGE_FAQ_002_P1":"Once you install Stremio on your device and create an account, all you have to do is to visit the addon catalog and install any addon you want, and you\'re good to go!","WEBSITE_MAINPAGE_FAQ_002_P2":"After that, you can go to the Discover or Board sections to start exploring content.","WEBSITE_MAINPAGE_FAQ_003_H1":"What can I watch here?","WEBSITE_MAINPAGE_FAQ_003_P1":"A lot: Movies, TV shows, Web channels, Sport, TV channels, listen to Podcasts and more. Thanks to our addon system, you can access a variety of content.","WEBSITE_MAINPAGE_FAQ_004_H1":"Is Stremio open-source?","WEBSITE_MAINPAGE_FAQ_004_P1":"Yes, you can check the following links: ${1}desktop app${2} and ${3}GitHub organization${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Is Stremio safe?","WEBSITE_MAINPAGE_FAQ_005_P1":"Yes: because it is open-source software, the code is publically auditable and you can review it yourself.","WEBSITE_MAINPAGE_FAQ_006_H1":"How about my privacy?","WEBSITE_MAINPAGE_FAQ_006_P1":"We respect users\' privacy and do not collect any personal data besides the essential minimum to create and sync your account.","WEBSITE_MAINPAGE_FAQ_006_P2":"There is also a ${1}Guest mode${2} at signup, which requires no data whatsoever: in this mode, no calls are made to our backend. However, it comes at the expense of useful features, such as being able to sync your library across devices.","WEBSITE_MAINPAGE_FAQ_007_H1":"Can I cast to my TV?","WEBSITE_MAINPAGE_FAQ_007_P1":"Yes, we support Chromecast and you can cast both from desktop and mobile apps (Android).","WEBSITE_MAINPAGE_FAQ_008_H1":"How many addons does Stremio have?","WEBSITE_MAINPAGE_FAQ_008_P1":"As of late 2019, over 50 - for more information, check our addon catalog.","WEBSITE_MAINPAGE_FAQ_009_H1":"Can Stremio be extended beyond what\'s in the addon catalog?","WEBSITE_MAINPAGE_FAQ_009_P1":"Yes, you should check those: ${1}PimpMyStremio${2}, ${3}Reddit communities${4}, ${5}Stremio Downloader${6}, etc.","WEBSITE_MAINPAGE_FAQ_010_H1":"What devices does Stremio support?","WEBSITE_MAINPAGE_FAQ_010_P1":"We have desktop apps for Windows, Mac and Linux. For mobile, we support Android and iOS, although keep in mind that the iOS is limited in functionality (does not support most addons).","WEBSITE_MAINPAGE_FAQ_010_P2":"There are many Android-based devices which you can run Stremio on, like NVIDIA Shield and Amazon Fire Stick, but we do not support them officially.","WEBSITE_MAINPAGE_FAQ_011_H1":"Can you add certain content to Stremio?","WEBSITE_MAINPAGE_FAQ_011_P1":"Sorry, we provide no content ourselves, but the more Stremio addons you have installed, the more content you will be able to find.","WEBSITE_MAINPAGE_FAQ_012_H1":"Can Stremio play magnet links?","WEBSITE_MAINPAGE_FAQ_012_P1":"Yes, and it can also play normal HTTP links and torrent files (drag and drop).","WEBSITE_MAINPAGE_FAQ_013_H1":"Can I download a video and watch offline?","WEBSITE_MAINPAGE_FAQ_013_P1":"Available offline is an upcoming feature, but if you allow Stremio to cache on your device (from the settings panel) you can watch the videos later without a connection.","WEBSITE_MAINPAGE_FAQ_014_H1":"Nothing works, help me!","WEBSITE_MAINPAGE_FAQ_014_P1":"Are you sure you have installed addons? If yes, check with our ${1}help center${2}.","WEBSITE_MAINPAGE_FAQ_015_H1":"How does Stremio sustain it\'s development operations?","WEBSITE_MAINPAGE_FAQ_015_P1":"We run non-intrusive ads through ${1}AdEx${2}, which is a company by the same founding team that focuses on privacy preserving, transparent ads.","WEBSITE_MAINPAGE_FAQ_015_P2":"For more questions, go to our ${1}help center${2}.","HELP_LEARN_MORE":"Help us learn more about you.","LIFESTYLE":"Lifestyle","SPORTS":"Sports","FOOD_HEALTH":"Food & health","BEAUTY_FASHION":"Beauty & Fashion","NEWS":"News","GAMING":"Gaming","SCIENCE_EDUCATION":"Science & education","MUSIC":"Music","TRAVEL":"Travel","LATE_NIGHT":"Late Night","REALITY":"Reality","COMEDY":"Comedy","DIY":"How to DIY","TECH":"Tech","CINEMA":"Cinema","CONTINUE":"Continue","SLOW_LOADING":"SLOW LOADING?","I_GIVE_UP":"I GIVE UP","LEARN_MORE":"Learn more","POOR_SOURCE":"This source is poorly available or your internet connection is not fast enough","PICK_CATEGORIES_ERR":"You have to pick at least 3 categories","ADJUST_TIMING":"Adjust timing with ","ADJUST_SIZE":"Adjust size with ","SEARCH_ANYTHING":"You Can Search Anything...","ALL_CATEGORIES":"All","SEARCH_CATEGORIES":"Movies, Series, YouTube & TV","SEARCH_PERSONS":"Actors, Directors & Writers","SEARCH_PROTOCOLS":"HTTP & Magnet Links","SEARCH_TYPES":"IMDB / TVDB links","WATCHED":"Watched","SHOW_LESS":"Show less","LAST_SEARCHES":"Last searches","CLEAR_HISTORY":"Clear history","CHOOSE_SOME":"CHOOSE SOME OF THIS:","NO_WEB_REMOTE":"Web Remote could not be loaded","STREMIO_OFFLINE":"Stremio is offline","STREMIO_EXPENSIVE_CONNECTION":"We\'ve detected that you are using a mobile data connection, do you want to continue?","USE_DATA":"Use data","WARNING":"Warning","MORE_INFO":"More Info ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Loading ...","STREMIO_TV_BACK_TO_LANGUAGES":"Back to languages","STREMIO_TV_REMOTE":"Remote","STREMIO_TV_GO_TO":"Go to:","STREMIO_TV_OR_SCAN":"or scan:","STREMIO_TV_ADDON_INSTRUCTIONS":"Please follow the instructions in order to install your preferred addons.","STREMIO_TV_LIVE_TV":"Live TV","STREMIO_TV_RESUME_WATCHING":"Resume Watching","STREMIO_TV_LOADING_BACKGROUND":"Loading Background","STREMIO_TV_CHECKING_AUTHENTICATION":"Checking Authentication","STREMIO_TV_LOADING_BOARD":"Loading Board","STREMIO_TV_LOGIN_HEADER_LINE_1":"We want our users to have the best possible personalized experience with our software.","STREMIO_TV_LOGIN_HEADER_LINE_2":"It is for this reason that we kindly ask you to make and/or login to your account.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Thank you for understanding,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"The Stremio Team","STREMIO_TV_REMOTE_INSTRUCTIONS":"In order to use the Web Remote with your Smartphone / Tablet / Desktop:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Setup","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle did not detect a internet connection.","STREMIO_TV_WIFI_DETAILS_1":"Connect to:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Use password:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Open a web browser with the link:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Default","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"By Last Watched","STREMIO_TV_LIBRARY_SORT_NAME":"By Name","STREMIO_TV_LIBRARY_TIMES_WATCHED":"By Times Watched","STREMIO_TV_DETAILS_SEASON_NUMBER":"Season ${1}","STREMIO_TV_STREAMS_LOADING":"Loaded ${1} / ${2} addons...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} addon is still loading...","STREMIO_TV_PLAYER_SETTINGS":"Player settings","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Subtitles delay","STREMIO_TV_PLAYER_AUDIO_DELAY":"Audio delay","STREMIO_TV_PLAYER_VIDEO_SCALING":"Video scaling","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Unsupported stream source","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Failed opening external link","STREMIO_TV_PLAYER_PLAY_IN_EXO":"Play with ExoPlayer","STREMIO_TV_PLAYER_PLAY_IN_VLC":"Play with libVLC player","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Switching to libVLC player due to a playback error","STREMIO_TV_ADDONS_TITLE":"Use Stremio on your Phone or PC to install or configure addons and press \\"Sync Addons\\"","STREMIO_TV_ADDONS_SUBTITLE":"Note: make sure you are using the same Stremio account","STREMIO_TV_ADDONS_SYNC_ADDONS":"Sync Addons","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Addons successfully synchronized","STREMIO_TV_ADDONS_SYNC_FAILED":"Failed to synchronize addons","STREMIO_TV_META_LINK_FAILED":"Failed opening meta link","STREMIO_TV_CATALOG_LOADING":"Catalog still loading...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Interface language updated","STREMIO_TV_SETTINGS_THEME_UPDATED":"Theme updated","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Preferred Language","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"Secondary Preferred Language","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tunnelled Playback","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Possible playback issues on some devices","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Some video formats might not work","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Auto frame rate matching","STREMIO_TV_SETTINGS_NO_CACHING":"No caching","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Default","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Soft","STREMIO_TV_SETTINGS_PROFILE_FAST":"Fast","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Ultra Fast","STREMIO_TV_SETTINGS_SERVER_URL":"Streaming server url","STREMIO_TV_SETTINGS_SERVER_VERSION":"Server version","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Unknown","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio version","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Edit server url","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Enter a streaming server url","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"To read Stremio\'s Privacy Policy, visit:","STREMIO_TV_SETTINGS_TOS_TEXT":"To read Stremio\'s Terms and Conditions, visit:","STREMIO_TV_NAV_SEARCH":"Search","STREMIO_TV_NAV_HOME":"Home","STREMIO_TV_NAV_DISCOVER":"Discover","STREMIO_TV_NAV_LIBRARY":"Library","STREMIO_TV_NAV_MOVIES":"Movies","STREMIO_TV_NAV_SERIES":"Series","STREMIO_TV_NAV_CHANNELS":"Channels","STREMIO_TV_NAV_TV":"Live TV","STREMIO_TV_NAV_SETTINGS":"Settings","STREMIO_TV_NAV_ADDONS":"Addons","STREMIO_TV_LOGIN_TITLE":"Link Account","STREMIO_TV_LOGIN_EXPIRES_IN":"Expires in","STREMIO_TV_LOGIN_STEP_ONE":"Scan QR Code above or go to","STREMIO_TV_LOGIN_STEP_TWO":"Log in to your Stremio account","STREMIO_TV_LOGIN_NEW_LINK":"Request a new link","STREMIO_TV_LOGIN_LINK_REFRESHED":"Login code refreshed","STREMIO_TV_SEARCH_PLACEHOLDER":"Type something","STREMIO_TV_SEARCH_NO_ADDONS":"No addons were requested for catalogs!","STREMIO_TV_SEARCH_BUTTON":"Search","STREMIO_TV_SEARCH_KEY_DEL":"Del","STREMIO_TV_SEARCH_KEY_SPACE":"Space","STREMIO_TV_SEARCH_KEY_CLEAR":"Clear","STREMIO_TV_SEARCH_HISTORY_TITLE":"Search History","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"You can search for Titles, Actors, Channels and more...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Clear Search History","STREMIO_TV_FILTERS_DESCRIPTION":"Choose from one of the filters below","FILTERS":"Filters","SETTINGS":"Settings","ACCOUNT":"Account","LOGOUT":"Logout","THEMES":"Themes","PLAYBACK":"Playback","PLAYBACK_SPEED":"Playback Speed","AUDIO_TRACKS":"Audio Tracks","VIDEOS":"Videos","SERVER":"Server","LINKS":"Links","ABOUT":"About","INTERFACE":"Interface","ANIMATIONS":"Animations","STATUS":"Status","LANGUAGE":"Language","SIZE":"Size","DELAY":"Delay","BOLD":"Bold","TEXT_COLOR":"Text Color","OUTLINE_COLOR":"Outline Color","BACKGROUND_COLOR":"Background Color","BACKGROUND_BLUR":"Background Blur","SEEK_TIME_DURATION":"Seek Time Duration","AUTO_PLAY":"Auto-Play Next Episode","PLAY_NOW":"Play Now","MARK_AS_WATCHED":"Mark as Watched","MARK_AS_UNWATCHED":"Mark as Unwatched","REWIND_TO_BEGINNING":"Rewind to Beginning","CONTINUE_WATCHING":"Continue Watching","ALL":"All","SECONDS":"seconds","ON":"ON","OFF":"OFF","RELOAD":"Reload","EDIT_URL":"Edit URL","NONE":"None","EMBEDDED":"Embedded","REMOTE_SWITCH_DEVICES":"Switch Devices","REMOTE_VIDEOS":"Videos","REMOTE_ADJUST_TIMING":"Adjust timing","REMOTE_ADJUST_SIZE":"Adjust size","REMOTE_COULD_NOT_BE_LOADED":"Web Remote could not be loaded","REMOTE_RETRY":"Retry","TORRENT_PROFILE_DEFAULT":"Default","TORRENT_PROFILE_SOFT":"Soft","TORRENT_PROFILE_FAST":"Fast","TORRENT_PROFILE_ULTRA_FAST":"Ultra Fast","FAQ_001_H1":"What is Stremio?","FAQ_001_P1":"Stremio is a media center software designed for video entertainment with ease of use in mind. Stremio allows you to organize & watch your own collection of movies, series, channels and live TV.","FAQ_001_P2":"Stremio collect the content it shows you from your local disk and our addons system.","FAQ_001_P3":"It will also notify you when new episodes/videos/movies you\'re interested in come out, and provide movie recommendations for you.","FAQ_02_H1":"How does Stremio compare to Kodi and Plex?","FAQ_02_P1":"We are inspired by those two pieces of software. But we have different goals - Stremio is specifically targeted towards entertainment video, and strives to become the mainstream solution for that by being very easy to use.","FAQ_02_P2":"Stremio will never be as customizable and feature-rich as Kodi and Plex, but it is significantly easier to use. Just ${1} get it and see ${2} :)","FAQ_03_H1":"How does Stremio compare to Netflix?","FAQ_03_P1":"Again, Netflix is one of our inspirations. We strive to achieve the user experience of Netflix, plus a lot of added goodies. But most importantly, we\'re giving you the freedom to manage your own library and add new content sources with our addon system.","FAQ_03_P2":"That makes Stremio infinitely extendable, so when you use Stremio, you\'re never limited to the content Netflix decides to license. For example, through Stremio you can watch content from ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} and even ${9}Netflix${10} itself!","FAQ_04_H1":"How does Stremio compare to Flipboard?","FAQ_04_P1":"We don’t get that question that often, except when talking to start-up people :)","FAQ_04_P2":"Stremio is by design a content aggregator, which essentially makes it Flipboard for video. This is very apparent in our Board section, which gives you catalogues and new episode/new video notifications for what you follow, just like Flipboard.","FAQ_05_H1":"How does Stremio compare to Popcorn Time?","FAQ_05_P1":"Stremio and Popcorn Time are similar in user interface, because there aren’t many ways to do video entertainment catalogues right :)","FAQ_05_P2":"But while Popcorn Time is focused on streaming torrents from specific sources, Stremio is unrestricted and is merely a content aggregator - it’s not locked into a specific content source.","FAQ_05_P3":"Furthermore, we do not provide any torrent addons by default, so Stremio does not cover the Popcorn Time use-case with official functionality.","FAQ_05_P4":"Another notable difference is that Popcorn Time is completely open source, while Stremio is ${1} partially open source${2}.","FAQ_06_H1":"Will you add this movie/series?","FAQ_06_P1":"No, sorry :(","FAQ_06_P2":"As is mentioned in most of the other questions, Stremio does not provide any content by itself - everything is added through the addons system. In case you have a content request, you can use the “Report” button in the Player, which will send an email to the author of the addon you’re currently using.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"Will you create addon for X?","FAQ_08_P1":"It\'s entirely possible.","FAQ_08_P2":"If you have an idea for an addon, drop us a line at ${1}office@stremio.com${2}, but please make sure your addon idea will not infringe on any copyrights or terms of use.","FAQ_08_P3":"At the moment, the next things on our roadmap are addons for FandangoNOW, Filmon.tv video on demand and Crunchyroll.","FAQ_09_H1":"Does Stremio use BitTorrent?","FAQ_09_P1":"Yes, Stremio supports BitTorrent as a streaming protocol. You can use that either with a torrent addon, or by drag-and-dropping a .torrent file into Stremio, or by pasting a magnet link into the Search Bar.","FAQ_09_P2":"Please note that the only official addon using BitTorrent is ${1}Vodo${2}, which provides indie content, all permitted to be distributed with BitTorrent.","FAQ_09_P3":"We do not support use of any third-party addons which may enable copyright infringement.","FAQ_10_H1":"What can I watch in Stremio with the official addons?","FAQ_10_P1":"By default, you can watch Filmon.tv, YouTube and Vodo content within Stremio itself, with it’s embedded player. Additionally, we have an addon for Twitch.tv and a few others.","FAQ_10_P2":"This combined provides a selection of:","FAQ_10_L1":"Popular TV channels, provided by Filmon.tv - for example E4, BBC, Bollyworld TV","FAQ_10_L2":"Everything from YouTube - for example BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Indie movies with Vodo","FAQ_10_L4":"Online gaming broadcasts with Twitch.tv","FAQ_10_P3":"Additionally, there are many content sources provided with Guidebox and the Netflix addons, which do not play entirely inside Stremio, but would redirect to the given service. For example, the Guidebox addon would give you a selection of movies you can stream in the US for free, from services like TubiTV and Crackle.","FAQ_11_H1":"Stremio won\'t install, what should I do?","FAQ_11_P1":"If you\'re on Windows, try ${1}this alternative installer${2}.","FAQ_11_P2":"If you\'re on Mac OS X, please be aware that we don\'t support anything older than OS X Mavericks (10.9).","FAQ_11_P3":"If you\'re on Linux, be aware that we only support 64 bit (x64) Linux at the moment.","FAQ_11_P4":"If you still can\'t resolve your problem, please write us at our ${1}Facebook group${2}.","FAQ_12_H1":"Why does my anti-virus complain? Is Stremio safe?","FAQ_12_P1":"We assure you Stremio is ${1}100% clean${2}.","FAQ_12_P2":"Your antivirus is complaining because we include advertising in our installer, which some anti-virus programs recognize as ad-ware.","FAQ_12_P3":"If you\'re still unsure, you can try our ${1}alternative installer${2}.","FAQ_13_H1":"How can I make an addon?","FAQ_13_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_13_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_13_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_14_H1":"How are addons published?","FAQ_14_P1":"When you create an addon and host, and put a endpoint field in your manifest, which points to a working addon address, the addon will automatically publish itself to our ${1}Addon catalogue${2}.","FAQ_14_P2":"This happens because the server part of the stremio-addons module automatically makes a call to our API to announce the addon. When our API validates your endpoint as a valid addon, it will start showing in the catalogue.","FAQ_15_H1":"Can I run Stremio in my browser?","FAQ_15_P1":"Not at the moment, but this is coming!","FAQ_15_P2":"If you\'re curious to see an Alpha, you can see it here: ${1}alpha4.strem.io${2}. Keep in mind streaming is disabled on this alpha. We support Chrome, Firefox, Opera and Edge.","FAQ_16_H1":"Casting to TV doesn\'t work / subtitles don\'t work","FAQ_16_P1":"Casting to TV uses the DLNA technology which is very inconsistent between different TV brands and models. For that reason, we do not have the ability to test it in every case, so it\'s far from perfect. Despite this, we\'re working on improving it constantly but we cannot give you a time estimate on when DLNA will start working properly with your TV.","FAQ_16_P2":"If you don\'t even see your TV in the casting menu, please try disabling your network connection and re-enabling it (on Windows, right click the Network and use Enable/Disable), as well as restarting your router, TV and PC.","FAQ_16_P3":"If you are still encountering issues, you can help us by sending your TV brand and model information at ${1}office@stremio.com${2}.","FAQ_16_P4":"In the meantime, we recommend Chromecast, which we support very well, or simply plugging in your TV to your PC with an HDMI cable.","FAQ_17_H1":"Stremio freezes and/or crashes, what can I do?","FAQ_17_P1":"First of all, if you\'re using Windows 7 with AVG anti-virus: we have a problem with that combination. The problem is in AVG itself, and there\'s no reasonable way to resolve it on our end. Unfortunately, exceptions or disabling the anti-virus won\'t work. The only solution is to replace AVG with something else.","FAQ_17_P2":"If that\'s not the issue, but you\'re still using Windows, please update to the latest service pack and update/re-install your GPU drivers, then try again.","FAQ_17_P3":"If you\'re problem is still not resolved, or you\'re using a Mac or Linux, please write us reporting the exact details of the problem at ${1}our Facebook group${2}.","FAQ_18_H1":"How can I make an addon?","FAQ_18_P1":"For starters, we recommend you check our ${1}addons system module${2} on GitHub.","FAQ_18_P2":"Afterwards, you can follow the ${1}Hello World tutorial${2}.","FAQ_18_P3":"If you don\'t have any programming skills, please post your idea on ${1}the Reddit community${2} and contact us with your addon idea on ${3}office@stremio.com${4}.","FAQ_19_H1":"Why is Stremio taking disk space?","FAQ_19_P1":"Stremio has a local cache to temporarily keep the video files you stream.","FAQ_19_P2":"This has two benefits: first, it allows Stremio to pre-buffer the video ahead so as to ensure smoother streaming. Second, it keeps the videos in the local cache so you can continue watching them offline.","FAQ_19_P3":"How much Stremio keeps depends on the Cache setting in the Settings panel. Stremio may keep up to the set amount (e.g. 2GB) on your disk, unless the currently streamed video is larger than that, in which case it has to allocate enough storage to keep it until you\'re streaming it.","FAQ_20_H1":"Where is the cache folder?","FAQ_20_P1":"On Windows, it\'s stremio-cache in the drive you picked in Settings (e.g. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"On MacOS, it\'s \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"On Linux, it\'s \\"~/.stremio/stremio-cache\\" or \\"~/stremio-cache\\"","FAQ_21_H1":"I get \\"Streaming server is not found\\" error, what can I do?","FAQ_21_P1":"If you get this error, it means one of few things:","FAQ_21_P2":"1) You are trying to use an addon backed by YouTube/BitTorrent source, through our ${1}web version${2}. In this case, you should install our desktop version from ${3}our website${4}.","FAQ_21_P3":"2) Something is wrong with your Stremio installation. In this case, try re-installing our latest desktop version from ${1}the website${2}. If this does not help, try disabling anti-virus programs and firewalls, restarting your PC and trying again. If this does not work too, please write us at our ${3}our Facebook group${4}.","FAQ_22_H1":"I cannot see/use most addons on iOS","FAQ_22_P1":"Because of restrictions in the Apple App Store terms and conditions, we have restricted the iOS application only to a particular set of addons.","FAQ_22_P2":"But rest assured - there will be more addons for iOS in the future, and we may also add an integration that will allow you to use all Stremio addons thanks to connecting the iOS app to the Stremio Streaming Server."}')},3191:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"Film","TYPE_series":"Dizi","TYPE_tv":"TV kanalı","TYPE_channel":"Kanal","TYPE_other":"Diğer","TYPE_movie_PL":"Filmler","TYPE_series_PL":"Diziler","TYPE_tv_PL":"TV kanalları","TYPE_channel_PL":"Kanallar","TYPE_other_PL":"Diğer","TYPE_ALL":"All","VIDEO":"Video","BACK":"Geri","MORE":"Daha Fazla","DONE":"Bitti","COPY":"Kopyala","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"Keşfet","Board":"Pano","Library":"Kitaplık","My Library":"Kitaplığım","Calendar":"Takvim","NOTIFICATION_ONLINE":"Şu anda çevrimiçisiniz","NOTIFICATION_OFFLINE":"Şu anda çevrimdışısınız","INTERNET_CONNECTION":"Ağ bağlantısı","STORAGE_FULL_TITLE":"Dikkat: Depolama tamamen dolu!","STORAGE_FULL_TEXT":"Stremio, ayarlarınızı, tercihlerinizi veya giriş bilgilerinizi kaydedemeyecektir. Stremio\'yu yeniden başlatmayı veya yeniden kurmayı düşünün.","SEARCH":"arama:","SEARCH_NO_RESULTS":"Sonuç bulunamadı","SEARCH_EXPLANATION_CONTENT":"Filmler, diziler, YouTube ve TV kanalları için ara","SEARCH_EXPLANATION_PEOPLE":"Aktörler, yönetmenler, yazarlar için ara","SEARCH_PASTE_LINKS":"HTTP ya da magnet bağlantısını yapıştır","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"Kitaplığa ekle","REMOVE_FROM_LIB":"Kitaplıktan kaldır","ADDED_TO_LIB":"Kitaplığa eklendi","REMOVED_FROM_LIB":"Kitaplıktan kaldırıldı","TRAILER":"Fragman","WATCH_TRAILER":"Fragmanı izle","WATCH_NOW":"Şimdi izle","SHOW":"Göster","SHOW_MOVIE":"Filmi göster","WATCH_RANDOM":"Rastgele izle","IMDB_RATING":"IMDB Puanı","YEAR":"Yıl","DIRECTOR":"Yönetmen","WRITER":"Yazar","LEAD_ACTORS":"Başroller","CAST":"Oyuncular","CREW":"Ekip","SHOW_MORE_CAST":"Daha fazla »","AIRED":"Yayın tarihi","SEASONS":"Sezonlar","GENRE":"Tür","CATALOG":"Katalog","SUMMARY":"Özet","SHOW_MORE":"Daha fazlasını göster","SIMILAR":"Benzer","UPCOMING":"Yaklaşan","ENDED":"Biten","DURATION":"Süre","FEATURED":"Öne çıkanlar","METADATA":"Meta verisi","CATEGORY":"kategori","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"video ara","SEARCH_PLACEHOLDER":"ara veya magnet bağlantısını yapıştır","ADDON":"eklenti","ADDONS":"Eklentiler","OFFICIAL":"resmi","ADDONS_OFFICIAL":"Resmi Stremio Eklentileri","ADDONS_POPULAR":"Çevrende popüler","ADDON_FREE":"ücretsiz","ADDON_PEERED":"peered","ADDON_SUBSCRIPTION":"abonelik","ADDON_STREAM_GEORESTRICTED":"Bölgenizde mevcut değil","ADDON_STREAM_OFFLINECACHE":"Çevrimdışı Önbellek","ADDON_STREAM_LOCALFILE":"Yerel Dosya","SHARE_ADDON":"Eklentiyi paylaş","AVAILABLE_STREAMS":"Uygun Akışlar","NO_STREAM":"Uygun akış yok","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"Daha fazla akış için lütfen daha fazla eklenti yükleyin","STREAM_NOT_SUPPORTED":"Seçilen akış bu platformda desteklenmiyor.","ADDON_CATALOGUE":"Tüm eklentileri göster »","ADDON_CATALOGUE_MORE":"Daha fazla eklenti »","REPO_ADDED":"Depo eklendi","ADDON_REPO_EXIST_ERR":"Bu eklenti deposu zaten var","ADDON_REPO_ERR":"Depo eklenirken hata oluştu","ADDON_ADD_ERR":"Eklenti eklenirken hata oluştu","ERR_ADDON_PROTECTED":"Korumalı eklenti","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"Bir şeyler ters gitti - kimlik doğrulaması başarısız olabilir","ERR_NOT_COLLECTION_URL":"Bir koleksiyon bağlantısı değil","ERR_NOT_ADDON_URL":"Eklenti bağlantısı değil","ERR_DETECTFROMURL":"Bağlantıdan tespit edilemiyor","ADDON_DUPLICATE_WARNING":"Uyarı: yinelenen eklenti","ADDON_COLLECTION_SET_FAILED":"Koleksiyona ekleme başarısız oldu","SETTINGS_DATA_EXPORT":"Verileri dışa aktar","ADDON_PULL_FAILED":"Eklenti ekleme başarısız","REFRESH_ON_CLICK":"Yeniden denemek için tıklayın","STILL_IN_THEATER":"Film hala gösterimde","WATCH_IN_CINEMA":"Yakındaki bir sinemada izleyin","IN_THEATER":"Sinemada","GET_TICKETS":"Bilet al","UPCOMING_EPISODE":"Yaklaşan bölüm","UPCOMING_EPISODE_MESSAGE":"Bu bölüm yayınlanacak:","MISSING_DATE_EPISODE":"Bölüm tarihi eksik","MISSING_DATE_EPISODE_MESSAGE":"Bu bölüm henüz yayınlanmamış olabilir","CHANNEL_NOT_SCRAPED":"Bu kanal henüz uygun değil.
Lütfen birkaç dakika içinde tekrar deneyin.","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"Uygun olduğunda bildirilmesi için kitaplığa ekleyin.","GET_NOTIFIED_WHEN_AVAILABLE":"Uygun olduğunda bildirim alacaksınız.","WARNING_STREAMING_SERVER":"Uyarı: yerel akış sunucusu bulunamadı. YouTube ve BitTorrent\'den akış gerçekleşmeyecek.","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"Uyarı: Bu video donanımınız tarafından desteklenmiyor olabilir. Oynatma işlemi yavaş olabilir, unutmayın.","PLAYER_ERROR":"Hay aksi, oynatıcı hatası","PLAYER_ERROR_LOOKSLIKE":"Benziyor","PLAYER_ORIENTATION":"Oynatıcı yönü","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"Kilitli","PLAYER_ORIENTATION_SENSOR_SHORT":"Sensör","PLAYER_ORIENTATION_LANDSCAPE":"Oynatıcı yönü yatay olarak kilitli","PLAYER_ORIENTATION_SENSOR":"Oynatıcı yönü otomatik (sensör)","PLAYER_PLAYBACK_SPEED":"Oynatma Hızı","PLAYER_PLAYBACK_ERROR":"Oynatma hatası, lütfen tekrar deneyin","PLAYER_PLAYBACK_ERROR_UNKNOWN":"Bilinmeyen hata","PLAYER_PLAYBACK_ERROR_DEFAULT":"Üzgünüz, bu video {{productName}} tarafından oynatılamaz.","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"Canlı","PLAYER_NEXT_VIDEO_TITLE":"Sıradaki:","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"Reddet","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"Şimdi izle","STREAMING_FROM":"şuradan yayınlanıyor","CASTING_TO":"Yayınlanıyor:","NETWORK_STATUS":"Ağ durumu","STREAM_SPEED":"Yayın hızı:","STREAM_BUFFERED":"Belleğe alınan:","PEERS_INFO":"Eş bilgisi","PEERS_ACTIVE":"Aktif:","PEERS_CONNECTED":"Bağlandı:","PEERS_WAITING":"Bekleniyor:","TRANSCODING_WARNING":"Uyarı: video kod dönüştürme.","STREAM_LOADING":"yükleniyor...","PLAYING_LOCAL":"yerel dosyadan oynatılıyor","PLAYING_CACHE":"önbellekten oynatılıyor","WRONG_SUBS":"Altyazı hatalı mı?","ERR_SUBS_LOADING_TITLE":"Altyazı yüklenirken hata oluştu","ERR_SUBS_LOADING":"Altyazı yüklemesi başarısız: bu kullandığınız eklenti ya da ağ bağlantınızdaki bir sorun ile ilgili olabilir","WARN_FOLLOWING_SUB_ADDONS_FAILED":"Aşağıdaki altyazı eklentileri başarısız oldu","ERR_CASTING_UPDATE_TITLE":"Yayınlama aygıtı bilgisi güncellenemedi: Akış sunucusu çevrimdışı olabilir","CHOOSE_DEVICE":"İzlemek için bir cihaz seçin","NO_CAST_DEVICES":"Yayınlamak için cihaz yok.","NO_SETTINGS":"Kullanılabilir ayar yok.","PHONE_TABLET":"Telefon / Tablet","SUBTITLES":"Altyazılar","SUBTITLES_CHANGE":"Altyazıyı şunun için değiştir: ","SUBTITLES_CHANGE_NONE":"Bu dil için başka altyazı yok, üzgünüz.","SUBTITLES_CHANGE_ACIVE":"Şu anda #{{subtitlesDialog.activeIdx + 1}} altyazı etkinleştirildi. Altyazıları #{{subtitlesDialog.pickedIdx + 1}} etkileştirmek için \\"Devam\\" düğmesine tıklayın.","SUBTITLES_OR":"Alternatif olarak,","SUBTITLES_ADJUST_DELAY":"Altyazı gecikmesini ayarlayın:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"Veya G / H tuşlarını kullanarak oynatırken ayarlayın.","SUBTITLES_ADJUST_DELAY_TIP":"İPUCU: G / H tuşlarını kullanarak oynatırken ayarlayabilirsiniz.","SUBTITLES_DELAY":"Altyazı gecikmesi:","SUBTITLES_LOADING":"Altyazılar yükleniyor...","SUBTITLES_UNAVAILABLE":"Harici altyazı yok","SUBTITLES_DISABLED":"Kapalı","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"Sezon","EPISODE":"Bölüm","SPECIAL":"Özel","SORT":"Sırala","SORT_BY":"Sırala:","FILTER":"filtre","SORT_TRENDING":"popüler","SORT_RECENT":"en yeni","SORT_ALPHABET":"a-z","SORT_RATING":"puan","SORT_WATCHED":"izlendi","SORT_YEAR":"yıl","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"Senin için yeni","New Episodes":"Yeni Bölümler","New Videos":"Yeni Videolar","Recommendations":"Önerilenler","LIBRARY_RESUME":"Devam et","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"Ayrıntılar","LIBRARY_RESUME_DISMISS":"Vazgeç","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"Seçilenler","DISCOVER_TOP":"En İyiler","DISCOVER_OSCAR":"Ödül Kazananlar","DISCOVER_WARNING_TITLE":"Hay aksi!","DISCOVER_EMPTY_CATALOG":"Bu eklenti boş içerik döndürdü.","DISCOVER_ADULT_WARNING":"Bu içerik yalnızca yetişkinler tarafından görüntülenebilir. 18 yaşından büyük müsünüz?","DISCOVER_NOADDON_WARNING":"Uyarı: Böyle bir aktif Stremio eklentisi yoktur. Kaydedilen ögeler gösteriliyor, içerik güncellenmez.","DISCOVER_LOAD_ERR":"Keşfet: eklentiden katalog yüklenemedi","DISCOVER_ADDON_UNINSTALLED":"Bu içerik artık mevcut değil, eklentiyi kaldırmış olabilirsiniz.","UNINSTALL_THIS_ADDON":"Bu eklentiyi kaldır","ERR_ADDON_NOT_INSTALLED":"Bu eklenti yüklü değil. Şimdi yüklensin mi?","DETAIL_RECEIVE_NOTIF_SERIES":"Yeni bölümler için bildirim alın","DETAIL_RECEIVE_NOTIF_VIDEOS":"Yeni videolar için bildirim alın","SIDEBAR_SHOW_STREAMS":"Akışları Göster","RELAUNCH":"Şimdi yeniden başlat!","UPGRADE":"Yeni sürüm mevcut! Güncel Stremio sürümüne yükseltin.","RELOAD_UI":"Kullanıcı arayüzünü yeniden yükleyin","MANUAL_UPDATE_TITLE":"Stremio sürümünüzü güncelleyin","MANUAL_UPDATE_LINE1":"Son derece önerilmeyen eski bir Stremio sürümü kullanıyorsunuz.","MANUAL_UPDATE_LINE2":"Lütfen en kısa sürede güncelleyin.","BUTTON_UPDATE_LATTER":"Şimdi değil","BUTTON_UPDATE_NOW":"Güncelle","ANONYMOUS_USER":"Bilinmeyen kullanıcı","DONT_HAVE_ACC":"Bir hesabın yok mu?","HAVE_ACC":"Zaten bir hesabın var mı?","PASSWORD":"Şifre","PASSWORD_CONFIRM":"Şifreyi doğrula","EMAIL":"E-posta","FB_LOGIN":"Facebook ile giriş yap","FB_NOTHINGSHARED":"İzniniz olmadan hiçbir şey paylaşılmaz.","FB_NOPOST":"Sizin adınıza herhangi bir şey göndermeyeceğiz","OR":"ya da","I_ACCEPT":"Kabul ediyorum","I_ACCEPT_BY_CLICKING":"Yukarıdaki düğmeyi tıklayarak, aşağıdakileri kabul ediyorum:","TOS":"Şartlar ve Koşullar","MUST_ACCEPT_TERMS":"Şartları kabul etmelisin","PASSWORDS_NOMATCH":"Şifreler eşleşmedi.","SIGN_UP":"Üye ol","SIGN_UP_EMAIL":"E-posta ile üye ol","CLICK_TO_SIGN_UP":"Üye olmak için buraya tıklayın.","LOG_IN":"Giriş yap","LOG_OUT":"Çıkış yap","EXIT_FULLSCREEN":"Tam ekran modundan çık","ENTER_FULLSCREEN":"Tam ekrana geç","PLAY_URL_MAGNET_LINK":"URL/Magnet bağlantısını oynat","HELP_FEEDBACK":"Yardım ve Geri Bildirim","TERMS_OF_SERVICE":"Kullanım Şartları","PRIVACY_POLICY":"Gizlilik Politikası","ABOUT_STREMIO":"Stremio Hakkında","USER_PANEL":"Kullanıcı Paneli","LOGIN_LABEL":"Giriş Yap","GUEST_LOGIN":"Misafir Girişi","GUEST_LOGIN_NOTICE":"Misafir girişi önerilmez. Normal şekilde oturum açarak, kitaplığını Stremio ile senkronize edebilir ve en sevdiğiniz diziler/kanallardan bildirimler alabilirsin. Devam etmek istediğinden emin misin?","GUEST_LOGIN_NOTICE_2":"Misafir girişi önerilmez. Stremio\'nun önemli özelliklerinde olan senkronize edilmiş kitaplık ve pano bildirimleri özelliğine sahip olamazsın. Devam etmek istediğinden emin misin?","CLICK_HERE":"buraya tıklayın","WRONG_PASSWORD":"Yanlış şifre. Eğer şifrenizi unuttuysanız, ","SET_A_PASS":"bir şifre belirleyin","RESET_PASSWORD":"Şifreyi sıfırla","FORGOT_PASSWORD":"Şifreni mi unuttun?","EMAIL_USED_WITH_FB":"Bu e-posta, Facebook ile giriş için kullanıldı.","INVALID_EMAIL":"Lütfen geçerli bir e-posta adresi girin","INVALID_PASSWORD":"Lütfen geçerli bir şifre girin","CONN_ERR":"Bağlantı hatası - Lütfen daha sonra tekrar deneyin.\\n\\nEğer sorun devam ederse, güvenlik duvarını/antivirüs programını devre dışı bırakın (özellikle Bitdefender).","IMPORT_FROM_GUEST":"Misafir hesabınızdan kitaplığa aktarın","RECEIVE_UPDATES_EMAIL":"Stremio\'dan e-postanıza ilişkin güncellemeler alın","LOGIN_FAILED":"Oturumu açma başarısız","SIGNUP_FAILED":"Kayıt başarısız","SEARCH_FAILED":"Arama başarısız","EMAIL_USED":"Bu e-posta zaten kullanılıyor.","WAITING_FB_LOGIN":"Facebook ile oturum aç...","EXTERNAL_PLAYER_TITLE":"Harici oynatıcıda oynat","EXTERNAL_REMEMBER_PLAYER":"Seçimini hatırlamak ister misin?","EXTERNAL_ALWAYS_PLAY":"Evet","EXTERNAL_ONLY_ONCE":"Hayır","BEST_FIT":"En uygun","FIT_SCREEN":"Ekrana sığdır","FILL":"Doldur","16:9":"16:9","4:3":"4:3","Original":"Gerçek boyut","INTRO_TASTE":"Bize nelerden hoşlandığını söyle","INTRO_TASTE_LONG":"Neleri izlemek istediğin hakkında bize bilgi ver","INTRO_TASTE_PICK":"{{interestsRemaining}} ilgi alanlarını seç","INTRO_TASTE_PICK_MORE":"{{interestsRemaining}} daha fazla ilgi alanı seç","INTRO_TASTE_HELP_US":"Hakkında daha fazla bilgi edinmemize yardımcı ol.","INTRO_TASTE_CHOOSE_THESE":"Bunlardan bazılarını seç:","INTRO_TASTE_CHOOSE_MIN":"En az 3 kategori seç","INTRO_TASTE_CHOOSE_MIN_ERR":"En az 3 kategori seçmen gerekiyor!","INTRO_TASTE_LIFESTYLE":"Yaşam stili","INTRO_TASTE_SPORTS":"Spor","INTRO_TASTE_FOOD_HEALTH":"Yemek ve Sağlık","INTRO_TASTE_BEAUTY_FASHION":"Güzellik ve Moda","INTRO_TASTE_NEWS":"Haber","INTRO_TASTE_GAMING":"Oyun","INTRO_TASTE_SCIENCE_EDU":"Bilim ve Eğitim","INTRO_TASTE_MUSIC":"Müzik","INTRO_TASTE_TRAVEL":"Seyahat","INTRO_TASTE_LATE_NIGHT":"Gece Şovları","INTRO_TASTE_REALITY":"Gerçeklik","INTRO_TASTE_COMEDY":"Komedi","INTRO_TASTE_DIY":"Nasıl Yapılır?","INTRO_TASTE_TECH":"Teknoloji","INTRO_TASTE_CINEMA":"Sinema","ADDON_NOT_SUPPORTED":"Seçilen eklenti bu platformda desteklenmiyor.","ADDON_DISCLAIMER":"Üçüncü taraf eklentileri kullanmak sizin sorumluluğunuzda ve bulunduğunuz bölgede geçerli olan yasalara tabidir.","ADDON_ACTIVATE":"Bu eklenti etkinleştirilsin mi?","ADDON_REPO_ADD":"Eklenti depo bağlantısı","ADDON_ADD":"Ekle","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"Yeni neler var?","BUTTON_CONTINUE":"Devam et","BUTTON_ACTIVATE":"Etkin","BUTTON_ACTIVATED":"Etkinleştirildi","BUTTON_CANCEL":"İptal Et","BUTTON_SUBMIT":"Gönder","BUTTON_DISMISS_ALL":"Hepsini kaldır","BUTTON_VIEW_ALL":"tümünü görüntüle","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"Kitaplığın boş görünüyor. Ne kadar kullanışlı olduğunu öğren :) ","HOW_START":"Nasıl başlayabileceğinle ilgili bilgiler burada:","LIB_EMPTY_CAL":"Takvimin kitaplığındaki sezonları gösterir.","HOW_START_CAL":"Nasıl dizi ekleyebileceğinle ilgili bilgiler burada:","LIB_EMPTY_BOARD":"Pano, bildirimleri ve kitaplığınla ilgili önerileri gösterir.","HOW_START_BOARD_WAIT":"Lütfen kitaplığına birkaç dizi veya kanalı ekle ve bize işlem yapmak için birkaç dakika ver. :)","HOW_START_BOARD":"Nasıl sezon ekleyebileceğin ve oynatabileceğinle ilgili bilgiler burada:","IMPORT_FB":"Facebook\'tan beğendiklerini aktar","IMPORT_TRAKT":"Trakt\'tan ortam kütüphaneni al","IMPORT_DISCOVER":"Keşfet üzerinden ilginç şeyler bul","IMPORT_DISK":"Bilgisayarından film veya şov aktar","PLEASE_CREATE_ACC":"Kitaplık ve Pano senkronizasyonu için lütfen bir hesap oluştur.","IMPORT_DISCOVER_SIGNUP":"Üye ol ve Keşfet\'ten ilginç şeyler bul","IMPORT_DISK_SIGNUP":"Üye ol ve yerel diskindeki filmleri ve şovları aktar","LIB_EMPTY_CLOUD":"Kitaplık","LIB_EMPTY_CLOUD_DESC":"Bulut kitaplığın tüm cihazlarda senkronize edilsin","LIB_EMPTY_EARLY":"Erken Uyarı","LIB_EMPTY_EARLY_DESC":"Yeni bölümler için bildirimler al","LIB_EMPTY_PERSONAL":"Kişisel","LIB_EMPTY_PERSONAL_DESC":"Sana özel önerileri al","LIB_EMPTY_CALENDAR_DESC":"İzleme takvimini planla","LIB_EMPTY_ALL":"Bunların hepsine sahip olmak için üye ol:","LIB_EMPTY_BEST":"Stremio\'dan en iyi şekilde yararlanmak için üye ol","LIB_EMPTY_OTHER":"Takvim ve diğer harika özellikleri etkinleştirmek için üye ol","CALENDAR_ADDED":"Stremio takvimi varsayılan masaüstü takvimine eklendi.","CALENDAR_ADDED_MSG":"Bu işe yaramazsa, lütfen bu URL\'yi takvim uygulamanıza elle ekle","TRAKT_EXPIRED":"Trakt kimlik doğrulaması süresi doldu, lütfen Ayarlar\'a git ve yeniden kimlik doğrulaması yap","TRAKT_REQUIRES_LOGIN":"Trakt hatası","TRAKT_REQUIRES_LOGIN_MSG":"Giriş yapmalısın","SETTINGS_LABEL":"Ayarlar","SETTINGS_NAV_GENERAL":"Genel","SETTINGS_NAV_PLAYER":"Oynatıcı","SETTINGS_NAV_STREAMING":"Yayın Akışı","SETTINGS_NAV_SHORTCUTS":"Kısayollar","SETTINGS_SHORTCUT_RELOAD_APP":"Uygulamayı Yeniden Yükle","SETTINGS_SHORTCUT_OPEN_SETTINGS":"Ayarları Aç","SETTINGS_SHORTCUT_SWITCH_TABS":"Sekmeleri Değiştir","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"Sekmelerde İleri Döngü","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"Sekmelerde Geri Döngü","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"Çık / Geri Dön","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"Tam Ekrana Geç","SETTINGS_SHORTCUT_SHOW_CONTROLS":"Kontrolleri Göster","SETTINGS_SHORTCUT_PLAY_PAUSE":"Başlat / Duraklat","SETTINGS_SHORTCUT_VOLUME_UP":"Sesi Artır","SETTINGS_SHORTCUT_VOLUME_DOWN":"Sesi Azalt","SETTINGS_SHORTCUT_SEEK_NEXT":"Sonrakini Ara","SETTINGS_SHORTCUT_SEEK_PREV":"Sonrakini Ara","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"Sonrakini Oynat","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"Altyazı Boyutunu Artır","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"Altyazı Boyutunu Azalt","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"Altyazı Gecikmesini Artır","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"Altyazı Gecikmesini Azalt","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"Kenar Çubuğunu Aç/Kapat","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"Başlangıçta Çalıştır","SETTINGS_VLC_DEFAULT":"VLC ile Oynat","SETTINGS_UI_LANGUAGE":"Arayüz Dili","SETTINGS_FULLSCREEN_EXIT":"Escape tuşuyla tam ekrandan çık","SETTINGS_GAMEPAD":"Gamepad desteğini etkinleştir","SETTINGS_CLOSE_WINDOW":"Pencere kapatıldığında uygulamayı kapat","SETTINGS_SUBTITLES_LANGUAGE":"Varsayılan Altyazı Dili","SETTINGS_SUBTITLES_SIZE":"Varsayılan Altyazı Boyutu","SETTINGS_SUBTITLES_BACKGROUND":"Altyazı Arka Planı","SETTINGS_SUBTITLES_COLOR":"Altyazı Rengi","SETTINGS_SUBTITLES_COLOR_OUTLINE":"Altyazı Anahat Rengi","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"Altyazı Arka Plan Rengi","SETTINGS_SEEK_KEY":"Ok tuşlarıyla zaman atlatma","SETTINGS_SEEK_KEY_SHIFT":"Shift tuşu basılı tutulduğunda Ok tuşlarıyla zaman atlatma","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"Sonraki bölümü otomatik oynat","SETTINGS_NEXT_VIDEO":"Sonraki bölümü başlatmak için bildirim göster","SETTINGS_NEXT_VIDEO_TRIGGER":"Bir sonraki bölüm bildirimini göster:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"Oynatmadan önce pencereyi otomatik olarak yeniden boyutlandır","SETTINGS_OVERRIDE_SERVER":"Akış sunucusu URL\'sini geçersiz kıl (gelişmiş)","SETTINGS_SERVER_URL":"Akış sunucusu URL\'si: ","SETTINGS_SERVER_AVAILABLE":"Akış sunucusu kullanılabilir.","SETTINGS_SERVER_UNAVAILABLE":"Akış sunucusu kullanılamıyor.","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"Akış HTTPS uç noktası: ","SETTINGS_USE_BETA":"Her zaman Beta sürümünü kullan","SETTINGS_IMPORT_FB":"Facebook\'tan aktar","SETTINGS_IMPORT_DISK":"Bilgisayardan aktar","SETTINGS_IMPORT_TRAKT":"Trakt\'tan aktar","SETTINGS_PAUSE_MINIMIZED":"Küçültüldüğünde oynatmayı duraklat","SETTINGS_HWDEC":"Donanım hızlandırmalı kod çözme","SETTINGS_BACKGROUND":"Arka planda oynatma","SETTINGS_SUBSCRIBE_CALENDAR":"Takvime abone ol","SETTINGS_REQ_EXPORT":"Veri dışa aktarma isteğinde bulun","SETTINGS_ACC_DELETE":"Hesap silme isteğinde bulun","SETTINGS_CHANGE_PASSWORD":"Şifreyi değiştir","SETTINGS_TOS":"Kullanım şartları","SETTINGS_SUPPORT":"Destek ile iletişime geç","SETTING_LANGUAGE":"Dil","SETTINGS_TRAKT":"Trakt Scrobbling","SETTINGS_TRAKT_LOGOUT":"Trakt.tv oturumunu kapat","SETTINGS_SCAN_FOR_REMOTE":"Uzaktan kumandayı açmak için QR kodunu tara","SETTINGS_DESKTOP_NOTIFICATIONS":"Masaüstü bildirimleri","SETTINGS_DATA_SAVER":"Veri tasarrufu","SETTINGS_LANGUAGE_INTERFACE":"arayüz","SETTINGS_LANGUAGE_SUBS":"varsayılan altyazılar","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"Ses parçasını otomatik seç","SETTINGS_DEFAULT_AUDIO_TRACK":"Varsayılan ses parçası","SETTINGS_ACCOUNT":"hesap","SETTINGS_VERSION":"sürüm","SETTINGS_MPV_WINDOW":"Oynatıcıyı ayrı bir pencerede başlat (gelişmiş)","SETTINGS_PLAY_IN_EXTERNAL":"Videoyu her zaman harici oynatıcıda başlat","SETTINGS_STORAGE_BUTTON":"Yerel Depolamayı Temizle","SETTINGS_STORAGE_MODAL_TITLE":"Emin misiniz?","SETTINGS_STORAGE_MODAL_MESSAGE":"Bu, yerel depolamayı temizleyecek ve oturumunuzu kapatacaktır.","SETTINGS_HWDEC_PICKER":"Donanım hızlandırmalı kod çözme ayarını seçin","SETTINGS_HW_AUTOMATIC":"Otomatik","SETTINGS_HW_DISABLED":"Kapalı","SETTINGS_HW_ACCELERATED":"Kod çözme ivmesi","SETTINGS_HW_FULL":"Tam hızlanma","SETTINGS_HW_LEGACY":"Geleneksel","SUBSPICKER_AUDIO":"Ses","SUBSPICKER_SUBTITLES":"Eklenti Altyazıları","SUBSPICKER_BLACK_BACKGROUND":"Siyah arka plan rengi kullan","SUBSPICKER_VERTICAL_OFFSET":"Dikey Hizalama","SUBSPICKER_SIZE":"Boyut","SUBSPICKER_DELAY":"Gecikme","SUBSPICKER_EMBEDDED_SUBS":"Gömülü Altyazılar","MOBILE_PRIVACY_POLICY":"Gizlilik Politikası","MOBILE_CRASH_REPORTING":"Çökme Raporlama","MOBILE_ZOOM_TO_FILL":"Ekranı Doldurmak için Yakınlaştır","MOBILE_PASSTHROUGH":"Dijital ses çıkışı (geçiş)","MOBILE_RUN_LOW_BATTERY":"Düşük pille çalıştır","MOBILE_RUN_FOREGROUND":"Ön plan hizmeti olarak çalıştır","MOBILE_PERFORMANCE":"PERFORMANS VE KARARLILIK","MOBILE_SERVER_ONLINE":"Çevrimiçi","MOBILE_SERVER_OFFLINE":"Çevrimdışı","MOBILE_QR_EXPIRES":"QR kodunun süresi sona eriyor: ","MOBILE_LOG_INTO":"Stremio hesabınıza giriş yapın ","MOBILE_SCAN_QR":"Yukarıdaki QR kodunu tarayın veya ","MOBILE_LINK_ACCOUNT":"Hesabı Bağla","MOBILE_SPEEDPICKER_CANCEL":"İptal Et","MOBILE_SPEEDPICKER_LABEL":"Oynatma Hızını Seçin","MOBILE_EMPTY_LIBRARY":"Kitaplığınız boş","MOBILE_NO_ADDON_ACTIVE":"Bu tür için aktif Stremio eklentisi yok.","MOBILE_ORGANIZER_WARNING":"Stremio Organizer uygulaması sınırlı işlevsellik sağlar. Oynatılabilir akışların listesi ve eksiksiz Stremio deneyimi için masaüstünde Stremio\'yu kullanın.","MOBILE_ADDON_LOADING":"hala yükleniyor","MOBILE_ADDONS_LOADING":"eklenti hala yükleniyor","MOBILE_ADDON":"Eklenti","MOBILE_CONFIGURE_ADDON":"Eklentinizi yapılandırın","MOBILE_CONFIGURE_ADDON_LABEL":"Eklentiyi Yapılandır","MOBILE_ORGANIZER_ADDONS_WARNING":"Stremio Organizer uygulaması sınırlı sayıda eklenti sunar. Tam Stremio deneyimi için Stremio\'yu masaüstünde kullanın.","MOBILE_DISCONNECT":"Bağlantıyı kes","MOBILE_LOOKING_FOR_DEVICES":"Cihazlar aranıyor...","MOBILE_CAST_TO":"Şuraya yayın:","NAVIGATION_ON":"Açık","NAVIGATION_OFF":"Kapalı","MARKETING_AGREE":"Stremio\'dan pazarlama haberleri almayı kabul ediyorum","QUIT":"Çıkış","CONNECTED":"Bağlandı","AUTHENTICATE":"Kimlik doğrulaması","CACHING":"Önbelleğe alma","SETTINGS_CACHING_DRIVE":"Önbellek sürücüsünü seçin","ENABLE_LOCAL_FILES_ADDON":"Yerel dosya eklentisini etkinleştir (yeniden başlatma gerektirir)","LOCAL_ADDON_NOT_ENABLED":"Yerel eklenti etkin değil. Ayarlara gitmek ve etkinleştirmek için buraya tıklayın","ENABLE_REMOTE_HTTPS_CONN":"Uzak HTTPS bağlantılarını etkinleştir","TORRENT_PROFILE":"Torrent Profili","DATA_CACHING":"Veri Önbelleği","MAGNET_PARSING":"Magnet bağlantısını ayrıştırma","January":"Ocak","February":"Şubat","March":"Mart","April":"Nisan","May":"Mayıs","June":"Haziran","July":"Temmuz","August":"Ağustos","September":"Eylül","October":"Ekim","November":"Kasım","December":"Aralık","Monday":"Pazartesi","Tuesday":"Salı","Wednesday":"Çarşamba","Thursday":"Perşembe","Friday":"Cuma","Saturday":"Cumartesi","Sunday":"Pazar","Action":"Aksiyon","Comedy":"Komedi","War":"Savaş","Family":"Aile","Animation":"Animasyon","Adventure":"Macera","Fantasy":"Fantastik","Crime":"Suç","Mystery":"Gizem","Romance":"Romantik","Drama":"Dram","Horror":"Korku","Thriller":"Gerilim","Sci-Fi":"Bilim Kurgu","Music":"Müzik","Biography":"Biyografi","Documentary":"Belgesel","Sport":"Spor","Musical":"Müzikal","Western":"Batı","Film-Noir":"Kara Film","News":"Haber","History":"Tarih","Game-Show":"Oyun Şovu","Reality-TV":"Reality-TV","Talk-Show":"Talk-Show","Film & Entertainment":"Film ve Eğlence","Gaming":"Kumar","From TV":"Televizyondan","Lifestyle":"Yaşam","Science & Education":"Bilim ve Eğitim","Cooking & Health":"Yemek Pişirme ve Sağlık","Beauty & Fashion":"Güzellik ve Moda","Sports":"Spor","News & Politics":"Haber ve Politika","How-to & DIY":"Nasıl Yapılır ve Kendin Yap","Tech":"Teknoloji","Automotive":"Otomotiv","Causes & Non-Profits":"Nedenler ve Kâr Amacı Gütmeyenler","Movies":"Filmler","Uk Live Tv":"İngiliz Canlı TV","Fashion":"Moda","Business News Radio":"İş Haberleri Radyosu","Business Tv":"İş Televizyonu","Cars & Auto":"Otomobil ve Otomotiv","Comedy Radio":"Komedi Radyosu","Lifestyle Radio":"Yaşam Stili Radyosu","News Tv":"Haber TV","Food And Wine":"Yemek ve Şarap","Latino Tv":"Latin TV","Shopping Tv":"Alışveriş Televizyonu","Religion":"Din","Kids":"Çocuklar","Body & Soul":"Vücut ve Ruh","Education":"Eğitim","Indian Tv":"Hindistan TV","Extreme Sports":"Ekstreme Sporlar","Middle Eastern Tv":"Ortadoğu TV","Celebrity Tv":"Magazin TV","Science Tv":"Bilim TV","Bikini babe":"Bikini güzelleri","Outdoors":"Açık Hava","German Tv":"Alman TV","French Tv":"Fransız TV","Italian Tv":"İtalyan TV","Gamer Tv":"Oyuncu TV","Travel":"Gezi","Asian Tv":"Asya TV","Entertainment":"Eğlence","News Radio":"Haber Radyosu","Music Radio":"Müzik Radyosu","Language Learning":"Dil Öğrenme","Science Radio":"Bilim Radyosu","Tech Radio":"Teknoloji Radyosu","Science & Technology Vod":"Bilim ve Teknoloji Video","new video":"yeni video","new episode":"yeni bölüm","new movie":"yeni film","recommended":"önerilen","we recommend":"önerdiklerimiz","offer of the day":"günün teklifi","news":"haberler","music video":"müzik videosu","CTX_SHOW_HOTKEYS":"Kısayol tuşlarını göster","CTX_DISMISS_NOTIF":"Bildirimleri kapat","CTX_DISMISS_ALL":"Hepsini bırak","CTX_SHARE":"Paylaş","CTX_COPY_SHARE_LINK":"Paylaşma bağlantısını kopyala","CTX_COPY_MAGNET_LINK":"Magnet bağlantısını kopyala","CTX_COPY_STREAM_LINK":"Akış bağlantısını kopyala","CTX_DOWNLOAD_VIDEO":"Bu videoyu indir","CTX_DOWNLOAD_SUBS":"Altyazıları indir","CTX_VIEW_ON_YOUTUBE":"YouTube\'da görüntüle","CTX_SHOW":"Göster","CTX_PLAY":"Oynat","CTX_PLAY_IN":"Oynat","CTX_PLAY_ON":"Oynat","CTX_WATCH_ON":"İzle","CTX_WATCH":"İzle","CTX_WATCHED":"İzlendi","CTX_WATCH_BEGINNING":"Baştan izle","CTX_WATCH_MOBILE":"Mobil bir cihazda izle","CTX_REWIND":"Baştan izle","CTX_MARK_WATCHED":"İzlendi olarak işaretle","CTX_MARK_NON_WATCHED":"İzlenmedi olarak işaretle","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"Geri kalanını izlendi olarak işaretle","CTX_UNMARK_REST":"Geri kalanını izlenmedi olarak işaretle","CTX_RECEIVE_NEW_NOTIF":"Yeni bildirimleri al","CTX_REMOVE_CACHE":"Önbelleği temizle","CTX_REMOVE_CACHE_EP":"Bölümü önbellekten kaldır","CTX_OPEN_CONTAINING":"İçeren klasörü aç","CTX_REMOVE":"Kitaplıktan kaldır","CTX_AVAILABLE_OFFLINE":"Çevrimdışı Kullanılabilir","CTX_PAUSED":"Duraklatıldı","CTX_ALWAYS_ON_TOP":"Her zaman üstte","CTX_FULLSCREEN":"Tam ekran","CTX_WRONG_SUBS":"Altyazı yanlış mı?","CTX_REPORT_ISSUES":"Sorun bildir","CTX_COPY":"Kopyala","CTX_PASTE":"Yapıştır","CTX_CLEAR":"Temizle","CTX_CLEAR_RECENT_SEARCHES":"Son arananları temizle","HELLO_THERE":"Merhaba","HOPE_YOU_ENJOY":"Stremio\'dan keyif aldığını ya da en favori uygulamalarından biri olduğunu umuyoruz!","WHO_ARE_WE":"Biz kimiz? Biz bunun arkasındaki takımız - son 3 yıldır bu ürünü daha iyi, daha iyi yapmak için her gün çalışan iki adam.","SUPPORT_US":"Eğer Stremio\'yu beğendiyseniz ve o sizin için değerliyse - duyurun!","SPREAD_THE_WORD":"Arkadaşınızla paylaşın, Stremio\'yu duyurun","MORE_PEOPLE":"Stremio\'yu ne kadar çok kişi kullanırsa, o kadar iyi olacaktır!","SEND_A_LINK":"Veya bizim sitemize bir bağlantı gönderin","TIP_LOCALFILES":"İpucu: yerel video dosyalarınızı Stremio\'ya sürükleyip bırakabilirsiniz","ADDON_MY":"Eklentilerim","ADDON_COMMUNITY":"Topluluk Eklentileri","ADDON_OFFICIAL":"Resmi Eklentiler","ADDON_REPOS":"Eklenti depoları","ADDON_SEARCH":"Eklenti ara","ADDON_INSTALL":"Yükle","ADDON_CONFIGURE":"Yapılandır","ADDON_UNINSTALL":"Kaldır","ADDON_UPGRADE":"Yükselt","ADDON_INSTALLED":"Yüklendi","ADDON_INSTALLED_MSG":"Eklenti yüklendi!","ADDON_UPGRADED_MSG":"Eklenti yükseltildi!","ADDON_UNKNOWN":"Bilinmeyen","ADDON_ERR":"Eklenti yükleme hatası!","ADDON_DISCONNECTED":"Bağlantı kesildi","ADDON_APP_MISSING":"bu kaynak için uygulama yüklü değil. Şimdi yüklemek istiyor musunuz?","ADDON_APP_INSTALL":"Şimdi Yükle","ADDON_PAGE":"Eklenti Sayfası","ADDON_TOP_CONTENT":"Bu eklenti en iyisi","ADDON_PROVIDES":"Bu eklenti sana sağlar:","ADDON_WATCH":"Şimdi #{types} izle!","ADDON_WATCH_FREE":"Şimdi #{types} ücretsiz izle!","ADDON_ADDON":"Eklenti","ADDON_SUPPORTED_TYPES":"Desteklenen türler","ADDON_SUPPORTED_CATALOGS":"Desteklenen kataloglar","ADDON_PROVIDES_DISCOVER":"#{types} daha fazlasını keşfet","ADDON_PROVIDES_STREAMS":"#{types} İzle","ADDON_PROVIDES_STREAMS_FREE":"#{types} ÜCRETSİZ İzle","ADDON_PROVIDES_SUBTITLES":"#{types} için altyazılar","ADDON_CANTDETECT":"Çalışmakta olan bir Stremio tespit edemedik, bu nedenle hangi eklentilerin yüklü olduğunu tespit edemedik.","ERR_NO_META":"Bu konuda hiçbir bilgi bulunamadı","ERR_GETTING_META":"Bu konuda bilgi alınırken hata oluştu.","ERR_CANT_PARSE_MAGNET":"Magnet ayrıştırılamadı","ERR_NO_MAGNET_INFOHASH":"Magnet için geçerli bir hash bilgisi yok","ERR_NO_FILE_PATH":"Dosya yolu olmayan istek gönderilemiyor","ERR_NO_TORRENT":"Torrent geri döndürülemedi","ERR_NO_SUPPORTERD_FILES":"Desteklenen dosya bulunamadı","ERR_OPENING_FILES":"Harici dosyalar açılamadı","ERR_INVALID_LINK":"Geçersiz bağlantı","ERR_REGISTERED_ONLY":"Bu seçenek yalnızca kayıtlı kullanıcılar için geçerlidir.","ERR_CLIPBOARD":"Panodan oynatılamıyor","ERR_CLIPBOARD_READ":"Bu platformda pano okunamıyor","ERR_CLIPBOARD_GENERIC":"Panoda oynatılabilir URL bulunamadı. Lütfen bir videoya ait URL\'yi (ör. magnet bağlantısı) kopyalayın.","BOARD_CONTINUE_WATCHING":"İzlemeye devam et","BOARD_EXPLANATION_RECOMMENDATIONS":"Filmler sana için özel olarak seçildi.
Bu film örnek bir öneri.","BOARD_EXPLANATION_EPISODES":"Favori dizilerinizden yeni bölümler buraya gelsin.
Takip ettiğiniz diziyi kitaplığınıza ekleyin.","BOARD_EXPLANATION_VIDEOS":"Favori kanalınızdan yeni bölümler buraya gelsin.
Kitaplığınıza takip ettiğiniz bir YouTube kanalını ekleyin.","WEBSITE_SLOGAN_WATCH":"Hemen İzleyin","WEBSITE_SLOGAN_ALL":"Seveceğin Tüm Video İçerikleri Tek Bir Yerde","WEBSITE_SLOGAN_NEW":"Tamamını İzleyebilirsin","WEBSITE_SLOGAN_NEW_NEW":"İzleme Özgürlüğü","WEBSITE_WATCH_FROM":"Şuradan izle","WEBSITE_DOWNLOAD":"Şimdi İndir","WEBSITE_DOWNLOAD_FOR":"için İndir","WEBSITE_IS_DESKTOP":"Stremio bir masaüstü uygulamasıdır, bu sayfayı bilgisayarınızda açın ve indirin","WEBSITE_DESKTOP_DEMO_VID":"Masaüstü demosu","WEBSITE_PAGE_HOME":"Ana sayfa","WEBSITE_PAGE_FEATURES":"Özellikler","WEBSITE_PAGE_ADDONS":"Eklentiler","WEBSITE_PAGE_TECH":"Teknoloji","WEBSITE_PAGE_CREATE_ADDON":"Eklenti Oluşur","WEBSITE_PAGE_CONTACTS":"İletişim","WEBSITE_PAGE_BLOG":"Blog","WEBSITE_TYPE_movie":"Filmler","WEBSITE_TYPE_series_PL":"Diziler","WEBSITE_TYPE_tv":"Canlı TV","WEBSITE_TYPE_channel":"Kanallar","WEBSITE_STREMIO_WHAT_IS":"Stremio, favori videolarınızı, filmlerinizi, TV dizilerizi ve TV kanallarınızı düzenlemenize ve anında izlemenize yardımcı olan bir uygulamadır.","WEBSITE_FEATURES_WATCH":"Anında HD olarak izle","WEBSITE_FEATURES_WATCH_DETAIL":"En sevdiğiniz filmleri, TV Şovlarını, videoları ve TV kanallarını tıklayın ve oynatın.","WEBSITE_FEATURES_SUBS":"Otomatik altyazılar","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio diliniz için senkronize edilmiş altyazıları otomatik olarak seçer.","WEBSITE_FEATURES_SUBS_LABEL":"Sıra sende, şef.","WEBSITE_FEATURES_CAST":"TV ve mobil cihazlarda oynat","WEBSITE_FEATURES_CAST_DETAIL":"Apple TV, Chromecast, Smart TV (DLNA / UPnP) ve mobil cihazlarda oynatın.","WEBSITE_LIB":"Tüm aygıtlarınızda senkronize edilen kişisel kitaplığınızın keyfini çıkarın","WEBSITE_LIB_COLLECT":"Stremio\'da toplayın","WEBSITE_LIB_IMPORT":"Facebook\'tan aktarın","WEBSITE_LIB_LOCAL":"Yerel sürücünüzden ekleyin","WEBSITE_BOARD":"Pano - Bildirimler ve öneriler için toplanma noktası","WEBSITE_BOARD_RECOMMEND":"Önerilen TV Programı","WEBSITE_BOARD_TRENDING":"Popüler Film","WEBSITE_BOARD_NEW":"Yeni Video","WEBSITE_BOARD_EPISODE":"Yeni Bölüm","WEBSITE_BOARD_1":"İzlemek için ilginç bir şeyler mi arıyorsun? Zevkinize göre öneriler al!","WEBSITE_BOARD_2":"En sevdiğin TV programında veya YouTube kanalında yeni bir bölüm çıktıkça haberdar ol!","WEBSITE_BOARD_YOUTUBE":"YouTube kanallarının yeni videoları","WEBSITE_BOARD_EPISODES":"Takip ettiğiniz dizilerin yeni bölümleri","WEBSITE_ADDONS":"İçerik Eklentileri","WEBSITE_TECH_DETAIL":"Teknolojiyi seviyoruz, deli bilimi seviyoruz!\\nStremio aşağıdaki açık kaynak teknolojilerini kullanıyor:","WEBSITE_TECH_WCJS":"WebChimera.js, Stremio\'nun iyi bir performans ile herhangi bir video formatını oynatmasına izin verir.","WEBSITE_TECH_WCJS_EXTRA":"Biz temel projeye katkıda bulunanlarız","WEBSITE_TECH_ELECTRON":"Electron, Stremio\'yu inşa etmek için yenilikçi bir platform sağlar.","WEBSITE_TECH_ELECTRON_EXTRA":"Biz proje katkıcılarıyız","WEBSITE_TECH_LINVODB":"Verilerinizi sağlayan bir veritabanı teknolojisi düzenlenmiştir ve oturum açtığınız her yerde kullanılabilir.","WEBSITE_TECH_LINVODB_EXTRA":"Şirket içi teknoloji","WEBSITE_CREATE_ADDON":"Kendi eklentini oluştur","WEBSITE_CREATE_ADDON_DETAIL":"Video içeriği sunan bir hizmetin var mı? Sizin eklenti oluşturarak Stremio\'nun özelliklerinden yararlanmanıza yardımcı olacağız.","WEBSITE_CREATE_ADDON_BENEFITS":"Stremio Eklentisi Yaratmanın Faydaları","WEBSITE_P2P_BEAUTY":"Uçtan uca akışının güzelliği","WEBSITE_P2P_1":"İsteğe bağlı veya canlı akışla güvenilir ve satın alınabilir Full HD/4K video","WEBSITE_P2P_2":"Mükemmel bir kullanıcı deneyimi sağlayan dağıtım platformu","WEBSITE_P2P_3":"Tam ihtiyaçlarınızı karşılayan bir eklenti oluşturacağız","WEBSITE_P2P_CONTACT":"İlgilendin mi? Bize ulaşmanı bekliyoruz.","WEBSITE_P2P_CONTACT_EXTRA":"İçeriğinizi Stremio ile entegre etmenize yardımcı olmaktan mutluluk duyacağız!","WEBSITE_P2P":"Bir süre sonra, oyunun adını değiştiren bir teknoloji gelir. Herhangi bir kullanım durumuna uyum sağlamak için mükemmel performans ve çok yönlülük sağlayan P2P video akışı motoru kurmaya zaman ve çaba harcadık.\\nDRM özellikli P2P video, talep üzerine veya canlı akış için bize ulaşın.","WEBSITE_THOUGHTS":"Paylaştığımız düşünceler:","WEBSITE_SPREAD":"Stremio kelimesini herkese duyurun:","WEBSITE_CONTACT":"Eğer bizimle iletişime geçmek istiyorsanız, devam edin","WEBSITE_OPENSOURCE":"Açık kaynak projelerimiz için, bize git","WEBSITE_BITCOIN":"Bitcoin bağışla:","WEBSITE_FAQ":"Sık sorulan sorular","WEBSITE_FAQ_SHORT":"SSS","WEBSITE_QUESTIONS":"Sorular","WEBSITE_TOS":"Kullanım Şartları","WEBSITE_LEGAL":"Yasal","WEBSITE_PAGE_ABOUT":"Hakkında","WEBSITE_PAGE_BECOME_PARTNER":"Ortak ol","WEBSITE_ALL_YOU_CAN_WATCH":"Tamamını İzleyebilirsin","WEBSITE_FREEDOM_TO_STREAM":"İzleme Özgürlüğü","WEBSITE_WHAT_IS_STREMIO":"Stremio nedir?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio, video içerik toplama için tek duraklı bir merkezdir. Sahip olduğunuz herhangi bir cihaz üzerinden her türlü kaynaktan video keşfedin, düzenleyin ve izleyin.","WEBSITE_WHAT_IS_STREMIO_P2":"Filmler, TV şovları, diziler, canlı televizyonlar ya da YouTube ve Twitch.tv gibi web kanalları. Bunların hepsini Stremio\'da bulabilirsiniz.","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio, video eğlence için tek noktadan çözüm sunan modern bir medya merkezidir. Kurulumu kolay eklentilerden video içeriğini keşfeder, izler ve düzenlersiniz.","WEBSITE_WHAT_IS_STREMIO_P2_V2":"Filmler, TV şovları, canlı TV veya web kanalları. Tüm bunları Stremio\'da bulabilirsiniz.","WEBSITE_ENJOI_ON_ALL_DEVICES":"Tüm medya cihazlarınızda keyfini çıkarın","WEBSITE_DEVICES_COLLECT":"Stremio\'da toplayın","WEBSITE_DEVICES_IMPORT_FB":"Facebook\'tan aktarın","WEBSITE_DEVICES_LOCAL":"Yerel sürücünüzden ekleyin","WEBSITE_JOIN_THE_PARTY_NOW":"Şimdi partiye katılın","WEBSITE_DEVICES_ALL":"Tüm cihazlarınızda kullanımı kolay;","WEBSITE_EXTENDABLE_CATALOG":"Sonsuz genişletilebilir video kataloğu;","WEBSITE_ORGANIZE_YOUR_MEDIA":"Medyanızı düzenlemek için harika özellikler;","WEBSITE_AS_SEEN_ON":"Görüldüğü gibi","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"Hakkımızda","WEBSITE_LINK_TECHNOLOGY":"Teknoloji","WEBSITE_LINK_APPS":"Uygulamalar","WEBSITE_LINK_DOWNLOADS":"İndirmeler","WEBSITE_MORE":"Daha fazlası","WEBSITE_LINK_ADDONS":"Eklentiler","WEBSITE_LINK_ADDON_SDK":"Eklenti SDK","WEBSITE_LINK_CONTRIBUTE":"Katkıda bulun","WEBSITE_LINK_COMMUNITY":"Topluluk","WEBSITE_LINK_BLOG":"Blog","WEBSITE_MORE_MORE":"Ve Daha Dazlası","WEBSITE_LINK_HELP":"Yardım merkezi","WEBSITE_LINK_CONTACTS":"İş görüşmeleri","WEBSITE_LINK_TOS":"Şartlar ve koşullar","WEBSITE_LINK_PRAVACY":"Gizlilik politikası","WEBSITE_SUBSCRIBE":"Abone ol","WEBSITE_NEWSLETTER":"Şaşırtıcı şeyler için haber bültenimize kaydolun","WEBSITE_PLACEHOLDER_EMAIL":"E-posta adresin","WEBSITE_COMMUNITY":"Topluluk","WEBSITE_LINK_PRAVACY_LEGAL":"Gizlilik ve yasal","WEBSITE_WHY":"Neden yapıyoruz?","WEBSITE_WHY_P1":"Stremio\'da her gün çalışmaya başlıyoruz, çünkü talep üzerine video endüstrisi için önemli bir sorunu çözmek istiyoruz. Her dakika yayınlanan yeni birçok içerik var ve bununlar içinde yol bulmanız neredeyse imkânsız.","WEBSITE_WHY_P2":"İnsanlara bu muazzam video eğlence dünyasında gezinmelerine ve keyif alacakları yeni içerikler keşfetmelerine yardımcı oluyoruz. Uygulamalarımız filmleri, dizileri, canlı televizyonlarını, web kanallarını ve daha fazlasını bir araya getirir. Kullanıcıların sevdikleri başlıkları ve yayıncıları bulmalarını inanılmaz derecede kolaylaştırmayı amaçlıyoruz.","WEBSITE_WHY_P3":"Hizmetimizi herhangi bir cihazda, istediğiniz zaman kullanabilir ve Stremio\'yu ihtiyacınız olan tek video eğlence merkezi haline getirebilirsiniz.","WEBSITE_TEAM":"TAKIM","WEBSITE_TEAM_P":"Stremio ekibi küçük ama güçlü: arkadaki 10 kişi ile, X dilinde kod yazıyoruz ve yazılım geliştirme, UI ve UX tasarım, pazarlama ve reklamcılık dahil iş dünyası ve girişimler konularında uzmanlıklar paylaşıyoruz.","WEBSITE_FEATURES":"Özellikler","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"Yeni içeriği kolayca keşfedin","WEBSITE_FEATURES_DISCOVER_P":"İzlenecek yeni filmleri, TV şovlarını, dizileri ve kanalları kolayca keşfedin. Kategoriye, türe, derecelendirmeye, yeniliğe vb. göre göz atın veya bulmak için sadece bir isim yazın. Stremio yeni video içeriği bulmayı çok kolay hale getiriyor.","WEBSITE_FEATURES_ALL_CONTENT":"Tüm video içeriğiniz tek bir ekranda","WEBSITE_FEATURES_ALL_CONTENT_P1":"Hangi filmleri, dizileri veya videoları tamamlamadığınızı görün ve izlemeye devam edin. Yeni bölümler ve sürümler için bildirim alın. Görüntüleme alışkanlıklarınıza göre alacağınız önerilere göz atın.","WEBSITE_FEATURES_LIBRARY":"Video kitaplığınızı düzenleyin","WEBSITE_FEATURES_LIBRARY_P1":"Tek bir tıklama ile Stremio kitaplığınıza herhangi bir başlık ekleyin ve içeriklerinizi türe, yeniliğe ya da alfabetik olarak düzenlenmiş bir şekilde bulun.","WEBSITE_FEATURES_CALENDAR":"İzlediğiniz her şeyi takip edin","WEBSITE_FEATURES_CALENDAR_P1":"Kitaplığınıza eklediğiniz tüm filmlerin ve dizilerin takvim görselleştirmesini alın. Stremio takviminizi dışa aktarın ve senkronize edin. Böylece yeni bir bölümün veya bir ilk gösterimin ne zaman sona ereceğini bilirsiniz.","WEBSITE_FEATURES_BIG_SCREEN":"Video içeriğinizin keyfini daha büyük bir ekranda çıkarın","WEBSITE_FEATURES_BIG_SCREEN_P1":"İzlediğiniz her şeyi tek bir tıklama ile ister telefon, ister tablet, isterseniz TV\'den başka bir cihaza aktarın.","WEBSITE_FEATURES_SOURCES":"Birçok farklı kaynaktan video izleyin","WEBSITE_FEATURES_SOURCES_P":"Tek bir şık, kullanımı kolay uygulama ile birçok farklı sağlayıcıdan elde edilen videonun keyfini çıkarmak için resmi ve topluluk eklentilerini yükleyin.","WEBSITE_CREATE_AN_ADDON":"Bir eklenti oluştur","WEBSITE_FEATURES_SYNC":"Kitaplığınızı farklı cihazlarda senkronize edin ve oynatmaya devam edin","WEBSITE_FEATURES_SYNC_P1":"Tüm cihazlarınıza hesabınızla giriş yapın ve kitaplığınızın, eklentilerinizin, oynatma ve takviminizin senkronize edilmesinin keyfini çıkarın.","WEBSITE_FEATURES_EXTENDABLE":"Eklentilerle genişletilebilir video kataloğu","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio eklenti kataloğu, çeşitli video içeriğini yüklemek ve izlemek için bir dizi eklenti sağlar. Bu eklenti kataloğu; filmler, şovlar, canlı TV, spor, haberler, podcast\'ler, web kanalları, video oyunları ve daha fazlasını içerir.","WEBSITE_FEATURES_AUTO_SUBS":"Otomatik altyazılar","WEBSITE_FEATURES_AUTO_SUBS_P1":"Altyazı eklentilerimizle, tercih ettiğiniz dil için otomatik olarak seçilen seçenekleri elde edersiniz.","WEBSITE_FEATURES_CHROMECAST":"Chromecast ile yayınlayın","WEBSITE_FEATURES_CHROMECAST_P1":"Video içeriğinizin keyfini daha büyük bir ekranda çıkarın veya izlediğiniz her şeyi başka bir cihaza yayınlayın.","WEBSITE_FEATURES_KEEP_TRACK":"En sevdiğiniz TV şovlarını ve web kanallarını takip edin","WEBSITE_FEATURES_KEEP_TRACK_P1":"Favori dizilerinizin ve web kanallarınızın yeni bölümleri için bir takvim görselleştirmesi ve bildirimler alın.","WEBSITE_FEATURES_POWER_USER":"Güçlü kullanıcı özellikleri","WEBSITE_FEATURES_POWER_USER_P1":"Harici oynatıcıda oynatın","WEBSITE_FEATURES_POWER_USER_P2":"Torrent dosyasından veya magnet bağlantısından oynatın","WEBSITE_FEATURES_POWER_USER_P3":"Facebook beğenilerinden veya yerel diskten kitaplığınıza aktarın","WEBSITE_ADD_ONS":"Eklentiler","WEBSITE_ADD_ONS_P1":"Stremio\'nun sağladığı tüm video içeriği, bir eklenti sistemi aracılığıyla sağlanır - hiçbir içerik veya içerik sağlayıcısı uygulamaya yerleştirilmemiştir.","WEBSITE_ADD_ONS_P2":"İki eklenti grubu mevcut: resmi eklentiler ve topluluk eklentileri","WEBSITE_ADD_ONS_P3":"Resmi olanlar Stremio tarafından geliştirilir ve barındırılır. Buna karşın topluluk eklentileri, onları barındıran topluluk üyelerimiz tarafından oluşturulur.","WEBSITE_ADDONS_OFFICIAL":"Resmi eklentiler","WEBSITE_ADDONS_WATCHUB":"En sevdiğiniz filmleri, dizileri ve şovları iTunes, Hulu, Amazon ve diğer İngiltere/ABD hizmetleri gibi sağlayıcılardan izleyin.","WEBSITE_ADDONS_YOUTUBE":"En sevdiğiniz YouTube kanallarını reklamsız izleyin ve yeni yüklemeler için bildirimler alın.","WEBSITE_ADDONS_FILMON":"Canlı TV, film ve sosyal televizyonu ücretsiz izleyin. 600 TV kanalı, 45.000 ücretsiz film, belgesel ve daha fazlası.","WEBSITE_ADDONS_OPENSUBTITLES":"Film ve diziler için, birçok dilde her gün güncellenen binlerce altyazı çevirisi.","WEBSITE_ADDONS_COMMUNITY":"Topluluk Eklentileri","WEBSITE_ADDONS_FILMON_VOD":"Filmon.tv\'den talep üzerine video izleyin.","WEBSITE_ADDONS_TWICH":"Twitch.tv\'den canlı akış izleyin - e-spor endüstrisi için bir video akış platformu.","WEBSITE_ADDONS_VODO":"Bağımsız filmleri kesinlikle ücretsiz izleyin.","WEBSITE_ADDONS_NETFLIX":"Netflix filmlerini ve web dizilerini izleyin.","WEBSITE_ADDONS_CREATE":"Eklenti oluştur","WEBSITE_ADDONS_CREATE_P1":"İsterseniz kendi eklentinizi geliştirebilirsiniz. Bu şekilde, kendiniz ve topluluğumu içim yeni video içeriklerine erişim verebilir ve dünya çapında milyonlarca kullanıcıdan oluşan yeni bir hedef kitleye ulaşabilirsiniz.","WEBSITE_ADDONS_START_CREATE":"Başlarken, Stremio eklenti SDK sayfasını ziyaret et:","WEBSITE_DOWNLOADS":"İndirmeler","WEBSITE_DOWNLOADS_P1":"En iyi performans için, Stremio uygulamalarının en güncel sürümünü kullanmanızı öneririz. Bununla birlikte, herhangi bir nedenle daha eski bir sürüm kullanmak istiyorsanız, buradan indirebilirsiniz.","WEBSITE_DOWNLOADS_FOR_WIN":"Windows için Stremio","WEBSITE_DOWNLOADS_FOR_MAC":"macOS için Stremio","WEBSITE_DOWNLOADS_FOR_LINUX":"Linux için Stremio","WEBSITE_DOWNLOADS_FOR_ANDROID":"Android için Stremio","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Android TV için Stremio","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Android Mobil için Stremio","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"iOS için Stremio","WEBSITE_CONTRIBUTE":"Katkıda Bulunun","WEBSITE_CONTRIBUTE_P1":"Stremio platformu, açık kaynak kodludur ve şu anda kaynağı olmayan içerik için kolayca bir eklenti oluşturabilirsiniz.","WEBSITE_CONTRIBUTE_WHY":"Neden bir eklenti oluşturmalısınız?","WEBSITE_CONTRIBUTE_WHY_P1":"Video içeriğiniz için yeni kitleye ulaşın","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio\'nun kullanıcı tabanı hızla büyüyor. Lansmanının ilk yılında Stremio, dünyada 1 milyon kullanıcı kazandı ve platformun ikinci yılında bu sayı 2,5 milyona yükseldi.","WEBSITE_CONTRIBUTE_WHY_P3":"Eklentiniz ile bu kitleye kolayca ulaşabilir ve video içeriğinizi onlara dağıtabilirsiniz.","WEBSITE_CONTRIBUTE_ALL":"En sevdiğiniz filmleri, videoları, dizileri ve kanalları tek bir yerden izleyin","WEBSITE_CONTRIBUTE_ALL_P1":"Stremio\'da henüz bulunmayan belirli bir türdeki içeriğin hayranı mısınız? Bunun için bir eklenti oluşturun ve piyasadaki en büyük ve en kolay kullanımlı eğlence merkezlerinden birinde favori videolarınızı izlemenin keyfini çıkarın.","WEBSITE_CONTRIBUTE_ALL_P2":"Üstüne üstlük, sizinle benzer şekilde düşünen diğer Stremio topluluğu üyelerinin sonsuz şükranlarını alırsınız.","WEBSITE_CONTRIBUTE_MONETIZE":"Eklentinizi para kazanılabilir hale getirin ve onun yardımıyla para kazanın","WEBSITE_CONTRIBUTE_MONETIZE_P1":"Stremio için yeni bir eklenti geliştirdikten sonra, birkaç farklı yolla kolaylıkla para kazanabilirsiniz. Bunu düşünüyorsanız, ","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":" adresinden bizimle iletişime geçmekten çekinmeyin. Eklentiden para kazanma seçenekleri konusunda danışmanlık sunmaktan ve size tavsiyelerde bulunmaktan memnuniyet duyarız.","WEBSITE_CONTRIBUTE_TRANSLATE":"Gönüllü çevirmen olun","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"Farklı dillerde Stremio uygulamalarının keyfini çıkarmak istiyorsanız, gönüllü çevirmenler topluluğumuza katılabilirsiniz. Onlar, Stremio\'nun sürümlerini birçok farklı dilde eklememize yardımcı oluyorlar.","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"Başlamak için sabırsızlanıyor musun?","WEBSITE_TRANSALTE_STREMIO":"Stremio\'yu Tercüme Et","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"Resmi topluluklar","WEBSITE_COMMUNITY_OFFICIALS_P1":"Büyüyen Stremio topluluğunun bir parçası olun. Bizi sosyal medyada takip edin ve \'Merhaba\' demekten çekinmeyin; hayranlarımızı dinlemeyi çok seviyoruz! ","WEBSITE_COMMUNITY_UNOFFICIALS":"Resmi olmayan topluluklar","STREMIO_COMMUNITY_NL":"Stremio Hollanda","STREMIO_COMMUNITY_BRASIL":"Stremio Brezilya","STREMIO_COMMUNITY_GERMANY":"Stremio Almanya","STREMIO_COMMUNITY_BELGIUM":"Stremio Belçika","STREMIO_COMMUNITY_FRANCE":"Stremio Fransa","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portekiz","STREMIO_COMMUNITY_ITALY":"Stremio İtalya","STREMIO_COMMUNITY_UK":"Stremio İngiltere","STREMIO_COMMUNITY_USA":"Stremio ABD","STREMIO_COMMUNITY_MEXICO":"Stremio Meksika","STREMIO_COMMUNITY_ADDONS":"Stremio Eklentileri","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"Ortaklar ve destekçiler","WEBSITE_COMMUNITY_GOODIES":"Stremio şekerlemeleri","WEBSITE_COMMUNITY_WALLPAPERS":"Duvar kağıtları","WEBSITE_COMMUNITY_ART":"Topluluk Sanat Galerisi","WEBSITE_LINK_ART":"Topluluk sanat galerisi","WEBSITE_CONTACT_US":"Bize ulaşın","WEBSITE_CONTACT_US_P1":"Herhangi bir sorunuz, yorum veya önerileriniz varsa, aşağıdaki iletişim formu aracılığıyla bizimle irtibata geçmekten çekinmeyin.","WEBSITE_CONTACT_US_P2":"Bulgaristan\'da bulunduğumuzu unutmayın; bu nedenle, saat dilimi farklılıklarına bağlı olarak yanıt için bir gecikme olabilir.","WEBSITE_CONTACT_US_SUCCESS":"Mesajınız gönderildi. Size en kısa sürede geri döneceğiz.","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"Lütfen geçerli bir e-posta adresi giriniz!","WEBSITE_CONTACT_US_Q_RELATED_TO":"Sorunuzla ne ile alakalı?","WEBSITE_CONTACT_US_Q_OS":"İşletim sisteminiz nedir?","WEBSITE_CONTACT_US_PH_EMAIL":"E-posta adresiniz","WEBSITE_CONTACT_US_PH_MESSAGE":"İletiniz","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"GÖNDER","WEBSITE_CONTACT_US_Q_1":"Nasıl yüklenir?","WEBSITE_CONTACT_US_Q_2":"Nasıl kaldırılır?","WEBSITE_CONTACT_US_Q_3":"(HTML) Lazanya nasıl yapılır?","WEBSITE_CONTACT_US_Q_4":"Eklentiler","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"Teknoloji","WEBSITE_TECHNOLOGY_P1":"Teknolojiyi ve çılgın bilimi seviyoruz.
İşte Stremio\'ya güç veren şeyler (hepsi açık kaynaklı).","WEBSITE_TECHNOLOGY_P_QT":"Geliştirilen en iyi çapraz platformlu yazılım.","WEBSITE_TECHNOLOGY_P_MPV":"Ücretsiz, açık kaynaklı ve çapraz platformlu bir medya oynatıcı","WEBSITE_TECHNOLOGY_P_RN":"React Native, yalnızca JavaScript kullanarak mobil uygulamalar oluşturmanızı sağlar.","WEBSITE_TECHNOLOGY_P_VLC":"Multimedya almak için uygulamaya gömülü medya çerçevesi.","WEBSITE_TECHNOLOGY_P_REALM":"Realm bir mobil platform ve SQLite & Core Data\'nın yerini alıyor.","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js açık kaynaklı, platformlar arası bir JavaScript çalışma zamanı ortamıdır.","WEBSITE_TECHNOLOGY_P_RUST":"Rust, özellikle güvenli eşzamanlılık olmak üzere güvenliğe odaklanan çok paradigmalı bir sistem programlama dilidir.","WEBSITE_TECHNOLOGY_CONTRIBUTE":"Projeye katkıda bulunun","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"Stremio\'ya katkıda bulunmanın ve ürünün daha da iyi olmasına yardımcı olmanın iki yolu vardır.","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"Platformu tercüme ederek değerli dil becerilerini bağışlayabilirsiniz...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"ya da","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... topluluk eklentileri oluşturmak için kodlama becerilerinizi kullanabilirsiniz. ","WEBSITE_TRANSLATE_STREMIO":"Stremio\'yu Yerelleştir","WEBSITE_404_OH_NO":"Olamaz! Aradığınız sayfa burada değil...","WEBSITE_GO_HOME":"Ana sayfaya git","WEBSITE_LINK_OTHER_DOWNLOADS":"Diğer indirmeler","WEBSITE_FAQ_ABR":"SSS","WEBSITE_SUPPORT":"Destek","WEBSITE_DOWNLOAD_4_0_BETA":"Stremio 4 Beta Sürümünü Hemen İndirin","WEBSITE_GET_FOR_DESKTOP":"Masaüstü için alın","WEBSITE_LINK_ADDON_COMPETITION":"Eklenti yarışması","WEBSITE_LINK_ART_CONTEST":"Sanat yarışması","WEBSITE_MY_ACCOUNT":"Hesabım","WEBSITE_MAINPAGE_FAQ_001_H1":"Stremio nedir?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio, istediğiniz her şeyi izleme özgürlüğü sunan modern bir medya merkezidir.","WEBSITE_MAINPAGE_FAQ_002_H1":"Nasıl çalışır?","WEBSITE_MAINPAGE_FAQ_002_P1":"Stremio\'yu cihazınıza yükleyip bir hesap oluşturduktan sonra, yapmanız gereken tek şey eklenti kataloğunu ziyaret etmek ve istediğiniz eklentiyi yüklemektir!","WEBSITE_MAINPAGE_FAQ_002_P2":"Bundan sonra, içeriği keşfetmeye başlamak için Keşfet veya Pano bölümlerine gidebilirsiniz.","WEBSITE_MAINPAGE_FAQ_003_H1":"Burada ne izleyebilirim?","WEBSITE_MAINPAGE_FAQ_003_P1":"Çok şey var: Filmler, TV şovları, web kanalları, spor, TV kanallarını izleyin ya da podcast\'leri ve daha fazlasını dinleyin. Eklenti sistemimiz sayesinde çeşitli içeriklere erişebilirsiniz.","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio açık kaynaklı mı?","WEBSITE_MAINPAGE_FAQ_004_P1":"Evet, şu bağlantıları kontrol edebilirsiniz: ${1}masaüstü uygulaması${2} ve ${3}GitHub kuruluşu${4}.","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio güvenli mi?","WEBSITE_MAINPAGE_FAQ_005_P1":"Evet, Stremio açık kaynak kodlu bir yazılım olduğundan, kod herkes tarafından denetlenebilir ve kendiniz de kodunu inceleyebilirsiniz.","WEBSITE_MAINPAGE_FAQ_006_H1":"Mahremiyetime ne dersin?","WEBSITE_MAINPAGE_FAQ_006_P1":"Kullanıcıların gizliliğine saygı duyuyoruz. Hesabınızı oluşturmak ve senkronize etmek için gerekli minimum temel veri dışında herhangi bir kişisel veri toplamıyoruz.","WEBSITE_MAINPAGE_FAQ_006_P2":"Ayrıca kayıt sırasında ${1}Misafir modu${2} vardır ve hiçbir veri gerektirmez: Bu modda, arka tarafa çağrı yapılmaz. Ancak, kitaplığınızı cihazlar arasında senkronize edebilmek gibi yararlı özelliklerin ödün vermeniz gerekir.","WEBSITE_MAINPAGE_FAQ_007_H1":"Televizyonuma yayınlayabilir miyim?","WEBSITE_MAINPAGE_FAQ_007_P1":"Evet, Chromecast\'i destekliyoruz ve hem masaüstü hem de mobil uygulamalardan (Android) yayınlayabilirsiniz.","WEBSITE_MAINPAGE_FAQ_008_H1":"Stremio\'nun kaç eklentisi var?","WEBSITE_MAINPAGE_FAQ_008_P1":"2019 sonu itibariyla, 50\'nin üzerinde. Daha fazla bilgi için eklenti kataloğumuza bakın.","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio eklenti kataloğundakinin ötesine genişletilebilir mi?","WEBSITE_MAINPAGE_FAQ_009_P1":"Evet, şunları kontrol etmelisiniz: ${1}PimpMyStremio${2}, ${3}Reddit toplulukları${4}, ${5}Stremio İndirici${6} vb.","WEBSITE_MAINPAGE_FAQ_010_H1":"Stremio hangi cihazları destekliyor?","WEBSITE_MAINPAGE_FAQ_010_P1":"Windows, Mac ve Linux için masaüstü uygulamalarımız mevcut. Mobil cihazlar için, Android ve iOS\'u destekliyoruz. Ancak iOS\'un işlevsellik açısından sınırlı olduğunu unutmayın (çoğu eklentiyi desteklemez).","WEBSITE_MAINPAGE_FAQ_010_P2":"NVIDIA Shield ve Amazon Fire Stick gibi Stremio\'yu çalıştırabileceğiniz birçok Android tabanlı cihaz var. Ancak bunları resmi olarak desteklemiyoruz.","WEBSITE_MAINPAGE_FAQ_011_H1":"Stremio\'ya bazı içerikler ekleyebilir misiniz?","WEBSITE_MAINPAGE_FAQ_011_P1":"Üzgünüz, kendimizi hiçbir içeriği sağlamıoruz. Ancak ne kadar çok Stremio eklentisi yüklerseniz, o kadar çok içerik bulabilirsiniz.","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio magnet bağlantılarını oynayabilir mi?","WEBSITE_MAINPAGE_FAQ_012_P1":"Evet. Ayrıca normal HTTP bağlantılarını ve torrent dosyalarını da oynatabilir (sürükleyin ve bırakın).","WEBSITE_MAINPAGE_FAQ_013_H1":"Bir video indirip çevrimdışı izleyebilir miyim?","WEBSITE_MAINPAGE_FAQ_013_P1":"Çevrimdışı kullanım gelecek bir özelliktir. Ancak Stremio\'nun cihazınızda önbelleklemesine izin verirseniz (ayarlar panelinden) videoyu daha sonra bağlantı olmadan izleyebilirsiniz.","WEBSITE_MAINPAGE_FAQ_014_H1":"Hiçbir şey çalışmıyor, yardım edin!","WEBSITE_MAINPAGE_FAQ_014_P1":"Eklentileri yüklediğinizden emin misiniz? Cevabınız evetse, ${1}yardım merkezimize${2} danışın.","WEBSITE_MAINPAGE_FAQ_015_H1":"Stremio geliştirme faaliyetlerini nasıl sürdürüyor?","WEBSITE_MAINPAGE_FAQ_015_P1":"Gizliliği koruyan, şeffaf reklamlara odaklanan aynı kurucu ekibin bir şirketi olan ${1}AdEx${2} aracılığıyla müdahaleci olmayan reklamlar yayınlıyoruz.","WEBSITE_MAINPAGE_FAQ_015_P2":"Daha fazla soru için ${1}yardım merkezimize${2} gidin.","HELP_LEARN_MORE":"Hakkınızda daha fazla bilgi edinmemize yardımcı olun.","LIFESTYLE":"Yaşam stili","SPORTS":"Spor","FOOD_HEALTH":"Yemek ve Sağlık","BEAUTY_FASHION":"Güzellik ve Moda","NEWS":"Haber","GAMING":"Oyun","SCIENCE_EDUCATION":"Bilim ve Eğitim","MUSIC":"Müzik","TRAVEL":"Seyahat","LATE_NIGHT":"Gece Şovu","REALITY":"Reality","COMEDY":"Komedi","DIY":"Nasıl Yapılır?","TECH":"Teknoloji","CINEMA":"Sinema","CONTINUE":"Devam et","SLOW_LOADING":"YAVAŞ MI YÜKLENİYOR?","I_GIVE_UP":"VAZGEÇTİM","LEARN_MORE":"Daha fazlasını öğrenin","POOR_SOURCE":"Kaynak kötü veya İnternet bağlantınız yeterince hızlı değil","PICK_CATEGORIES_ERR":"En az 3 kategori seçmeniz gerekiyor","ADJUST_TIMING":"Zamanlama ayarlama","ADJUST_SIZE":"Boyut ayarlama","SEARCH_ANYTHING":"Her şeyi arayabilirsin...","ALL_CATEGORIES":"Tümü","SEARCH_CATEGORIES":"Filmler, Diziler, YouTube ve TV","SEARCH_PERSONS":"Aktörler, Yönetmenler ve Yazarlar","SEARCH_PROTOCOLS":"HTTP ve Magnet Bağlantıları","SEARCH_TYPES":"IMDB / TVDB Bağlantıları","WATCHED":"İzlendi","SHOW_LESS":"Daha az göster","LAST_SEARCHES":"Son aramalar","CLEAR_HISTORY":"Geçmişi temizle","CHOOSE_SOME":"BUNLARDAN BAZILARINI SEÇ:","NO_WEB_REMOTE":"Web Uzaktan Kontrolü yüklenemedi","STREMIO_OFFLINE":"Stremio çevrimdışı","STREMIO_EXPENSIVE_CONNECTION":"Ağ bağlantısı maliyetli","USE_DATA":"Veriyi kullan","WARNING":"Dikkat","MORE_INFO":"Daha fazla bilgi ...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"Yükleniyor ...","STREMIO_TV_BACK_TO_LANGUAGES":"Dillere geri dön","STREMIO_TV_REMOTE":"Uzaktan Kontrol","STREMIO_TV_GO_TO":"Git:","STREMIO_TV_OR_SCAN":"ve tara:","STREMIO_TV_ADDON_INSTRUCTIONS":"Tercih ettiğiniz eklentileri yüklemek için lütfen talimatları uygulayın.","STREMIO_TV_LIVE_TV":"Canlı TV","STREMIO_TV_RESUME_WATCHING":"İzlemeye Devam Et","STREMIO_TV_LOADING_BACKGROUND":"Arka planda yükleniyor","STREMIO_TV_CHECKING_AUTHENTICATION":"Doğrulama kontrol edililiyor","STREMIO_TV_LOADING_BOARD":"Pano yükleniyor","STREMIO_TV_LOGIN_HEADER_LINE_1":"Kullanıcılarımızın yazılımımızla mümkün olan en iyi kişiselleştirilmiş deneyime sahip olmalarını istiyoruz.","STREMIO_TV_LOGIN_HEADER_LINE_2":"Bu nedenle, hesabınızı oluşturmanızı ya da hesabınıza giriş yapmanızı rica ederiz.","STREMIO_TV_LOGIN_FOOTER_LINE_1":"Anlayışın için teşekkürler,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio Ekibi","STREMIO_TV_REMOTE_INSTRUCTIONS":"Web Uzaktan Konrolünü Akıllı Telefon / Tablet / Masaüstünüzle kullanmak için:","STREMIO_TV_WIFI_SETUP":"Wi-Fi Kurulumu","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle internet bağlantısı bulamadı.","STREMIO_TV_WIFI_DETAILS_1":"Bağlan:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"Şifreyi kullan:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"Bağlantıyı bir web tarayıcısı ile açın:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"Varsayılan","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"Son İzlenene Göre","STREMIO_TV_LIBRARY_SORT_NAME":"Ada Göre","STREMIO_TV_LIBRARY_TIMES_WATCHED":"İzlenen Zamanlara Göre","STREMIO_TV_DETAILS_SEASON_NUMBER":"Sezon ${1}","STREMIO_TV_STREAMS_LOADING":"${1} / ${2} eklenti yüklendi...","STREMIO_TV_STREAMS_STILL_LOADING":"${1} eklentisi hala yükleniyor...","STREMIO_TV_PLAYER_SETTINGS":"Oynatıcı ayarları","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"Altyazı gecikmesi","STREMIO_TV_PLAYER_AUDIO_DELAY":"Ses gecikmesi","STREMIO_TV_PLAYER_VIDEO_SCALING":"Görüntü ölçeği","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"Desteklenmeyen akış kaynağı","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"Harici bağlantı açılamadı","STREMIO_TV_PLAYER_PLAY_IN_EXO":"ExoPlayer ile oynayın","STREMIO_TV_PLAYER_PLAY_IN_VLC":"libVLC player ile oynayın","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"Oynatma hatası nedeniyle libVLC player\'a geçişiliyor","STREMIO_TV_ADDONS_TITLE":"Eklentileri yüklemek veya yapılandırmak için telefonunuzda veya PC\'nizde Stremio\'yu kullanın ve \\"Eklentileri Eşitle\\" seçeneğine basın","STREMIO_TV_ADDONS_SUBTITLE":"Not: Aynı Stremio hesabını kullandığınızdan emin olun.","STREMIO_TV_ADDONS_SYNC_ADDONS":"Eklentileri Eşitle","STREMIO_TV_ADDONS_SYNC_SUCCESS":"Eklentiler başarıyla eşitlendi","STREMIO_TV_ADDONS_SYNC_FAILED":"Eklentiler eşitlenemedi","STREMIO_TV_META_LINK_FAILED":"Meta bağlantı açılamadı","STREMIO_TV_CATALOG_LOADING":"Katalog hala yükleniyor...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"Arayüz dili güncellendi","STREMIO_TV_SETTINGS_THEME_UPDATED":"Tema güncellendi","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"Tercih Edilen Dil","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"İkincil Tercih Edilen Dil","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"Tünelli Oynatma","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"Bazı cihazlarda olası oynatma sorunları","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"Bazı video biçimleri çalışmayabilir","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"Otomatik kare hızı eşleştirme","STREMIO_TV_SETTINGS_NO_CACHING":"Önbelleğe alma yok","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"Varsayılan","STREMIO_TV_SETTINGS_PROFILE_SOFT":"Yavaş","STREMIO_TV_SETTINGS_PROFILE_FAST":"Hızlı","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"Çok Hızlı","STREMIO_TV_SETTINGS_SERVER_URL":"Akış sunucusu URL\'si","STREMIO_TV_SETTINGS_SERVER_VERSION":"Sunucu sürümü","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"Bilinmeyen","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio sürümü","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"Sunucu URL\'sini düzenle","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"Bir akış sunucusu URL\'si girin","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"Stremio\'nun Gizlilik Politikasını okumak için şu adresi ziyaret edin:","STREMIO_TV_SETTINGS_TOS_TEXT":"Stremio\'nun Hüküm ve Koşullarını okumak için şu adresi ziyaret edin:","STREMIO_TV_NAV_SEARCH":"Ara","STREMIO_TV_NAV_HOME":"Ana Sayfa","STREMIO_TV_NAV_DISCOVER":"Keşfet","STREMIO_TV_NAV_LIBRARY":"Kitaplık","STREMIO_TV_NAV_MOVIES":"Filmler","STREMIO_TV_NAV_SERIES":"Diziler","STREMIO_TV_NAV_CHANNELS":"Kanallar","STREMIO_TV_NAV_TV":"Canlı TV","STREMIO_TV_NAV_SETTINGS":"Ayarlar","STREMIO_TV_NAV_ADDONS":"Eklentiler","STREMIO_TV_LOGIN_TITLE":"Hesabımı Bağla","STREMIO_TV_LOGIN_EXPIRES_IN":"Sona erecek:","STREMIO_TV_LOGIN_STEP_ONE":"Yukarıdaki QR Kodunu tarayın veya","STREMIO_TV_LOGIN_STEP_TWO":"Stremio hesabınıza giriş yapın","STREMIO_TV_LOGIN_NEW_LINK":"Yeni bir bağlantı isteyin","STREMIO_TV_LOGIN_LINK_REFRESHED":"Giriş kodu yenilendi","STREMIO_TV_SEARCH_PLACEHOLDER":"Bir şeyler yazın","STREMIO_TV_SEARCH_NO_ADDONS":"Kataloglar için herhangi bir eklenti istenmedi!","STREMIO_TV_SEARCH_BUTTON":"Ara","STREMIO_TV_SEARCH_KEY_DEL":"Sil","STREMIO_TV_SEARCH_KEY_SPACE":"Boşluk","STREMIO_TV_SEARCH_KEY_CLEAR":"Temizle","STREMIO_TV_SEARCH_HISTORY_TITLE":"Geçmişi Temizle","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"Başlık, Aktör, Kanal ve daha fazlasını arayabilirsiniz...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"Arama Geçmişini Temizle","STREMIO_TV_FILTERS_DESCRIPTION":"Aşağıdaki filtrelerden birini seçin","FILTERS":"Filtreler","SETTINGS":"Ayarlar","ACCOUNT":"Hesap","LOGOUT":"Çıkış Yap","THEMES":"Temalar","PLAYBACK":"Oynatma","PLAYBACK_SPEED":"Oynatma Hızı","AUDIO_TRACKS":"Ses Parçaları","VIDEOS":"Videolar","SERVER":"Sunucu","LINKS":"Bağlantılar","ABOUT":"Hakkında","INTERFACE":"Arayüz","ANIMATIONS":"Animasyonlar","STATUS":"Durum","LANGUAGE":"Dil","SIZE":"Boyut","DELAY":"Gecikme","BOLD":"Kalın","TEXT_COLOR":"Metin Rengi","OUTLINE_COLOR":"Anahat Rengi","BACKGROUND_COLOR":"Arkaplan Rengi","BACKGROUND_BLUR":"Arkaplan Bulanıklığı","SEEK_TIME_DURATION":"Atlama Süresi","AUTO_PLAY":"Sonraki Bölümü Otomatik Oynate","PLAY_NOW":"Şimdi Oynat","MARK_AS_WATCHED":"İzlendi olarak işaretle","MARK_AS_UNWATCHED":"İzlenmedi olarak işaretle","REWIND_TO_BEGINNING":"Baştan Oynat","CONTINUE_WATCHING":"İzlemeye Devam Et","ALL":"Tümü","SECONDS":"saniye","ON":"AÇIK","OFF":"KAPALI","RELOAD":"Yeniden Yükle","EDIT_URL":"URL Düzenle","NONE":"Hiçbiri","EMBEDDED":"Gömülü","REMOTE_SWITCH_DEVICES":"Cihazı Değiştir","REMOTE_VIDEOS":"Videolar","REMOTE_ADJUST_TIMING":"Zamanlamayı ayarla","REMOTE_ADJUST_SIZE":"Boyutu ayarla","REMOTE_COULD_NOT_BE_LOADED":"Uzaktan Web Kontrolü yüklenemedi","REMOTE_RETRY":"Tekrar deneyin","TORRENT_PROFILE_DEFAULT":"Varsayılan","TORRENT_PROFILE_SOFT":"Yavaş","TORRENT_PROFILE_FAST":"Hızlı","TORRENT_PROFILE_ULTRA_FAST":"Çok Hızlı","FAQ_001_H1":"Stremio nedir?","FAQ_001_P1":"Stremio, video eğlencesi için kullanım kolaylığı düşüncesiyle tasarlanmış bir medya merkezi yazılımıdır. Stremio organize etmenize izin verir & kendi film, dizi, kanal ve canlı TV koleksiyonunuzu izleyin.","FAQ_001_P2":"Stremio, size gösterilen içeriği yerel diskinizden ve eklentiler sisteminden toplar.","FAQ_001_P3":"İlgilerinize göre yeni bölümler/videolar/filmler çıktığında da sizi uyarır ve size özel film önerileri sunar.","FAQ_02_H1":"Stremio\'nun Kodi ve Plex\'ten ne farkı var?","FAQ_02_P1":"Bu iki yazılımdan ilham aldık. Ancak farklı hedeflerimiz var - Stremio özellikle eğlence videolarını hedef alıyor ve kullanımının çok kolay olması nedeniyle ana çözüm olma yolunu arıyor.","FAQ_02_P2":"Stremio, Kodi ve Plex kadar özelleştirilebilir ve zengin özellikli olmayacak, ancak kullanımı çok daha kolay. Sadece ${1} al ve ${2} gör :)","FAQ_03_H1":"Stremio\'nun Netflix\'ten farkı nedir?","FAQ_03_P1":"Yine, Netflix ilham kaynağımızdan biridir. Netflix\'in kullanıcı deneyimine ek olarak bir çok eklenti elde etmeye çalışıyoruz. Ama en önemlisi, kendi kütüphanenizi yönetme ve eklenti sistemimizle yeni içerik kaynaklarını ekleme özgürlüğünü sunuyoruz.","FAQ_03_P2":"Stremio\'yu sınırsız olarak genişletebilirsiniz. Bu nedenle Stremio\'yu kullandığınızda, Netflix\'in lisansını alabildiği içerikle asla sınırlı kalmazsınız. Örneğin, Stremio aracılığıyla ${1} Filmon.tv ${2}, ${3} Twitch.tv${4}, ${5}YouTube${6}, ${7}Vodo${8} ve hatta ${9}Netflix${10}\'in kendisinden içerik izleyebilirsiniz!","FAQ_04_H1":"Stremio\'nun Flipboard\'dan farkı nedir?","FAQ_04_P1":"Bu soruyu sıkça görmüyoruz, yeni başlayanlarla konuşurken hariç :)","FAQ_04_P2":"Stremio, tasarım gereği videonun Flipboard olmasını sağlayan bir içerik toplayıcısıdır. Bu, Pano bölümünde çok açık bir şekilde görülmektedir; Flipboard gibi takip ettikleriniz için size kataloglar ve yeni bölüm/yeni video bildirimleri sunar.","FAQ_05_H1":"Stremio\'nun Popcorn Time\'dan farkı nedir?","FAQ_05_P1":"Stremio ve Popcorn Time, kullanıcı arabirimi olarak benzer, çünkü video eğlence kataloglarını doğru yapmanın başka bir yolu yok :)","FAQ_05_P2":"Ancak, Popcorn Time, belirli kaynaklardaki torrentleri akış yapmaya odaklanırken, Stremio sınırsızdır ve yalnızca bir içerik toplayıcısıdır - belirli bir içerik kaynağına kilitlenmez.","FAQ_05_P3":"Ayrıca, varsayılan olarak herhangi bir torrent eklentisi sağlamıyoruz. Bu nedenle Stremio, resmi işlevselliği olan Popcorn Time kullanım durumunu kapsamamaktadır.","FAQ_05_P4":"Bir diğer önemli fark ise, Popcorn Zamanı tamamen açık kaynaklı, Stremio ise ${1} kısmen açık kaynaklıdır${2}.","FAQ_06_H1":"Bu filmi/diziyi ekler misiniz?","FAQ_06_P1":"Hayır, üzgünüz :(","FAQ_06_P2":"Diğer sorularda birçok kez belirtildiği gibi, Stremio kendisi tarafından herhangi bir içerik sağlamaz; her şey eklentiler sistemi aracılığıyla eklenir. Bir içerik isteğiniz var ise Oynatıcı içindeki “Sorun bildir” düğmesini kullanabilirsiniz: Bu kullanmakta olduğunuz eklentinin oluşturucusuna bir e-posta gönderecektir.","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"X için eklenti oluşturur musunuz?","FAQ_08_P1":"Bu tamamen mümkündür.","FAQ_08_P2":"Bir eklenti ile ilgili bir fikriniz varsa, bize ${1}office@stremio.com${2} adresinden birkaç satır yazın, ancak lütfen eklenti fikrinizin herhangi bir telif hakkı veya kullanım şartlarını ihlal etmediğinden emin olun.","FAQ_08_P3":"Şu anda, yol haritamızda bulunan sonraki şeyler; FandangoNOW, Filmon.tv, talep üzerine video, Crunchyroll için eklenti.","FAQ_09_H1":"Stremio, BitTorrent kullanıyor mu?","FAQ_09_P1":"Evet, Stremio bir akış protokolü olarak BitTorrent\'i destekliyor. Bunu bir torrent eklentisiyle veya bir .torrent dosyasını Stremio\'ya sürükleyip bırakarak ya da Arama Çubuğuna bir magnet bağlantısı yapıştırarak kullanabilirsiniz.","FAQ_09_P2":"BitTorrent\'i kullanan tek resmi eklentinin, indie içerik sağlayan ve tamamının BitTorrent ile dağıtılmasına izin veren ${1}Vodo${2} olduğunu lütfen unutmayın.","FAQ_09_P3":"Telif hakkı ihlaline neden olabilecek üçüncü taraf eklentilerinin kullanılmasını desteklemiyoruz.","FAQ_10_H1":"Stremio\'da resmi eklentilerle neleri izleyebilirim?","FAQ_10_P1":"Varsayılan olarak, Filmon.tv, YouTube ve Vodo içeriğini gömülü oynatıcı ile Stremio\'nun içinde izleyebilirsiniz. Ayrıca, Twitch.tv ve diğerleri için bir eklentimiz var.","FAQ_10_P2":"Bu birleştirilmiş bir seçim sağlar:","FAQ_10_L1":"Popüler TV kanalları, Filmon.tv tarafından sağlanmıştır - örneğin E4, BBC, Bollyworld TV","FAQ_10_L2":"YouTube\'dan her şey - örneğin BBC News, Top Gear, Vevo, PewDiePie","FAQ_10_L3":"Vodo ile Indie filmleri","FAQ_10_L4":"Twitch.tv ile çevrimiçi oyun yayınları","FAQ_10_P3":"Buna ek olarak, Guidebox ve Netflix eklentileri ile sağlanan, tamamen, Stremio\'da oynatılmayan, ancak verilen hizmete yönlendiren birçok içerik kaynağı vardır. Örneğin, Guidebox eklentisi, TubiTV ve Crackle gibi hizmetlerden ABD\'de ücretsiz olarak yayın yapabileceğiniz bir film seçimi yapacaktır.","FAQ_11_H1":"Stremio yüklenmiyor, ne yapabilirim?","FAQ_11_P1":"Windows kullanıyorsanız,bu ${1}alternatif yükleyiciyi${2} deneyin","FAQ_11_P2":"Mac OS X kullanıyorsanız, lütfen OS X Mavericks(10.9)\'den daha eski hiçbir şeyi desteklemediğimizi unutmayın.","FAQ_11_P3":"Linux kullanıyorsanız, şu anda yalnızca 64 bit (x64) Linux\'u desteklediğimizin farkında olun.","FAQ_11_P4":"Sorununuzu yine de çözemezseniz, lütfen ${1}Facebook grubumuza${2} yazın.","FAQ_12_H1":"Antivirüs programım neden uyarı veriyor? Stremio güvenli mi?","FAQ_12_P1":"Stremio\'nun ${1}100% temiz${2} olduğundan emin olun.","FAQ_12_P2":"Virüsten koruma yazılımınız şikayetçi. Çünkü bazı antivirüs programlarının reklam yazılımı olarak tanıdığı reklamcıyı yükleyicimize dahil ediyoruz.","FAQ_12_P3":"Hala emin değilseniz, bizim ${1}alternatif yükleyicimizi${2} deneyebilirsiniz.","FAQ_13_H1":"Nasıl eklenti oluşturabilirim?","FAQ_13_P1":"Yeni başlayanlar için, GitHub\'daki ${1}eklentiler sistemi modülüne${2} göz atmanızı öneririz.","FAQ_13_P2":"Ardından, ${1}Merhaba dünya dersini${2} takip edebilirsiniz.","FAQ_13_P3":"Herhangi bir programlama becerisine sahip değilseniz, lütfen fikrinizi bize ${1}Reddit topluluğundan${2} ya da ${3}office@stremio.com${4} adresinden bildirebilirsiniz.","FAQ_14_H1":"Eklentiler nasıl yayınlanır?","FAQ_14_P1":"Bir eklenti ve sunucu oluştururken ve bildiriminize çalışan bir eklenti adresini işaret eden bir bitiş noktası alanı koyduğunuzda, eklenti kendisini ${1}Eklenti kataloğumuzda${2} otomatik olarak yayınlayacaktır.","FAQ_14_P2":"Bu durum, stremio-addons modülünün sunucu parçası, eklentiyi duyurmak için API\'yı otomatik olarak çağırır. API\'mız, bitiş noktası değerini geçerli bir eklenti olarak doğruladığında, katalogda gösterilmeye başlayacaktır.","FAQ_15_H1":"Tarayıcımda Stremio\'yu çalıştırabilir miyim?","FAQ_15_P1":"Şu an değil, ama bu geliyor!","FAQ_15_P2":"Bir Alfa görmekten hoşlanıyorsanız, burada görebilirsiniz: ${1}alpha4.strem.io${2}. Bu alfa üzerinde akışın devre dışı olduğunu unutmayın. Chrome, Firefox, Opera ve Edge\'i destekliyoruz.","FAQ_16_H1":"TV\'ye yayın yapma çalışmıyor/altyazı çalışmıyor","FAQ_16_P1":"TV\'ye yayın yapmak, farklı TV markaları ve modelleri arasında tutarsız olan DLNA teknolojisini kullanıyor. Bu nedenle, her durumda test etme yeteneğine sahip değiliz, bu yüzden mükemmel olmaktan çok uzak. Buna rağmen, sürekli olarak geliştirmeye çalışıyoruz ancak DLNA\'nın TV\'nizle ne zaman düzgün bir şekilde çalışmaya başlayacağına dair size bir zaman tahmini veremiyoruz.","FAQ_16_P2":"Yayın yapma menüsünde TV\'nizi göremiyorsanız, lütfen yönlendiricinizi, TV\'yi ve PC\'nizi yeniden başlatmanın yanı sıra ağ bağlantınızı devre dışı bırakmayı ve yeniden etkinleştirmeyi deneyin (Windows\'ta, Ağ\'a sağ tıklayın ve Etkinleştir/Devre Dışı Bırak\'ı kullanın).","FAQ_16_P3":"Hala bir sorunla karşılaşıyorsanız, TV markanızı ve model bilgilerinizi ${1}office@stremio.com${2} adresine göndererek bize yardımcı olabilirsiniz.","FAQ_16_P4":"Bu arada, çok iyi desteklediğimiz Chromecast\'i öneriyoruz ya da TV\'nizi bir HDMI kablosu ile bilgisayarınıza takmanız yeterlidir.","FAQ_17_H1":"Stremio donuyor ya da çöküyor, ne yapabilirim?","FAQ_17_P1":"Her şeyden önce, Windows 7\'yi AVG anti-virüs ile kullanıyorsanız: bu kombinasyonda bir sorunumuz var. Sorun AVG\'nin kendi içindedir ve bizim tarafımızdan çözülmesinin makul bir yolu yoktur. Ne yazık ki, istisnalar veya anti-virüs devre dışı bırakmak işe yaramaz. Tek çözüm, AVG\'yi başka bir şeyle değiştirmektir.","FAQ_17_P2":"Sorun bu değilse de, ancak hala Windows kullanıyorsanız, lütfen en son hizmet paketine güncelleyin ve GPU sürücülerinizi güncelleyin/yeniden yükleyin, sonra tekrar deneyin.","FAQ_17_P3":"Sorun hala devam ediyorsa veya Mac veya Linux kullanıyorsanız, lütfen sorunun ayrıntılarını bize ${1}Facebook grubumuzdan${2} yazabilirsiniz.","FAQ_18_H1":"Bir eklentiyi nasıl yapabilirim?","FAQ_18_P1":"Yeni başlayanlar için, GitHub\'daki ${1}eklentiler sistemi modülüne${2} göz atmanızı öneririz.","FAQ_18_P2":"Ardından, ${1}Merhaba dünya dersini${2} takip edebilirsiniz.","FAQ_18_P3":"Herhangi bir programlama becerisine sahip değilseniz, lütfen fikrinizi bize ${1}Reddit topluluğundan${2} ya da ${3}office@stremio.com${4} adresinden bildirebilirsiniz.","FAQ_19_H1":"Stremio neden disk alanı kaplıyor?","FAQ_19_P1":"Stremio\'da aktarılan video dosyalarını geçici olarak saklamak için yerel önbellek vardır.","FAQ_19_P2":"Bu iki avantaja sahiptir: Birincisi, Stremio\'nun akışını daha pürüzsüzleştirmek için videoyu ön yüklemeye olanak tanır. İkincisi, videoları yerel önbellekte tutar, böylece onları çevrimdışı izlemeye devam edebilirsiniz.","FAQ_19_P3":"Stremio\'nun ne kadar yer tuttuğu Ayarlar panelindeki Önbellek ayarına bağlıdır. Şu anda akışlı video bundan daha büyük olmadığı sürece, Stremio diskinizde belirlenen miktara (ör. 2GB) kadar tutabilir, bu durumda onu korumak için yeterli miktarda saklama alanı ayırmanız gerekir.","FAQ_20_H1":"Önbellek klasörü nerede?","FAQ_20_P1":"Windows\'ta, Ayarlar\'da seçtiğiniz sürücüdeki stremio-cache (ör. \\"E:\\\\stremio-cache\\")","FAQ_20_P2":"MacOS\'ta, burada \\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"Linux\'ta, burada \\"~/.stremio/stremio-cache\\" ya da \\"~/stremio-cache\\"","FAQ_21_H1":"\\"Akış sunucusu bulunamadı\\" hatası alıyorum, ne yapabilirim?","FAQ_21_P1":"Bu hatayı alırsanız, bu birkaç şeyden biri anlamına gelir:","FAQ_21_P2":"1) ${1}Web sürümümüz${2} aracılığıyla YouTube / BitTorrent kaynağı tarafından desteklenen bir eklenti kullanmaya çalışıyorsunuz. Bu durumda, ${3}web sitemizden${4} masaüstü sürümümüzü yüklemelisiniz.","FAQ_21_P3":"2) Stremio kurulumunuzda bir sorun var. Bu durumda, ${1}web sitesinden${2} en yeni masaüstü sürümünü yeniden yüklemeyi deneyin. Bu işe yaramazsa, anti-virüs programları ve güvenlik duvarları devre dışı bırakarak PC\'nizi yeniden başlatın ve tekrar deneyin. Bu da işe yaramazsa, lütfen ${3}Facebook grubumuzdan${4} bize yazın.","FAQ_22_H1":"IOS\'ta çoğu eklentiyi göremiyorum/kullanamıyorum","FAQ_22_P1":"Çünkü, Apple\'ın App Store hüküm ve koşullarındaki kısıtlamalar nedeniyle iOS uygulamasını yalnızca belirli bir eklenti grubuyla sınırladık.","FAQ_22_P2":"Ancak gelecekte iOS için daha fazla eklenti olacak ve ayrıca iOS uygulamasını Stremio akış sunucusuna bağlayarak tüm Stremio eklentilerini kullanmanızı sağlayacak bir entegrasyon da ekleyebiliriz."}')},8714:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"电影","TYPE_series":"剧集","TYPE_tv":"电视频道","TYPE_channel":"频道","TYPE_other":"其他","TYPE_movie_PL":"电影","TYPE_series_PL":"剧集","TYPE_tv_PL":"电视频道","TYPE_channel_PL":"频道","TYPE_other_PL":"其他","TYPE_ALL":"All","VIDEO":"视频","BACK":"返回","MORE":"更多","DONE":"完成","COPY":"复制","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"发现","Board":"首页","Library":"库","My Library":"我的库","Calendar":"日历","NOTIFICATION_ONLINE":"您当前处于在线状态","NOTIFICATION_OFFLINE":"您当前处于离线状态","INTERNET_CONNECTION":"网络连接","STORAGE_FULL_TITLE":"警告:储存空间已满!","STORAGE_FULL_TEXT":"Stremio将无法保存您的设置、首选项或登录信息,考虑重新启动或重新安装Stremio。","SEARCH":"搜索","SEARCH_NO_RESULTS":"未找到结果","SEARCH_EXPLANATION_CONTENT":"搜索电影、剧集、YouTube和电视频道","SEARCH_EXPLANATION_PEOPLE":"搜索演员、导演和编剧","SEARCH_PASTE_LINKS":"粘贴HTTP和Magnet链接","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"添加到库中","REMOVE_FROM_LIB":"从库中删除","ADDED_TO_LIB":"添加到库中","REMOVED_FROM_LIB":"从库中删除","TRAILER":"预告片","WATCH_TRAILER":"观看预告片","WATCH_NOW":"立即观看","SHOW":"查看","SHOW_MOVIE":"查看电影","WATCH_RANDOM":"随机观看","IMDB_RATING":"IMDb评分","YEAR":"年份","DIRECTOR":"导演","WRITER":"编剧","LEAD_ACTORS":"主演","CAST":"全部演员","CREW":"全部工作人员","SHOW_MORE_CAST":"显示更多 »","AIRED":"播出时间","SEASONS":"季","GENRE":"类型","CATALOG":"目录","SUMMARY":"简介","SHOW_MORE":"显示更多","SIMILAR":"相似","UPCOMING":"即将上映","ENDED":"已完结","DURATION":"时长","FEATURED":"功能","METADATA":"元数据","CATEGORY":"类别","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"搜索视频","SEARCH_PLACEHOLDER":"搜索或粘贴URL","ADDON":"插件","ADDONS":"插件","OFFICIAL":"官方","ADDONS_OFFICIAL":"官方Stremio插件","ADDONS_POPULAR":"在您所在的地区很受欢迎","ADDON_FREE":"免费","ADDON_PEERED":"连接","ADDON_SUBSCRIPTION":"订阅","ADDON_STREAM_GEORESTRICTED":"在您所在的地区不提供","ADDON_STREAM_OFFLINECACHE":"离线缓存","ADDON_STREAM_LOCALFILE":"本地文件","SHARE_ADDON":"分享插件","AVAILABLE_STREAMS":"可用流媒体","NO_STREAM":"未找到流媒体","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"要获取更多流媒体,请安装更多插件","STREAM_NOT_SUPPORTED":"此平台不支持所选流媒体。","ADDON_CATALOGUE":"显示所有插件 »","ADDON_CATALOGUE_MORE":"安装插件","REPO_ADDED":"已添加存储库","ADDON_REPO_EXIST_ERR":"此插件集合已存在","ADDON_REPO_ERR":"添加集合时出错","ADDON_ADD_ERR":"添加插件时出错","ERR_ADDON_PROTECTED":"无法卸载插件,它受到保护","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"出了一些问题——身份验证可能失败","ERR_NOT_COLLECTION_URL":"不是集合URL","ERR_NOT_ADDON_URL":"不是有效的插件URL","ERR_DETECTFROMURL":"再此URL中找不到插件/集合","ADDON_DUPLICATE_WARNING":"警告:重复的插件","ADDON_COLLECTION_SET_FAILED":"将已安装的插件同步到您的账户失败","SETTINGS_DATA_EXPORT":"导出用户数据","ADDON_PULL_FAILED":"从您的帐户同步已安装的插件失败","REFRESH_ON_CLICK":"点击重试","STILL_IN_THEATER":"电影还在影院上映","WATCH_IN_CINEMA":"请到您本地的影院观看","IN_THEATER":"在影院上映","GET_TICKETS":"购票","UPCOMING_EPISODE":"下一集","UPCOMING_EPISODE_MESSAGE":"这一集即将播出","MISSING_DATE_EPISODE":"缺失的一集日期","MISSING_DATE_EPISODE_MESSAGE":"这一集可能还没有播出","CHANNEL_NOT_SCRAPED":"这个频道还没有被削刮,请过几分钟再来。","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"将其添加到库中,以便在可用时收到通知。","GET_NOTIFIED_WHEN_AVAILABLE":"一旦可用,您将会收到通知。","WARNING_STREAMING_SERVER":"警告:找不到本地流媒体服务器,来自本地文件、YouTube、和BitTorrent的流媒体将不可用。","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"警告:您的硬件可能不支持此视频,请记住,播放可能会很慢。","PLAYER_ERROR":"糟糕,播放器错误","PLAYER_ERROR_LOOKSLIKE":"看起来似乎","PLAYER_ORIENTATION":"播放器方向","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"锁定","PLAYER_ORIENTATION_SENSOR_SHORT":"传感器","PLAYER_ORIENTATION_LANDSCAPE":"播放器方向锁定横向","PLAYER_ORIENTATION_SENSOR":"播放器方向自动(传感器)","PLAYER_PLAYBACK_SPEED":"播放速度","PLAYER_PLAYBACK_ERROR":"播放错误,请重试","PLAYER_PLAYBACK_ERROR_UNKNOWN":"未知错误","PLAYER_PLAYBACK_ERROR_DEFAULT":"抱歉,{{productName}}无法播放此视频。","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"直播","PLAYER_NEXT_VIDEO_TITLE":"下个视频","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"关闭","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"现在观看","STREAMING_FROM":"流媒体","CASTING_TO":"投屏到","NETWORK_STATUS":"网络状态","STREAM_SPEED":"串流速度:","STREAM_BUFFERED":"已缓冲:","PEERS_INFO":"节点信息","PEERS_ACTIVE":"活跃:","PEERS_CONNECTED":"已连接:","PEERS_WAITING":"等待:","TRANSCODING_WARNING":"警告:转码视频。","STREAM_LOADING":"加载...","PLAYING_LOCAL":"从本地文件播放","PLAYING_CACHE":"从缓存播放","WRONG_SUBS":"字幕错误?","ERR_SUBS_LOADING_TITLE":"加载字幕时出错","ERR_SUBS_LOADING":"字幕加载失败:这可能是您正在使用的插件或网络连接的问题","WARN_FOLLOWING_SUB_ADDONS_FAILED":"以下字幕插件失败","ERR_CASTING_UPDATE_TITLE":"无法更新投屏设备信息:流媒体服务器可能离线","CHOOSE_DEVICE":"选择在哪个设备上播放","NO_CAST_DEVICES":"无可用投屏设备。","NO_SETTINGS":"无可用设置。","PHONE_TABLET":"手机/平板电脑","SUBTITLES":"字幕","SUBTITLES_CHANGE":"调整字幕","SUBTITLES_CHANGE_NONE":"抱歉,这种语言没有其他字幕。","SUBTITLES_CHANGE_ACIVE":"当前字幕#{{subtitlesDialog.activeIdx + 1}}被激活,点击\\"继续\\"激活字幕#{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"或者,","SUBTITLES_ADJUST_DELAY":"调整字幕延迟:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"或在播放时使用G / H键进行调整。","SUBTITLES_ADJUST_DELAY_TIP":"提示:您可以在播放时使用G / H键进行调整。","SUBTITLES_DELAY":"字幕延迟:","SUBTITLES_LOADING":"加载字幕...","SUBTITLES_UNAVAILABLE":"没有可用的外部字幕","SUBTITLES_DISABLED":"关闭","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"季","EPISODE":"集","SPECIAL":"Special","SORT":"排序","SORT_BY":"排序按照","FILTER":"筛选","SORT_TRENDING":"热门","SORT_RECENT":"最近","SORT_ALPHABET":"首字母","SORT_RATING":"评分","SORT_WATCHED":"已观看","SORT_YEAR":"年份","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"新的","New Episodes":"新剧集","New Videos":"新视频","Recommendations":"推荐","LIBRARY_RESUME":"简介","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"详情","LIBRARY_RESUME_DISMISS":"清除","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"功能","DISCOVER_TOP":"热门","DISCOVER_OSCAR":"奥斯卡获奖作品","DISCOVER_WARNING_TITLE":"糟糕!","DISCOVER_EMPTY_CATALOG":"此插件返回空内容。","DISCOVER_ADULT_WARNING":"此内容仅对成人可见,您是否已满18周岁?","DISCOVER_NOADDON_WARNING":"警告:此类型没有可用的Stremio插件,显示已保存的项目,此处不会更新任何内容。","DISCOVER_LOAD_ERR":"内容未加载,发生错误。","DISCOVER_ADDON_UNINSTALLED":"此内容不再可用,您可能已卸载插件。","UNINSTALL_THIS_ADDON":"卸载此插件","ERR_ADDON_NOT_INSTALLED":"未安装此插件,立即安装?","DETAIL_RECEIVE_NOTIF_SERIES":"接受新剧集的通知","DETAIL_RECEIVE_NOTIF_VIDEOS":"接受新视频的通知","SIDEBAR_SHOW_STREAMS":"显示流媒体","RELAUNCH":"立即重新启动!","UPGRADE":"新版本可用!升级至Stremio的最新版本","RELOAD_UI":"重新加载用户界面","MANUAL_UPDATE_TITLE":"更新您的Stremio版本","MANUAL_UPDATE_LINE1":"您运行的是一个过时的Stremio版本,这是非常不推荐的。","MANUAL_UPDATE_LINE2":"请尽快更新。","BUTTON_UPDATE_LATTER":"不是现在","BUTTON_UPDATE_NOW":"更新","ANONYMOUS_USER":"匿名用户","DONT_HAVE_ACC":"还没有账户?","HAVE_ACC":"已经有账户了?","PASSWORD":"密码","PASSWORD_CONFIRM":"确认密码","EMAIL":"电子邮箱","FB_LOGIN":"使用Facebook登录","FB_NOTHINGSHARED":"未经您的允许,任何内容都不会被共享","FB_NOPOST":"我们不会替您发送任何东西","OR":"或","I_ACCEPT":"我接受","I_ACCEPT_BY_CLICKING":"通过点击上面的按钮,我声明我接受","TOS":"条款和条件","MUST_ACCEPT_TERMS":"您必须接受条款","PASSWORDS_NOMATCH":"密码不匹配","SIGN_UP":"注册","SIGN_UP_EMAIL":"使用电子邮箱注册","CLICK_TO_SIGN_UP":"点击此处注册。","LOG_IN":"登录","LOG_OUT":"注销","EXIT_FULLSCREEN":"退出全屏模式","ENTER_FULLSCREEN":"进入全屏模式","PLAY_URL_MAGNET_LINK":"播放URL/Magnet链接","HELP_FEEDBACK":"帮助和反馈","TERMS_OF_SERVICE":"服务条款","PRIVACY_POLICY":"隐私政策","ABOUT_STREMIO":"关于Stremio","USER_PANEL":"用户面板","LOGIN_LABEL":"Login","GUEST_LOGIN":"访客登录","GUEST_LOGIN_NOTICE":"不建议访客登录,使用常规登录允许Stremio同步您的库,接受喜爱的剧集/频道的通知。您确定要继续吗?","GUEST_LOGIN_NOTICE_2":"不建议访客登录,您将没有同步的库和首页通知,这是Stremio的重要功能。您确定要继续吗?","CLICK_HERE":"点击此处","WRONG_PASSWORD":"错误的电子邮箱或密码,如果您忘了密码,","SET_A_PASS":"设置密码","RESET_PASSWORD":"重置密码","FORGOT_PASSWORD":"忘记密码?","EMAIL_USED_WITH_FB":"此电子邮箱与Facebook登陆一起使用。","INVALID_EMAIL":"请输入有效的电子邮箱地址","INVALID_PASSWORD":"请输入有效的密码","CONN_ERR":"连接错误,请稍后再试。\\n\\n如果问题仍然存在,请禁用防火墙/杀毒软件(特别是Bitdefender)。","IMPORT_FROM_GUEST":"从访客账户导入库","RECEIVE_UPDATES_EMAIL":"从Stremio接受电子邮件更新","LOGIN_FAILED":"登陆失败。","SIGNUP_FAILED":"注册失败。","SEARCH_FAILED":"搜索失败","EMAIL_USED":"此电子邮箱已被使用。","WAITING_FB_LOGIN":"使用Facebook登录...","EXTERNAL_PLAYER_TITLE":"在外部播放器中播放","EXTERNAL_REMEMBER_PLAYER":"您想记住您的选择吗","EXTERNAL_ALWAYS_PLAY":"是","EXTERNAL_ONLY_ONCE":"不是","BEST_FIT":"最佳","FIT_SCREEN":"适合屏幕","FILL":"填充","16:9":"16:9","4:3":"4:3","Original":"原始","INTRO_TASTE":"告诉我们您喜欢什么","INTRO_TASTE_LONG":"告诉我们您想看什么","INTRO_TASTE_PICK":"选择{{interestsRemaining}}兴趣","INTRO_TASTE_PICK_MORE":"选择{{interestsRemaining}}更多兴趣","INTRO_TASTE_HELP_US":"帮助我们了解更多有关您的信息。","INTRO_TASTE_CHOOSE_THESE":"选择其中一些:","INTRO_TASTE_CHOOSE_MIN":"至少选3个类别","INTRO_TASTE_CHOOSE_MIN_ERR":"您必须至少选择3个类别!","INTRO_TASTE_LIFESTYLE":"生活方式","INTRO_TASTE_SPORTS":"体育","INTRO_TASTE_FOOD_HEALTH":"饮食与健康","INTRO_TASTE_BEAUTY_FASHION":"美丽与时尚","INTRO_TASTE_NEWS":"新闻","INTRO_TASTE_GAMING":"游戏","INTRO_TASTE_SCIENCE_EDU":"科学与教育","INTRO_TASTE_MUSIC":"音乐","INTRO_TASTE_TRAVEL":"旅行","INTRO_TASTE_LATE_NIGHT":"深夜秀","INTRO_TASTE_REALITY":"真人","INTRO_TASTE_COMEDY":"喜剧","INTRO_TASTE_DIY":"DIY","INTRO_TASTE_TECH":"技术","INTRO_TASTE_CINEMA":"影院","ADDON_NOT_SUPPORTED":"此平台不支持选定的插件。","ADDON_DISCLAIMER":"使用第三方插件将始终受到您的责任和您所在的司法管辖区的法律的约束。","ADDON_ACTIVATE":"激活此插件?","ADDON_REPO_ADD":"插件集合URL","ADDON_ADD":"添加","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"最新消息","BUTTON_CONTINUE":"继续","BUTTON_ACTIVATE":"激活","BUTTON_ACTIVATED":"已激活","BUTTON_CANCEL":"取消","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"清除全部","BUTTON_VIEW_ALL":"查看全部","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"您的库看起来是空的,看看它有多有用:)","HOW_START":"您可以从这里开始:","LIB_EMPTY_CAL":"您的日历显示您库中的剧集。","HOW_START_CAL":"下面是如何添加剧集:","LIB_EMPTY_BOARD":"主页显示与您的库相关的通知&推荐。","HOW_START_BOARD_WAIT":"请在您的库中添加一些剧集或频道给我们几分钟来处理:)","HOW_START_BOARD":"下面是如何向其中添加剧集&电影:","IMPORT_FB":"从Facebook导入您喜欢的东西","IMPORT_TRAKT":"从Trakt导入媒体库","IMPORT_DISCOVER":"从发现中找到有趣的东西","IMPORT_DISK":"导入本地磁盘上的电影或节目","PLEASE_CREATE_ACC":"请创建一个账户以启用库同步&主页。","IMPORT_DISCOVER_SIGNUP":"注册并从发现中找到有趣的东西","IMPORT_DISK_SIGNUP":"注册并导入本地磁盘上的电影或节目","LIB_EMPTY_CLOUD":"云端库","LIB_EMPTY_CLOUD_DESC":"在所有设备上同步个人云端库","LIB_EMPTY_EARLY":"第一时间","LIB_EMPTY_EARLY_DESC":"接收新剧集的通知","LIB_EMPTY_PERSONAL":"个性化","LIB_EMPTY_PERSONAL_DESC":"获取个性化推荐","LIB_EMPTY_CALENDAR_DESC":"安排您的个性化观看日历","LIB_EMPTY_ALL":"注册以获取所有这些:","LIB_EMPTY_BEST":"注册以获得最佳的Stremio","LIB_EMPTY_OTHER":"注册以启用日历和其他炫酷功能","CALENDAR_ADDED":"Stremio日历已添加到默认桌面日历中。","CALENDAR_ADDED_MSG":"如果这不起作用,请手动将此URL添加到日历应用程序中","TRAKT_EXPIRED":"Trakt验证已过期,请转到设置并重新验证","TRAKT_REQUIRES_LOGIN":"Trakt错误","TRAKT_REQUIRES_LOGIN_MSG":"您需要登录","SETTINGS_LABEL":"设置","SETTINGS_NAV_GENERAL":"常规","SETTINGS_NAV_PLAYER":"播放器","SETTINGS_NAV_STREAMING":"流媒体","SETTINGS_NAV_SHORTCUTS":"快捷键","SETTINGS_SHORTCUT_RELOAD_APP":"重新加载应用程序","SETTINGS_SHORTCUT_OPEN_SETTINGS":"打开设置","SETTINGS_SHORTCUT_SWITCH_TABS":"切换标签","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"向前循环标签","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"向后循环标签","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"退出/返回","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"切换全屏","SETTINGS_SHORTCUT_SHOW_CONTROLS":"显示控件","SETTINGS_SHORTCUT_PLAY_PAUSE":"播放/暂停","SETTINGS_SHORTCUT_VOLUME_UP":"增大音量","SETTINGS_SHORTCUT_VOLUME_DOWN":"降低音量","SETTINGS_SHORTCUT_SEEK_NEXT":"寻找下一个","SETTINGS_SHORTCUT_SEEK_PREV":"寻找上一个","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"播放下一个","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"增加字幕大小","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"减小字幕大小","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"增加字幕延迟","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"减少字幕延迟","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"切换侧边栏","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"开机时启动","SETTINGS_VLC_DEFAULT":"使用VLC播放","SETTINGS_UI_LANGUAGE":"用户界面语言","SETTINGS_FULLSCREEN_EXIT":"Esc键退出全屏","SETTINGS_GAMEPAD":"启用游戏手柄支持","SETTINGS_CLOSE_WINDOW":"关闭窗口时结束应用程序","SETTINGS_SUBTITLES_LANGUAGE":"默认字幕语言","SETTINGS_SUBTITLES_SIZE":"默认字幕大小","SETTINGS_SUBTITLES_BACKGROUND":"字幕背景","SETTINGS_SUBTITLES_COLOR":"字幕颜色","SETTINGS_SUBTITLES_COLOR_OUTLINE":"字幕轮廓颜色","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"字幕背景颜色","SETTINGS_SEEK_KEY":"方向键控制进度","SETTINGS_SEEK_KEY_SHIFT":"按住Shift键时方向键控制进度","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"自动播放下一集","SETTINGS_NEXT_VIDEO":"显示播放下一集的通知","SETTINGS_NEXT_VIDEO_TRIGGER":"显示下一集的通知:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"播放前自动调整窗口大小","SETTINGS_OVERRIDE_SERVER":"覆盖流媒体服务器URL(高级)","SETTINGS_SERVER_URL":"流媒体服务器URL:","SETTINGS_SERVER_AVAILABLE":"流媒体服务器可用。","SETTINGS_SERVER_UNAVAILABLE":"流媒体服务器不可用。","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"流媒体HTTPS结点:","SETTINGS_USE_BETA":"始终使用最新的测试版","SETTINGS_IMPORT_FB":"从Facebook导入","SETTINGS_IMPORT_DISK":"从本地磁盘导入","SETTINGS_IMPORT_TRAKT":"从Trakt导入","SETTINGS_PAUSE_MINIMIZED":"最小化时暂停播放","SETTINGS_HWDEC":"硬件解码加速","SETTINGS_BACKGROUND":"后台播放","SETTINGS_SUBSCRIBE_CALENDAR":"订阅到日历","SETTINGS_REQ_EXPORT":"请求导出数据","SETTINGS_ACC_DELETE":"请求删除账户","SETTINGS_CHANGE_PASSWORD":"更改密码","SETTINGS_TOS":"服务条款","SETTINGS_SUPPORT":"联系支持人员","SETTING_LANGUAGE":"语言","SETTINGS_TRAKT":"Trakt自动跟踪","SETTINGS_TRAKT_LOGOUT":"从Trakt.tv注销","SETTINGS_SCAN_FOR_REMOTE":"扫描二维码打开遥控器","SETTINGS_DESKTOP_NOTIFICATIONS":"桌面通知","SETTINGS_DATA_SAVER":"移动数据警告","SETTINGS_LANGUAGE_INTERFACE":"界面","SETTINGS_LANGUAGE_SUBS":"默认字幕","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"自动选择音轨","SETTINGS_DEFAULT_AUDIO_TRACK":"默认音轨","SETTINGS_ACCOUNT":"账户","SETTINGS_VERSION":"版本","SETTINGS_MPV_WINDOW":"在单独窗口中启动播放器(高级)","SETTINGS_PLAY_IN_EXTERNAL":"总是在外部播放器中打开视频","SETTINGS_STORAGE_BUTTON":"清除本地存储","SETTINGS_STORAGE_MODAL_TITLE":"您确定吗?","SETTINGS_STORAGE_MODAL_MESSAGE":"这将清除本地存储并使您注销","SETTINGS_HWDEC_PICKER":"选择硬件加速解码设置","SETTINGS_HW_AUTOMATIC":"自动","SETTINGS_HW_DISABLED":"关闭","SETTINGS_HW_ACCELERATED":"解码加速","SETTINGS_HW_FULL":"全加速","SETTINGS_HW_LEGACY":"旧版","SUBSPICKER_AUDIO":"音频","SUBSPICKER_SUBTITLES":"插件字幕","SUBSPICKER_BLACK_BACKGROUND":"使用黑色背景色","SUBSPICKER_VERTICAL_OFFSET":"垂直偏移量","SUBSPICKER_SIZE":"大小","SUBSPICKER_DELAY":"延迟","SUBSPICKER_EMBEDDED_SUBS":"内嵌字幕","MOBILE_PRIVACY_POLICY":"隐私政策","MOBILE_CRASH_REPORTING":"崩溃报告","MOBILE_ZOOM_TO_FILL":"缩放填充屏幕","MOBILE_PASSTHROUGH":"数字音频输出(直通)","MOBILE_RUN_LOW_BATTERY":"电池电量低时运行","MOBILE_RUN_FOREGROUND":"作为前台服务运行","MOBILE_PERFORMANCE":"性能&稳定性","MOBILE_SERVER_ONLINE":"在线","MOBILE_SERVER_OFFLINE":"离线","MOBILE_QR_EXPIRES":"二维码到期时间","MOBILE_LOG_INTO":"登陆到您的Stremio账户","MOBILE_SCAN_QR":"扫描上面的二维码或转到","MOBILE_LINK_ACCOUNT":"链接账户","MOBILE_SPEEDPICKER_CANCEL":"取消","MOBILE_SPEEDPICKER_LABEL":"选择播放速度","MOBILE_EMPTY_LIBRARY":"您的库为空","MOBILE_NO_ADDON_ACTIVE":"没有活动的此类型Stremio插件。","MOBILE_ORGANIZER_WARNING":"Stremio Organizer应用程序提供的功能有限,要获得可播放流的列表和完整的Stremio体验,请使用Stremio桌面客户端。","MOBILE_ADDON_LOADING":"仍在加载","MOBILE_ADDONS_LOADING":"插件仍在加载","MOBILE_ADDON":"插件","MOBILE_CONFIGURE_ADDON":"配置插件","MOBILE_CONFIGURE_ADDON_LABEL":"配置插件","MOBILE_ORGANIZER_ADDONS_WARNING":"Stremio Organizer应用程序仅提供有限的插件,要获得完整的Stremio体验,请使用Stremio桌面客户端。","MOBILE_DISCONNECT":"断开连接","MOBILE_LOOKING_FOR_DEVICES":"正在查找设备...","MOBILE_CAST_TO":"投屏到","NAVIGATION_ON":"开启","NAVIGATION_OFF":"关闭","MARKETING_AGREE":"我同意接收Stremio的营销通知","QUIT":"退出","CONNECTED":"已连接","AUTHENTICATE":"验证","CACHING":"缓存","SETTINGS_CACHING_DRIVE":"缓存磁盘","ENABLE_LOCAL_FILES_ADDON":"启用本地文件插件(需要重新启动)","LOCAL_ADDON_NOT_ENABLED":"未启用本地插件,单击此处转到设置并启用它","ENABLE_REMOTE_HTTPS_CONN":"启用远程HTTPS连接","TORRENT_PROFILE":"Torrent配置","DATA_CACHING":"数据缓存","MAGNET_PARSING":"分析Magnet链接","January":"一月","February":"二月","March":"三月","April":"四月","May":"五月","June":"六月","July":"七月","August":"八月","September":"九月","October":"十月","November":"十一月","December":"十二月","Monday":"星期一","Tuesday":"星期二","Wednesday":"星期三","Thursday":"星期四","Friday":"星期五","Saturday":"星期六","Sunday":"星期天","Action":"动作","Comedy":"喜剧","War":"战争","Family":"家庭","Animation":"动画","Adventure":"冒险","Fantasy":"幻想","Crime":"犯罪","Mystery":"神秘","Romance":"浪漫","Drama":"剧情","Horror":"恐怖","Thriller":"惊悚","Sci-Fi":"科幻","Music":"音乐","Biography":"传记","Documentary":"纪录","Sport":"运动","Musical":"音乐剧","Western":"西部","Film-Noir":"黑色电影","News":"新闻","History":"历史","Game-Show":"游戏节目","Reality-TV":"真人秀","Talk-Show":"脱口秀","Film & Entertainment":"电影与娱乐","Gaming":"游戏","From TV":"电视","Lifestyle":"生活方式","Science & Education":"科学与教育","Cooking & Health":"烹饪与健康","Beauty & Fashion":"美丽与时尚","Sports":"体育","News & Politics":"新闻与政治","How-to & DIY":"DIY","Tech":"技术","Automotive":"汽车","Causes & Non-Profits":"事业与公益","Movies":"影视","Uk Live Tv":"英国直播电视台","Fashion":"流行","Business News Radio":"商业新闻电台","Business Tv":"商业电视","Cars & Auto":"汽车与自动化","Comedy Radio":"喜剧电台","Lifestyle Radio":"生活方式电台","News Tv":"新闻电视","Food And Wine":"食物与酒","Latino Tv":"拉丁语电视台","Shopping Tv":"购物电视台","Religion":"宗教","Kids":"儿童","Body & Soul":"身体与灵魂","Education":"教育","Indian Tv":"印度电视台","Extreme Sports":"极限运动","Middle Eastern Tv":"中东电视台","Celebrity Tv":"名人电视台","Science Tv":"科学电视台","Bikini babe":"比基尼宝贝","Outdoors":"户外","German Tv":"德国电视台","French Tv":"法国电视台","Italian Tv":"意大利电视台","Gamer Tv":"伽马电视台","Travel":"旅行","Asian Tv":"亚洲电视台","Entertainment":"游戏娱乐","News Radio":"新闻电台","Music Radio":"音乐电台","Language Learning":"语言学习","Science Radio":"科学电台","Tech Radio":"科技电台","Science & Technology Vod":"科技视频点播","new video":"新视频","new episode":"新一集","new movie":"新电影","recommended":"推荐","we recommend":"我们建议","offer of the day":"当日优惠","news":"新闻","music video":"音乐视频","CTX_SHOW_HOTKEYS":"显示快捷键","CTX_DISMISS_NOTIF":"清除通知","CTX_DISMISS_ALL":"全部清除","CTX_SHARE":"分享","CTX_COPY_SHARE_LINK":"复制分享链接","CTX_COPY_MAGNET_LINK":"复制Magnet链接","CTX_COPY_STREAM_LINK":"复制流媒体链接","CTX_DOWNLOAD_VIDEO":"下载此视频","CTX_DOWNLOAD_SUBS":"下载字幕","CTX_VIEW_ON_YOUTUBE":"在YouTube上观看","CTX_SHOW":"显示","CTX_PLAY":"播放","CTX_PLAY_IN":"播放","CTX_PLAY_ON":"正在播放","CTX_WATCH_ON":"正在观看","CTX_WATCH":"观看","CTX_WATCHED":"已观看","CTX_WATCH_BEGINNING":"从头开始观看","CTX_WATCH_MOBILE":"在移动设备上观看","CTX_REWIND":"回到开头","CTX_MARK_WATCHED":"标记为已观看","CTX_MARK_NON_WATCHED":"标记为未观看","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"将其余部分标记为已观看","CTX_UNMARK_REST":"将其余部分标记为未观看","CTX_RECEIVE_NEW_NOTIF":"接受新通知","CTX_REMOVE_CACHE":"从缓存中删除","CTX_REMOVE_CACHE_EP":"从缓存中删除集","CTX_OPEN_CONTAINING":"打开所在文件夹","CTX_REMOVE":"从库中删除","CTX_AVAILABLE_OFFLINE":"离线可用","CTX_PAUSED":"暂停","CTX_ALWAYS_ON_TOP":"置顶","CTX_FULLSCREEN":"全屏","CTX_WRONG_SUBS":"错误的字幕?","CTX_REPORT_ISSUES":"报告问题","CTX_COPY":"复制","CTX_PASTE":"粘贴","CTX_CLEAR":"清除","CTX_CLEAR_RECENT_SEARCHES":"清除最近搜索记录","HELLO_THERE":"您好","HOPE_YOU_ENJOY":"我们希望您喜欢Stremio,也许它已经是您最喜欢的应用之一了!","WHO_ARE_WE":"我们是谁?我们是它背后的团队。在过去三年里的每天,我们两个努力工作使这个产品越来越好。","SUPPORT_US":"如果您喜欢Stremio,如果Stremio对您来说很有价值,请传播它!","SPREAD_THE_WORD":"现在与您的朋友分享传播关于Stremio的信息","MORE_PEOPLE":"使用Stremio的人越多,效果就越好!","SEND_A_LINK":"或发送一个链接到我们的网站","TIP_LOCALFILES":"提示:您可以将本地视频文件拖放到Stremio中","ADDON_MY":"我的插件","ADDON_COMMUNITY":"社区插件","ADDON_OFFICIAL":"官方插件","ADDON_REPOS":"插件集合","ADDON_SEARCH":"搜索插件","ADDON_INSTALL":"安装","ADDON_CONFIGURE":"配置","ADDON_UNINSTALL":"卸载","ADDON_UPGRADE":"更新","ADDON_INSTALLED":"已安装","ADDON_INSTALLED_MSG":"插件已安装!","ADDON_UPGRADED_MSG":"插件已更新!","ADDON_UNKNOWN":"未知","ADDON_ERR":"插件安装错误!","ADDON_DISCONNECTED":"已断开连接","ADDON_APP_MISSING":"未安装此源的应用程序,您想现在安装吗?","ADDON_APP_INSTALL":"立即安装","ADDON_PAGE":"插件页","ADDON_TOP_CONTENT":"最好从这个插件","ADDON_PROVIDES":"这个插件会给您:","ADDON_WATCH":"立即观看#{types}!","ADDON_WATCH_FREE":"立即免费观看#{types}!","ADDON_ADDON":"插件","ADDON_SUPPORTED_TYPES":"支持的类型","ADDON_SUPPORTED_CATALOGS":"支持的目录","ADDON_PROVIDES_DISCOVER":"发现中的更多#{types}","ADDON_PROVIDES_STREAMS":"观看#{types}","ADDON_PROVIDES_STREAMS_FREE":"免费观看#{types}","ADDON_PROVIDES_SUBTITLES":"#{types}的字幕","ADDON_CANTDETECT":"我们无法检测到正在运行的Stremio,因此我们无法检测您安装了哪些插件。","ERR_NO_META":"找不到有关于此的信息","ERR_GETTING_META":"检索有关于此的信息时出错","ERR_CANT_PARSE_MAGNET":"无法分析Magnet","ERR_NO_MAGNET_INFOHASH":"Magnet缺少有效的Hash","ERR_NO_FILE_PATH":"没有文件路径无法发送请求","ERR_NO_TORRENT":"没有Torrent返回","ERR_NO_SUPPORTERD_FILES":"找不到支持的文件","ERR_OPENING_FILES":"无法打开外部文件","ERR_INVALID_LINK":"无效链接","ERR_REGISTERED_ONLY":"此选项仅适用于已注册用户。","ERR_CLIPBOARD":"无法从剪切板播放","ERR_CLIPBOARD_READ":"无法读取此平台上的剪切板","ERR_CLIPBOARD_GENERIC":"在剪切板中找不到可播放的URL. 请将URL(例如Magnet链接)复制到视频。","BOARD_CONTINUE_WATCHING":"继续观看","BOARD_EXPLANATION_RECOMMENDATIONS":"专门为您挑选的电影。
这部电影是一个推荐样例。","BOARD_EXPLANATION_EPISODES":"这里是您最喜爱的剧集的新一集。
将您关注的剧集添加到库中。","BOARD_EXPLANATION_VIDEOS":"这里是您最喜爱的频道的新一集。
将您关注的YouTube频道添加到库中。","WEBSITE_SLOGAN_WATCH":"立即观看","WEBSITE_SLOGAN_ALL":"一站式视频娱乐解决方案","WEBSITE_SLOGAN_NEW":"您能观看一切","WEBSITE_SLOGAN_NEW_NEW":"自由串流","WEBSITE_WATCH_FROM":"观看","WEBSITE_DOWNLOAD":"立即下载","WEBSITE_DOWNLOAD_FOR":"立即下载","WEBSITE_IS_DESKTOP":"Stremio是一个桌面应用程序,请在PC上打开此页并下载","WEBSITE_DESKTOP_DEMO_VID":"桌面演示","WEBSITE_PAGE_HOME":"首页","WEBSITE_PAGE_FEATURES":"功能","WEBSITE_PAGE_ADDONS":"插件","WEBSITE_PAGE_TECH":"技术","WEBSITE_PAGE_CREATE_ADDON":"创建插件","WEBSITE_PAGE_CONTACTS":"联络","WEBSITE_PAGE_BLOG":"博客","WEBSITE_TYPE_movie":"电影","WEBSITE_TYPE_series_PL":"剧集","WEBSITE_TYPE_tv":"直播电视","WEBSITE_TYPE_channel":"频道","WEBSITE_STREMIO_WHAT_IS":"Stremio是一款帮助您管理和随时观看您喜爱的视频、电影、剧集和电视频道的应用程序","WEBSITE_FEATURES_WATCH":"立即观看高清视频","WEBSITE_FEATURES_WATCH_DETAIL":"点击并播放您喜爱的电影、剧集、视频和电视频道。","WEBSITE_FEATURES_SUBS":"自动加载字幕","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio会自动为您的语言选择同步字幕。","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"在电视和移动设备上播放","WEBSITE_FEATURES_CAST_DETAIL":"适用于AppleTV、Chromecast、智能电视(DLNA/UPnP)和移动设备。","WEBSITE_LIB":"享受在所有设备上同步的个人库","WEBSITE_LIB_COLLECT":"从Stremio收集","WEBSITE_LIB_IMPORT":"从Facebook导入","WEBSITE_LIB_LOCAL":"从本地磁盘添加","WEBSITE_BOARD":"首页 - 通知和推荐的一站式场所","WEBSITE_BOARD_RECOMMEND":"推荐电视节目","WEBSITE_BOARD_TRENDING":"流行电影","WEBSITE_BOARD_NEW":"新视频","WEBSITE_BOARD_EPISODE":"新一集","WEBSITE_BOARD_1":"想看些有趣的东西吗?根据您的喜好得到推荐!","WEBSITE_BOARD_2":"当您最喜爱的电视节目或YouTube频道的新一集播出时获得通知!","WEBSITE_BOARD_YOUTUBE":"YouTube频道的新视频","WEBSITE_BOARD_EPISODES":"您关注的剧集的新一集","WEBSITE_ADDONS":"内容插件","WEBSITE_TECH_DETAIL":"我们热爱科技,我们热爱疯狂的科学!\\nStremio使用了以下开源技术:","WEBSITE_TECH_WCJS":"WebChimera.js允许Stremio以良好的性能播放任何视频格式。","WEBSITE_TECH_WCJS_EXTRA":"我们是项目的核心贡献者","WEBSITE_TECH_ELECTRON":"Electron为Stremio提供了一个创新平台。","WEBSITE_TECH_ELECTRON_EXTRA":"我们是项目贡献者","WEBSITE_TECH_LINVODB":"一种数据库技术,确保您的数据在任何地方登录都受管理和可用。","WEBSITE_TECH_LINVODB_EXTRA":"内部技术","WEBSITE_CREATE_ADDON":"创建您的插件","WEBSITE_CREATE_ADDON_DETAIL":"您有提供视频内容的服务吗?我们将通过创建插件来帮助您从Stremio的功能中获益。","WEBSITE_CREATE_ADDON_BENEFITS":"为Stremio创建插件的好处","WEBSITE_P2P_BEAUTY":"点对点流媒体之美","WEBSITE_P2P_1":"可靠且价格合理的全高清/4K视频点播或流媒体直播","WEBSITE_P2P_2":"提供良好用户体验的分销平台","WEBSITE_P2P_3":"我们将创建一个插件来满足您的确切需要","WEBSITE_P2P_CONTACT":"有兴趣吗?欢迎您通过联系我们.","WEBSITE_P2P_CONTACT_EXTRA":"我们很乐意帮助您将您的内容集成到Stremio!","WEBSITE_P2P":"偶然间出现了一种改变游戏名称的技术。 我们投入了大量的时间和精力来构建我们的点对点(P2P)视频流媒体引擎,该引擎可提供出色的性能和多功能性,以适应任何用例。\\n请联系我们以获取支持DRM的P2P视频点播或实时流媒体。","WEBSITE_THOUGHTS":"我们分享的想法:","WEBSITE_SPREAD":"传播关于Stremio的信息:","WEBSITE_CONTACT":"联系我们,我们很高兴收到您的来信!","WEBSITE_OPENSOURCE":"有关我们的开源项目,请转到:","WEBSITE_BITCOIN":"捐赠比特币:","WEBSITE_FAQ":"常见问题","WEBSITE_FAQ_SHORT":"常见问题","WEBSITE_QUESTIONS":"问题","WEBSITE_TOS":"使用条款","WEBSITE_LEGAL":"法律","WEBSITE_PAGE_ABOUT":"关于","WEBSITE_PAGE_BECOME_PARTNER":"成为合作伙伴","WEBSITE_ALL_YOU_CAN_WATCH":"自由观看\\n您想看的一切。","WEBSITE_FREEDOM_TO_STREAM":"自由串流","WEBSITE_WHAT_IS_STREMIO":"什么是Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio是一个一站式视频内容聚合中心。在您拥有的任何设备上发现,管理和观看来自各种来源的视频。","WEBSITE_WHAT_IS_STREMIO_P2":"电影、电视节目、剧集、电视直播或网络频道例如YouTube或Twitch.tv等,您可以在Stremio上找到所有这些内容。","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio是一个现代化的媒体中心,为您的视频娱乐提供一站式解决方案。您可以通过易于安装的插件发现,观看和整理视频内容。","WEBSITE_WHAT_IS_STREMIO_P2_V2":"电影、电视节目、直播电视或网络频道——在Stremio上找到所有这些。","WEBSITE_ENJOI_ON_ALL_DEVICES":"在所有媒体设备上享受","WEBSITE_DEVICES_COLLECT":"从Stremio收集","WEBSITE_DEVICES_IMPORT_FB":"从Facebook导入","WEBSITE_DEVICES_LOCAL":"从本地磁盘添加","WEBSITE_JOIN_THE_PARTY_NOW":"立即加入聚会","WEBSITE_DEVICES_ALL":"易于在所有设备上使用;","WEBSITE_EXTENDABLE_CATALOG":"可无限扩展的视频目录;","WEBSITE_ORGANIZE_YOUR_MEDIA":"强大的媒体管理功能;","WEBSITE_AS_SEEN_ON":"如图所示","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"关于我们","WEBSITE_LINK_TECHNOLOGY":"技术","WEBSITE_LINK_APPS":"应用程序","WEBSITE_LINK_DOWNLOADS":"下载","WEBSITE_MORE":"更多","WEBSITE_LINK_ADDONS":"插件","WEBSITE_LINK_ADDON_SDK":"插件SDK","WEBSITE_LINK_CONTRIBUTE":"贡献","WEBSITE_LINK_COMMUNITY":"社区","WEBSITE_LINK_BLOG":"博客","WEBSITE_MORE_MORE":"... & 更多","WEBSITE_LINK_HELP":"帮助中心","WEBSITE_LINK_CONTACTS":"业务查询","WEBSITE_LINK_TOS":"条款和条件","WEBSITE_LINK_PRAVACY":"隐私政策","WEBSITE_SUBSCRIBE":"订阅","WEBSITE_NEWSLETTER":"加入我们的实时通讯,了解精彩的内容","WEBSITE_PLACEHOLDER_EMAIL":"您的电子邮箱","WEBSITE_COMMUNITY":"社区","WEBSITE_LINK_PRAVACY_LEGAL":"隐私与法律","WEBSITE_WHY":"我们为什么这样做","WEBSITE_WHY_P1":"在Stremio,我们每天都工作,因为我们想解决视频点播行业的一个重要问题。每分钟都有这么多的新内容发布,几乎不可能找到解决的方法。","WEBSITE_WHY_P2":"我们帮助人们浏览这个巨大的视频娱乐世界,发现新的内容来享受。我们的应用程序汇集了电影、剧集、电视直播、网络频道等。我们致力于让用户非常容易地找到他们喜欢的标题和广播。","WEBSITE_WHY_P3":"您可以随时在任何设备上使用我们的服务,使Stremio成为您唯一需要的视频娱乐中心。","WEBSITE_TEAM":"团队","WEBSITE_TEAM_P":"Stremio团队虽小但很强大:我们10个人用X语言编写代码,分享软件开发、UI和UX设计、营销和广告、商业和初创企业方面的专业知识。","WEBSITE_FEATURES":"功能","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"轻松发现新内容","WEBSITE_FEATURES_DISCOVER_P":"轻松发现要观看的新电影、电视节目、剧集和频道。按类别、流派、评分、时间等浏览,或者只需键入一个名称即可找到。Stremio让寻找新的视频内容变得轻而易举。","WEBSITE_FEATURES_ALL_CONTENT":"一块屏幕显示所有视频内容","WEBSITE_FEATURES_ALL_CONTENT_P1":"查看您未看完的电影、剧集或视频,并继续观看;获得新剧集和版本的通知;浏览根据您的观看习惯获得的推荐。","WEBSITE_FEATURES_LIBRARY":"管理您的视频库","WEBSITE_FEATURES_LIBRARY_P1":"只需点击一下,即可将任何标题添加到您的Stremio库中,并按类型、时间或字母顺序整齐地排列内容。","WEBSITE_FEATURES_CALENDAR":"记录您所观看的一切","WEBSITE_FEATURES_CALENDAR_P1":"获取添加到库中的所有电影和系列的日历可视化。导出您的Stremio日历并同步它,这样您就可以随时知道新的一集或首映何时到来。","WEBSITE_FEATURES_BIG_SCREEN":"在大屏幕上欣赏您的视频内容","WEBSITE_FEATURES_BIG_SCREEN_P1":"将您正在观看的任何内容都投屏到另一台设备上,无论是手机、平板电脑还是电视,只需点击一下即可。","WEBSITE_FEATURES_SOURCES":"观看不同来源的视频","WEBSITE_FEATURES_SOURCES_P":"安装官方和社区插件,欣赏来自多个不同供应商的视频。","WEBSITE_CREATE_AN_ADDON":"创建插件","WEBSITE_FEATURES_SYNC":"跨设备同步库并恢复播放","WEBSITE_FEATURES_SYNC_P1":"使用您的帐户在所有设备上登录,享受同步的库、插件、播放和日历。","WEBSITE_FEATURES_EXTENDABLE":"通过插件扩展视频目录","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio插件目录提供了许多插件,可以从中安装和观看各种视频内容。这包括电影、节目、电视直播、体育、新闻、播客、网络频道、视频游戏等。","WEBSITE_FEATURES_AUTO_SUBS":"自动加载字幕","WEBSITE_FEATURES_AUTO_SUBS_P1":"通过我们的字幕插件,您可以自动选择您喜欢的语言。","WEBSITE_FEATURES_CHROMECAST":"投屏到Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"在更大的屏幕上欣赏您的视频内容,或者将您正在观看的内容投屏到其他设备上。","WEBSITE_FEATURES_KEEP_TRACK":"跟踪您最喜爱的电视节目和网络频道","WEBSITE_FEATURES_KEEP_TRACK_P1":"获取您最喜爱的剧集和网络频道的新一集的日历可视化和通知。","WEBSITE_FEATURES_POWER_USER":"超级用户功能","WEBSITE_FEATURES_POWER_USER_P1":"在外部播放器中播放","WEBSITE_FEATURES_POWER_USER_P2":"从Torrent文件或Magnet链接播放","WEBSITE_FEATURES_POWER_USER_P3":"从Facebook喜爱或本地磁盘导入您的库","WEBSITE_ADD_ONS":"插件","WEBSITE_ADD_ONS_P1":"Stremio提供的所有视频内容都是通过插件系统获取的,应用程序中没有内置任何内容或内容提供商。","WEBSITE_ADD_ONS_P2":"有两组插件可用:官方和社区插件。","WEBSITE_ADD_ONS_P3":"官方插件由Stremio开发和托管,而社区插件由我们的社区成员创建和托管。","WEBSITE_ADDONS_OFFICIAL":"官方插件","WEBSITE_ADDONS_WATCHUB":"从iTunes、Hulu、Amazon和其他英国/美国服务提供商处流式播放您喜爱的电影、剧集和节目。","WEBSITE_ADDONS_YOUTUBE":"观看您喜爱的YouTube频道,获得您关注的贡献者的新上传通知。","WEBSITE_ADDONS_FILMON":"免费观看直播电视、电影和社交电视。600个电视频道,45000部免费电影,纪录片以及更多","WEBSITE_ADDONS_OPENSUBTITLES":"多语种影视字幕,每天上传上千个翻译字幕。","WEBSITE_ADDONS_COMMUNITY":"社区插件","WEBSITE_ADDONS_FILMON_VOD":"观看来自Filmon.tv的点播视频。","WEBSITE_ADDONS_TWICH":"观看来自Twitch.tv(电子竞技行业的视频流媒体平台)的直播。","WEBSITE_ADDONS_VODO":"观看完全免费的独立电影。","WEBSITE_ADDONS_NETFLIX":"观看Netflix的电影和网剧。","WEBSITE_ADDONS_CREATE":"创建插件","WEBSITE_ADDONS_CREATE_P1":"如果您愿意,您可以开发自己的插件。通过这种方式,您可以让自己和我们的社区访问新的视频内容,并接触到全球数百万用户的新目标受众。","WEBSITE_ADDONS_START_CREATE":"要开始,请访问Stremio插件SDK页面:","WEBSITE_DOWNLOADS":"下载","WEBSITE_DOWNLOADS_P1":"为了获得最佳性能,我们建议您使用最新版本的Stremio应用程序。但是,如果出于某种原因,您想使用旧版本,可以在此处下载。","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS(限制版本)","WEBSITE_CONTRIBUTE":"贡献","WEBSITE_CONTRIBUTE_P1":"Stremio平台是开源的,您可以轻松地为当前没有来源的内容创建一个插件。","WEBSITE_CONTRIBUTE_WHY":"为什么要创建插件?","WEBSITE_CONTRIBUTE_WHY_P1":"为您的视频内容吸引新观众","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio的用户群体正在快速增长,在推出的第一年,Stremio在全球获得了100万用户,在该平台存在的第二年,这个数字增长到250万。","WEBSITE_CONTRIBUTE_WHY_P3":"用插件,您可以轻松接触这些观众并向他们分发您的视频内容。","WEBSITE_CONTRIBUTE_ALL":"在一处观看您喜爱的电影、视频、剧集和频道。","WEBSITE_CONTRIBUTE_ALL_P1":"您是Stremio上尚未提供的特定类型内容的粉丝?为它创建一个插件,在市场上最大、最易使用的娱乐中心之一欣赏您喜爱的视频。","WEBSITE_CONTRIBUTE_ALL_P2":"除此之外,您还会得到其他志同道合的Stremio社区成员的无尽感激。","WEBSITE_CONTRIBUTE_MONETIZE":"通过插件营利,并在其帮助下赚钱","WEBSITE_CONTRIBUTE_MONETIZE_P1":"一旦您为Stremio开发了一个新的插件,您就可以通过多种不同的方式轻松地靠其营利。如果您正在考虑此问题,请随时与我们联系","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":",我们很乐意就插件营利选项向您提供咨询和建议。","WEBSITE_CONTRIBUTE_TRANSLATE":"成为一名志愿翻译者","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"如果您想享受不同语言的Stremio应用程序,您可以加入我们的志愿翻译者社区。他们帮助我们添加多种不同语言的Stremio版本。","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"您想开始吗?","WEBSITE_TRANSALTE_STREMIO":"翻译Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"官方社区","WEBSITE_COMMUNITY_OFFICIALS_P1":"成为不断增长的Stremio社区的一部分。在社交媒体上关注我们,不要害羞地打招呼,我们喜欢听到粉丝的声音!","WEBSITE_COMMUNITY_UNOFFICIALS":"非官方社区","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"合作伙伴和支持者","WEBSITE_COMMUNITY_GOODIES":"Stremio特典","WEBSITE_COMMUNITY_WALLPAPERS":"壁纸","WEBSITE_COMMUNITY_ART":"社区艺术画廊","WEBSITE_LINK_ART":"社区艺术画廊","WEBSITE_CONTACT_US":"联系我们","WEBSITE_CONTACT_US_P1":"如果您有任何问题、意见或建议,请随时通过下面的联系方式与我们联系。","WEBSITE_CONTACT_US_P2":"请记住,我们位于保加利亚,因此可能会由于时区差异而延迟处理您的问题。","WEBSITE_CONTACT_US_SUCCESS":"您的信息已发送。我们会在方便的时候尽快给您回复。","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"请输入有效的电子邮箱!","WEBSITE_CONTACT_US_Q_RELATED_TO":"您的问题与什么有关?","WEBSITE_CONTACT_US_Q_OS":"您的操作系统是什么?","WEBSITE_CONTACT_US_PH_EMAIL":"您的电子邮箱","WEBSITE_CONTACT_US_PH_MESSAGE":"短信","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"发送","WEBSITE_CONTACT_US_Q_1":"如何安装?","WEBSITE_CONTACT_US_Q_2":"如何卸载?","WEBSITE_CONTACT_US_Q_3":"(HTML)如何制作千层面?","WEBSITE_CONTACT_US_Q_4":"插件","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"技术","WEBSITE_TECHNOLOGY_P1":"我们热爱科技,热爱科学。
这是Stremio的动力(它都是开源的)。","WEBSITE_TECHNOLOGY_P_QT":"最佳跨平台软件开发工具。","WEBSITE_TECHNOLOGY_P_MPV":"一款免费、开源、跨平台的媒体播放器。","WEBSITE_TECHNOLOGY_P_RN":"React Native允许您仅使用JavaScript构建移动应用程序。","WEBSITE_TECHNOLOGY_P_VLC":"嵌入到应用程序中获取多媒体的媒体框架。","WEBSITE_TECHNOLOGY_P_REALM":"Realm是一个移动平台,是SQLite和Core Data的替代品。","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js是一个开源、跨平台的JavaScript运行环境。","WEBSITE_TECHNOLOGY_P_RUST":"Rust是一种多范式系统编程语言,关注安全性,尤其是安全并发性。","WEBSITE_TECHNOLOGY_CONTRIBUTE":"为项目贡献力量","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"您可以通过两种方式为Stremio做贡献,帮助我们将产品做得更好。","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"您可以通过翻译平台来贡献您宝贵的语言技能...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"或","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... 您可以利用您的编程技巧来创建社区插件。","WEBSITE_TRANSLATE_STREMIO":"翻译Stremio","WEBSITE_404_OH_NO":"糟糕!您要找的页面不在这里...","WEBSITE_GO_HOME":"回到主页","WEBSITE_LINK_OTHER_DOWNLOADS":"其他下载","WEBSITE_FAQ_ABR":"常见问题","WEBSITE_SUPPORT":"支持","WEBSITE_DOWNLOAD_4_0_BETA":"立即下载Stremio 4测试版","WEBSITE_GET_FOR_DESKTOP":"获取桌面","WEBSITE_LINK_ADDON_COMPETITION":"插件比赛","WEBSITE_LINK_ART_CONTEST":"艺术比赛","WEBSITE_MY_ACCOUNT":"我的账户","WEBSITE_MAINPAGE_FAQ_001_H1":"什么是Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio是一个现代化的媒体中心,让您可以自由观看任何您想要的东西。","WEBSITE_MAINPAGE_FAQ_002_H1":"它是如何工作的?","WEBSITE_MAINPAGE_FAQ_002_P1":"一旦您在设备上安装了Stremio并创建了一个帐户,您所要做的就是访问插件目录并安装任何您想要的插件,就可以开始了!","WEBSITE_MAINPAGE_FAQ_002_P2":"之后,您可以进入“发现”或“板”部分,开始探索内容。","WEBSITE_MAINPAGE_FAQ_003_H1":"我可以在这里看什么?","WEBSITE_MAINPAGE_FAQ_003_P1":"很多:电影、电视节目、网络频道、体育、电视频道、收听播客等等。感谢我们的插件系统,您可以访问各种内容。","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio是开源的吗?","WEBSITE_MAINPAGE_FAQ_004_P1":"是的,您可以查看以下链接:${1}桌面应用${2}和${3}GitHub组织${4}。","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio安全吗?","WEBSITE_MAINPAGE_FAQ_005_P1":"是:因为它是开源软件,所以代码可以公开审核,您可以自己查看。","WEBSITE_MAINPAGE_FAQ_006_H1":"我的隐私如何?","WEBSITE_MAINPAGE_FAQ_006_P1":"我们尊重用户隐私,除了创建和同步您的帐户所必需的最低限度外,不收集任何个人数据。","WEBSITE_MAINPAGE_FAQ_006_P2":"注册时还有一个${1}访客模式${2},它不需要任何数据:在这种模式下,不会调用我们的后端。然而,这是以牺牲有用的功能为代价的,比如能够跨设备同步您的库。","WEBSITE_MAINPAGE_FAQ_007_H1":"我可以投屏到电视吗?","WEBSITE_MAINPAGE_FAQ_007_P1":"是的,我们支持Chromecast,您可以从桌面和移动应用程序(Android)进行强制转换。","WEBSITE_MAINPAGE_FAQ_008_H1":"Stremio有多少插件?","WEBSITE_MAINPAGE_FAQ_008_P1":"截至2019年末,超过50个。有关更多信息,请查看我们的插件目录。","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio是否可以扩展到插件目录之外?","WEBSITE_MAINPAGE_FAQ_009_P1":"是的,您应该查看这些:${1}PimpMyStremio${2},${3}Reddit communities${4},${5}Stremio Downloader${6},等等。","WEBSITE_MAINPAGE_FAQ_010_H1":"Stremio支持哪些设备?","WEBSITE_MAINPAGE_FAQ_010_P1":"我们有适用于Windows、Mac和Linux的桌面应用程序。对于移动设备,我们支持Android和iOS,但请记住iOS的功能有限(不支持大多数插件)。","WEBSITE_MAINPAGE_FAQ_010_P2":"有很多基于Android的设备可以在上面运行Stremio,比如NVIDIA Shield和Amazon Fire Stick,但我们并不正式支持它们。","WEBSITE_MAINPAGE_FAQ_011_H1":"您们能为Stremio添加某些内容吗?","WEBSITE_MAINPAGE_FAQ_011_P1":"抱歉,我们本身不提供任何内容,但是您安装的Stremio插件越多,您可以找到的内容就越多。","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio可以播放Magnet链接吗?","WEBSITE_MAINPAGE_FAQ_012_P1":"是的,它还可以播放正常的HTTP链接和Torrent文件(拖放)。","WEBSITE_MAINPAGE_FAQ_013_H1":"我可以下载视频并离线观看吗?","WEBSITE_MAINPAGE_FAQ_013_P1":"离线可用是一项即将推出的功能,但如果您允许Stremio在设备上缓存(从“设置”面板),您可以稍后在没有连接的情况下观看视频。","WEBSITE_MAINPAGE_FAQ_014_H1":"什么都不能用,帮帮我!","WEBSITE_MAINPAGE_FAQ_014_P1":"您确定已安装插件吗?如果是,请与我们的${1}帮助中心${2}联系","WEBSITE_MAINPAGE_FAQ_015_H1":"Stremio如何维持其开发运营?","WEBSITE_MAINPAGE_FAQ_015_P1":"我们通过${1}AdEx${2}运行非侵入性广告,这是一家由同一创始团队创建的公司,专注于隐私保护、透明广告。","WEBSITE_MAINPAGE_FAQ_015_P2":"有关更多问题,请访问我们的${1}帮助中心${2}。","HELP_LEARN_MORE":"帮助我们了解更多有关您的信息。","LIFESTYLE":"生活方式","SPORTS":"体育","FOOD_HEALTH":"饮食与健康","BEAUTY_FASHION":"美丽与时尚","NEWS":"新闻","GAMING":"游戏","SCIENCE_EDUCATION":"科学与教育","MUSIC":"音乐","TRAVEL":"旅行","LATE_NIGHT":"深夜","REALITY":"真人","COMEDY":"喜剧","DIY":"DIY","TECH":"技术","CINEMA":"影院","CONTINUE":"继续","SLOW_LOADING":"加载缓慢?","I_GIVE_UP":"我放弃了","LEARN_MORE":"了解更多","POOR_SOURCE":"此源不可用或您的网络连接不够快","PICK_CATEGORIES_ERR":"您必须至少选择3个类别","ADJUST_TIMING":"调整时间","ADJUST_SIZE":"调整大小","SEARCH_ANYTHING":"您可以搜索一切...","ALL_CATEGORIES":"全部","SEARCH_CATEGORIES":"电影、剧集、YouTube和电视","SEARCH_PERSONS":"演员、导演和编剧","SEARCH_PROTOCOLS":"HTTP或Magnet链接","SEARCH_TYPES":"IMDB/TVDB链接","WATCHED":"已观看","SHOW_LESS":"显示较少","LAST_SEARCHES":"上次搜索","CLEAR_HISTORY":"清除历史记录","CHOOSE_SOME":"选择其中一些:","NO_WEB_REMOTE":"无法加载Web Remote","STREMIO_OFFLINE":"Stremio离线","STREMIO_EXPENSIVE_CONNECTION":"我们检测到您正在使用移动数据连接,是否继续?","USE_DATA":"使用移动数据","WARNING":"警告","MORE_INFO":"更多信息...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"加载...","STREMIO_TV_BACK_TO_LANGUAGES":"返回语言","STREMIO_TV_REMOTE":"远程","STREMIO_TV_GO_TO":"去往:","STREMIO_TV_OR_SCAN":"或扫描:","STREMIO_TV_ADDON_INSTRUCTIONS":"请按照说明安装您喜欢的插件。","STREMIO_TV_LIVE_TV":"直播电视","STREMIO_TV_RESUME_WATCHING":"继续观看","STREMIO_TV_LOADING_BACKGROUND":"加载背景","STREMIO_TV_CHECKING_AUTHENTICATION":"正在检测身份验证","STREMIO_TV_LOADING_BOARD":"加载主页","STREMIO_TV_LOGIN_HEADER_LINE_1":"我们希望用户在使用我们的软件时有最好的个性化体验,","STREMIO_TV_LOGIN_HEADER_LINE_2":"正是出于这个原因,我们恳请您建立和/或登录您的账户,","STREMIO_TV_LOGIN_FOOTER_LINE_1":"感谢您的理解,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio团队","STREMIO_TV_REMOTE_INSTRUCTIONS":"为了在您的智能手机/平板电脑/桌面使用Web Remote:","STREMIO_TV_WIFI_SETUP":"Wi-Fi设置","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle未检测到互联网连接。","STREMIO_TV_WIFI_DETAILS_1":"连接到:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"使用密码:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"在浏览器中打开链接:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"默认","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"按最近观看","STREMIO_TV_LIBRARY_SORT_NAME":"按名字","STREMIO_TV_LIBRARY_TIMES_WATCHED":"按观看次数","STREMIO_TV_DETAILS_SEASON_NUMBER":"季${1}","STREMIO_TV_STREAMS_LOADING":"已加载${1}/${2}插件...","STREMIO_TV_STREAMS_STILL_LOADING":"${1}插件仍在加载...","STREMIO_TV_PLAYER_SETTINGS":"播放器设置","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"字幕延迟","STREMIO_TV_PLAYER_AUDIO_DELAY":"音频延迟","STREMIO_TV_PLAYER_VIDEO_SCALING":"视频缩放","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"不支持的流媒体源","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"打开外部链接失败","STREMIO_TV_PLAYER_PLAY_IN_EXO":"使用ExoPlayer播放","STREMIO_TV_PLAYER_PLAY_IN_VLC":"使用libVLC player播放","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"由于播放错误而切换到libVLC player","STREMIO_TV_ADDONS_TITLE":"在手机或PC上使用Stremio安装或配置插件,然后按\\"同步插件\\"","STREMIO_TV_ADDONS_SUBTITLE":"注意:确保您使用的是相同的Stremio帐户","STREMIO_TV_ADDONS_SYNC_ADDONS":"同步插件","STREMIO_TV_ADDONS_SYNC_SUCCESS":"插件成功同步","STREMIO_TV_ADDONS_SYNC_FAILED":"插件同步失败","STREMIO_TV_META_LINK_FAILED":"打开元链接失败","STREMIO_TV_CATALOG_LOADING":"目录仍在加载...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"界面语言已更新","STREMIO_TV_SETTINGS_THEME_UPDATED":"主题已更新","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"首选语言","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"次要首选语言","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"隧道播放","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"某些设备上可能存在播放问题","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"某些视频格式可能无法播放","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"自动帧速率匹配","STREMIO_TV_SETTINGS_NO_CACHING":"无缓存","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"默认","STREMIO_TV_SETTINGS_PROFILE_SOFT":"慢","STREMIO_TV_SETTINGS_PROFILE_FAST":"快","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"超快","STREMIO_TV_SETTINGS_SERVER_URL":"流媒体服务器URL","STREMIO_TV_SETTINGS_SERVER_VERSION":"服务器版本","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"未知","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio版本","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"编辑服务器URL","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"输入流媒体服务器URL","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"要阅读Stremio的隐私政策,请访问:","STREMIO_TV_SETTINGS_TOS_TEXT":"要阅读Stremio的条款和条件,请访问:","STREMIO_TV_NAV_SEARCH":"搜索","STREMIO_TV_NAV_HOME":"主页","STREMIO_TV_NAV_DISCOVER":"发现","STREMIO_TV_NAV_LIBRARY":"库","STREMIO_TV_NAV_MOVIES":"电影","STREMIO_TV_NAV_SERIES":"剧集","STREMIO_TV_NAV_CHANNELS":"频道","STREMIO_TV_NAV_TV":"电视直播","STREMIO_TV_NAV_SETTINGS":"设置","STREMIO_TV_NAV_ADDONS":"插件","STREMIO_TV_LOGIN_TITLE":"链接账户","STREMIO_TV_LOGIN_EXPIRES_IN":"过期日期到","STREMIO_TV_LOGIN_STEP_ONE":"扫描上方的二维码或转到","STREMIO_TV_LOGIN_STEP_TWO":"登录您的Stremio帐户","STREMIO_TV_LOGIN_NEW_LINK":"请求新链接","STREMIO_TV_LOGIN_LINK_REFRESHED":"登录代码已刷新","STREMIO_TV_SEARCH_PLACEHOLDER":"输入一些东西","STREMIO_TV_SEARCH_NO_ADDONS":"没有为目录请求插件!","STREMIO_TV_SEARCH_BUTTON":"搜索","STREMIO_TV_SEARCH_KEY_DEL":"删除","STREMIO_TV_SEARCH_KEY_SPACE":"空格","STREMIO_TV_SEARCH_KEY_CLEAR":"清除","STREMIO_TV_SEARCH_HISTORY_TITLE":"搜索历史","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"您可以搜索标题、演员、频道...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"清除搜索历史","STREMIO_TV_FILTERS_DESCRIPTION":"从以下过滤器中选择一个","FILTERS":"过滤器","SETTINGS":"设置","ACCOUNT":"账户","LOGOUT":"注销","THEMES":"主题","PLAYBACK":"播放","PLAYBACK_SPEED":"播放速度","AUDIO_TRACKS":"音轨","VIDEOS":"视频","SERVER":"服务器","LINKS":"链接","ABOUT":"关于","INTERFACE":"界面","ANIMATIONS":"动画","STATUS":"状态","LANGUAGE":"语言","SIZE":"大小","DELAY":"延迟","BOLD":"粗体","TEXT_COLOR":"文本颜色","OUTLINE_COLOR":"轮廓颜色","BACKGROUND_COLOR":"背景颜色","BACKGROUND_BLUR":"背景模糊","SEEK_TIME_DURATION":"寻找持续时间","AUTO_PLAY":"自动播放下一集","PLAY_NOW":"现在播放","MARK_AS_WATCHED":"标记为已观看","MARK_AS_UNWATCHED":"标记为未观看","REWIND_TO_BEGINNING":"倒回开始","CONTINUE_WATCHING":"继续观看","ALL":"全部","SECONDS":"秒","ON":"开","OFF":"关","RELOAD":"重新加载","EDIT_URL":"编辑URL","NONE":"无","EMBEDDED":"内嵌","REMOTE_SWITCH_DEVICES":"开关设备","REMOTE_VIDEOS":"视频","REMOTE_ADJUST_TIMING":"调整时间","REMOTE_ADJUST_SIZE":"调整大小","REMOTE_COULD_NOT_BE_LOADED":"无法加载Web Remote","REMOTE_RETRY":"重试","TORRENT_PROFILE_DEFAULT":"默认","TORRENT_PROFILE_SOFT":"慢","TORRENT_PROFILE_FAST":"快","TORRENT_PROFILE_ULTRA_FAST":"超快","FAQ_001_H1":"什么是Stremio?","FAQ_001_P1":"Stremio是专为视频娱乐而设计的多媒体中心软件,易于使用。Stremio允许您管理和观看自己的电影,剧集,频道和实况电视收藏。","FAQ_001_P2":"Stremio从本地磁盘和插件系统中收集显示给您的内容。","FAQ_001_P3":"它还会在您感兴趣的新剧集/视频/电影播出时通知您,并为您提供电影推荐。","FAQ_02_H1":"Stremio与Kodi和Plex相比如何?","FAQ_02_P1":"我们受到这两种软件的启发。但是我们有不同的目标——Stremio专门针对娱乐视频,并通过易于使用成为其主流解决方案。","FAQ_02_P2":"Stremio将永远不会像Kodi和Plex那样具有可定制性和丰富的功能,但它更易于使用。只需${1}就可以获取它,并查看${2}:)","FAQ_03_H1":"Stremio与Netflix相比如何?","FAQ_03_P1":"同样,Netflix是我们的灵感之一。我们努力实现Netflix的用户体验,再加上许多附加的好处。但最重要的是,我们让您可以自由管理自己的库,并使用我们的插件系统添加新的内容源。","FAQ_03_P2":"这使得Stremio可以无限扩展,因此当您使用Stremio时,您永远不会局限于Netflix决定许可的内容。例如,您可以通过Stremio观看${1}中的内容电影电视${2}, ${3} Twitch.tv${4},${5}YouTube${6},${7}Vodo${8}甚至${9}Netflix${10}本身!","FAQ_04_H1":"Stremio与Flipboard相比如何?","FAQ_04_P1":"我们不常听到这个问题,除非与初创企业的人交谈:)","FAQ_04_P2":"Stremio是通过设计一个内容聚合器来实现的,它本质上就是视频的Flipboard。这一点在我们的首页部分非常明显,它为您提供目录和新的插曲/新的视频通知,让您了解您所关注的内容,就像Flipboard一样。","FAQ_05_H1":"Stremio与Popcorn Time相比如何?","FAQ_05_P1":"Stremio和Popcorn Time在用户界面上很相似,因为没有很多方法可以正确制作视频娱乐目录:)","FAQ_05_P2":"Popcorn Time主要集中在特定来源的流媒体上,但Stremio是不受限制的,只是一个内容聚合器,它没有锁定到特定的内容源。","FAQ_05_P3":"此外,我们默认不提供任何Torrent插件,因此Stremio不提供官方功能的Popcorn Time用例。","FAQ_05_P4":"另一个显著的区别是Popcorn Time是完全开源的,而Stremio是${1}部分开源的${2}。","FAQ_06_H1":"是否要添加此电影/系列?","FAQ_06_P1":"不,对不起 :(","FAQ_06_P2":"正如大多数其他问题中提到的,Stremio本身不提供任何内容,所有内容都是通过插件系统添加的。如果您有内容请求,您可以使用播放器中的“报告”按钮,它将向您当前使用的插件的作者发送电子邮件。","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"能否为X创建插件?","FAQ_08_P1":"完全有可能。","FAQ_08_P2":"如果您有一个插件的想法,请在${1}office@stremio.com${2}给我们留言,但请确保您的插件想法不会侵犯任何版权或使用条款。","FAQ_08_P3":"目前,我们路线图上的下一件事是FandangoNOW,Filmon.tv video on demand和Crunchyroll的插件。","FAQ_09_H1":"Stremio是否使用BitTorrent?","FAQ_09_P1":"是的,Stremio支持BitTorrent作为流媒体协议。您可以将其与Torrent插件一起使用,也可以将.Torrent文件拖放到Stremio中,或者将磁铁链接粘贴到搜索栏中。","FAQ_09_P2":"请注意,使用BitTorrent的唯一官方插件是${1}Vodo${2},它提供独立内容,所有内容都允许与BitTorrent一起分发。","FAQ_09_P3":"我们不支持使用任何可能导致版权侵权的第三方插件。","FAQ_10_H1":"我可以在Stremio中通过官方插件观看什么节目?","FAQ_10_P1":"默认情况下,您可以在Stremio与它的嵌入式播放器观看Filmon.tv,YouTube和Vodo的内容。另外,我们还有一个Twitch.tv插件,以及其他一些插件。","FAQ_10_P2":"此组合提供以下选项:","FAQ_10_L1":"Filmon.tv上的热门电视频道,例如E4、BBC、Bollyworld TV","FAQ_10_L2":"YouTube上的所有内容,例如BBC News、Top Gear、Vevo、PewDiePie","FAQ_10_L3":"Vodo上的独立电影","FAQ_10_L4":"Twitch.tv上的在线游戏广播","FAQ_10_P3":"此外,Guidebox和Netflix插件提供了许多内容源,它们不完全在Stremio中播放,而是重定向到给定的服务。例如,Guidebox插件将为您提供可在美国免费播放的精选电影,这些电影来自TubiTV和Crackle等服务。","FAQ_11_H1":"Stremio无法安装,我该怎么办?","FAQ_11_P1":"如果您在Windows上,请尝试${1}此替代安装程序${2}。","FAQ_11_P2":"如果您使用的是Mac OS X,请注意,我们不支持任何比OS X Mavericks(10.9)更旧的版本。","FAQ_11_P3":"如果您使用的是Linux,请注意,我们目前只支持64位(x64)Linux。","FAQ_11_P4":"如果您仍然无法解决您的问题,请写信给我们的${1}Facebook群组${2}。","FAQ_12_H1":"为什么我的杀毒软件会报毒?Stremio安全吗?","FAQ_12_P1":"我们向您保证Stremio是${1}100%安全的${2}。","FAQ_12_P2":"您的杀毒软件报毒是因为我们的安装程序中包含广告,一些杀毒软件将其识别为广告软件。","FAQ_12_P3":"如果您仍然不确定,可以尝试我们的${1}替代安装程序${2}。","FAQ_13_H1":"如何制作插件?","FAQ_13_P1":"对于初学者,我们建议您查看GitHub上的${1}插件系统模块${2}。","FAQ_13_P2":"之后,您可以按照${1}Hello World教程${2}进行操作。","FAQ_13_P3":"如果您没有任何编程技能,请在${1}Reddit社区${2}上发布您的想法,并在${3}office@stremio.com${4}上与我们联系您的插件想法。","FAQ_14_H1":"插件是如何发布的?","FAQ_14_P1":"当您创建一个插件和主机,并在清单中放置一个指向工作插件地址的终端节点字段时,该插件将自动发布到我们的${1}插件目录${2}。","FAQ_14_P2":"发生这种情况是因为Stremio插件模块的服务器部分会自动调用我们的API来声明插件。当我们的API验证您的终端节点为有效的插件时,它将开始显示在目录中。","FAQ_15_H1":"我可以在浏览器中运行Stremio吗?","FAQ_15_P1":"目前还没有,但即将到来!","FAQ_15_P2":"如果您想看到Alpha版本,可以在这里看到:${1}alpha4.strem.io${2}. 请记住,此Alpha版本上已禁用流式处理。我们支持Chrome、Firefox、Opera和Edge","FAQ_16_H1":"电视投屏不起作用/字幕不起作用","FAQ_16_P1":"电视投屏使用DLNA技术,这在不同的电视品牌和型号之间非常不一致。由于这个原因,我们没有能力在每种情况下都测试它,所以它还远远不够完美。尽管如此,我们仍在不断改进,但我们无法为您提供DLNA能够在您的电视上开始正常工作的预计时间。","FAQ_16_P2":"如果您在“投屏”菜单中看不到您的电视,请尝试禁用网络连接并重新启用它(在Windows上,右键单击网络并使用“启用/禁用”),以及重新启动路由器、电视和PC。","FAQ_16_P3":"如果您仍然遇到问题,您可以通过将您的电视品牌和型号信息发送到${1}来帮助我们”office@stremio.com${2}。","FAQ_16_P4":"同时,我们推荐Chromecast,我们非常支持Chromecast,或者直接用HDMI线将电视与PC连接。","FAQ_17_H1":"Stremio卡死和/或崩溃,我能做什么?","FAQ_17_P1":"首先,如果您使用的是带有AVG杀毒软件的Windows 7,这种组合会产生问题。问题出在AVG本身,我们这边没有合理的办法解决。不幸的是,去除或禁用杀毒软件将不起作用。唯一的解决办法是用别的东西代替AVG","FAQ_17_P2":"如果不是这个问题,但您仍在使用Windows,请更新到最新的service pack并更新/重新安装您的GPU驱动程序,然后重试。","FAQ_17_P3":"如果您的问题仍未解决,或者您使用的是Mac或Linux,请写信给我们,在${1}我们的Facebook群组${2}报告问题的确切细节。","FAQ_18_H1":"如何制作插件?","FAQ_18_P1":"对于初学者,我们建议您查看GitHub上的${1}插件系统模块${2}。","FAQ_18_P2":"之后,您可以按照${1}Hello World教程${2}进行操作。","FAQ_18_P3":"如果您没有任何编程技能,请在${1}Reddit社区${2}上发布您的想法,并在${3}上与我们联系您的插件想法。”office@stremio.com${4}。","FAQ_19_H1":"为什么Stremio占用磁盘空间?","FAQ_19_P1":"Stremio有一个本地缓存来临时保存您流式传输的视频文件。","FAQ_19_P2":"这有两个好处:第一,它允许Stremio预先缓冲视频,以确保流媒体更流畅。其次,它将视频保存在本地缓存中,以便您可以继续离线观看。","FAQ_19_P3":"Stremio保留了多少取决于“设置”面板中的缓存设置。Stremio可能会在您的磁盘上保留到设置的数量(例如2GB),除非当前流式传输的视频大于该数量,在这种情况下,必须分配足够的存储来保留它,直到您结束流式传输。","FAQ_20_H1":"缓存文件夹在哪里?","FAQ_20_P1":"在Windows上,Stremio缓存位于您在设置中选择的驱动器中(例如\\"E:\\\\stremio-cache\\")","FAQ_20_P2":"在MacOS上,它位于\\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"在Linux上,它位于\\"~/.stremio/stremio-cache\\"或\\"~/stremio-cache\\"","FAQ_21_H1":"我得到\\"流媒体服务器未找到\\"错误,我能做什么?","FAQ_21_P1":"如果出现此错误,则表示以下几点之一:","FAQ_21_P2":"1)您正试图通过我们的${1}web版本${2}使用一个由YouTube/BitTorrent源代码支持的插件。在这种情况下,您应该从${3}我们的网站${4}安装我们的桌面版本","FAQ_21_P3":"2)Stremio安装有问题。在这种情况下,请尝试从${1}网站${2}重新安装我们的最新桌面版本。如果这没有帮助,请尝试禁用杀毒软件和防火墙,重新启动电脑,然后重试。如果这依然不起作用,请写信给我们的${3}Facebook群组${4}","FAQ_22_H1":"我无法在iOS上看到/使用大多数插件","FAQ_22_P1":"由于Apple App Store条款和条件中的限制,我们限制iOS应用程序只能使用一组特定的插件。","FAQ_22_P2":"不过,请放心,将来会有更多的iOS插件,我们还可能添加一个集成,通过将iOS应用程序连接到Stremio流媒体服务器,您将可以使用所有Stremio插件。"}')},9542:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"電影","TYPE_series":"劇集","TYPE_tv":"電視頻道","TYPE_channel":"頻道","TYPE_other":"其他","TYPE_movie_PL":"電影","TYPE_series_PL":"劇集","TYPE_tv_PL":"電視頻道","TYPE_channel_PL":"頻道","TYPE_other_PL":"其他","TYPE_ALL":"All","VIDEO":"視頻","BACK":"返回","MORE":"更多","DONE":"完成","COPY":"複製","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"發現","Board":"首頁","Library":"庫","My Library":"我的庫","Calendar":"日曆","NOTIFICATION_ONLINE":"您當前處於在線狀態","NOTIFICATION_OFFLINE":"您當前處於離線狀態","INTERNET_CONNECTION":"網絡連接","STORAGE_FULL_TITLE":"警吿:儲存空間已滿!","STORAGE_FULL_TEXT":"Stremio將無法保存您的設置、首選項或登錄信息,考慮重新啟動或重新安裝Stremio。","SEARCH":"搜索","SEARCH_NO_RESULTS":"未找到結果","SEARCH_EXPLANATION_CONTENT":"搜索電影、劇集、YouTube和電視頻道","SEARCH_EXPLANATION_PEOPLE":"搜索演員、導演和編劇","SEARCH_PASTE_LINKS":"粘貼HTTP和Magnet鏈接","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"添加到庫中","REMOVE_FROM_LIB":"從庫中刪除","ADDED_TO_LIB":"添加到庫中","REMOVED_FROM_LIB":"從庫中刪除","TRAILER":"預吿片","WATCH_TRAILER":"觀看預吿片","WATCH_NOW":"立即觀看","SHOW":"查看","SHOW_MOVIE":"查看電影","WATCH_RANDOM":"隨機觀看","IMDB_RATING":"IMDb評分","YEAR":"年份","DIRECTOR":"導演","WRITER":"編劇","LEAD_ACTORS":"主演","CAST":"全部演員","CREW":"全部工作人員","SHOW_MORE_CAST":"顯示更多 »","AIRED":"播出時間","SEASONS":"季","GENRE":"類型","CATALOG":"目錄","SUMMARY":"簡介","SHOW_MORE":"顯示更多","SIMILAR":"相似","UPCOMING":"即將上映","ENDED":"已完結","DURATION":"時長","FEATURED":"功能","METADATA":"元數據","CATEGORY":"類別","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"搜索視頻","SEARCH_PLACEHOLDER":"搜索或粘貼URL","ADDON":"插件","ADDONS":"插件","OFFICIAL":"官方","ADDONS_OFFICIAL":"官方Stremio插件","ADDONS_POPULAR":"在您所在的地區很受歡迎","ADDON_FREE":"免費","ADDON_PEERED":"連接","ADDON_SUBSCRIPTION":"訂閲","ADDON_STREAM_GEORESTRICTED":"在您所在的地區不提供","ADDON_STREAM_OFFLINECACHE":"離線緩存","ADDON_STREAM_LOCALFILE":"本地文件","SHARE_ADDON":"分享插件","AVAILABLE_STREAMS":"可用流媒體","NO_STREAM":"未找到流媒體","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"要獲取更多流媒體,請安裝更多插件","STREAM_NOT_SUPPORTED":"此平台不支持所選流媒體。","ADDON_CATALOGUE":"顯示所有插件 »","ADDON_CATALOGUE_MORE":"安裝插件","REPO_ADDED":"已添加存儲庫","ADDON_REPO_EXIST_ERR":"此插件集合已存在","ADDON_REPO_ERR":"添加集合時出錯","ADDON_ADD_ERR":"添加插件時出錯","ERR_ADDON_PROTECTED":"無法卸載插件,它受到保護","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"出了一些問題——身份驗證可能失敗","ERR_NOT_COLLECTION_URL":"不是集合URL","ERR_NOT_ADDON_URL":"不是有效的插件URL","ERR_DETECTFROMURL":"再此URL中找不到插件/集合","ADDON_DUPLICATE_WARNING":"警吿:重複的插件","ADDON_COLLECTION_SET_FAILED":"將已安裝的插件同步到您的賬户失敗","SETTINGS_DATA_EXPORT":"導出用户數據","ADDON_PULL_FAILED":"從您的帳户同步已安裝的插件失敗","REFRESH_ON_CLICK":"點擊重試","STILL_IN_THEATER":"電影還在影院上映","WATCH_IN_CINEMA":"請到您本地的影院觀看","IN_THEATER":"在影院上映","GET_TICKETS":"購票","UPCOMING_EPISODE":"下一集","UPCOMING_EPISODE_MESSAGE":"這一集即將播出","MISSING_DATE_EPISODE":"缺失的一集日期","MISSING_DATE_EPISODE_MESSAGE":"這一集可能還沒有播出","CHANNEL_NOT_SCRAPED":"這個頻道還沒有被削刮,請過幾分鐘再來。","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"將其添加到庫中,以便在可用時收到通知。","GET_NOTIFIED_WHEN_AVAILABLE":"一旦可用,您將會收到通知。","WARNING_STREAMING_SERVER":"警吿:找不到本地流媒體服務器,來自本地文件、YouTube、和BitTorrent的流媒體將不可用。","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"警吿:您的硬件可能不支持此視頻,請記住,播放可能會很慢。","PLAYER_ERROR":"糟糕,播放器錯誤","PLAYER_ERROR_LOOKSLIKE":"看起來似乎","PLAYER_ORIENTATION":"播放器方向","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"鎖定","PLAYER_ORIENTATION_SENSOR_SHORT":"傳感器","PLAYER_ORIENTATION_LANDSCAPE":"播放器方向鎖定橫向","PLAYER_ORIENTATION_SENSOR":"播放器方向自動(傳感器)","PLAYER_PLAYBACK_SPEED":"播放速度","PLAYER_PLAYBACK_ERROR":"播放錯誤,請重試","PLAYER_PLAYBACK_ERROR_UNKNOWN":"未知錯誤","PLAYER_PLAYBACK_ERROR_DEFAULT":"抱歉,{{productName}}無法播放此視頻。","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"直播","PLAYER_NEXT_VIDEO_TITLE":"下個視頻","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"關閉","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"現在觀看","STREAMING_FROM":"流媒體","CASTING_TO":"投屏到","NETWORK_STATUS":"網絡狀態","STREAM_SPEED":"串流速度:","STREAM_BUFFERED":"已緩衝:","PEERS_INFO":"節點信息","PEERS_ACTIVE":"活躍:","PEERS_CONNECTED":"已連接:","PEERS_WAITING":"等待:","TRANSCODING_WARNING":"警吿:轉碼視頻。","STREAM_LOADING":"加載...","PLAYING_LOCAL":"從本地文件播放","PLAYING_CACHE":"從緩存播放","WRONG_SUBS":"字幕錯誤?","ERR_SUBS_LOADING_TITLE":"加載字幕時出錯","ERR_SUBS_LOADING":"字幕加載失敗:這可能是您正在使用的插件或網絡連接的問題","WARN_FOLLOWING_SUB_ADDONS_FAILED":"以下字幕插件失敗","ERR_CASTING_UPDATE_TITLE":"無法更新投屏設備信息:流媒體服務器可能離線","CHOOSE_DEVICE":"選擇在哪個設備上播放","NO_CAST_DEVICES":"無可用投屏設備。","NO_SETTINGS":"無可用設置。","PHONE_TABLET":"手機/平板電腦","SUBTITLES":"字幕","SUBTITLES_CHANGE":"調整字幕","SUBTITLES_CHANGE_NONE":"抱歉,這種語言沒有其他字幕。","SUBTITLES_CHANGE_ACIVE":"當前字幕#{{subtitlesDialog.activeIdx + 1}}被激活,點擊\\"繼續\\"激活字幕#{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"或者,","SUBTITLES_ADJUST_DELAY":"調整字幕延遲:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"或在播放時使用G / H鍵進行調整。","SUBTITLES_ADJUST_DELAY_TIP":"提示:您可以在播放時使用G / H鍵進行調整。","SUBTITLES_DELAY":"字幕延遲:","SUBTITLES_LOADING":"加載字幕...","SUBTITLES_UNAVAILABLE":"沒有可用的外部字幕","SUBTITLES_DISABLED":"關閉","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"季","EPISODE":"集","SPECIAL":"Special","SORT":"排序","SORT_BY":"排序按照","FILTER":"篩選","SORT_TRENDING":"熱門","SORT_RECENT":"最近","SORT_ALPHABET":"首字母","SORT_RATING":"評分","SORT_WATCHED":"已觀看","SORT_YEAR":"年份","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"新的","New Episodes":"新劇集","New Videos":"新視頻","Recommendations":"推薦","LIBRARY_RESUME":"簡介","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"詳情","LIBRARY_RESUME_DISMISS":"清除","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"功能","DISCOVER_TOP":"熱門","DISCOVER_OSCAR":"奧斯卡獲獎作品","DISCOVER_WARNING_TITLE":"糟糕!","DISCOVER_EMPTY_CATALOG":"此插件返回空內容。","DISCOVER_ADULT_WARNING":"此內容僅對成人可見,您是否已滿18週歲?","DISCOVER_NOADDON_WARNING":"警吿:此類型沒有可用的Stremio插件,顯示已保存的項目,此處不會更新任何內容。","DISCOVER_LOAD_ERR":"內容未加載,發生錯誤。","DISCOVER_ADDON_UNINSTALLED":"此內容不再可用,您可能已卸載插件。","UNINSTALL_THIS_ADDON":"卸載此插件","ERR_ADDON_NOT_INSTALLED":"未安裝此插件,立即安裝?","DETAIL_RECEIVE_NOTIF_SERIES":"接受新劇集的通知","DETAIL_RECEIVE_NOTIF_VIDEOS":"接受新視頻的通知","SIDEBAR_SHOW_STREAMS":"顯示流媒體","RELAUNCH":"立即重新啟動!","UPGRADE":"新版本可用!升級至Stremio的最新版本","RELOAD_UI":"重新加載用户界面","MANUAL_UPDATE_TITLE":"更新您的Stremio版本","MANUAL_UPDATE_LINE1":"您運行的是一個過時的Stremio版本,這是非常不推薦的。","MANUAL_UPDATE_LINE2":"請儘快更新。","BUTTON_UPDATE_LATTER":"不是現在","BUTTON_UPDATE_NOW":"更新","ANONYMOUS_USER":"匿名用户","DONT_HAVE_ACC":"還沒有賬户?","HAVE_ACC":"已經有賬户了?","PASSWORD":"密碼","PASSWORD_CONFIRM":"確認密碼","EMAIL":"電子郵箱","FB_LOGIN":"使用Facebook登錄","FB_NOTHINGSHARED":"未經您的允許,任何內容都不會被共享","FB_NOPOST":"我們不會替您發送任何東西","OR":"或","I_ACCEPT":"我接受","I_ACCEPT_BY_CLICKING":"通過點擊上面的按鈕,我聲明我接受","TOS":"條款和條件","MUST_ACCEPT_TERMS":"您必須接受條款","PASSWORDS_NOMATCH":"密碼不匹配","SIGN_UP":"註冊","SIGN_UP_EMAIL":"使用電子郵箱註冊","CLICK_TO_SIGN_UP":"點擊此處註冊。","LOG_IN":"登錄","LOG_OUT":"註銷","EXIT_FULLSCREEN":"退出全屏模式","ENTER_FULLSCREEN":"進入全屏模式","PLAY_URL_MAGNET_LINK":"播放URL/Magnet鏈接","HELP_FEEDBACK":"幫助和反饋","TERMS_OF_SERVICE":"服務條款","PRIVACY_POLICY":"隱私政策","ABOUT_STREMIO":"關於Stremio","USER_PANEL":"用户面板","LOGIN_LABEL":"Login","GUEST_LOGIN":"訪客登錄","GUEST_LOGIN_NOTICE":"不建議訪客登錄,使用常規登錄允許Stremio同步您的庫,接受喜愛的劇集/頻道的通知。您確定要繼續嗎?","GUEST_LOGIN_NOTICE_2":"不建議訪客登錄,您將沒有同步的庫和首頁通知,這是Stremio的重要功能。您確定要繼續嗎?","CLICK_HERE":"點擊此處","WRONG_PASSWORD":"錯誤的電子郵箱或密碼,如果您忘了密碼,","SET_A_PASS":"設置密碼","RESET_PASSWORD":"重置密碼","FORGOT_PASSWORD":"忘記密碼?","EMAIL_USED_WITH_FB":"此電子郵箱與Facebook登陸一起使用。","INVALID_EMAIL":"請輸入有效的電子郵箱地址","INVALID_PASSWORD":"請輸入有效的密碼","CONN_ERR":"連接錯誤,請稍後再試。\\n\\n如果問題仍然存在,請禁用防火牆/殺毒軟件(特別是Bitdefender)。","IMPORT_FROM_GUEST":"從訪客賬户導入庫","RECEIVE_UPDATES_EMAIL":"從Stremio接受電子郵件更新","LOGIN_FAILED":"登陸失敗。","SIGNUP_FAILED":"註冊失敗。","SEARCH_FAILED":"搜索失敗","EMAIL_USED":"此電子郵箱已被使用。","WAITING_FB_LOGIN":"使用Facebook登錄...","EXTERNAL_PLAYER_TITLE":"在外部播放器中播放","EXTERNAL_REMEMBER_PLAYER":"您想記住您的選擇嗎","EXTERNAL_ALWAYS_PLAY":"是","EXTERNAL_ONLY_ONCE":"不是","BEST_FIT":"最佳","FIT_SCREEN":"適合屏幕","FILL":"填充","16:9":"16:9","4:3":"4:3","Original":"原始","INTRO_TASTE":"吿訴我們您喜歡什麼","INTRO_TASTE_LONG":"吿訴我們您想看什麼","INTRO_TASTE_PICK":"選擇{{interestsRemaining}}興趣","INTRO_TASTE_PICK_MORE":"選擇{{interestsRemaining}}更多興趣","INTRO_TASTE_HELP_US":"幫助我們瞭解更多有關您的信息。","INTRO_TASTE_CHOOSE_THESE":"選擇其中一些:","INTRO_TASTE_CHOOSE_MIN":"至少選3個類別","INTRO_TASTE_CHOOSE_MIN_ERR":"您必須至少選擇3個類別!","INTRO_TASTE_LIFESTYLE":"生活方式","INTRO_TASTE_SPORTS":"體育","INTRO_TASTE_FOOD_HEALTH":"飲食與健康","INTRO_TASTE_BEAUTY_FASHION":"美麗與時尚","INTRO_TASTE_NEWS":"新聞","INTRO_TASTE_GAMING":"遊戲","INTRO_TASTE_SCIENCE_EDU":"科學與教育","INTRO_TASTE_MUSIC":"音樂","INTRO_TASTE_TRAVEL":"旅行","INTRO_TASTE_LATE_NIGHT":"深夜秀","INTRO_TASTE_REALITY":"真人","INTRO_TASTE_COMEDY":"喜劇","INTRO_TASTE_DIY":"DIY","INTRO_TASTE_TECH":"技術","INTRO_TASTE_CINEMA":"影院","ADDON_NOT_SUPPORTED":"此平台不支持選定的插件。","ADDON_DISCLAIMER":"使用第三方插件將始終受到您的責任和您所在的司法管轄區的法律的約束。","ADDON_ACTIVATE":"激活此插件?","ADDON_REPO_ADD":"插件集合URL","ADDON_ADD":"添加","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"最新消息","BUTTON_CONTINUE":"繼續","BUTTON_ACTIVATE":"激活","BUTTON_ACTIVATED":"已激活","BUTTON_CANCEL":"取消","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"清除全部","BUTTON_VIEW_ALL":"查看全部","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"您的庫看起來是空的,看看它有多有用:)","HOW_START":"您可以從這裏開始:","LIB_EMPTY_CAL":"您的日曆顯示您庫中的劇集。","HOW_START_CAL":"下面是如何添加劇集:","LIB_EMPTY_BOARD":"主頁顯示與您的庫相關的通知&推薦。","HOW_START_BOARD_WAIT":"請在您的庫中添加一些劇集或頻道給我們幾分鐘來處理:)","HOW_START_BOARD":"下面是如何向其中添加劇集&電影:","IMPORT_FB":"從Facebook導入您喜歡的東西","IMPORT_TRAKT":"從Trakt導入媒體庫","IMPORT_DISCOVER":"從發現中找到有趣的東西","IMPORT_DISK":"導入本地磁盤上的電影或節目","PLEASE_CREATE_ACC":"請創建一個賬户以啟用庫同步&主頁。","IMPORT_DISCOVER_SIGNUP":"註冊並從發現中找到有趣的東西","IMPORT_DISK_SIGNUP":"註冊並導入本地磁盤上的電影或節目","LIB_EMPTY_CLOUD":"雲端庫","LIB_EMPTY_CLOUD_DESC":"在所有設備上同步個人雲端庫","LIB_EMPTY_EARLY":"第一時間","LIB_EMPTY_EARLY_DESC":"接收新劇集的通知","LIB_EMPTY_PERSONAL":"個性化","LIB_EMPTY_PERSONAL_DESC":"獲取個性化推薦","LIB_EMPTY_CALENDAR_DESC":"安排您的個性化觀看日曆","LIB_EMPTY_ALL":"註冊以獲取所有這些:","LIB_EMPTY_BEST":"註冊以獲得最佳的Stremio","LIB_EMPTY_OTHER":"註冊以啟用日曆和其他炫酷功能","CALENDAR_ADDED":"Stremio日曆已添加到默認桌面日曆中。","CALENDAR_ADDED_MSG":"如果這不起作用,請手動將此URL添加到日曆應用程序中","TRAKT_EXPIRED":"Trakt驗證已過期,請轉到設置並重新驗證","TRAKT_REQUIRES_LOGIN":"Trakt錯誤","TRAKT_REQUIRES_LOGIN_MSG":"您需要登錄","SETTINGS_LABEL":"設置","SETTINGS_NAV_GENERAL":"常規","SETTINGS_NAV_PLAYER":"播放器","SETTINGS_NAV_STREAMING":"流媒體","SETTINGS_NAV_SHORTCUTS":"快捷鍵","SETTINGS_SHORTCUT_RELOAD_APP":"重新加載應用程序","SETTINGS_SHORTCUT_OPEN_SETTINGS":"打開設置","SETTINGS_SHORTCUT_SWITCH_TABS":"切換標籤","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"向前循環標籤","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"向後循環標籤","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"退出/返回","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"切換全屏","SETTINGS_SHORTCUT_SHOW_CONTROLS":"顯示控件","SETTINGS_SHORTCUT_PLAY_PAUSE":"播放/暫停","SETTINGS_SHORTCUT_VOLUME_UP":"增大音量","SETTINGS_SHORTCUT_VOLUME_DOWN":"降低音量","SETTINGS_SHORTCUT_SEEK_NEXT":"尋找下一個","SETTINGS_SHORTCUT_SEEK_PREV":"尋找上一個","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"播放下一個","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"增加字幕大小","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"減小字幕大小","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"增加字幕延遲","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"減少字幕延遲","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"切換側邊欄","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"開機時啟動","SETTINGS_VLC_DEFAULT":"使用VLC播放","SETTINGS_UI_LANGUAGE":"用户界面語言","SETTINGS_FULLSCREEN_EXIT":"Esc鍵退出全屏","SETTINGS_GAMEPAD":"啟用遊戲手柄支持","SETTINGS_CLOSE_WINDOW":"關閉窗口時結束應用程序","SETTINGS_SUBTITLES_LANGUAGE":"默認字幕語言","SETTINGS_SUBTITLES_SIZE":"默認字幕大小","SETTINGS_SUBTITLES_BACKGROUND":"字幕背景","SETTINGS_SUBTITLES_COLOR":"字幕顏色","SETTINGS_SUBTITLES_COLOR_OUTLINE":"字幕輪廓顏色","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"字幕背景顏色","SETTINGS_SEEK_KEY":"方向鍵控制進度","SETTINGS_SEEK_KEY_SHIFT":"按住Shift鍵時方向鍵控制進度","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"自動播放下一集","SETTINGS_NEXT_VIDEO":"顯示播放下一集的通知","SETTINGS_NEXT_VIDEO_TRIGGER":"顯示下一集的通知:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"播放前自動調整窗口大小","SETTINGS_OVERRIDE_SERVER":"覆蓋流媒體服務器URL(高級)","SETTINGS_SERVER_URL":"流媒體服務器URL:","SETTINGS_SERVER_AVAILABLE":"流媒體服務器可用。","SETTINGS_SERVER_UNAVAILABLE":"流媒體服務器不可用。","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"流媒體HTTPS結點:","SETTINGS_USE_BETA":"始終使用最新的測試版","SETTINGS_IMPORT_FB":"從Facebook導入","SETTINGS_IMPORT_DISK":"從本地磁盤導入","SETTINGS_IMPORT_TRAKT":"從Trakt導入","SETTINGS_PAUSE_MINIMIZED":"最小化時暫停播放","SETTINGS_HWDEC":"硬件解碼加速","SETTINGS_BACKGROUND":"後台播放","SETTINGS_SUBSCRIBE_CALENDAR":"訂閲到日曆","SETTINGS_REQ_EXPORT":"請求導出數據","SETTINGS_ACC_DELETE":"請求刪除賬户","SETTINGS_CHANGE_PASSWORD":"更改密碼","SETTINGS_TOS":"服務條款","SETTINGS_SUPPORT":"聯繫支持人員","SETTING_LANGUAGE":"語言","SETTINGS_TRAKT":"Trakt自動跟蹤","SETTINGS_TRAKT_LOGOUT":"從Trakt.tv註銷","SETTINGS_SCAN_FOR_REMOTE":"掃描二維碼打開遙控器","SETTINGS_DESKTOP_NOTIFICATIONS":"桌面通知","SETTINGS_DATA_SAVER":"移動數據警吿","SETTINGS_LANGUAGE_INTERFACE":"界面","SETTINGS_LANGUAGE_SUBS":"默認字幕","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"自動選擇音軌","SETTINGS_DEFAULT_AUDIO_TRACK":"默認音軌","SETTINGS_ACCOUNT":"賬户","SETTINGS_VERSION":"版本","SETTINGS_MPV_WINDOW":"在單獨窗口中啟動播放器(高級)","SETTINGS_PLAY_IN_EXTERNAL":"總是在外部播放器中打開視頻","SETTINGS_STORAGE_BUTTON":"清除本地存儲","SETTINGS_STORAGE_MODAL_TITLE":"您確定嗎?","SETTINGS_STORAGE_MODAL_MESSAGE":"這將清除本地存儲並使您註銷","SETTINGS_HWDEC_PICKER":"選擇硬件加速解碼設置","SETTINGS_HW_AUTOMATIC":"自動","SETTINGS_HW_DISABLED":"關閉","SETTINGS_HW_ACCELERATED":"解碼加速","SETTINGS_HW_FULL":"全加速","SETTINGS_HW_LEGACY":"舊版","SUBSPICKER_AUDIO":"音頻","SUBSPICKER_SUBTITLES":"插件字幕","SUBSPICKER_BLACK_BACKGROUND":"使用黑色背景色","SUBSPICKER_VERTICAL_OFFSET":"垂直偏移量","SUBSPICKER_SIZE":"大小","SUBSPICKER_DELAY":"延遲","SUBSPICKER_EMBEDDED_SUBS":"內嵌字幕","MOBILE_PRIVACY_POLICY":"隱私政策","MOBILE_CRASH_REPORTING":"崩潰報吿","MOBILE_ZOOM_TO_FILL":"縮放填充屏幕","MOBILE_PASSTHROUGH":"數字音頻輸出(直通)","MOBILE_RUN_LOW_BATTERY":"電池電量低時運行","MOBILE_RUN_FOREGROUND":"作為前台服務運行","MOBILE_PERFORMANCE":"性能&穩定性","MOBILE_SERVER_ONLINE":"在線","MOBILE_SERVER_OFFLINE":"離線","MOBILE_QR_EXPIRES":"二維碼到期時間","MOBILE_LOG_INTO":"登陸到您的Stremio賬户","MOBILE_SCAN_QR":"掃描上面的二維碼或轉到","MOBILE_LINK_ACCOUNT":"鏈接賬户","MOBILE_SPEEDPICKER_CANCEL":"取消","MOBILE_SPEEDPICKER_LABEL":"選擇播放速度","MOBILE_EMPTY_LIBRARY":"您的庫為空","MOBILE_NO_ADDON_ACTIVE":"沒有活動的此類型Stremio插件。","MOBILE_ORGANIZER_WARNING":"Stremio Organizer應用程序提供的功能有限,要獲得可播放流的列表和完整的Stremio體驗,請使用Stremio桌面客户端。","MOBILE_ADDON_LOADING":"仍在加載","MOBILE_ADDONS_LOADING":"插件仍在加載","MOBILE_ADDON":"插件","MOBILE_CONFIGURE_ADDON":"配置插件","MOBILE_CONFIGURE_ADDON_LABEL":"配置插件","MOBILE_ORGANIZER_ADDONS_WARNING":"Stremio Organizer應用程序僅提供有限的插件,要獲得完整的Stremio體驗,請使用Stremio桌面客户端。","MOBILE_DISCONNECT":"斷開連接","MOBILE_LOOKING_FOR_DEVICES":"正在查找設備...","MOBILE_CAST_TO":"投屏到","NAVIGATION_ON":"開啟","NAVIGATION_OFF":"關閉","MARKETING_AGREE":"我同意接收Stremio的營銷通知","QUIT":"退出","CONNECTED":"已連接","AUTHENTICATE":"驗證","CACHING":"緩存","SETTINGS_CACHING_DRIVE":"緩存磁盤","ENABLE_LOCAL_FILES_ADDON":"啟用本地文件插件(需要重新啟動)","LOCAL_ADDON_NOT_ENABLED":"未啟用本地插件,單擊此處轉到設置並啟用它","ENABLE_REMOTE_HTTPS_CONN":"啟用遠程HTTPS連接","TORRENT_PROFILE":"Torrent配置","DATA_CACHING":"數據緩存","MAGNET_PARSING":"分析Magnet鏈接","January":"一月","February":"二月","March":"三月","April":"四月","May":"五月","June":"六月","July":"七月","August":"八月","September":"九月","October":"十月","November":"十一月","December":"十二月","Monday":"星期一","Tuesday":"星期二","Wednesday":"星期三","Thursday":"星期四","Friday":"星期五","Saturday":"星期六","Sunday":"星期天","Action":"動作","Comedy":"喜劇","War":"戰爭","Family":"家庭","Animation":"動畫","Adventure":"冒險","Fantasy":"幻想","Crime":"犯罪","Mystery":"神祕","Romance":"浪漫","Drama":"劇情","Horror":"恐怖","Thriller":"驚悚","Sci-Fi":"科幻","Music":"音樂","Biography":"傳記","Documentary":"紀錄","Sport":"運動","Musical":"音樂劇","Western":"西部","Film-Noir":"黑色電影","News":"新聞","History":"歷史","Game-Show":"遊戲節目","Reality-TV":"真人秀","Talk-Show":"脱口秀","Film & Entertainment":"電影與娛樂","Gaming":"遊戲","From TV":"電視","Lifestyle":"生活方式","Science & Education":"科學與教育","Cooking & Health":"烹飪與健康","Beauty & Fashion":"美麗與時尚","Sports":"體育","News & Politics":"新聞與政治","How-to & DIY":"DIY","Tech":"技術","Automotive":"汽車","Causes & Non-Profits":"事業與公益","Movies":"影視","Uk Live Tv":"英國直播電視台","Fashion":"流行","Business News Radio":"商業新聞電台","Business Tv":"商業電視","Cars & Auto":"汽車與自動化","Comedy Radio":"喜劇電台","Lifestyle Radio":"生活方式電台","News Tv":"新聞電視","Food And Wine":"食物與酒","Latino Tv":"拉丁語電視台","Shopping Tv":"購物電視台","Religion":"宗教","Kids":"兒童","Body & Soul":"身體與靈魂","Education":"教育","Indian Tv":"印度電視台","Extreme Sports":"極限運動","Middle Eastern Tv":"中東電視台","Celebrity Tv":"名人電視台","Science Tv":"科學電視台","Bikini babe":"比基尼寶貝","Outdoors":"户外","German Tv":"德國電視台","French Tv":"法國電視台","Italian Tv":"意大利電視台","Gamer Tv":"伽馬電視台","Travel":"旅行","Asian Tv":"亞洲電視台","Entertainment":"遊戲娛樂","News Radio":"新聞電台","Music Radio":"音樂電台","Language Learning":"語言學習","Science Radio":"科學電台","Tech Radio":"科技電台","Science & Technology Vod":"科技視頻點播","new video":"新視頻","new episode":"新一集","new movie":"新電影","recommended":"推薦","we recommend":"我們建議","offer of the day":"當日優惠","news":"新聞","music video":"音樂視頻","CTX_SHOW_HOTKEYS":"顯示快捷鍵","CTX_DISMISS_NOTIF":"清除通知","CTX_DISMISS_ALL":"全部清除","CTX_SHARE":"分享","CTX_COPY_SHARE_LINK":"複製分享鏈接","CTX_COPY_MAGNET_LINK":"複製Magnet鏈接","CTX_COPY_STREAM_LINK":"複製流媒體鏈接","CTX_DOWNLOAD_VIDEO":"下載此視頻","CTX_DOWNLOAD_SUBS":"下載字幕","CTX_VIEW_ON_YOUTUBE":"在YouTube上觀看","CTX_SHOW":"顯示","CTX_PLAY":"播放","CTX_PLAY_IN":"播放","CTX_PLAY_ON":"正在播放","CTX_WATCH_ON":"正在觀看","CTX_WATCH":"觀看","CTX_WATCHED":"已觀看","CTX_WATCH_BEGINNING":"從頭開始觀看","CTX_WATCH_MOBILE":"在移動設備上觀看","CTX_REWIND":"回到開頭","CTX_MARK_WATCHED":"標記為已觀看","CTX_MARK_NON_WATCHED":"標記為未觀看","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"將其餘部分標記為已觀看","CTX_UNMARK_REST":"將其餘部分標記為未觀看","CTX_RECEIVE_NEW_NOTIF":"接受新通知","CTX_REMOVE_CACHE":"從緩存中刪除","CTX_REMOVE_CACHE_EP":"從緩存中刪除集","CTX_OPEN_CONTAINING":"打開所在文件夾","CTX_REMOVE":"從庫中刪除","CTX_AVAILABLE_OFFLINE":"離線可用","CTX_PAUSED":"暫停","CTX_ALWAYS_ON_TOP":"置頂","CTX_FULLSCREEN":"全屏","CTX_WRONG_SUBS":"錯誤的字幕?","CTX_REPORT_ISSUES":"報吿問題","CTX_COPY":"複製","CTX_PASTE":"粘貼","CTX_CLEAR":"清除","CTX_CLEAR_RECENT_SEARCHES":"清除最近搜索記錄","HELLO_THERE":"您好","HOPE_YOU_ENJOY":"我們希望您喜歡Stremio,也許它已經是您最喜歡的應用之一了!","WHO_ARE_WE":"我們是誰?我們是它背後的團隊。在過去三年裏的每天,我們兩個努力工作使這個產品越來越好。","SUPPORT_US":"如果您喜歡Stremio,如果Stremio對您來説很有價值,請傳播它!","SPREAD_THE_WORD":"現在與您的朋友分享傳播關於Stremio的信息","MORE_PEOPLE":"使用Stremio的人越多,效果就越好!","SEND_A_LINK":"或發送一個鏈接到我們的網站","TIP_LOCALFILES":"提示:您可以將本地視頻文件拖放到Stremio中","ADDON_MY":"我的插件","ADDON_COMMUNITY":"社區插件","ADDON_OFFICIAL":"官方插件","ADDON_REPOS":"插件集合","ADDON_SEARCH":"搜索插件","ADDON_INSTALL":"安裝","ADDON_CONFIGURE":"配置","ADDON_UNINSTALL":"卸載","ADDON_UPGRADE":"更新","ADDON_INSTALLED":"已安裝","ADDON_INSTALLED_MSG":"插件已安裝!","ADDON_UPGRADED_MSG":"插件已更新!","ADDON_UNKNOWN":"未知","ADDON_ERR":"插件安裝錯誤!","ADDON_DISCONNECTED":"已斷開連接","ADDON_APP_MISSING":"未安裝此源的應用程序,您想現在安裝嗎?","ADDON_APP_INSTALL":"立即安裝","ADDON_PAGE":"插件頁","ADDON_TOP_CONTENT":"最好從這個插件","ADDON_PROVIDES":"這個插件會給您:","ADDON_WATCH":"立即觀看#{types}!","ADDON_WATCH_FREE":"立即免費觀看#{types}!","ADDON_ADDON":"插件","ADDON_SUPPORTED_TYPES":"支持的類型","ADDON_SUPPORTED_CATALOGS":"支持的目錄","ADDON_PROVIDES_DISCOVER":"發現中的更多#{types}","ADDON_PROVIDES_STREAMS":"觀看#{types}","ADDON_PROVIDES_STREAMS_FREE":"免費觀看#{types}","ADDON_PROVIDES_SUBTITLES":"#{types}的字幕","ADDON_CANTDETECT":"我們無法檢測到正在運行的Stremio,因此我們無法檢測您安裝了哪些插件。","ERR_NO_META":"找不到有關於此的信息","ERR_GETTING_META":"檢索有關於此的信息時出錯","ERR_CANT_PARSE_MAGNET":"無法分析Magnet","ERR_NO_MAGNET_INFOHASH":"Magnet缺少有效的Hash","ERR_NO_FILE_PATH":"沒有文件路徑無法發送請求","ERR_NO_TORRENT":"沒有Torrent返回","ERR_NO_SUPPORTERD_FILES":"找不到支持的文件","ERR_OPENING_FILES":"無法打開外部文件","ERR_INVALID_LINK":"無效鏈接","ERR_REGISTERED_ONLY":"此選項僅適用於已註冊用户。","ERR_CLIPBOARD":"無法從剪切板播放","ERR_CLIPBOARD_READ":"無法讀取此平台上的剪切板","ERR_CLIPBOARD_GENERIC":"在剪切板中找不到可播放的URL. 請將URL(例如Magnet鏈接)複製到視頻。","BOARD_CONTINUE_WATCHING":"繼續觀看","BOARD_EXPLANATION_RECOMMENDATIONS":"專門為您挑選的電影。
這部電影是一個推薦樣例。","BOARD_EXPLANATION_EPISODES":"這裏是您最喜愛的劇集的新一集。
將您關注的劇集添加到庫中。","BOARD_EXPLANATION_VIDEOS":"這裏是您最喜愛的頻道的新一集。
將您關注的YouTube頻道添加到庫中。","WEBSITE_SLOGAN_WATCH":"立即觀看","WEBSITE_SLOGAN_ALL":"一站式視頻娛樂解決方案","WEBSITE_SLOGAN_NEW":"您能觀看一切","WEBSITE_SLOGAN_NEW_NEW":"自由串流","WEBSITE_WATCH_FROM":"觀看","WEBSITE_DOWNLOAD":"立即下載","WEBSITE_DOWNLOAD_FOR":"立即下載","WEBSITE_IS_DESKTOP":"Stremio是一個桌面應用程序,請在PC上打開此頁並下載","WEBSITE_DESKTOP_DEMO_VID":"桌面演示","WEBSITE_PAGE_HOME":"首頁","WEBSITE_PAGE_FEATURES":"功能","WEBSITE_PAGE_ADDONS":"插件","WEBSITE_PAGE_TECH":"技術","WEBSITE_PAGE_CREATE_ADDON":"創建插件","WEBSITE_PAGE_CONTACTS":"聯絡","WEBSITE_PAGE_BLOG":"博客","WEBSITE_TYPE_movie":"電影","WEBSITE_TYPE_series_PL":"劇集","WEBSITE_TYPE_tv":"直播電視","WEBSITE_TYPE_channel":"頻道","WEBSITE_STREMIO_WHAT_IS":"Stremio是一款幫助您管理和隨時觀看您喜愛的視頻、電影、劇集和電視頻道的應用程序","WEBSITE_FEATURES_WATCH":"立即觀看高清視頻","WEBSITE_FEATURES_WATCH_DETAIL":"點擊並播放您喜愛的電影、劇集、視頻和電視頻道。","WEBSITE_FEATURES_SUBS":"自動加載字幕","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio會自動為您的語言選擇同步字幕。","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"在電視和移動設備上播放","WEBSITE_FEATURES_CAST_DETAIL":"適用於AppleTV、Chromecast、智能電視(DLNA/UPnP)和移動設備。","WEBSITE_LIB":"享受在所有設備上同步的個人庫","WEBSITE_LIB_COLLECT":"從Stremio收集","WEBSITE_LIB_IMPORT":"從Facebook導入","WEBSITE_LIB_LOCAL":"從本地磁盤添加","WEBSITE_BOARD":"首頁 - 通知和推薦的一站式場所","WEBSITE_BOARD_RECOMMEND":"推薦電視節目","WEBSITE_BOARD_TRENDING":"流行電影","WEBSITE_BOARD_NEW":"新視頻","WEBSITE_BOARD_EPISODE":"新一集","WEBSITE_BOARD_1":"想看些有趣的東西嗎?根據您的喜好得到推薦!","WEBSITE_BOARD_2":"當您最喜愛的電視節目或YouTube頻道的新一集播出時獲得通知!","WEBSITE_BOARD_YOUTUBE":"YouTube頻道的新視頻","WEBSITE_BOARD_EPISODES":"您關注的劇集的新一集","WEBSITE_ADDONS":"內容插件","WEBSITE_TECH_DETAIL":"我們熱愛科技,我們熱愛瘋狂的科學!\\nStremio使用了以下開源技術:","WEBSITE_TECH_WCJS":"WebChimera.js允許Stremio以良好的性能播放任何視頻格式。","WEBSITE_TECH_WCJS_EXTRA":"我們是項目的核心貢獻者","WEBSITE_TECH_ELECTRON":"Electron為Stremio提供了一個創新平台。","WEBSITE_TECH_ELECTRON_EXTRA":"我們是項目貢獻者","WEBSITE_TECH_LINVODB":"一種數據庫技術,確保您的數據在任何地方登錄都受管理和可用。","WEBSITE_TECH_LINVODB_EXTRA":"內部技術","WEBSITE_CREATE_ADDON":"創建您的插件","WEBSITE_CREATE_ADDON_DETAIL":"您有提供視頻內容的服務嗎?我們將通過創建插件來幫助您從Stremio的功能中獲益。","WEBSITE_CREATE_ADDON_BENEFITS":"為Stremio創建插件的好處","WEBSITE_P2P_BEAUTY":"點對點流媒體之美","WEBSITE_P2P_1":"可靠且價格合理的全高清/4K視頻點播或流媒體直播","WEBSITE_P2P_2":"提供良好用户體驗的分銷平台","WEBSITE_P2P_3":"我們將創建一個插件來滿足您的確切需要","WEBSITE_P2P_CONTACT":"有興趣嗎?歡迎您通過聯繫我們.","WEBSITE_P2P_CONTACT_EXTRA":"我們很樂意幫助您將您的內容集成到Stremio!","WEBSITE_P2P":"偶然間出現了一種改變遊戲名稱的技術。 我們投入了大量的時間和精力來構建我們的點對點(P2P)視頻流媒體引擎,該引擎可提供出色的性能和多功能性,以適應任何用例。\\n請聯繫我們以獲取支持DRM的P2P視頻點播或實時流媒體。","WEBSITE_THOUGHTS":"我們分享的想法:","WEBSITE_SPREAD":"傳播關於Stremio的信息:","WEBSITE_CONTACT":"聯繫我們,我們很高興收到您的來信!","WEBSITE_OPENSOURCE":"有關我們的開源項目,請轉到:","WEBSITE_BITCOIN":"捐贈比特幣:","WEBSITE_FAQ":"常見問題","WEBSITE_FAQ_SHORT":"常見問題","WEBSITE_QUESTIONS":"問題","WEBSITE_TOS":"使用條款","WEBSITE_LEGAL":"法律","WEBSITE_PAGE_ABOUT":"關於","WEBSITE_PAGE_BECOME_PARTNER":"成為合作伙伴","WEBSITE_ALL_YOU_CAN_WATCH":"自由觀看\\n您想看的一切。","WEBSITE_FREEDOM_TO_STREAM":"自由串流","WEBSITE_WHAT_IS_STREMIO":"什麼是Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio是一個一站式視頻內容聚合中心。在您擁有的任何設備上發現,管理和觀看來自各種來源的視頻。","WEBSITE_WHAT_IS_STREMIO_P2":"電影、電視節目、劇集、電視直播或網絡頻道例如YouTube或Twitch.tv等,您可以在Stremio上找到所有這些內容。","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio是一個現代化的媒體中心,為您的視頻娛樂提供一站式解決方案。您可以通過易於安裝的插件發現,觀看和整理視頻內容。","WEBSITE_WHAT_IS_STREMIO_P2_V2":"電影、電視節目、直播電視或網絡頻道——在Stremio上找到所有這些。","WEBSITE_ENJOI_ON_ALL_DEVICES":"在所有媒體設備上享受","WEBSITE_DEVICES_COLLECT":"從Stremio收集","WEBSITE_DEVICES_IMPORT_FB":"從Facebook導入","WEBSITE_DEVICES_LOCAL":"從本地磁盤添加","WEBSITE_JOIN_THE_PARTY_NOW":"立即加入聚會","WEBSITE_DEVICES_ALL":"易於在所有設備上使用;","WEBSITE_EXTENDABLE_CATALOG":"可無限擴展的視頻目錄;","WEBSITE_ORGANIZE_YOUR_MEDIA":"強大的媒體管理功能;","WEBSITE_AS_SEEN_ON":"如圖所示","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"關於我們","WEBSITE_LINK_TECHNOLOGY":"技術","WEBSITE_LINK_APPS":"應用程序","WEBSITE_LINK_DOWNLOADS":"下載","WEBSITE_MORE":"更多","WEBSITE_LINK_ADDONS":"插件","WEBSITE_LINK_ADDON_SDK":"插件SDK","WEBSITE_LINK_CONTRIBUTE":"貢獻","WEBSITE_LINK_COMMUNITY":"社區","WEBSITE_LINK_BLOG":"博客","WEBSITE_MORE_MORE":"... & 更多","WEBSITE_LINK_HELP":"幫助中心","WEBSITE_LINK_CONTACTS":"業務查詢","WEBSITE_LINK_TOS":"條款和條件","WEBSITE_LINK_PRAVACY":"隱私政策","WEBSITE_SUBSCRIBE":"訂閲","WEBSITE_NEWSLETTER":"加入我們的實時通訊,瞭解精彩的內容","WEBSITE_PLACEHOLDER_EMAIL":"您的電子郵箱","WEBSITE_COMMUNITY":"社區","WEBSITE_LINK_PRAVACY_LEGAL":"隱私與法律","WEBSITE_WHY":"我們為什麼這樣做","WEBSITE_WHY_P1":"在Stremio,我們每天都工作,因為我們想解決視頻點播行業的一個重要問題。每分鐘都有這麼多的新內容發佈,幾乎不可能找到解決的方法。","WEBSITE_WHY_P2":"我們幫助人們瀏覽這個巨大的視頻娛樂世界,發現新的內容來享受。我們的應用程序彙集了電影、劇集、電視直播、網絡頻道等。我們致力於讓用户非常容易地找到他們喜歡的標題和廣播。","WEBSITE_WHY_P3":"您可以隨時在任何設備上使用我們的服務,使Stremio成為您唯一需要的視頻娛樂中心。","WEBSITE_TEAM":"團隊","WEBSITE_TEAM_P":"Stremio團隊雖小但很強大:我們10個人用X語言編寫代碼,分享軟件開發、UI和UX設計、營銷和廣吿、商業和初創企業方面的專業知識。","WEBSITE_FEATURES":"功能","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"輕鬆發現新內容","WEBSITE_FEATURES_DISCOVER_P":"輕鬆發現要觀看的新電影、電視節目、劇集和頻道。按類別、流派、評分、時間等瀏覽,或者只需鍵入一個名稱即可找到。Stremio讓尋找新的視頻內容變得輕而易舉。","WEBSITE_FEATURES_ALL_CONTENT":"一塊屏幕顯示所有視頻內容","WEBSITE_FEATURES_ALL_CONTENT_P1":"查看您未看完的電影、劇集或視頻,並繼續觀看;獲得新劇集和版本的通知;瀏覽根據您的觀看習慣獲得的推薦。","WEBSITE_FEATURES_LIBRARY":"管理您的視頻庫","WEBSITE_FEATURES_LIBRARY_P1":"只需點擊一下,即可將任何標題添加到您的Stremio庫中,並按類型、時間或字母順序整齊地排列內容。","WEBSITE_FEATURES_CALENDAR":"記錄您所觀看的一切","WEBSITE_FEATURES_CALENDAR_P1":"獲取添加到庫中的所有電影和系列的日曆可視化。導出您的Stremio日曆並同步它,這樣您就可以隨時知道新的一集或首映何時到來。","WEBSITE_FEATURES_BIG_SCREEN":"在大屏幕上欣賞您的視頻內容","WEBSITE_FEATURES_BIG_SCREEN_P1":"將您正在觀看的任何內容都投屏到另一台設備上,無論是手機、平板電腦還是電視,只需點擊一下即可。","WEBSITE_FEATURES_SOURCES":"觀看不同來源的視頻","WEBSITE_FEATURES_SOURCES_P":"安裝官方和社區插件,欣賞來自多個不同供應商的視頻。","WEBSITE_CREATE_AN_ADDON":"創建插件","WEBSITE_FEATURES_SYNC":"跨設備同步庫並恢復播放","WEBSITE_FEATURES_SYNC_P1":"使用您的帳户在所有設備上登錄,享受同步的庫、插件、播放和日曆。","WEBSITE_FEATURES_EXTENDABLE":"通過插件擴展視頻目錄","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio插件目錄提供了許多插件,可以從中安裝和觀看各種視頻內容。這包括電影、節目、電視直播、體育、新聞、播客、網絡頻道、視頻遊戲等。","WEBSITE_FEATURES_AUTO_SUBS":"自動加載字幕","WEBSITE_FEATURES_AUTO_SUBS_P1":"通過我們的字幕插件,您可以自動選擇您喜歡的語言。","WEBSITE_FEATURES_CHROMECAST":"投屏到Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"在更大的屏幕上欣賞您的視頻內容,或者將您正在觀看的內容投屏到其他設備上。","WEBSITE_FEATURES_KEEP_TRACK":"跟蹤您最喜愛的電視節目和網絡頻道","WEBSITE_FEATURES_KEEP_TRACK_P1":"獲取您最喜愛的劇集和網絡頻道的新一集的日曆可視化和通知。","WEBSITE_FEATURES_POWER_USER":"超級用户功能","WEBSITE_FEATURES_POWER_USER_P1":"在外部播放器中播放","WEBSITE_FEATURES_POWER_USER_P2":"從Torrent文件或Magnet鏈接播放","WEBSITE_FEATURES_POWER_USER_P3":"從Facebook喜愛或本地磁盤導入您的庫","WEBSITE_ADD_ONS":"插件","WEBSITE_ADD_ONS_P1":"Stremio提供的所有視頻內容都是通過插件系統獲取的,應用程序中沒有內置任何內容或內容提供商。","WEBSITE_ADD_ONS_P2":"有兩組插件可用:官方和社區插件。","WEBSITE_ADD_ONS_P3":"官方插件由Stremio開發和託管,而社區插件由我們的社區成員創建和託管。","WEBSITE_ADDONS_OFFICIAL":"官方插件","WEBSITE_ADDONS_WATCHUB":"從iTunes、Hulu、Amazon和其他英國/美國服務提供商處流式播放您喜愛的電影、劇集和節目。","WEBSITE_ADDONS_YOUTUBE":"觀看您喜愛的YouTube頻道,獲得您關注的貢獻者的新上傳通知。","WEBSITE_ADDONS_FILMON":"免費觀看直播電視、電影和社交電視。600個電視頻道,45000部免費電影,紀錄片以及更多","WEBSITE_ADDONS_OPENSUBTITLES":"多語種影視字幕,每天上傳上千個翻譯字幕。","WEBSITE_ADDONS_COMMUNITY":"社區插件","WEBSITE_ADDONS_FILMON_VOD":"觀看來自Filmon.tv的點播視頻。","WEBSITE_ADDONS_TWICH":"觀看來自Twitch.tv(電子競技行業的視頻流媒體平台)的直播。","WEBSITE_ADDONS_VODO":"觀看完全免費的獨立電影。","WEBSITE_ADDONS_NETFLIX":"觀看Netflix的電影和網劇。","WEBSITE_ADDONS_CREATE":"創建插件","WEBSITE_ADDONS_CREATE_P1":"如果您願意,您可以開發自己的插件。通過這種方式,您可以讓自己和我們的社區訪問新的視頻內容,並接觸到全球數百萬用户的新目標受眾。","WEBSITE_ADDONS_START_CREATE":"要開始,請訪問Stremio插件SDK頁面:","WEBSITE_DOWNLOADS":"下載","WEBSITE_DOWNLOADS_P1":"為了獲得最佳性能,我們建議您使用最新版本的Stremio應用程序。但是,如果出於某種原因,您想使用舊版本,可以在此處下載。","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS(限制版本)","WEBSITE_CONTRIBUTE":"貢獻","WEBSITE_CONTRIBUTE_P1":"Stremio平台是開源的,您可以輕鬆地為當前沒有來源的內容創建一個插件。","WEBSITE_CONTRIBUTE_WHY":"為什麼要創建插件?","WEBSITE_CONTRIBUTE_WHY_P1":"為您的視頻內容吸引新觀眾","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio的用户羣體正在快速增長,在推出的第一年,Stremio在全球獲得了100萬用户,在該平台存在的第二年,這個數字增長到250萬。","WEBSITE_CONTRIBUTE_WHY_P3":"用插件,您可以輕鬆接觸這些觀眾並向他們分發您的視頻內容。","WEBSITE_CONTRIBUTE_ALL":"在一處觀看您喜愛的電影、視頻、劇集和頻道。","WEBSITE_CONTRIBUTE_ALL_P1":"您是Stremio上尚未提供的特定類型內容的粉絲?為它創建一個插件,在市場上最大、最易使用的娛樂中心之一欣賞您喜愛的視頻。","WEBSITE_CONTRIBUTE_ALL_P2":"除此之外,您還會得到其他志同道合的Stremio社區成員的無盡感激。","WEBSITE_CONTRIBUTE_MONETIZE":"通過插件營利,並在其幫助下賺錢","WEBSITE_CONTRIBUTE_MONETIZE_P1":"一旦您為Stremio開發了一個新的插件,您就可以通過多種不同的方式輕鬆地靠其營利。如果您正在考慮此問題,請隨時與我們聯繫","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":",我們很樂意就插件營利選項向您提供諮詢和建議。","WEBSITE_CONTRIBUTE_TRANSLATE":"成為一名志願翻譯者","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"如果您想享受不同語言的Stremio應用程序,您可以加入我們的志願翻譯者社區。他們幫助我們添加多種不同語言的Stremio版本。","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"您想開始嗎?","WEBSITE_TRANSALTE_STREMIO":"翻譯Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"官方社區","WEBSITE_COMMUNITY_OFFICIALS_P1":"成為不斷增長的Stremio社區的一部分。在社交媒體上關注我們,不要害羞地打招呼,我們喜歡聽到粉絲的聲音!","WEBSITE_COMMUNITY_UNOFFICIALS":"非官方社區","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"合作伙伴和支持者","WEBSITE_COMMUNITY_GOODIES":"Stremio特典","WEBSITE_COMMUNITY_WALLPAPERS":"壁紙","WEBSITE_COMMUNITY_ART":"社區藝術畫廊","WEBSITE_LINK_ART":"社區藝術畫廊","WEBSITE_CONTACT_US":"聯繫我們","WEBSITE_CONTACT_US_P1":"如果您有任何問題、意見或建議,請隨時通過下面的聯繫方式與我們聯繫。","WEBSITE_CONTACT_US_P2":"請記住,我們位於保加利亞,因此可能會由於時區差異而延遲處理您的問題。","WEBSITE_CONTACT_US_SUCCESS":"您的信息已發送。我們會在方便的時候儘快給您回覆。","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"請輸入有效的電子郵箱!","WEBSITE_CONTACT_US_Q_RELATED_TO":"您的問題與什麼有關?","WEBSITE_CONTACT_US_Q_OS":"您的操作系統是什麼?","WEBSITE_CONTACT_US_PH_EMAIL":"您的電子郵箱","WEBSITE_CONTACT_US_PH_MESSAGE":"短信","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"發送","WEBSITE_CONTACT_US_Q_1":"如何安裝?","WEBSITE_CONTACT_US_Q_2":"如何卸載?","WEBSITE_CONTACT_US_Q_3":"(HTML)如何製作千層麪?","WEBSITE_CONTACT_US_Q_4":"插件","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"技術","WEBSITE_TECHNOLOGY_P1":"我們熱愛科技,熱愛科學。
這是Stremio的動力(它都是開源的)。","WEBSITE_TECHNOLOGY_P_QT":"最佳跨平台軟件開發工具。","WEBSITE_TECHNOLOGY_P_MPV":"一款免費、開源、跨平台的媒體播放器。","WEBSITE_TECHNOLOGY_P_RN":"React Native允許您僅使用JavaScript構建移動應用程序。","WEBSITE_TECHNOLOGY_P_VLC":"嵌入到應用程序中獲取多媒體的媒體框架。","WEBSITE_TECHNOLOGY_P_REALM":"Realm是一個移動平台,是SQLite和Core Data的替代品。","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js是一個開源、跨平台的JavaScript運行環境。","WEBSITE_TECHNOLOGY_P_RUST":"Rust是一種多範式系統編程語言,關注安全性,尤其是安全併發性。","WEBSITE_TECHNOLOGY_CONTRIBUTE":"為項目貢獻力量","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"您可以通過兩種方式為Stremio做貢獻,幫助我們將產品做得更好。","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"您可以通過翻譯平台來貢獻您寶貴的語言技能...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"或","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... 您可以利用您的編程技巧來創建社區插件。","WEBSITE_TRANSLATE_STREMIO":"翻譯Stremio","WEBSITE_404_OH_NO":"糟糕!您要找的頁面不在這裏...","WEBSITE_GO_HOME":"回到主頁","WEBSITE_LINK_OTHER_DOWNLOADS":"其他下載","WEBSITE_FAQ_ABR":"常見問題","WEBSITE_SUPPORT":"支持","WEBSITE_DOWNLOAD_4_0_BETA":"立即下載Stremio 4測試版","WEBSITE_GET_FOR_DESKTOP":"獲取桌面","WEBSITE_LINK_ADDON_COMPETITION":"插件比賽","WEBSITE_LINK_ART_CONTEST":"藝術比賽","WEBSITE_MY_ACCOUNT":"我的賬户","WEBSITE_MAINPAGE_FAQ_001_H1":"什麼是Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio是一個現代化的媒體中心,讓您可以自由觀看任何您想要的東西。","WEBSITE_MAINPAGE_FAQ_002_H1":"它是如何工作的?","WEBSITE_MAINPAGE_FAQ_002_P1":"一旦您在設備上安裝了Stremio並創建了一個帳户,您所要做的就是訪問插件目錄並安裝任何您想要的插件,就可以開始了!","WEBSITE_MAINPAGE_FAQ_002_P2":"之後,您可以進入“發現”或“板”部分,開始探索內容。","WEBSITE_MAINPAGE_FAQ_003_H1":"我可以在這裏看什麼?","WEBSITE_MAINPAGE_FAQ_003_P1":"很多:電影、電視節目、網絡頻道、體育、電視頻道、收聽播客等等。感謝我們的插件系統,您可以訪問各種內容。","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio是開源的嗎?","WEBSITE_MAINPAGE_FAQ_004_P1":"是的,您可以查看以下鏈接:${1}桌面應用${2}和${3}GitHub組織${4}。","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio安全嗎?","WEBSITE_MAINPAGE_FAQ_005_P1":"是:因為它是開源軟件,所以代碼可以公開審核,您可以自己查看。","WEBSITE_MAINPAGE_FAQ_006_H1":"我的隱私如何?","WEBSITE_MAINPAGE_FAQ_006_P1":"我們尊重用户隱私,除了創建和同步您的帳户所必需的最低限度外,不收集任何個人數據。","WEBSITE_MAINPAGE_FAQ_006_P2":"註冊時還有一個${1}訪客模式${2},它不需要任何數據:在這種模式下,不會調用我們的後端。然而,這是以犧牲有用的功能為代價的,比如能夠跨設備同步您的庫。","WEBSITE_MAINPAGE_FAQ_007_H1":"我可以投屏到電視嗎?","WEBSITE_MAINPAGE_FAQ_007_P1":"是的,我們支持Chromecast,您可以從桌面和移動應用程序(Android)進行強制轉換。","WEBSITE_MAINPAGE_FAQ_008_H1":"Stremio有多少插件?","WEBSITE_MAINPAGE_FAQ_008_P1":"截至2019年末,超過50個。有關更多信息,請查看我們的插件目錄。","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio是否可以擴展到插件目錄之外?","WEBSITE_MAINPAGE_FAQ_009_P1":"是的,您應該查看這些:${1}PimpMyStremio${2},${3}Reddit communities${4},${5}Stremio Downloader${6},等等。","WEBSITE_MAINPAGE_FAQ_010_H1":"Stremio支持哪些設備?","WEBSITE_MAINPAGE_FAQ_010_P1":"我們有適用於Windows、Mac和Linux的桌面應用程序。對於移動設備,我們支持Android和iOS,但請記住iOS的功能有限(不支持大多數插件)。","WEBSITE_MAINPAGE_FAQ_010_P2":"有很多基於Android的設備可以在上面運行Stremio,比如NVIDIA Shield和Amazon Fire Stick,但我們並不正式支持它們。","WEBSITE_MAINPAGE_FAQ_011_H1":"您們能為Stremio添加某些內容嗎?","WEBSITE_MAINPAGE_FAQ_011_P1":"抱歉,我們本身不提供任何內容,但是您安裝的Stremio插件越多,您可以找到的內容就越多。","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio可以播放Magnet鏈接嗎?","WEBSITE_MAINPAGE_FAQ_012_P1":"是的,它還可以播放正常的HTTP鏈接和Torrent文件(拖放)。","WEBSITE_MAINPAGE_FAQ_013_H1":"我可以下載視頻並離線觀看嗎?","WEBSITE_MAINPAGE_FAQ_013_P1":"離線可用是一項即將推出的功能,但如果您允許Stremio在設備上緩存(從“設置”面板),您可以稍後在沒有連接的情況下觀看視頻。","WEBSITE_MAINPAGE_FAQ_014_H1":"什麼都不能用,幫幫我!","WEBSITE_MAINPAGE_FAQ_014_P1":"您確定已安裝插件嗎?如果是,請與我們的${1}幫助中心${2}聯繫","WEBSITE_MAINPAGE_FAQ_015_H1":"Stremio如何維持其開發運營?","WEBSITE_MAINPAGE_FAQ_015_P1":"我們通過${1}AdEx${2}運行非侵入性廣吿,這是一家由同一創始團隊創建的公司,專注於隱私保護、透明廣吿。","WEBSITE_MAINPAGE_FAQ_015_P2":"有關更多問題,請訪問我們的${1}幫助中心${2}。","HELP_LEARN_MORE":"幫助我們瞭解更多有關您的信息。","LIFESTYLE":"生活方式","SPORTS":"體育","FOOD_HEALTH":"飲食與健康","BEAUTY_FASHION":"美麗與時尚","NEWS":"新聞","GAMING":"遊戲","SCIENCE_EDUCATION":"科學與教育","MUSIC":"音樂","TRAVEL":"旅行","LATE_NIGHT":"深夜","REALITY":"真人","COMEDY":"喜劇","DIY":"DIY","TECH":"技術","CINEMA":"影院","CONTINUE":"繼續","SLOW_LOADING":"加載緩慢?","I_GIVE_UP":"我放棄了","LEARN_MORE":"瞭解更多","POOR_SOURCE":"此源不可用或您的網絡連接不夠快","PICK_CATEGORIES_ERR":"您必須至少選擇3個類別","ADJUST_TIMING":"調整時間","ADJUST_SIZE":"調整大小","SEARCH_ANYTHING":"您可以搜索一切...","ALL_CATEGORIES":"全部","SEARCH_CATEGORIES":"電影、劇集、YouTube和電視","SEARCH_PERSONS":"演員、導演和編劇","SEARCH_PROTOCOLS":"HTTP或Magnet鏈接","SEARCH_TYPES":"IMDB/TVDB鏈接","WATCHED":"已觀看","SHOW_LESS":"顯示較少","LAST_SEARCHES":"上次搜索","CLEAR_HISTORY":"清除歷史記錄","CHOOSE_SOME":"選擇其中一些:","NO_WEB_REMOTE":"無法加載Web Remote","STREMIO_OFFLINE":"Stremio離線","STREMIO_EXPENSIVE_CONNECTION":"我們檢測到您正在使用移動數據連接,是否繼續?","USE_DATA":"使用移動數據","WARNING":"警吿","MORE_INFO":"更多信息...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"加載...","STREMIO_TV_BACK_TO_LANGUAGES":"返回語言","STREMIO_TV_REMOTE":"遠程","STREMIO_TV_GO_TO":"去往:","STREMIO_TV_OR_SCAN":"或掃描:","STREMIO_TV_ADDON_INSTRUCTIONS":"請按照説明安裝您喜歡的插件。","STREMIO_TV_LIVE_TV":"直播電視","STREMIO_TV_RESUME_WATCHING":"繼續觀看","STREMIO_TV_LOADING_BACKGROUND":"加載背景","STREMIO_TV_CHECKING_AUTHENTICATION":"正在檢測身份驗證","STREMIO_TV_LOADING_BOARD":"加載主頁","STREMIO_TV_LOGIN_HEADER_LINE_1":"我們希望用户在使用我們的軟件時有最好的個性化體驗,","STREMIO_TV_LOGIN_HEADER_LINE_2":"正是出於這個原因,我們懇請您建立和/或登錄您的賬户,","STREMIO_TV_LOGIN_FOOTER_LINE_1":"感謝您的理解,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio團隊","STREMIO_TV_REMOTE_INSTRUCTIONS":"為了在您的智能手機/平板電腦/桌面使用Web Remote:","STREMIO_TV_WIFI_SETUP":"Wi-Fi設置","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle未檢測到互聯網連接。","STREMIO_TV_WIFI_DETAILS_1":"連接到:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"使用密碼:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"在瀏覽器中打開鏈接:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"默認","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"按最近觀看","STREMIO_TV_LIBRARY_SORT_NAME":"按名字","STREMIO_TV_LIBRARY_TIMES_WATCHED":"按觀看次數","STREMIO_TV_DETAILS_SEASON_NUMBER":"季${1}","STREMIO_TV_STREAMS_LOADING":"已加載${1}/${2}插件...","STREMIO_TV_STREAMS_STILL_LOADING":"${1}插件仍在加載...","STREMIO_TV_PLAYER_SETTINGS":"播放器設置","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"字幕延遲","STREMIO_TV_PLAYER_AUDIO_DELAY":"音頻延遲","STREMIO_TV_PLAYER_VIDEO_SCALING":"視頻縮放","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"不支持的流媒體源","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"打開外部鏈接失敗","STREMIO_TV_PLAYER_PLAY_IN_EXO":"使用ExoPlayer播放","STREMIO_TV_PLAYER_PLAY_IN_VLC":"使用libVLC player播放","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"由於播放錯誤而切換到libVLC player","STREMIO_TV_ADDONS_TITLE":"在手機或PC上使用Stremio安裝或配置插件,然後按\\"同步插件\\"","STREMIO_TV_ADDONS_SUBTITLE":"注意:確保您使用的是相同的Stremio帳户","STREMIO_TV_ADDONS_SYNC_ADDONS":"同步插件","STREMIO_TV_ADDONS_SYNC_SUCCESS":"插件成功同步","STREMIO_TV_ADDONS_SYNC_FAILED":"插件同步失敗","STREMIO_TV_META_LINK_FAILED":"打開元鏈接失敗","STREMIO_TV_CATALOG_LOADING":"目錄仍在加載...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"界面語言已更新","STREMIO_TV_SETTINGS_THEME_UPDATED":"主題已更新","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"首選語言","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"次要首選語言","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"隧道播放","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"某些設備上可能存在播放問題","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"某些視頻格式可能無法播放","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"自動幀速率匹配","STREMIO_TV_SETTINGS_NO_CACHING":"無緩存","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"默認","STREMIO_TV_SETTINGS_PROFILE_SOFT":"慢","STREMIO_TV_SETTINGS_PROFILE_FAST":"快","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"超快","STREMIO_TV_SETTINGS_SERVER_URL":"流媒體服務器URL","STREMIO_TV_SETTINGS_SERVER_VERSION":"服務器版本","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"未知","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio版本","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"編輯服務器URL","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"輸入流媒體服務器URL","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"要閲讀Stremio的隱私政策,請訪問:","STREMIO_TV_SETTINGS_TOS_TEXT":"要閲讀Stremio的條款和條件,請訪問:","STREMIO_TV_NAV_SEARCH":"搜索","STREMIO_TV_NAV_HOME":"主頁","STREMIO_TV_NAV_DISCOVER":"發現","STREMIO_TV_NAV_LIBRARY":"庫","STREMIO_TV_NAV_MOVIES":"電影","STREMIO_TV_NAV_SERIES":"劇集","STREMIO_TV_NAV_CHANNELS":"頻道","STREMIO_TV_NAV_TV":"電視直播","STREMIO_TV_NAV_SETTINGS":"設置","STREMIO_TV_NAV_ADDONS":"插件","STREMIO_TV_LOGIN_TITLE":"鏈接賬户","STREMIO_TV_LOGIN_EXPIRES_IN":"過期日期到","STREMIO_TV_LOGIN_STEP_ONE":"掃描上方的二維碼或轉到","STREMIO_TV_LOGIN_STEP_TWO":"登錄您的Stremio帳户","STREMIO_TV_LOGIN_NEW_LINK":"請求新鏈接","STREMIO_TV_LOGIN_LINK_REFRESHED":"登錄代碼已刷新","STREMIO_TV_SEARCH_PLACEHOLDER":"輸入一些東西","STREMIO_TV_SEARCH_NO_ADDONS":"沒有為目錄請求插件!","STREMIO_TV_SEARCH_BUTTON":"搜索","STREMIO_TV_SEARCH_KEY_DEL":"刪除","STREMIO_TV_SEARCH_KEY_SPACE":"空格","STREMIO_TV_SEARCH_KEY_CLEAR":"清除","STREMIO_TV_SEARCH_HISTORY_TITLE":"搜索歷史","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"您可以搜索標題、演員、頻道...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"清除搜索歷史","STREMIO_TV_FILTERS_DESCRIPTION":"從以下過濾器中選擇一個","FILTERS":"過濾器","SETTINGS":"設置","ACCOUNT":"賬户","LOGOUT":"註銷","THEMES":"主題","PLAYBACK":"播放","PLAYBACK_SPEED":"播放速度","AUDIO_TRACKS":"音軌","VIDEOS":"視頻","SERVER":"服務器","LINKS":"鏈接","ABOUT":"關於","INTERFACE":"界面","ANIMATIONS":"動畫","STATUS":"狀態","LANGUAGE":"語言","SIZE":"大小","DELAY":"延遲","BOLD":"粗體","TEXT_COLOR":"文本顏色","OUTLINE_COLOR":"輪廓顏色","BACKGROUND_COLOR":"背景顏色","BACKGROUND_BLUR":"背景模糊","SEEK_TIME_DURATION":"尋找持續時間","AUTO_PLAY":"自動播放下一集","PLAY_NOW":"現在播放","MARK_AS_WATCHED":"標記為已觀看","MARK_AS_UNWATCHED":"標記為未觀看","REWIND_TO_BEGINNING":"倒回開始","CONTINUE_WATCHING":"繼續觀看","ALL":"全部","SECONDS":"秒","ON":"開","OFF":"關","RELOAD":"重新加載","EDIT_URL":"編輯URL","NONE":"無","EMBEDDED":"內嵌","REMOTE_SWITCH_DEVICES":"開關設備","REMOTE_VIDEOS":"視頻","REMOTE_ADJUST_TIMING":"調整時間","REMOTE_ADJUST_SIZE":"調整大小","REMOTE_COULD_NOT_BE_LOADED":"無法加載Web Remote","REMOTE_RETRY":"重試","TORRENT_PROFILE_DEFAULT":"默認","TORRENT_PROFILE_SOFT":"慢","TORRENT_PROFILE_FAST":"快","TORRENT_PROFILE_ULTRA_FAST":"超快","FAQ_001_H1":"什麼是Stremio?","FAQ_001_P1":"Stremio是專為視頻娛樂而設計的多媒體中心軟件,易於使用。Stremio允許您管理和觀看自己的電影,劇集,頻道和實況電視收藏。","FAQ_001_P2":"Stremio從本地磁盤和插件系統中收集顯示給您的內容。","FAQ_001_P3":"它還會在您感興趣的新劇集/視頻/電影播出時通知您,併為您提供電影推薦。","FAQ_02_H1":"Stremio與Kodi和Plex相比如何?","FAQ_02_P1":"我們受到這兩種軟件的啟發。但是我們有不同的目標——Stremio專門針對娛樂視頻,並通過易於使用成為其主流解決方案。","FAQ_02_P2":"Stremio將永遠不會像Kodi和Plex那樣具有可定製性和豐富的功能,但它更易於使用。只需${1}就可以獲取它,並查看${2}:)","FAQ_03_H1":"Stremio與Netflix相比如何?","FAQ_03_P1":"同樣,Netflix是我們的靈感之一。我們努力實現Netflix的用户體驗,再加上許多附加的好處。但最重要的是,我們讓您可以自由管理自己的庫,並使用我們的插件系統添加新的內容源。","FAQ_03_P2":"這使得Stremio可以無限擴展,因此當您使用Stremio時,您永遠不會侷限於Netflix決定許可的內容。例如,您可以通過Stremio觀看${1}中的內容電影電視${2}, ${3} Twitch.tv${4},${5}YouTube${6},${7}Vodo${8}甚至${9}Netflix${10}本身!","FAQ_04_H1":"Stremio與Flipboard相比如何?","FAQ_04_P1":"我們不常聽到這個問題,除非與初創企業的人交談:)","FAQ_04_P2":"Stremio是通過設計一個內容聚合器來實現的,它本質上就是視頻的Flipboard。這一點在我們的首頁部分非常明顯,它為您提供目錄和新的插曲/新的視頻通知,讓您瞭解您所關注的內容,就像Flipboard一樣。","FAQ_05_H1":"Stremio與Popcorn Time相比如何?","FAQ_05_P1":"Stremio和Popcorn Time在用户界面上很相似,因為沒有很多方法可以正確製作視頻娛樂目錄:)","FAQ_05_P2":"Popcorn Time主要集中在特定來源的流媒體上,但Stremio是不受限制的,只是一個內容聚合器,它沒有鎖定到特定的內容源。","FAQ_05_P3":"此外,我們默認不提供任何Torrent插件,因此Stremio不提供官方功能的Popcorn Time用例。","FAQ_05_P4":"另一個顯著的區別是Popcorn Time是完全開源的,而Stremio是${1}部分開源的${2}。","FAQ_06_H1":"是否要添加此電影/系列?","FAQ_06_P1":"不,對不起 :(","FAQ_06_P2":"正如大多數其他問題中提到的,Stremio本身不提供任何內容,所有內容都是通過插件系統添加的。如果您有內容請求,您可以使用播放器中的“報吿”按鈕,它將向您當前使用的插件的作者發送電子郵件。","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"能否為X創建插件?","FAQ_08_P1":"完全有可能。","FAQ_08_P2":"如果您有一個插件的想法,請在${1}office@stremio.com${2}給我們留言,但請確保您的插件想法不會侵犯任何版權或使用條款。","FAQ_08_P3":"目前,我們路線圖上的下一件事是FandangoNOW,Filmon.tv video on demand和Crunchyroll的插件。","FAQ_09_H1":"Stremio是否使用BitTorrent?","FAQ_09_P1":"是的,Stremio支持BitTorrent作為流媒體協議。您可以將其與Torrent插件一起使用,也可以將.Torrent文件拖放到Stremio中,或者將磁鐵鏈接粘貼到搜索欄中。","FAQ_09_P2":"請注意,使用BitTorrent的唯一官方插件是${1}Vodo${2},它提供獨立內容,所有內容都允許與BitTorrent一起分發。","FAQ_09_P3":"我們不支持使用任何可能導致版權侵權的第三方插件。","FAQ_10_H1":"我可以在Stremio中通過官方插件觀看什麼節目?","FAQ_10_P1":"默認情況下,您可以在Stremio與它的嵌入式播放器觀看Filmon.tv,YouTube和Vodo的內容。另外,我們還有一個Twitch.tv插件,以及其他一些插件。","FAQ_10_P2":"此組合提供以下選項:","FAQ_10_L1":"Filmon.tv上的熱門電視頻道,例如E4、BBC、Bollyworld TV","FAQ_10_L2":"YouTube上的所有內容,例如BBC News、Top Gear、Vevo、PewDiePie","FAQ_10_L3":"Vodo上的獨立電影","FAQ_10_L4":"Twitch.tv上的在線遊戲廣播","FAQ_10_P3":"此外,Guidebox和Netflix插件提供了許多內容源,它們不完全在Stremio中播放,而是重定向到給定的服務。例如,Guidebox插件將為您提供可在美國免費播放的精選電影,這些電影來自TubiTV和Crackle等服務。","FAQ_11_H1":"Stremio無法安裝,我該怎麼辦?","FAQ_11_P1":"如果您在Windows上,請嘗試${1}此替代安裝程序${2}。","FAQ_11_P2":"如果您使用的是Mac OS X,請注意,我們不支持任何比OS X Mavericks(10.9)更舊的版本。","FAQ_11_P3":"如果您使用的是Linux,請注意,我們目前只支持64位(x64)Linux。","FAQ_11_P4":"如果您仍然無法解決您的問題,請寫信給我們的${1}Facebook羣組${2}。","FAQ_12_H1":"為什麼我的殺毒軟件會報毒?Stremio安全嗎?","FAQ_12_P1":"我們向您保證Stremio是${1}100%安全的${2}。","FAQ_12_P2":"您的殺毒軟件報毒是因為我們的安裝程序中包含廣吿,一些殺毒軟件將其識別為廣吿軟件。","FAQ_12_P3":"如果您仍然不確定,可以嘗試我們的${1}替代安裝程序${2}。","FAQ_13_H1":"如何製作插件?","FAQ_13_P1":"對於初學者,我們建議您查看GitHub上的${1}插件系統模塊${2}。","FAQ_13_P2":"之後,您可以按照${1}Hello World教程${2}進行操作。","FAQ_13_P3":"如果您沒有任何編程技能,請在${1}Reddit社區${2}上發佈您的想法,並在${3}office@stremio.com${4}上與我們聯繫您的插件想法。","FAQ_14_H1":"插件是如何發佈的?","FAQ_14_P1":"當您創建一個插件和主機,並在清單中放置一個指向工作插件地址的終端節點字段時,該插件將自動發佈到我們的${1}插件目錄${2}。","FAQ_14_P2":"發生這種情況是因為Stremio插件模塊的服務器部分會自動調用我們的API來聲明插件。當我們的API驗證您的終端節點為有效的插件時,它將開始顯示在目錄中。","FAQ_15_H1":"我可以在瀏覽器中運行Stremio嗎?","FAQ_15_P1":"目前還沒有,但即將到來!","FAQ_15_P2":"如果您想看到Alpha版本,可以在這裏看到:${1}alpha4.strem.io${2}. 請記住,此Alpha版本上已禁用流式處理。我們支持Chrome、Firefox、Opera和Edge","FAQ_16_H1":"電視投屏不起作用/字幕不起作用","FAQ_16_P1":"電視投屏使用DLNA技術,這在不同的電視品牌和型號之間非常不一致。由於這個原因,我們沒有能力在每種情況下都測試它,所以它還遠遠不夠完美。儘管如此,我們仍在不斷改進,但我們無法為您提供DLNA能夠在您的電視上開始正常工作的預計時間。","FAQ_16_P2":"如果您在“投屏”菜單中看不到您的電視,請嘗試禁用網絡連接並重新啟用它(在Windows上,右鍵單擊網絡並使用“啟用/禁用”),以及重新啟動路由器、電視和PC。","FAQ_16_P3":"如果您仍然遇到問題,您可以通過將您的電視品牌和型號信息發送到${1}來幫助我們”office@stremio.com${2}。","FAQ_16_P4":"同時,我們推薦Chromecast,我們非常支持Chromecast,或者直接用HDMI線將電視與PC連接。","FAQ_17_H1":"Stremio卡死和/或崩潰,我能做什麼?","FAQ_17_P1":"首先,如果您使用的是帶有AVG殺毒軟件的Windows 7,這種組合會產生問題。問題出在AVG本身,我們這邊沒有合理的辦法解決。不幸的是,去除或禁用殺毒軟件將不起作用。唯一的解決辦法是用別的東西代替AVG","FAQ_17_P2":"如果不是這個問題,但您仍在使用Windows,請更新到最新的service pack並更新/重新安裝您的GPU驅動程序,然後重試。","FAQ_17_P3":"如果您的問題仍未解決,或者您使用的是Mac或Linux,請寫信給我們,在${1}我們的Facebook羣組${2}報吿問題的確切細節。","FAQ_18_H1":"如何製作插件?","FAQ_18_P1":"對於初學者,我們建議您查看GitHub上的${1}插件系統模塊${2}。","FAQ_18_P2":"之後,您可以按照${1}Hello World教程${2}進行操作。","FAQ_18_P3":"如果您沒有任何編程技能,請在${1}Reddit社區${2}上發佈您的想法,並在${3}上與我們聯繫您的插件想法。”office@stremio.com${4}。","FAQ_19_H1":"為什麼Stremio佔用磁盤空間?","FAQ_19_P1":"Stremio有一個本地緩存來臨時保存您流式傳輸的視頻文件。","FAQ_19_P2":"這有兩個好處:第一,它允許Stremio預先緩衝視頻,以確保流媒體更流暢。其次,它將視頻保存在本地緩存中,以便您可以繼續離線觀看。","FAQ_19_P3":"Stremio保留了多少取決於“設置”面板中的緩存設置。Stremio可能會在您的磁盤上保留到設置的數量(例如2GB),除非當前流式傳輸的視頻大於該數量,在這種情況下,必須分配足夠的存儲來保留它,直到您結束流式傳輸。","FAQ_20_H1":"緩存文件夾在哪裏?","FAQ_20_P1":"在Windows上,Stremio緩存位於您在設置中選擇的驅動器中(例如\\"E:\\\\stremio-cache\\")","FAQ_20_P2":"在MacOS上,它位於\\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"在Linux上,它位於\\"~/.stremio/stremio-cache\\"或\\"~/stremio-cache\\"","FAQ_21_H1":"我得到\\"流媒體服務器未找到\\"錯誤,我能做什麼?","FAQ_21_P1":"如果出現此錯誤,則表示以下幾點之一:","FAQ_21_P2":"1)您正試圖通過我們的${1}web版本${2}使用一個由YouTube/BitTorrent源代碼支持的插件。在這種情況下,您應該從${3}我們的網站${4}安裝我們的桌面版本","FAQ_21_P3":"2)Stremio安裝有問題。在這種情況下,請嘗試從${1}網站${2}重新安裝我們的最新桌面版本。如果這沒有幫助,請嘗試禁用殺毒軟件和防火牆,重新啟動電腦,然後重試。如果這依然不起作用,請寫信給我們的${3}Facebook羣組${4}","FAQ_22_H1":"我無法在iOS上看到/使用大多數插件","FAQ_22_P1":"由於Apple App Store條款和條件中的限制,我們限制iOS應用程序只能使用一組特定的插件。","FAQ_22_P2":"不過,請放心,將來會有更多的iOS插件,我們還可能添加一個集成,通過將iOS應用程序連接到Stremio流媒體服務器,您將可以使用所有Stremio插件。"}')},8097:e=>{"use strict";e.exports=JSON.parse('{"TYPE_movie":"電影","TYPE_series":"劇集","TYPE_tv":"電影片道","TYPE_channel":"頻道","TYPE_other":"其他","TYPE_movie_PL":"電影","TYPE_series_PL":"劇集","TYPE_tv_PL":"電影片道","TYPE_channel_PL":"頻道","TYPE_other_PL":"其他","TYPE_ALL":"All","VIDEO":"影片","BACK":"返回","MORE":"更多","DONE":"完成","COPY":"複製","SETTINGS_CASTING_MODE_PICKER":"Casting mode","CASTING_MODE_HLSV2":"Default","CASTING_MODE_VLC":"libVLC","CASTING_MODE_NO_TRANSCODING":"No transcoding","Discover":"發現","Board":"首頁","Library":"庫","My Library":"我的庫","Calendar":"日曆","NOTIFICATION_ONLINE":"您當前處於線上狀態","NOTIFICATION_OFFLINE":"您當前處於離線狀態","INTERNET_CONNECTION":"網路連線","STORAGE_FULL_TITLE":"警告:儲存空間已滿!","STORAGE_FULL_TEXT":"Stremio將無法儲存您的設定、首選項或登入資訊,考慮重新啟動或重新安裝Stremio。","SEARCH":"搜尋","SEARCH_NO_RESULTS":"未找到結果","SEARCH_EXPLANATION_CONTENT":"搜尋電影、劇集、YouTube和電影片道","SEARCH_EXPLANATION_PEOPLE":"搜尋演員、導演和編劇","SEARCH_PASTE_LINKS":"貼上HTTP和Magnet連結","SEARCH_OR_PASTE_LINK":"Search or paste link","ADD_TO_LIB":"新增到庫中","REMOVE_FROM_LIB":"從庫中刪除","ADDED_TO_LIB":"新增到庫中","REMOVED_FROM_LIB":"從庫中刪除","TRAILER":"預告片","WATCH_TRAILER":"觀看預告片","WATCH_NOW":"立即觀看","SHOW":"檢視","SHOW_MOVIE":"檢視電影","WATCH_RANDOM":"隨機觀看","IMDB_RATING":"IMDb評分","YEAR":"年份","DIRECTOR":"導演","WRITER":"編劇","LEAD_ACTORS":"主演","CAST":"全部演員","CREW":"全部工作人員","SHOW_MORE_CAST":"顯示更多 »","AIRED":"播出時間","SEASONS":"季","GENRE":"型別","CATALOG":"目錄","SUMMARY":"簡介","SHOW_MORE":"顯示更多","SIMILAR":"相似","UPCOMING":"即將上映","ENDED":"已完結","DURATION":"時長","FEATURED":"功能","METADATA":"元資料","CATEGORY":"類別","LINKS_GENRES":"Genres","LINKS_CAST":"Cast","LINKS_DIRECTORS":"Directors","SEARCH_VIDEOS":"搜尋影片","SEARCH_PLACEHOLDER":"搜尋或貼上URL","ADDON":"外掛","ADDONS":"外掛","OFFICIAL":"官方","ADDONS_OFFICIAL":"官方Stremio外掛","ADDONS_POPULAR":"在您所在的地區很受歡迎","ADDON_FREE":"免費","ADDON_PEERED":"連線","ADDON_SUBSCRIPTION":"訂閱","ADDON_STREAM_GEORESTRICTED":"在您所在的地區不提供","ADDON_STREAM_OFFLINECACHE":"離線快取","ADDON_STREAM_LOCALFILE":"本地檔案","SHARE_ADDON":"分享外掛","AVAILABLE_STREAMS":"可用流媒體","NO_STREAM":"未找到流媒體","ALL_ADDONS":"All","INSTALL_MORE_ADDONS":"要獲取更多流媒體,請安裝更多外掛","STREAM_NOT_SUPPORTED":"此平臺不支援所選流媒體。","ADDON_CATALOGUE":"顯示所有外掛 »","ADDON_CATALOGUE_MORE":"安裝外掛","REPO_ADDED":"已新增儲存庫","ADDON_REPO_EXIST_ERR":"此外掛集合已存在","ADDON_REPO_ERR":"新增集合時出錯","ADDON_ADD_ERR":"新增外掛時出錯","ERR_ADDON_PROTECTED":"無法解除安裝外掛,它受到保護","ERR_ADDON_INTERNAL_SOMETHING_WRONG":"出了一些問題——身份驗證可能失敗","ERR_NOT_COLLECTION_URL":"不是集合URL","ERR_NOT_ADDON_URL":"不是有效的外掛URL","ERR_DETECTFROMURL":"再此URL中找不到外掛/集合","ADDON_DUPLICATE_WARNING":"警告:重複的外掛","ADDON_COLLECTION_SET_FAILED":"將已安裝的外掛同步到您的賬戶失敗","SETTINGS_DATA_EXPORT":"匯出使用者資料","ADDON_PULL_FAILED":"從您的帳戶同步已安裝的外掛失敗","REFRESH_ON_CLICK":"點選重試","STILL_IN_THEATER":"電影還在影院上映","WATCH_IN_CINEMA":"請到您本地的影院觀看","IN_THEATER":"在影院上映","GET_TICKETS":"購票","UPCOMING_EPISODE":"下一集","UPCOMING_EPISODE_MESSAGE":"這一集即將播出","MISSING_DATE_EPISODE":"缺失的一集日期","MISSING_DATE_EPISODE_MESSAGE":"這一集可能還沒有播出","CHANNEL_NOT_SCRAPED":"這個頻道還沒有被削刮,請過幾分鐘再來。","ADD_TO_LIBRARY_TO_GET_NOTIFIED":"將其新增到庫中,以便在可用時收到通知。","GET_NOTIFIED_WHEN_AVAILABLE":"一旦可用,您將會收到通知。","WARNING_STREAMING_SERVER":"警告:找不到本地流媒體伺服器,來自本地檔案、YouTube、和BitTorrent的流媒體將不可用。","WARNING_STREAMING_SERVER_DISMISS":"Dismiss","WARNING_STREAMING_SERVER_LATER":"Later","DECODER_WARNING":"警告:您的硬體可能不支援此影片,請記住,播放可能會很慢。","PLAYER_ERROR":"糟糕,播放器錯誤","PLAYER_ERROR_LOOKSLIKE":"看起來似乎","PLAYER_ORIENTATION":"播放器方向","PLAYER_ORIENTATION_LANDSCAPE_SHORT":"鎖定","PLAYER_ORIENTATION_SENSOR_SHORT":"感測器","PLAYER_ORIENTATION_LANDSCAPE":"播放器方向鎖定橫向","PLAYER_ORIENTATION_SENSOR":"播放器方向自動(感測器)","PLAYER_PLAYBACK_SPEED":"播放速度","PLAYER_PLAYBACK_ERROR":"播放錯誤,請重試","PLAYER_PLAYBACK_ERROR_UNKNOWN":"未知錯誤","PLAYER_PLAYBACK_ERROR_DEFAULT":"抱歉,{{productName}}無法播放此影片。","PLAYER_SUBTITLES_LANGUAGES":"Subtitles Languages","PLAYER_SUBTITLES_VARIANTS":"Subtitles Variants","PLAYER_SUBTITLES_SETTINGS":"Subtitles Settings","PLAYER_SUBTITLES_DISABLED":"Subtitles are disabled","PLAYER_SUBTITLES_VERTICAL_POSIITON":"Vertical Position","PLAYER_PLAY":"Play","PLAYER_PAUSE":"Pause","PLAYER_NEXT_VIDEO":"Next Video","PLAYER_MUTE":"Mute","PLAYER_UNMUTE":"Unmute","PLAYER_LIVE":"直播","PLAYER_NEXT_VIDEO_TITLE":"下個影片","PLAYER_NEXT_VIDEO_BUTTON_DISMISS":"關閉","PLAYER_NEXT_VIDEO_BUTTON_WATCH":"現在觀看","STREAMING_FROM":"流媒體","CASTING_TO":"投屏到","NETWORK_STATUS":"網路狀態","STREAM_SPEED":"串流速度:","STREAM_BUFFERED":"已緩衝:","PEERS_INFO":"節點資訊","PEERS_ACTIVE":"活躍:","PEERS_CONNECTED":"已連線:","PEERS_WAITING":"等待:","TRANSCODING_WARNING":"警告:轉碼影片。","STREAM_LOADING":"載入...","PLAYING_LOCAL":"從本地檔案播放","PLAYING_CACHE":"從快取播放","WRONG_SUBS":"字幕錯誤?","ERR_SUBS_LOADING_TITLE":"載入字幕時出錯","ERR_SUBS_LOADING":"字幕載入失敗:這可能是您正在使用的外掛或網路連線的問題","WARN_FOLLOWING_SUB_ADDONS_FAILED":"以下字幕外掛失敗","ERR_CASTING_UPDATE_TITLE":"無法更新投屏裝置資訊:流媒體伺服器可能離線","CHOOSE_DEVICE":"選擇在哪個裝置上播放","NO_CAST_DEVICES":"無可用投屏裝置。","NO_SETTINGS":"無可用設定。","PHONE_TABLET":"手機/平板電腦","SUBTITLES":"字幕","SUBTITLES_CHANGE":"調整字幕","SUBTITLES_CHANGE_NONE":"抱歉,這種語言沒有其他字幕。","SUBTITLES_CHANGE_ACIVE":"當前字幕#{{subtitlesDialog.activeIdx + 1}}被啟用,點選\\"繼續\\"啟用字幕#{{subtitlesDialog.pickedIdx + 1}}.","SUBTITLES_OR":"或者,","SUBTITLES_ADJUST_DELAY":"調整字幕延遲:","SUBTITLES_ADJUST_DELAY_SHORTCUT":"或在播放時使用G / H鍵進行調整。","SUBTITLES_ADJUST_DELAY_TIP":"提示:您可以在播放時使用G / H鍵進行調整。","SUBTITLES_DELAY":"字幕延遲:","SUBTITLES_LOADING":"載入字幕...","SUBTITLES_UNAVAILABLE":"沒有可用的外部字幕","SUBTITLES_DISABLED":"關閉","AUDIO":"Audio","DEFAULT_LANGUAGE":"Default Language","DEFAULT_SECONDARY_LANGUAGE":"Default Secondary Language","SEASON":"季","EPISODE":"集","SPECIAL":"Special","SORT":"排序","SORT_BY":"排序按照","FILTER":"篩選","SORT_TRENDING":"熱門","SORT_RECENT":"最近","SORT_ALPHABET":"首字母","SORT_RATING":"評分","SORT_WATCHED":"已觀看","SORT_YEAR":"年份","SELECT_TYPE":"Select type","SELECT_SORT":"Select sort","SELECT_CATALOG":"Select catalog","SELECT_GENRE":"Select genre","SORT_LASTWATCHED":"By last watched","SORT_NAME":"By name","SORT_TIMESWATCHED":"By times watched","New for You":"新的","New Episodes":"新劇集","New Videos":"新影片","Recommendations":"推薦","LIBRARY_RESUME":"簡介","LIBRARY_PLAY":"Play","LIBRARY_DETAILS":"詳情","LIBRARY_RESUME_DISMISS":"清除","LIBRARY_CLEAR_PROGRESS":"Clear Progress","LIBRARY_REMOVE":"Remove","DISCOVER_FEATURED":"功能","DISCOVER_TOP":"熱門","DISCOVER_OSCAR":"奧斯卡獲獎作品","DISCOVER_WARNING_TITLE":"糟糕!","DISCOVER_EMPTY_CATALOG":"此外掛返回空內容。","DISCOVER_ADULT_WARNING":"此內容僅對成人可見,您是否已滿18週歲?","DISCOVER_NOADDON_WARNING":"警告:此型別沒有可用的Stremio外掛,顯示已儲存的專案,此處不會更新任何內容。","DISCOVER_LOAD_ERR":"內容未載入,發生錯誤。","DISCOVER_ADDON_UNINSTALLED":"此內容不再可用,您可能已解除安裝外掛。","UNINSTALL_THIS_ADDON":"解除安裝此外掛","ERR_ADDON_NOT_INSTALLED":"未安裝此外掛,立即安裝?","DETAIL_RECEIVE_NOTIF_SERIES":"接受新劇集的通知","DETAIL_RECEIVE_NOTIF_VIDEOS":"接受新影片的通知","SIDEBAR_SHOW_STREAMS":"顯示流媒體","RELAUNCH":"立即重新啟動!","UPGRADE":"新版本可用!升級至Stremio的最新版本","RELOAD_UI":"重新載入使用者介面","MANUAL_UPDATE_TITLE":"更新您的Stremio版本","MANUAL_UPDATE_LINE1":"您執行的是一個過時的Stremio版本,這是非常不推薦的。","MANUAL_UPDATE_LINE2":"請儘快更新。","BUTTON_UPDATE_LATTER":"不是現在","BUTTON_UPDATE_NOW":"更新","ANONYMOUS_USER":"匿名使用者","DONT_HAVE_ACC":"還沒有賬戶?","HAVE_ACC":"已經有賬戶了?","PASSWORD":"密碼","PASSWORD_CONFIRM":"確認密碼","EMAIL":"電子郵箱","FB_LOGIN":"使用Facebook登入","FB_NOTHINGSHARED":"未經您的允許,任何內容都不會被共享","FB_NOPOST":"我們不會替您傳送任何東西","OR":"或","I_ACCEPT":"我接受","I_ACCEPT_BY_CLICKING":"透過點選上面的按鈕,我宣告我接受","TOS":"條款和條件","MUST_ACCEPT_TERMS":"您必須接受條款","PASSWORDS_NOMATCH":"密碼不匹配","SIGN_UP":"註冊","SIGN_UP_EMAIL":"使用電子郵箱註冊","CLICK_TO_SIGN_UP":"點選此處註冊。","LOG_IN":"登入","LOG_OUT":"登出","EXIT_FULLSCREEN":"退出全屏模式","ENTER_FULLSCREEN":"進入全屏模式","PLAY_URL_MAGNET_LINK":"播放URL/Magnet連結","HELP_FEEDBACK":"幫助和反饋","TERMS_OF_SERVICE":"服務條款","PRIVACY_POLICY":"隱私政策","ABOUT_STREMIO":"關於Stremio","USER_PANEL":"使用者面板","LOGIN_LABEL":"Login","GUEST_LOGIN":"訪客登入","GUEST_LOGIN_NOTICE":"不建議訪客登入,使用常規登入允許Stremio同步您的庫,接受喜愛的劇集/頻道的通知。您確定要繼續嗎?","GUEST_LOGIN_NOTICE_2":"不建議訪客登入,您將沒有同步的庫和首頁通知,這是Stremio的重要功能。您確定要繼續嗎?","CLICK_HERE":"點選此處","WRONG_PASSWORD":"錯誤的電子郵箱或密碼,如果您忘了密碼,","SET_A_PASS":"設定密碼","RESET_PASSWORD":"重置密碼","FORGOT_PASSWORD":"忘記密碼?","EMAIL_USED_WITH_FB":"此電子郵箱與Facebook登陸一起使用。","INVALID_EMAIL":"請輸入有效的電子郵箱地址","INVALID_PASSWORD":"請輸入有效的密碼","CONN_ERR":"連線錯誤,請稍後再試。\\n\\n如果問題仍然存在,請禁用防火牆/防毒軟體(特別是Bitdefender)。","IMPORT_FROM_GUEST":"從訪客賬戶匯入庫","RECEIVE_UPDATES_EMAIL":"從Stremio接受電子郵件更新","LOGIN_FAILED":"登陸失敗。","SIGNUP_FAILED":"註冊失敗。","SEARCH_FAILED":"搜尋失敗","EMAIL_USED":"此電子郵箱已被使用。","WAITING_FB_LOGIN":"使用Facebook登入...","EXTERNAL_PLAYER_TITLE":"在外部播放器中播放","EXTERNAL_REMEMBER_PLAYER":"您想記住您的選擇嗎","EXTERNAL_ALWAYS_PLAY":"是","EXTERNAL_ONLY_ONCE":"不是","BEST_FIT":"最佳","FIT_SCREEN":"適合螢幕","FILL":"填充","16:9":"16:9","4:3":"4:3","Original":"原始","INTRO_TASTE":"告訴我們您喜歡什麼","INTRO_TASTE_LONG":"告訴我們您想看什麼","INTRO_TASTE_PICK":"選擇{{interestsRemaining}}興趣","INTRO_TASTE_PICK_MORE":"選擇{{interestsRemaining}}更多興趣","INTRO_TASTE_HELP_US":"幫助我們瞭解更多有關您的資訊。","INTRO_TASTE_CHOOSE_THESE":"選擇其中一些:","INTRO_TASTE_CHOOSE_MIN":"至少選3個類別","INTRO_TASTE_CHOOSE_MIN_ERR":"您必須至少選擇3個類別!","INTRO_TASTE_LIFESTYLE":"生活方式","INTRO_TASTE_SPORTS":"體育","INTRO_TASTE_FOOD_HEALTH":"飲食與健康","INTRO_TASTE_BEAUTY_FASHION":"美麗與時尚","INTRO_TASTE_NEWS":"新聞","INTRO_TASTE_GAMING":"遊戲","INTRO_TASTE_SCIENCE_EDU":"科學與教育","INTRO_TASTE_MUSIC":"音樂","INTRO_TASTE_TRAVEL":"旅行","INTRO_TASTE_LATE_NIGHT":"深夜秀","INTRO_TASTE_REALITY":"真人","INTRO_TASTE_COMEDY":"喜劇","INTRO_TASTE_DIY":"DIY","INTRO_TASTE_TECH":"技術","INTRO_TASTE_CINEMA":"影院","ADDON_NOT_SUPPORTED":"此平臺不支援選定的外掛。","ADDON_DISCLAIMER":"使用第三方外掛將始終受到您的責任和您所在的司法管轄區的法律的約束。","ADDON_ACTIVATE":"啟用此外掛?","ADDON_REPO_ADD":"外掛集合URL","ADDON_ADD":"新增","ADD_ADDON":"Add addon","ADD_ADDON_DESCRIPTION":"You can add an addon via an external link, which will appear under Installed addons.","PASTE_ADDON_URL":"Paste addon URL","WHATS_NEW":"最新訊息","BUTTON_CONTINUE":"繼續","BUTTON_ACTIVATE":"啟用","BUTTON_ACTIVATED":"已啟用","BUTTON_CANCEL":"取消","BUTTON_SUBMIT":"Submit","BUTTON_DISMISS_ALL":"清除全部","BUTTON_VIEW_ALL":"檢視全部","BUTTON_SEE_ALL":"See All","BUTTON_COLOR_TRANSPARENT":"Transparent","LIB_EMPTY":"您的庫看起來是空的,看看它有多有用:)","HOW_START":"您可以從這裡開始:","LIB_EMPTY_CAL":"您的日曆顯示您庫中的劇集。","HOW_START_CAL":"下面是如何新增劇集:","LIB_EMPTY_BOARD":"主頁顯示與您的庫相關的通知&推薦。","HOW_START_BOARD_WAIT":"請在您的庫中新增一些劇集或頻道給我們幾分鐘來處理:)","HOW_START_BOARD":"下面是如何向其中新增劇集&電影:","IMPORT_FB":"從Facebook匯入您喜歡的東西","IMPORT_TRAKT":"從Trakt匯入媒體庫","IMPORT_DISCOVER":"從發現中找到有趣的東西","IMPORT_DISK":"匯入本地磁碟上的電影或節目","PLEASE_CREATE_ACC":"請建立一個賬戶以啟用庫同步&主頁。","IMPORT_DISCOVER_SIGNUP":"註冊並從發現中找到有趣的東西","IMPORT_DISK_SIGNUP":"註冊並匯入本地磁碟上的電影或節目","LIB_EMPTY_CLOUD":"雲端庫","LIB_EMPTY_CLOUD_DESC":"在所有裝置上同步個人雲端庫","LIB_EMPTY_EARLY":"第一時間","LIB_EMPTY_EARLY_DESC":"接收新劇集的通知","LIB_EMPTY_PERSONAL":"個性化","LIB_EMPTY_PERSONAL_DESC":"獲取個性化推薦","LIB_EMPTY_CALENDAR_DESC":"安排您的個性化觀看日曆","LIB_EMPTY_ALL":"註冊以獲取所有這些:","LIB_EMPTY_BEST":"註冊以獲得最佳的Stremio","LIB_EMPTY_OTHER":"註冊以啟用日曆和其他炫酷功能","CALENDAR_ADDED":"Stremio日曆已新增到預設桌面日曆中。","CALENDAR_ADDED_MSG":"如果這不起作用,請手動將此URL新增到日曆應用程式中","TRAKT_EXPIRED":"Trakt驗證已過期,請轉到設定並重新驗證","TRAKT_REQUIRES_LOGIN":"Trakt錯誤","TRAKT_REQUIRES_LOGIN_MSG":"您需要登入","SETTINGS_LABEL":"設定","SETTINGS_NAV_GENERAL":"常規","SETTINGS_NAV_PLAYER":"播放器","SETTINGS_NAV_STREAMING":"流媒體","SETTINGS_NAV_SHORTCUTS":"快捷鍵","SETTINGS_SHORTCUT_RELOAD_APP":"重新載入應用程式","SETTINGS_SHORTCUT_OPEN_SETTINGS":"開啟設定","SETTINGS_SHORTCUT_SWITCH_TABS":"切換標籤","SETTINGS_SHORTCUT_CYCLE_TABS_FORWARD":"向前迴圈標籤","SETTINGS_SHORTCUT_CYCLE_TABS_BACKWARD":"向後迴圈標籤","SETTINGS_SHORTCUT_NAVIGATE_MENUS":"Navigate Between Menus","SETTINGS_SHORTCUT_GO_TO_SEARCH":"Go to Search","SETTINGS_SHORTCUT_EXIT_BACK":"退出/返回","SETTINGS_SHORTCUT_MENU_PLAYBACK_SPEED":"Toggle Playback Speed Menu","SETTINGS_SHORTCUT_MENU_VIDEOS":"Toggle Videos Menu","SETTINGS_SHORTCUT_MENU_SUBTITLES":"Toggle Subtitles Menu","SETTINGS_SHORTCUT_MENU_INFO":"Toggle Info Menu","SETTINGS_SHORTCUT_FULLSCREEN":"切換全屏","SETTINGS_SHORTCUT_SHOW_CONTROLS":"顯示控制元件","SETTINGS_SHORTCUT_PLAY_PAUSE":"播放/暫停","SETTINGS_SHORTCUT_VOLUME_UP":"增大音量","SETTINGS_SHORTCUT_VOLUME_DOWN":"降低音量","SETTINGS_SHORTCUT_SEEK_NEXT":"尋找下一個","SETTINGS_SHORTCUT_SEEK_PREV":"尋找上一個","SETTINGS_SHORTCUT_SEEK_BACKWARD":"Seek Backward","SETTINGS_SHORTCUT_SEEK_FORWARD":"Seek Forward","SETTINGS_SHORTCUT_PLAY_NEXT":"播放下一個","SETTINGS_SHORTCUT_INCREASE_SUB_SIZE":"增加字幕大小","SETTINGS_SHORTCUT_DECREASE_SUB_SIZE":"減小字幕大小","SETTINGS_SHORTCUT_INCREASE_SUB_DELAY":"增加字幕延遲","SETTINGS_SHORTCUT_DECREASE_SUB_DELAY":"減少字幕延遲","SETTINGS_SHORTCUT_TOGGLE_SIDEBAR":"切換側邊欄","SETTINGS_SHORTCUT_OR":"or","SETTINGS_SHORTCUT_TO":"to","SETTINGS_SHORTCUT_SPACE":"Space","SETTINGS_SHORTCUT_SHIFT":"Shift","SETTINGS_SHORTCUT_ESC":"Esc","SETTINGS_TRAKT_AUTHENTICATE":"Authenticate","SETTINGS_FACEBOOK_IMPORT":"Import","SETTINGS_CALENDAR_SUBSCRIBE":"Subscribe","SETTINGS_INTERFACE_LANGUAGE":"Interface Language","SETTINGS_LAUNCH_STARTUP":"開機時啟動","SETTINGS_VLC_DEFAULT":"使用VLC播放","SETTINGS_UI_LANGUAGE":"使用者介面語言","SETTINGS_FULLSCREEN_EXIT":"Esc鍵退出全屏","SETTINGS_GAMEPAD":"啟用遊戲手柄支援","SETTINGS_CLOSE_WINDOW":"關閉視窗時結束應用程式","SETTINGS_SUBTITLES_LANGUAGE":"預設字幕語言","SETTINGS_SUBTITLES_SIZE":"預設字幕大小","SETTINGS_SUBTITLES_BACKGROUND":"字幕背景","SETTINGS_SUBTITLES_COLOR":"字幕顏色","SETTINGS_SUBTITLES_COLOR_OUTLINE":"字幕輪廓顏色","SETTINGS_SUBTITLES_COLOR_BACKGROUND":"字幕背景顏色","SETTINGS_SEEK_KEY":"方向鍵控制進度","SETTINGS_SEEK_KEY_SHIFT":"按住Shift鍵時方向鍵控制進度","SETTINGS_REWIND_FAST_FORWARD_DURATION":"Rewind & Fast-forward duration","SETTINGS_BINGE":"自動播放下一集","SETTINGS_NEXT_VIDEO":"顯示播放下一集的通知","SETTINGS_NEXT_VIDEO_TRIGGER":"顯示下一集的通知:","SETTINGS_NEXT_VIDEO_POPUP_DURATION":"Next video popup duration","SETTINGS_PLAY_IN_BACKGROUND":"Play in background","SETTINGS_PLAY_IN_EXTERNAL_PLAYER":"Play in external player","SETTINGS_RESIZE":"播放前自動調整視窗大小","SETTINGS_OVERRIDE_SERVER":"覆蓋流媒體伺服器URL(高階)","SETTINGS_SERVER_URL":"流媒體伺服器URL:","SETTINGS_SERVER_AVAILABLE":"流媒體伺服器可用。","SETTINGS_SERVER_UNAVAILABLE":"流媒體伺服器不可用。","SETTINGS_SERVER_STATUS_ONLINE":"Online","SETTINGS_SERVER_STATUS_ERROR":"Error","SETTINGS_SERVER_CONFIGURE_TITLE":"Configure streaming server url","SETTINGS_SERVER_CONFIGURE_INPUT":"Enter a streaming server url","SETTINGS_SERVER_CACHE_SIZE":"Cache size","SETTINGS_SERVER_TORRENT_PROFILE":"Torrent profile","SETTINGS_HTTPS_ENDPOINT":"流媒體HTTPS結點:","SETTINGS_USE_BETA":"始終使用最新的測試版","SETTINGS_IMPORT_FB":"從Facebook匯入","SETTINGS_IMPORT_DISK":"從本地磁碟匯入","SETTINGS_IMPORT_TRAKT":"從Trakt匯入","SETTINGS_PAUSE_MINIMIZED":"最小化時暫停播放","SETTINGS_HWDEC":"硬體解碼加速","SETTINGS_BACKGROUND":"後臺播放","SETTINGS_SUBSCRIBE_CALENDAR":"訂閱到日曆","SETTINGS_REQ_EXPORT":"請求匯出資料","SETTINGS_ACC_DELETE":"請求刪除賬戶","SETTINGS_CHANGE_PASSWORD":"更改密碼","SETTINGS_TOS":"服務條款","SETTINGS_SUPPORT":"聯絡支援人員","SETTING_LANGUAGE":"語言","SETTINGS_TRAKT":"Trakt自動跟蹤","SETTINGS_TRAKT_LOGOUT":"從Trakt.tv登出","SETTINGS_SCAN_FOR_REMOTE":"掃描二維碼開啟遙控器","SETTINGS_DESKTOP_NOTIFICATIONS":"桌面通知","SETTINGS_DATA_SAVER":"移動資料警告","SETTINGS_LANGUAGE_INTERFACE":"介面","SETTINGS_LANGUAGE_SUBS":"預設字幕","SETTINGS_ENABLE_DEFAULT_AUDIO_TRACK":"自動選擇音軌","SETTINGS_DEFAULT_AUDIO_TRACK":"預設音軌","SETTINGS_ACCOUNT":"賬戶","SETTINGS_VERSION":"版本","SETTINGS_MPV_WINDOW":"在單獨視窗中啟動播放器(高階)","SETTINGS_PLAY_IN_EXTERNAL":"總是在外部播放器中開啟影片","SETTINGS_STORAGE_BUTTON":"清除本地儲存","SETTINGS_STORAGE_MODAL_TITLE":"您確定嗎?","SETTINGS_STORAGE_MODAL_MESSAGE":"這將清除本地儲存並使您登出","SETTINGS_HWDEC_PICKER":"選擇硬體加速解碼設定","SETTINGS_HW_AUTOMATIC":"自動","SETTINGS_HW_DISABLED":"關閉","SETTINGS_HW_ACCELERATED":"解碼加速","SETTINGS_HW_FULL":"全加速","SETTINGS_HW_LEGACY":"舊版","SUBSPICKER_AUDIO":"音訊","SUBSPICKER_SUBTITLES":"外掛字幕","SUBSPICKER_BLACK_BACKGROUND":"使用黑色背景色","SUBSPICKER_VERTICAL_OFFSET":"垂直偏移量","SUBSPICKER_SIZE":"大小","SUBSPICKER_DELAY":"延遲","SUBSPICKER_EMBEDDED_SUBS":"內嵌字幕","MOBILE_PRIVACY_POLICY":"隱私政策","MOBILE_CRASH_REPORTING":"崩潰報告","MOBILE_ZOOM_TO_FILL":"縮放填充螢幕","MOBILE_PASSTHROUGH":"數字音訊輸出(直通)","MOBILE_RUN_LOW_BATTERY":"電池電量低時執行","MOBILE_RUN_FOREGROUND":"作為前臺服務執行","MOBILE_PERFORMANCE":"效能&穩定性","MOBILE_SERVER_ONLINE":"線上","MOBILE_SERVER_OFFLINE":"離線","MOBILE_QR_EXPIRES":"二維碼到期時間","MOBILE_LOG_INTO":"登陸到您的Stremio賬戶","MOBILE_SCAN_QR":"掃描上面的二維碼或轉到","MOBILE_LINK_ACCOUNT":"連結賬戶","MOBILE_SPEEDPICKER_CANCEL":"取消","MOBILE_SPEEDPICKER_LABEL":"選擇播放速度","MOBILE_EMPTY_LIBRARY":"您的庫為空","MOBILE_NO_ADDON_ACTIVE":"沒有活動的此型別Stremio外掛。","MOBILE_ORGANIZER_WARNING":"Stremio Organizer應用程式提供的功能有限,要獲得可播放流的列表和完整的Stremio體驗,請使用Stremio桌面客戶端。","MOBILE_ADDON_LOADING":"仍在載入","MOBILE_ADDONS_LOADING":"外掛仍在載入","MOBILE_ADDON":"外掛","MOBILE_CONFIGURE_ADDON":"配置外掛","MOBILE_CONFIGURE_ADDON_LABEL":"配置外掛","MOBILE_ORGANIZER_ADDONS_WARNING":"Stremio Organizer應用程式僅提供有限的外掛,要獲得完整的Stremio體驗,請使用Stremio桌面客戶端。","MOBILE_DISCONNECT":"斷開連線","MOBILE_LOOKING_FOR_DEVICES":"正在查詢裝置...","MOBILE_CAST_TO":"投屏到","NAVIGATION_ON":"開啟","NAVIGATION_OFF":"關閉","MARKETING_AGREE":"我同意接收Stremio的營銷通知","QUIT":"退出","CONNECTED":"已連線","AUTHENTICATE":"驗證","CACHING":"快取","SETTINGS_CACHING_DRIVE":"快取磁碟","ENABLE_LOCAL_FILES_ADDON":"啟用本地檔案外掛(需要重新啟動)","LOCAL_ADDON_NOT_ENABLED":"未啟用本地外掛,單擊此處轉到設定並啟用它","ENABLE_REMOTE_HTTPS_CONN":"啟用遠端HTTPS連線","TORRENT_PROFILE":"Torrent配置","DATA_CACHING":"資料快取","MAGNET_PARSING":"分析Magnet連結","January":"一月","February":"二月","March":"三月","April":"四月","May":"五月","June":"六月","July":"七月","August":"八月","September":"九月","October":"十月","November":"十一月","December":"十二月","Monday":"星期一","Tuesday":"星期二","Wednesday":"星期三","Thursday":"星期四","Friday":"星期五","Saturday":"星期六","Sunday":"星期天","Action":"動作","Comedy":"喜劇","War":"戰爭","Family":"家庭","Animation":"動畫","Adventure":"冒險","Fantasy":"幻想","Crime":"犯罪","Mystery":"神祕","Romance":"浪漫","Drama":"劇情","Horror":"恐怖","Thriller":"驚悚","Sci-Fi":"科幻","Music":"音樂","Biography":"傳記","Documentary":"紀錄","Sport":"運動","Musical":"音樂劇","Western":"西部","Film-Noir":"黑色電影","News":"新聞","History":"歷史","Game-Show":"遊戲節目","Reality-TV":"真人秀","Talk-Show":"脫口秀","Film & Entertainment":"電影與娛樂","Gaming":"遊戲","From TV":"電視","Lifestyle":"生活方式","Science & Education":"科學與教育","Cooking & Health":"烹飪與健康","Beauty & Fashion":"美麗與時尚","Sports":"體育","News & Politics":"新聞與政治","How-to & DIY":"DIY","Tech":"技術","Automotive":"汽車","Causes & Non-Profits":"事業與公益","Movies":"影視","Uk Live Tv":"英國直播電視臺","Fashion":"流行","Business News Radio":"商業新聞電臺","Business Tv":"商業電視","Cars & Auto":"汽車與自動化","Comedy Radio":"喜劇電臺","Lifestyle Radio":"生活方式電臺","News Tv":"新聞電視","Food And Wine":"食物與酒","Latino Tv":"拉丁語電視臺","Shopping Tv":"購物電視臺","Religion":"宗教","Kids":"兒童","Body & Soul":"身體與靈魂","Education":"教育","Indian Tv":"印度電視臺","Extreme Sports":"極限運動","Middle Eastern Tv":"中東電視臺","Celebrity Tv":"名人電視臺","Science Tv":"科學電視臺","Bikini babe":"比基尼寶貝","Outdoors":"戶外","German Tv":"德國電視臺","French Tv":"法國電視臺","Italian Tv":"義大利電視臺","Gamer Tv":"伽馬電視臺","Travel":"旅行","Asian Tv":"亞洲電視臺","Entertainment":"遊戲娛樂","News Radio":"新聞電臺","Music Radio":"音樂電臺","Language Learning":"語言學習","Science Radio":"科學電臺","Tech Radio":"科技電臺","Science & Technology Vod":"科技影片點播","new video":"新影片","new episode":"新一集","new movie":"新電影","recommended":"推薦","we recommend":"我們建議","offer of the day":"當日優惠","news":"新聞","music video":"音樂影片","CTX_SHOW_HOTKEYS":"顯示快捷鍵","CTX_DISMISS_NOTIF":"清除通知","CTX_DISMISS_ALL":"全部清除","CTX_SHARE":"分享","CTX_COPY_SHARE_LINK":"複製分享連結","CTX_COPY_MAGNET_LINK":"複製Magnet連結","CTX_COPY_STREAM_LINK":"複製流媒體連結","CTX_DOWNLOAD_VIDEO":"下載此影片","CTX_DOWNLOAD_SUBS":"下載字幕","CTX_VIEW_ON_YOUTUBE":"在YouTube上觀看","CTX_SHOW":"顯示","CTX_PLAY":"播放","CTX_PLAY_IN":"播放","CTX_PLAY_ON":"正在播放","CTX_WATCH_ON":"正在觀看","CTX_WATCH":"觀看","CTX_WATCHED":"已觀看","CTX_WATCH_BEGINNING":"從頭開始觀看","CTX_WATCH_MOBILE":"在移動裝置上觀看","CTX_REWIND":"回到開頭","CTX_MARK_WATCHED":"標記為已觀看","CTX_MARK_NON_WATCHED":"標記為未觀看","CTX_MARK_UNWATCHED":"Mark as unwatched","CTX_MARK_REST":"將其餘部分標記為已觀看","CTX_UNMARK_REST":"將其餘部分標記為未觀看","CTX_RECEIVE_NEW_NOTIF":"接受新通知","CTX_REMOVE_CACHE":"從快取中刪除","CTX_REMOVE_CACHE_EP":"從快取中刪除集","CTX_OPEN_CONTAINING":"開啟所在資料夾","CTX_REMOVE":"從庫中刪除","CTX_AVAILABLE_OFFLINE":"離線可用","CTX_PAUSED":"暫停","CTX_ALWAYS_ON_TOP":"置頂","CTX_FULLSCREEN":"全屏","CTX_WRONG_SUBS":"錯誤的字幕?","CTX_REPORT_ISSUES":"報告問題","CTX_COPY":"複製","CTX_PASTE":"貼上","CTX_CLEAR":"清除","CTX_CLEAR_RECENT_SEARCHES":"清除最近搜尋記錄","HELLO_THERE":"您好","HOPE_YOU_ENJOY":"我們希望您喜歡Stremio,也許它已經是您最喜歡的應用之一了!","WHO_ARE_WE":"我們是誰?我們是它背後的團隊。在過去三年裡的每天,我們兩個努力工作使這個產品越來越好。","SUPPORT_US":"如果您喜歡Stremio,如果Stremio對您來說很有價值,請傳播它!","SPREAD_THE_WORD":"現在與您的朋友分享傳播關於Stremio的資訊","MORE_PEOPLE":"使用Stremio的人越多,效果就越好!","SEND_A_LINK":"或傳送一個連結到我們的網站","TIP_LOCALFILES":"提示:您可以將本地影片檔案拖放到Stremio中","ADDON_MY":"我的外掛","ADDON_COMMUNITY":"社群外掛","ADDON_OFFICIAL":"官方外掛","ADDON_REPOS":"外掛集合","ADDON_SEARCH":"搜尋外掛","ADDON_INSTALL":"安裝","ADDON_CONFIGURE":"配置","ADDON_UNINSTALL":"解除安裝","ADDON_UPGRADE":"更新","ADDON_INSTALLED":"已安裝","ADDON_INSTALLED_MSG":"外掛已安裝!","ADDON_UPGRADED_MSG":"外掛已更新!","ADDON_UNKNOWN":"未知","ADDON_ERR":"外掛安裝錯誤!","ADDON_DISCONNECTED":"已斷開連線","ADDON_APP_MISSING":"未安裝此源的應用程式,您想現在安裝嗎?","ADDON_APP_INSTALL":"立即安裝","ADDON_PAGE":"外掛頁","ADDON_TOP_CONTENT":"最好從這個外掛","ADDON_PROVIDES":"這個外掛會給您:","ADDON_WATCH":"立即觀看#{types}!","ADDON_WATCH_FREE":"立即免費觀看#{types}!","ADDON_ADDON":"外掛","ADDON_SUPPORTED_TYPES":"支援的型別","ADDON_SUPPORTED_CATALOGS":"支援的目錄","ADDON_PROVIDES_DISCOVER":"發現中的更多#{types}","ADDON_PROVIDES_STREAMS":"觀看#{types}","ADDON_PROVIDES_STREAMS_FREE":"免費觀看#{types}","ADDON_PROVIDES_SUBTITLES":"#{types}的字幕","ADDON_CANTDETECT":"我們無法檢測到正在執行的Stremio,因此我們無法檢測您安裝了哪些外掛。","ERR_NO_META":"找不到有關於此的資訊","ERR_GETTING_META":"檢索有關於此的資訊時出錯","ERR_CANT_PARSE_MAGNET":"無法分析Magnet","ERR_NO_MAGNET_INFOHASH":"Magnet缺少有效的Hash","ERR_NO_FILE_PATH":"沒有檔案路徑無法傳送請求","ERR_NO_TORRENT":"沒有Torrent返回","ERR_NO_SUPPORTERD_FILES":"找不到支援的檔案","ERR_OPENING_FILES":"無法開啟外部檔案","ERR_INVALID_LINK":"無效連結","ERR_REGISTERED_ONLY":"此選項僅適用於已註冊使用者。","ERR_CLIPBOARD":"無法從剪下板播放","ERR_CLIPBOARD_READ":"無法讀取此平臺上的剪下板","ERR_CLIPBOARD_GENERIC":"在剪下板中找不到可播放的URL. 請將URL(例如Magnet連結)複製到影片。","BOARD_CONTINUE_WATCHING":"繼續觀看","BOARD_EXPLANATION_RECOMMENDATIONS":"專門為您挑選的電影。
這部電影是一個推薦樣例。","BOARD_EXPLANATION_EPISODES":"這裡是您最喜愛的劇集的新一集。
將您關注的劇集新增到庫中。","BOARD_EXPLANATION_VIDEOS":"這裡是您最喜愛的頻道的新一集。
將您關注的YouTube頻道新增到庫中。","WEBSITE_SLOGAN_WATCH":"立即觀看","WEBSITE_SLOGAN_ALL":"一站式影片娛樂解決方案","WEBSITE_SLOGAN_NEW":"您能觀看一切","WEBSITE_SLOGAN_NEW_NEW":"自由串流","WEBSITE_WATCH_FROM":"觀看","WEBSITE_DOWNLOAD":"立即下載","WEBSITE_DOWNLOAD_FOR":"立即下載","WEBSITE_IS_DESKTOP":"Stremio是一個桌面應用程式,請在PC上開啟此頁並下載","WEBSITE_DESKTOP_DEMO_VID":"桌面演示","WEBSITE_PAGE_HOME":"首頁","WEBSITE_PAGE_FEATURES":"功能","WEBSITE_PAGE_ADDONS":"外掛","WEBSITE_PAGE_TECH":"技術","WEBSITE_PAGE_CREATE_ADDON":"建立外掛","WEBSITE_PAGE_CONTACTS":"聯絡","WEBSITE_PAGE_BLOG":"部落格","WEBSITE_TYPE_movie":"電影","WEBSITE_TYPE_series_PL":"劇集","WEBSITE_TYPE_tv":"直播電視","WEBSITE_TYPE_channel":"頻道","WEBSITE_STREMIO_WHAT_IS":"Stremio是一款幫助您管理和隨時觀看您喜愛的影片、電影、劇集和電影片道的應用程式","WEBSITE_FEATURES_WATCH":"立即觀看高畫質影片","WEBSITE_FEATURES_WATCH_DETAIL":"點選並播放您喜愛的電影、劇集、影片和電影片道。","WEBSITE_FEATURES_SUBS":"自動載入字幕","WEBSITE_FEATURES_SUBS_DETAIL":"Stremio會自動為您的語言選擇同步字幕。","WEBSITE_FEATURES_SUBS_LABEL":"Your move, chief.","WEBSITE_FEATURES_CAST":"在電視和移動裝置上播放","WEBSITE_FEATURES_CAST_DETAIL":"適用於AppleTV、Chromecast、智慧電視(DLNA/UPnP)和移動裝置。","WEBSITE_LIB":"享受在所有裝置上同步的個人庫","WEBSITE_LIB_COLLECT":"從Stremio收集","WEBSITE_LIB_IMPORT":"從Facebook匯入","WEBSITE_LIB_LOCAL":"從本地磁碟新增","WEBSITE_BOARD":"首頁 - 通知和推薦的一站式場所","WEBSITE_BOARD_RECOMMEND":"推薦電視節目","WEBSITE_BOARD_TRENDING":"流行電影","WEBSITE_BOARD_NEW":"新影片","WEBSITE_BOARD_EPISODE":"新一集","WEBSITE_BOARD_1":"想看些有趣的東西嗎?根據您的喜好得到推薦!","WEBSITE_BOARD_2":"當您最喜愛的電視節目或YouTube頻道的新一集播出時獲得通知!","WEBSITE_BOARD_YOUTUBE":"YouTube頻道的新影片","WEBSITE_BOARD_EPISODES":"您關注的劇集的新一集","WEBSITE_ADDONS":"內容外掛","WEBSITE_TECH_DETAIL":"我們熱愛科技,我們熱愛瘋狂的科學!\\nStremio使用了以下開源技術:","WEBSITE_TECH_WCJS":"WebChimera.js允許Stremio以良好的效能播放任何影片格式。","WEBSITE_TECH_WCJS_EXTRA":"我們是專案的核心貢獻者","WEBSITE_TECH_ELECTRON":"Electron為Stremio提供了一個創新平臺。","WEBSITE_TECH_ELECTRON_EXTRA":"我們是專案貢獻者","WEBSITE_TECH_LINVODB":"一種資料庫技術,確保您的資料在任何地方登入都受管理和可用。","WEBSITE_TECH_LINVODB_EXTRA":"內部技術","WEBSITE_CREATE_ADDON":"建立您的外掛","WEBSITE_CREATE_ADDON_DETAIL":"您有提供影片內容的服務嗎?我們將透過建立外掛來幫助您從Stremio的功能中獲益。","WEBSITE_CREATE_ADDON_BENEFITS":"為Stremio建立外掛的好處","WEBSITE_P2P_BEAUTY":"點對點流媒體之美","WEBSITE_P2P_1":"可靠且價格合理的全高畫質/4K影片點播或流媒體直播","WEBSITE_P2P_2":"提供良好使用者體驗的分銷平臺","WEBSITE_P2P_3":"我們將建立一個外掛來滿足您的確切需要","WEBSITE_P2P_CONTACT":"有興趣嗎?歡迎您透過聯絡我們.","WEBSITE_P2P_CONTACT_EXTRA":"我們很樂意幫助您將您的內容整合到Stremio!","WEBSITE_P2P":"偶然間出現了一種改變遊戲名稱的技術。 我們投入了大量的時間和精力來構建我們的點對點(P2P)影片流媒體引擎,該引擎可提供出色的效能和多功能性,以適應任何用例。\\n請聯絡我們以獲取支援DRM的P2P影片點播或實時流媒體。","WEBSITE_THOUGHTS":"我們分享的想法:","WEBSITE_SPREAD":"傳播關於Stremio的資訊:","WEBSITE_CONTACT":"聯絡我們,我們很高興收到您的來信!","WEBSITE_OPENSOURCE":"有關我們的開源專案,請轉到:","WEBSITE_BITCOIN":"捐贈比特幣:","WEBSITE_FAQ":"常見問題","WEBSITE_FAQ_SHORT":"常見問題","WEBSITE_QUESTIONS":"問題","WEBSITE_TOS":"使用條款","WEBSITE_LEGAL":"法律","WEBSITE_PAGE_ABOUT":"關於","WEBSITE_PAGE_BECOME_PARTNER":"成為合作伙伴","WEBSITE_ALL_YOU_CAN_WATCH":"自由觀看\\n您想看的一切。","WEBSITE_FREEDOM_TO_STREAM":"自由串流","WEBSITE_WHAT_IS_STREMIO":"什麼是Stremio?","WEBSITE_WHAT_IS_STREMIO_P1":"Stremio是一個一站式影片內容聚合中心。在您擁有的任何裝置上發現,管理和觀看來自各種來源的影片。","WEBSITE_WHAT_IS_STREMIO_P2":"電影、電視節目、劇集、電視直播或網路頻道例如YouTube或Twitch.tv等,您可以在Stremio上找到所有這些內容。","WEBSITE_WHAT_IS_STREMIO_P1_V2":"Stremio是一個現代化的媒體中心,為您的影片娛樂提供一站式解決方案。您可以透過易於安裝的外掛發現,觀看和整理影片內容。","WEBSITE_WHAT_IS_STREMIO_P2_V2":"電影、電視節目、直播電視或網路頻道——在Stremio上找到所有這些。","WEBSITE_ENJOI_ON_ALL_DEVICES":"在所有媒體裝置上享受","WEBSITE_DEVICES_COLLECT":"從Stremio收集","WEBSITE_DEVICES_IMPORT_FB":"從Facebook匯入","WEBSITE_DEVICES_LOCAL":"從本地磁碟新增","WEBSITE_JOIN_THE_PARTY_NOW":"立即加入聚會","WEBSITE_DEVICES_ALL":"易於在所有裝置上使用;","WEBSITE_EXTENDABLE_CATALOG":"可無限擴充套件的影片目錄;","WEBSITE_ORGANIZE_YOUR_MEDIA":"強大的媒體管理功能;","WEBSITE_AS_SEEN_ON":"如圖所示","WEBSITE_STREMIO":"Stremio","WEBSITE_LINK_ABOUT_US":"關於我們","WEBSITE_LINK_TECHNOLOGY":"技術","WEBSITE_LINK_APPS":"應用程式","WEBSITE_LINK_DOWNLOADS":"下載","WEBSITE_MORE":"更多","WEBSITE_LINK_ADDONS":"外掛","WEBSITE_LINK_ADDON_SDK":"外掛SDK","WEBSITE_LINK_CONTRIBUTE":"貢獻","WEBSITE_LINK_COMMUNITY":"社群","WEBSITE_LINK_BLOG":"部落格","WEBSITE_MORE_MORE":"... & 更多","WEBSITE_LINK_HELP":"幫助中心","WEBSITE_LINK_CONTACTS":"業務查詢","WEBSITE_LINK_TOS":"條款和條件","WEBSITE_LINK_PRAVACY":"隱私政策","WEBSITE_SUBSCRIBE":"訂閱","WEBSITE_NEWSLETTER":"加入我們的實時通訊,瞭解精彩的內容","WEBSITE_PLACEHOLDER_EMAIL":"您的電子郵箱","WEBSITE_COMMUNITY":"社群","WEBSITE_LINK_PRAVACY_LEGAL":"隱私與法律","WEBSITE_WHY":"我們為什麼這樣做","WEBSITE_WHY_P1":"在Stremio,我們每天都工作,因為我們想解決影片點播行業的一個重要問題。每分鐘都有這麼多的新內容釋出,幾乎不可能找到解決的方法。","WEBSITE_WHY_P2":"我們幫助人們瀏覽這個巨大的影片娛樂世界,發現新的內容來享受。我們的應用程式彙集了電影、劇集、電視直播、網路頻道等。我們致力於讓使用者非常容易地找到他們喜歡的標題和廣播。","WEBSITE_WHY_P3":"您可以隨時在任何裝置上使用我們的服務,使Stremio成為您唯一需要的影片娛樂中心。","WEBSITE_TEAM":"團隊","WEBSITE_TEAM_P":"Stremio團隊雖小但很強大:我們10個人用X語言編寫程式碼,分享軟體開發、UI和UX設計、營銷和廣告、商業和初創企業方面的專業知識。","WEBSITE_FEATURES":"功能","WEBSITE_FEATURES_P1":"","WEBSITE_FEATURES_DISCOVER":"輕鬆發現新內容","WEBSITE_FEATURES_DISCOVER_P":"輕鬆發現要觀看的新電影、電視節目、劇集和頻道。按類別、流派、評分、時間等瀏覽,或者只需鍵入一個名稱即可找到。Stremio讓尋找新的影片內容變得輕而易舉。","WEBSITE_FEATURES_ALL_CONTENT":"一塊螢幕顯示所有影片內容","WEBSITE_FEATURES_ALL_CONTENT_P1":"檢視您未看完的電影、劇集或影片,並繼續觀看;獲得新劇集和版本的通知;瀏覽根據您的觀看習慣獲得的推薦。","WEBSITE_FEATURES_LIBRARY":"管理您的影片庫","WEBSITE_FEATURES_LIBRARY_P1":"只需點選一下,即可將任何標題新增到您的Stremio庫中,並按型別、時間或字母順序整齊地排列內容。","WEBSITE_FEATURES_CALENDAR":"記錄您所觀看的一切","WEBSITE_FEATURES_CALENDAR_P1":"獲取新增到庫中的所有電影和系列的日曆視覺化。匯出您的Stremio日曆並同步它,這樣您就可以隨時知道新的一集或首映何時到來。","WEBSITE_FEATURES_BIG_SCREEN":"在大螢幕上欣賞您的影片內容","WEBSITE_FEATURES_BIG_SCREEN_P1":"將您正在觀看的任何內容都投屏到另一臺裝置上,無論是手機、平板電腦還是電視,只需點選一下即可。","WEBSITE_FEATURES_SOURCES":"觀看不同來源的影片","WEBSITE_FEATURES_SOURCES_P":"安裝官方和社群外掛,欣賞來自多個不同供應商的影片。","WEBSITE_CREATE_AN_ADDON":"建立外掛","WEBSITE_FEATURES_SYNC":"跨裝置同步庫並恢復播放","WEBSITE_FEATURES_SYNC_P1":"使用您的帳戶在所有裝置上登入,享受同步的庫、外掛、播放和日曆。","WEBSITE_FEATURES_EXTENDABLE":"透過外掛擴充套件影片目錄","WEBSITE_FEATURES_EXTENDABLE_P1":"Stremio外掛目錄提供了許多外掛,可以從中安裝和觀看各種影片內容。這包括電影、節目、電視直播、體育、新聞、播客、網路頻道、影片遊戲等。","WEBSITE_FEATURES_AUTO_SUBS":"自動載入字幕","WEBSITE_FEATURES_AUTO_SUBS_P1":"透過我們的字幕外掛,您可以自動選擇您喜歡的語言。","WEBSITE_FEATURES_CHROMECAST":"投屏到Chromecast","WEBSITE_FEATURES_CHROMECAST_P1":"在更大的螢幕上欣賞您的影片內容,或者將您正在觀看的內容投屏到其他裝置上。","WEBSITE_FEATURES_KEEP_TRACK":"跟蹤您最喜愛的電視節目和網路頻道","WEBSITE_FEATURES_KEEP_TRACK_P1":"獲取您最喜愛的劇集和網路頻道的新一集的日曆視覺化和通知。","WEBSITE_FEATURES_POWER_USER":"超級使用者功能","WEBSITE_FEATURES_POWER_USER_P1":"在外部播放器中播放","WEBSITE_FEATURES_POWER_USER_P2":"從Torrent檔案或Magnet連結播放","WEBSITE_FEATURES_POWER_USER_P3":"從Facebook喜愛或本地磁碟匯入您的庫","WEBSITE_ADD_ONS":"外掛","WEBSITE_ADD_ONS_P1":"Stremio提供的所有影片內容都是透過外掛系統獲取的,應用程式中沒有內建任何內容或內容提供商。","WEBSITE_ADD_ONS_P2":"有兩組外掛可用:官方和社群外掛。","WEBSITE_ADD_ONS_P3":"官方外掛由Stremio開發和託管,而社群外掛由我們的社群成員建立和託管。","WEBSITE_ADDONS_OFFICIAL":"官方外掛","WEBSITE_ADDONS_WATCHUB":"從iTunes、Hulu、Amazon和其他英國/美國服務提供商處流式播放您喜愛的電影、劇集和節目。","WEBSITE_ADDONS_YOUTUBE":"觀看您喜愛的YouTube頻道,獲得您關注的貢獻者的新上傳通知。","WEBSITE_ADDONS_FILMON":"免費觀看直播電視、電影和社交電視。600個電影片道,45000部免費電影,紀錄片以及更多","WEBSITE_ADDONS_OPENSUBTITLES":"多語種影視字幕,每天上傳上千個翻譯字幕。","WEBSITE_ADDONS_COMMUNITY":"社群外掛","WEBSITE_ADDONS_FILMON_VOD":"觀看來自Filmon.tv的點播影片。","WEBSITE_ADDONS_TWICH":"觀看來自Twitch.tv(電子競技行業的影片流媒體平臺)的直播。","WEBSITE_ADDONS_VODO":"觀看完全免費的獨立電影。","WEBSITE_ADDONS_NETFLIX":"觀看Netflix的電影和網劇。","WEBSITE_ADDONS_CREATE":"建立外掛","WEBSITE_ADDONS_CREATE_P1":"如果您願意,您可以開發自己的外掛。透過這種方式,您可以讓自己和我們的社群訪問新的影片內容,並接觸到全球數百萬使用者的新目標受眾。","WEBSITE_ADDONS_START_CREATE":"要開始,請訪問Stremio外掛SDK頁面:","WEBSITE_DOWNLOADS":"下載","WEBSITE_DOWNLOADS_P1":"為了獲得最佳效能,我們建議您使用最新版本的Stremio應用程式。但是,如果出於某種原因,您想使用舊版本,可以在此處下載。","WEBSITE_DOWNLOADS_FOR_WIN":"Stremio for Windows","WEBSITE_DOWNLOADS_FOR_MAC":"Stremio for macOS","WEBSITE_DOWNLOADS_FOR_LINUX":"Stremio for Linux","WEBSITE_DOWNLOADS_FOR_ANDROID":"Stremio for Android","WEBSITE_DOWNLOADS_FOR_ANDROID_TV":"Stremio for Android TV","WEBSITE_DOWNLOADS_FOR_ANDROID_MOBILE":"Stremio for Android Mobile","WEBSITE_DOWNLOADS_FOR_STEAM_DECK":"Stremio for Steam Deck","WEBSITE_DOWNLOADS_FOR_IOS":"Stremio for iOS(限制版本)","WEBSITE_CONTRIBUTE":"貢獻","WEBSITE_CONTRIBUTE_P1":"Stremio平臺是開源的,您可以輕鬆地為當前沒有來源的內容建立一個外掛。","WEBSITE_CONTRIBUTE_WHY":"為什麼要建立外掛?","WEBSITE_CONTRIBUTE_WHY_P1":"為您的影片內容吸引新觀眾","WEBSITE_CONTRIBUTE_WHY_P2":"Stremio的使用者群體正在快速增長,在推出的第一年,Stremio在全球獲得了100萬用戶,在該平臺存在的第二年,這個數字增長到250萬。","WEBSITE_CONTRIBUTE_WHY_P3":"用外掛,您可以輕鬆接觸這些觀眾並向他們分發您的影片內容。","WEBSITE_CONTRIBUTE_ALL":"在一處觀看您喜愛的電影、影片、劇集和頻道。","WEBSITE_CONTRIBUTE_ALL_P1":"您是Stremio上尚未提供的特定型別內容的粉絲?為它建立一個外掛,在市場上最大、最易使用的娛樂中心之一欣賞您喜愛的影片。","WEBSITE_CONTRIBUTE_ALL_P2":"除此之外,您還會得到其他志同道合的Stremio社群成員的無盡感激。","WEBSITE_CONTRIBUTE_MONETIZE":"透過外掛營利,並在其幫助下賺錢","WEBSITE_CONTRIBUTE_MONETIZE_P1":"一旦您為Stremio開發了一個新的外掛,您就可以透過多種不同的方式輕鬆地靠其營利。如果您正在考慮此問題,請隨時與我們聯絡","WEBSITE_CONTRIBUTE_MONETIZE_E":"addons@stremio.com","WEBSITE_CONTRIBUTE_MONETIZE_P2":",我們很樂意就外掛營利選項向您提供諮詢和建議。","WEBSITE_CONTRIBUTE_TRANSLATE":"成為一名志願翻譯者","WEBSITE_CONTRIBUTE_TRANSLATE_P1":"如果您想享受不同語言的Stremio應用程式,您可以加入我們的志願翻譯者社群。他們幫助我們新增多種不同語言的Stremio版本。","WEBSITE_CONTRIBUTE_TRANSLATE_P2":"您想開始嗎?","WEBSITE_TRANSALTE_STREMIO":"翻譯Stremio","WEBSITE_COMMUNITY_P1":"","WEBSITE_COMMUNITY_OFFICIALS":"官方社群","WEBSITE_COMMUNITY_OFFICIALS_P1":"成為不斷增長的Stremio社群的一部分。在社交媒體上關注我們,不要害羞地打招呼,我們喜歡聽到粉絲的聲音!","WEBSITE_COMMUNITY_UNOFFICIALS":"非官方社群","STREMIO_COMMUNITY_NL":"Stremio Netherlands","STREMIO_COMMUNITY_BRASIL":"Stremio Brasil","STREMIO_COMMUNITY_GERMANY":"Stremio Germany","STREMIO_COMMUNITY_BELGIUM":"Stremio Belgium","STREMIO_COMMUNITY_FRANCE":"Stremio France","STREMIO_COMMUNITY_PORTUGAL":"Stremio Portugal","STREMIO_COMMUNITY_ITALY":"Stremio Italy","STREMIO_COMMUNITY_UK":"Stremio UK","STREMIO_COMMUNITY_USA":"Stremio USA","STREMIO_COMMUNITY_MEXICO":"Stremio Mexico","STREMIO_COMMUNITY_ADDONS":"Stremio Addons","STREMIO_COMMUNITY_AWESOME":"Awesome Stremio","WEBSITE_COMMUNITY_PARTNERS":"合作伙伴和支持者","WEBSITE_COMMUNITY_GOODIES":"Stremio特典","WEBSITE_COMMUNITY_WALLPAPERS":"桌布","WEBSITE_COMMUNITY_ART":"社群藝術畫廊","WEBSITE_LINK_ART":"社群藝術畫廊","WEBSITE_CONTACT_US":"聯絡我們","WEBSITE_CONTACT_US_P1":"如果您有任何問題、意見或建議,請隨時透過下面的聯絡方式與我們聯絡。","WEBSITE_CONTACT_US_P2":"請記住,我們位於保加利亞,因此可能會由於時區差異而延遲處理您的問題。","WEBSITE_CONTACT_US_SUCCESS":"您的資訊已傳送。我們會在方便的時候儘快給您回覆。","WEBSITE_CONTACT_US_ERR_INV_EMAIL":"請輸入有效的電子郵箱!","WEBSITE_CONTACT_US_Q_RELATED_TO":"您的問題與什麼有關?","WEBSITE_CONTACT_US_Q_OS":"您的作業系統是什麼?","WEBSITE_CONTACT_US_PH_EMAIL":"您的電子郵箱","WEBSITE_CONTACT_US_PH_MESSAGE":"簡訊","WEBSITE_CONTACT_US_PH_MESSAGE_BTN":"傳送","WEBSITE_CONTACT_US_Q_1":"如何安裝?","WEBSITE_CONTACT_US_Q_2":"如何解除安裝?","WEBSITE_CONTACT_US_Q_3":"(HTML)如何製作千層麵?","WEBSITE_CONTACT_US_Q_4":"外掛","WEBSITE_CONTACT_US_OS_1":"Windows","WEBSITE_CONTACT_US_OS_2":"macOS","WEBSITE_CONTACT_US_OS_3":"Linux","WEBSITE_CONTACT_US_OS_4":"Android","WEBSITE_CONTACT_US_OS_5":"iOS","WEBSITE_TECHNOLOGY":"技術","WEBSITE_TECHNOLOGY_P1":"我們熱愛科技,熱愛科學。
這是Stremio的動力(它都是開源的)。","WEBSITE_TECHNOLOGY_P_QT":"最佳跨平臺軟體開發工具。","WEBSITE_TECHNOLOGY_P_MPV":"一款免費、開源、跨平臺的媒體播放器。","WEBSITE_TECHNOLOGY_P_RN":"React Native允許您僅使用JavaScript構建移動應用程式。","WEBSITE_TECHNOLOGY_P_VLC":"嵌入到應用程式中獲取多媒體的媒體框架。","WEBSITE_TECHNOLOGY_P_REALM":"Realm是一個移動平臺,是SQLite和Core Data的替代品。","WEBSITE_TECHNOLOGY_P_NODEJS":"Node.js是一個開源、跨平臺的JavaScript執行環境。","WEBSITE_TECHNOLOGY_P_RUST":"Rust是一種多正規化系統程式語言,關注安全性,尤其是安全併發性。","WEBSITE_TECHNOLOGY_CONTRIBUTE":"為專案貢獻力量","WEBSITE_TECHNOLOGY_CONTRIBUTE_P1":"您可以透過兩種方式為Stremio做貢獻,幫助我們將產品做得更好。","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_TRANSALTE":"您可以透過翻譯平臺來貢獻您寶貴的語言技能...","WEBSITE_TECHNOLOGY_CONTRIBUTE_OR":"或","WEBSITE_TECHNOLOGY_CONTRIBUTE_P_CREATE":"... 您可以利用您的程式設計技巧來建立社群外掛。","WEBSITE_TRANSLATE_STREMIO":"翻譯Stremio","WEBSITE_404_OH_NO":"糟糕!您要找的頁面不在這裡...","WEBSITE_GO_HOME":"回到主頁","WEBSITE_LINK_OTHER_DOWNLOADS":"其他下載","WEBSITE_FAQ_ABR":"常見問題","WEBSITE_SUPPORT":"支援","WEBSITE_DOWNLOAD_4_0_BETA":"立即下載Stremio 4測試版","WEBSITE_GET_FOR_DESKTOP":"獲取桌面","WEBSITE_LINK_ADDON_COMPETITION":"外掛比賽","WEBSITE_LINK_ART_CONTEST":"藝術比賽","WEBSITE_MY_ACCOUNT":"我的賬戶","WEBSITE_MAINPAGE_FAQ_001_H1":"什麼是Stremio?","WEBSITE_MAINPAGE_FAQ_001_P1":"Stremio是一個現代化的媒體中心,讓您可以自由觀看任何您想要的東西。","WEBSITE_MAINPAGE_FAQ_002_H1":"它是如何工作的?","WEBSITE_MAINPAGE_FAQ_002_P1":"一旦您在裝置上安裝了Stremio並建立了一個帳戶,您所要做的就是訪問外掛目錄並安裝任何您想要的外掛,就可以開始了!","WEBSITE_MAINPAGE_FAQ_002_P2":"之後,您可以進入“發現”或“板”部分,開始探索內容。","WEBSITE_MAINPAGE_FAQ_003_H1":"我可以在這裡看什麼?","WEBSITE_MAINPAGE_FAQ_003_P1":"很多:電影、電視節目、網路頻道、體育、電影片道、收聽播客等等。感謝我們的外掛系統,您可以訪問各種內容。","WEBSITE_MAINPAGE_FAQ_004_H1":"Stremio是開源的嗎?","WEBSITE_MAINPAGE_FAQ_004_P1":"是的,您可以檢視以下連結:${1}桌面應用${2}和${3}GitHub組織${4}。","WEBSITE_MAINPAGE_FAQ_005_H1":"Stremio安全嗎?","WEBSITE_MAINPAGE_FAQ_005_P1":"是:因為它是開源軟體,所以程式碼可以公開稽核,您可以自己檢視。","WEBSITE_MAINPAGE_FAQ_006_H1":"我的隱私如何?","WEBSITE_MAINPAGE_FAQ_006_P1":"我們尊重使用者隱私,除了建立和同步您的帳戶所必需的最低限度外,不收集任何個人資料。","WEBSITE_MAINPAGE_FAQ_006_P2":"註冊時還有一個${1}訪客模式${2},它不需要任何資料:在這種模式下,不會呼叫我們的後端。然而,這是以犧牲有用的功能為代價的,比如能夠跨裝置同步您的庫。","WEBSITE_MAINPAGE_FAQ_007_H1":"我可以投屏到電視嗎?","WEBSITE_MAINPAGE_FAQ_007_P1":"是的,我們支援Chromecast,您可以從桌面和移動應用程式(Android)進行強制轉換。","WEBSITE_MAINPAGE_FAQ_008_H1":"Stremio有多少外掛?","WEBSITE_MAINPAGE_FAQ_008_P1":"截至2019年末,超過50個。有關更多資訊,請檢視我們的外掛目錄。","WEBSITE_MAINPAGE_FAQ_009_H1":"Stremio是否可以擴充套件到外掛目錄之外?","WEBSITE_MAINPAGE_FAQ_009_P1":"是的,您應該檢視這些:${1}PimpMyStremio${2},${3}Reddit communities${4},${5}Stremio Downloader${6},等等。","WEBSITE_MAINPAGE_FAQ_010_H1":"Stremio支援哪些裝置?","WEBSITE_MAINPAGE_FAQ_010_P1":"我們有適用於Windows、Mac和Linux的桌面應用程式。對於移動裝置,我們支援Android和iOS,但請記住iOS的功能有限(不支援大多數外掛)。","WEBSITE_MAINPAGE_FAQ_010_P2":"有很多基於Android的裝置可以在上面執行Stremio,比如NVIDIA Shield和Amazon Fire Stick,但我們並不正式支援它們。","WEBSITE_MAINPAGE_FAQ_011_H1":"您們能為Stremio新增某些內容嗎?","WEBSITE_MAINPAGE_FAQ_011_P1":"抱歉,我們本身不提供任何內容,但是您安裝的Stremio外掛越多,您可以找到的內容就越多。","WEBSITE_MAINPAGE_FAQ_012_H1":"Stremio可以播放Magnet連結嗎?","WEBSITE_MAINPAGE_FAQ_012_P1":"是的,它還可以播放正常的HTTP連結和Torrent檔案(拖放)。","WEBSITE_MAINPAGE_FAQ_013_H1":"我可以下載影片並離線觀看嗎?","WEBSITE_MAINPAGE_FAQ_013_P1":"離線可用是一項即將推出的功能,但如果您允許Stremio在裝置上快取(從“設定”面板),您可以稍後在沒有連線的情況下觀看影片。","WEBSITE_MAINPAGE_FAQ_014_H1":"什麼都不能用,幫幫我!","WEBSITE_MAINPAGE_FAQ_014_P1":"您確定已安裝外掛嗎?如果是,請與我們的${1}幫助中心${2}聯絡","WEBSITE_MAINPAGE_FAQ_015_H1":"Stremio如何維持其開發運營?","WEBSITE_MAINPAGE_FAQ_015_P1":"我們透過${1}AdEx${2}執行非侵入性廣告,這是一家由同一創始團隊建立的公司,專注於隱私保護、透明廣告。","WEBSITE_MAINPAGE_FAQ_015_P2":"有關更多問題,請訪問我們的${1}幫助中心${2}。","HELP_LEARN_MORE":"幫助我們瞭解更多有關您的資訊。","LIFESTYLE":"生活方式","SPORTS":"體育","FOOD_HEALTH":"飲食與健康","BEAUTY_FASHION":"美麗與時尚","NEWS":"新聞","GAMING":"遊戲","SCIENCE_EDUCATION":"科學與教育","MUSIC":"音樂","TRAVEL":"旅行","LATE_NIGHT":"深夜","REALITY":"真人","COMEDY":"喜劇","DIY":"DIY","TECH":"技術","CINEMA":"影院","CONTINUE":"繼續","SLOW_LOADING":"載入緩慢?","I_GIVE_UP":"我放棄了","LEARN_MORE":"瞭解更多","POOR_SOURCE":"此源不可用或您的網路連線不夠快","PICK_CATEGORIES_ERR":"您必須至少選擇3個類別","ADJUST_TIMING":"調整時間","ADJUST_SIZE":"調整大小","SEARCH_ANYTHING":"您可以搜尋一切...","ALL_CATEGORIES":"全部","SEARCH_CATEGORIES":"電影、劇集、YouTube和電視","SEARCH_PERSONS":"演員、導演和編劇","SEARCH_PROTOCOLS":"HTTP或Magnet連結","SEARCH_TYPES":"IMDB/TVDB連結","WATCHED":"已觀看","SHOW_LESS":"顯示較少","LAST_SEARCHES":"上次搜尋","CLEAR_HISTORY":"清除歷史記錄","CHOOSE_SOME":"選擇其中一些:","NO_WEB_REMOTE":"無法載入Web Remote","STREMIO_OFFLINE":"Stremio離線","STREMIO_EXPENSIVE_CONNECTION":"我們檢測到您正在使用移動資料連線,是否繼續?","USE_DATA":"使用移動資料","WARNING":"警告","MORE_INFO":"更多資訊...","STREMIO_TV_STREMIO":"Stremio","STREMIO_TV_LOADING":"載入...","STREMIO_TV_BACK_TO_LANGUAGES":"返回語言","STREMIO_TV_REMOTE":"遠端","STREMIO_TV_GO_TO":"去往:","STREMIO_TV_OR_SCAN":"或掃描:","STREMIO_TV_ADDON_INSTRUCTIONS":"請按照說明安裝您喜歡的外掛。","STREMIO_TV_LIVE_TV":"直播電視","STREMIO_TV_RESUME_WATCHING":"繼續觀看","STREMIO_TV_LOADING_BACKGROUND":"載入背景","STREMIO_TV_CHECKING_AUTHENTICATION":"正在檢測身份驗證","STREMIO_TV_LOADING_BOARD":"載入主頁","STREMIO_TV_LOGIN_HEADER_LINE_1":"我們希望使用者在使用我們的軟體時有最好的個性化體驗,","STREMIO_TV_LOGIN_HEADER_LINE_2":"正是出於這個原因,我們懇請您建立和/或登入您的賬戶,","STREMIO_TV_LOGIN_FOOTER_LINE_1":"感謝您的理解,","STREMIO_TV_LOGIN_FOOTER_LINE_2":"Stremio團隊","STREMIO_TV_REMOTE_INSTRUCTIONS":"為了在您的智慧手機/平板電腦/桌面使用Web Remote:","STREMIO_TV_WIFI_SETUP":"Wi-Fi設定","STREMIO_TV_WIFI_HEADER_LINE_1":"Stremio Circle未檢測到網際網路連線。","STREMIO_TV_WIFI_DETAILS_1":"連線到:","STREMIO_TV_WIFI_DETAILS_2":"stremio-circle","STREMIO_TV_WIFI_DETAILS_3":"使用密碼:","STREMIO_TV_WIFI_DETAILS_4":"stremiocircle","STREMIO_TV_WIFI_DETAILS_5":"在瀏覽器中開啟連結:","STREMIO_TV_DISCOVER_GENRE_DEFAULT":"預設","STREMIO_TV_LIBRARY_SORT_LAST_WATCHED":"按最近觀看","STREMIO_TV_LIBRARY_SORT_NAME":"按名字","STREMIO_TV_LIBRARY_TIMES_WATCHED":"按觀看次數","STREMIO_TV_DETAILS_SEASON_NUMBER":"季${1}","STREMIO_TV_STREAMS_LOADING":"已載入${1}/${2}外掛...","STREMIO_TV_STREAMS_STILL_LOADING":"${1}外掛仍在載入...","STREMIO_TV_PLAYER_SETTINGS":"播放器設定","STREMIO_TV_PLAYER_SUBTITLES_DELAY":"字幕延遲","STREMIO_TV_PLAYER_AUDIO_DELAY":"音訊延遲","STREMIO_TV_PLAYER_VIDEO_SCALING":"影片縮放","STREMIO_TV_PLAYER_UNSUPPORTED_STREAM":"不支援的流媒體源","STREMIO_TV_PLAYER_FAILED_EXTERNAL_LINK":"開啟外部連結失敗","STREMIO_TV_PLAYER_PLAY_IN_EXO":"使用ExoPlayer播放","STREMIO_TV_PLAYER_PLAY_IN_VLC":"使用libVLC player播放","STREMIO_TV_PLAYER_SWITCH_TO_VLC_DUE_ERROR":"由於播放錯誤而切換到libVLC player","STREMIO_TV_ADDONS_TITLE":"在手機或PC上使用Stremio安裝或配置外掛,然後按\\"同步外掛\\"","STREMIO_TV_ADDONS_SUBTITLE":"注意:確保您使用的是相同的Stremio帳戶","STREMIO_TV_ADDONS_SYNC_ADDONS":"同步外掛","STREMIO_TV_ADDONS_SYNC_SUCCESS":"外掛成功同步","STREMIO_TV_ADDONS_SYNC_FAILED":"外掛同步失敗","STREMIO_TV_META_LINK_FAILED":"開啟元連結失敗","STREMIO_TV_CATALOG_LOADING":"目錄仍在載入...","STREMIO_TV_SETTINGS_LANGUAGE_UPDATED":"介面語言已更新","STREMIO_TV_SETTINGS_THEME_UPDATED":"主題已更新","STREMIO_TV_SETTINGS_DEFAULT_PLAYER":"Default Player","STREMIO_TV_SETTINGS_EXTERNAL_PLAYER":"External Player","STREMIO_TV_SETTINGS_PREFERRED_LANGUAGE":"首選語言","STREMIO_TV_SETTINGS_SECONDARY_PREFERRED_LANGUAGE":"次要首選語言","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK":"隧道播放","STREMIO_TV_SETTINGS_TUNNELLED_PLAYBACK_HINT":"某些裝置上可能存在播放問題","STREMIO_TV_SETTINGS_HW_DECODING_HINT":"某些影片格式可能無法播放","STREMIO_TV_SETTINGS_AUTO_FRAME_RATE":"自動幀速率匹配","STREMIO_TV_SETTINGS_NO_CACHING":"無快取","STREMIO_TV_SETTINGS_PROFILE_DEFAULT":"預設","STREMIO_TV_SETTINGS_PROFILE_SOFT":"慢","STREMIO_TV_SETTINGS_PROFILE_FAST":"快","STREMIO_TV_SETTINGS_PROFILE_ULTRA_FAST":"超快","STREMIO_TV_SETTINGS_SERVER_URL":"流媒體伺服器URL","STREMIO_TV_SETTINGS_SERVER_VERSION":"伺服器版本","STREMIO_TV_SETTINGS_SERVER_UNKNOWN":"未知","STREMIO_TV_SETTINGS_STREMIO_VERSION":"Stremio版本","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_TITLE":"編輯伺服器URL","STREMIO_TV_SETTINGS_SERVER_MODAL_EDIT_DESCRIPTION":"輸入流媒體伺服器URL","STREMIO_TV_SETTINGS_PRIVACY_POLICY_TEXT":"要閱讀Stremio的隱私政策,請訪問:","STREMIO_TV_SETTINGS_TOS_TEXT":"要閱讀Stremio的條款和條件,請訪問:","STREMIO_TV_NAV_SEARCH":"搜尋","STREMIO_TV_NAV_HOME":"主頁","STREMIO_TV_NAV_DISCOVER":"發現","STREMIO_TV_NAV_LIBRARY":"庫","STREMIO_TV_NAV_MOVIES":"電影","STREMIO_TV_NAV_SERIES":"劇集","STREMIO_TV_NAV_CHANNELS":"頻道","STREMIO_TV_NAV_TV":"電視直播","STREMIO_TV_NAV_SETTINGS":"設定","STREMIO_TV_NAV_ADDONS":"外掛","STREMIO_TV_LOGIN_TITLE":"連結賬戶","STREMIO_TV_LOGIN_EXPIRES_IN":"過期日期到","STREMIO_TV_LOGIN_STEP_ONE":"掃描上方的二維碼或轉到","STREMIO_TV_LOGIN_STEP_TWO":"登入您的Stremio帳戶","STREMIO_TV_LOGIN_NEW_LINK":"請求新連結","STREMIO_TV_LOGIN_LINK_REFRESHED":"登入程式碼已重新整理","STREMIO_TV_SEARCH_PLACEHOLDER":"輸入一些東西","STREMIO_TV_SEARCH_NO_ADDONS":"沒有為目錄請求外掛!","STREMIO_TV_SEARCH_BUTTON":"搜尋","STREMIO_TV_SEARCH_KEY_DEL":"刪除","STREMIO_TV_SEARCH_KEY_SPACE":"空格","STREMIO_TV_SEARCH_KEY_CLEAR":"清除","STREMIO_TV_SEARCH_HISTORY_TITLE":"搜尋歷史","STREMIO_TV_SEARCH_HISTORY_DESCRIPTION":"您可以搜尋標題、演員、頻道...","STREMIO_TV_SEARCH_HISTORY_CLEAR":"清除搜尋歷史","STREMIO_TV_FILTERS_DESCRIPTION":"從以下過濾器中選擇一個","FILTERS":"過濾器","SETTINGS":"設定","ACCOUNT":"賬戶","LOGOUT":"登出","THEMES":"主題","PLAYBACK":"播放","PLAYBACK_SPEED":"播放速度","AUDIO_TRACKS":"音軌","VIDEOS":"影片","SERVER":"伺服器","LINKS":"連結","ABOUT":"關於","INTERFACE":"介面","ANIMATIONS":"動畫","STATUS":"狀態","LANGUAGE":"語言","SIZE":"大小","DELAY":"延遲","BOLD":"粗體","TEXT_COLOR":"文字顏色","OUTLINE_COLOR":"輪廓顏色","BACKGROUND_COLOR":"背景顏色","BACKGROUND_BLUR":"背景模糊","SEEK_TIME_DURATION":"尋找持續時間","AUTO_PLAY":"自動播放下一集","PLAY_NOW":"現在播放","MARK_AS_WATCHED":"標記為已觀看","MARK_AS_UNWATCHED":"標記為未觀看","REWIND_TO_BEGINNING":"倒回開始","CONTINUE_WATCHING":"繼續觀看","ALL":"全部","SECONDS":"秒","ON":"開","OFF":"關","RELOAD":"重新載入","EDIT_URL":"編輯URL","NONE":"無","EMBEDDED":"內嵌","REMOTE_SWITCH_DEVICES":"開關裝置","REMOTE_VIDEOS":"影片","REMOTE_ADJUST_TIMING":"調整時間","REMOTE_ADJUST_SIZE":"調整大小","REMOTE_COULD_NOT_BE_LOADED":"無法載入Web Remote","REMOTE_RETRY":"重試","TORRENT_PROFILE_DEFAULT":"預設","TORRENT_PROFILE_SOFT":"慢","TORRENT_PROFILE_FAST":"快","TORRENT_PROFILE_ULTRA_FAST":"超快","FAQ_001_H1":"什麼是Stremio?","FAQ_001_P1":"Stremio是專為影片娛樂而設計的多媒體中心軟體,易於使用。Stremio允許您管理和觀看自己的電影,劇集,頻道和實況電視收藏。","FAQ_001_P2":"Stremio從本地磁碟和外掛系統中收集顯示給您的內容。","FAQ_001_P3":"它還會在您感興趣的新劇集/影片/電影播出時通知您,併為您提供電影推薦。","FAQ_02_H1":"Stremio與Kodi和Plex相比如何?","FAQ_02_P1":"我們受到這兩種軟體的啟發。但是我們有不同的目標——Stremio專門針對娛樂影片,並透過易於使用成為其主流解決方案。","FAQ_02_P2":"Stremio將永遠不會像Kodi和Plex那樣具有可定製性和豐富的功能,但它更易於使用。只需${1}就可以獲取它,並檢視${2}:)","FAQ_03_H1":"Stremio與Netflix相比如何?","FAQ_03_P1":"同樣,Netflix是我們的靈感之一。我們努力實現Netflix的使用者體驗,再加上許多附加的好處。但最重要的是,我們讓您可以自由管理自己的庫,並使用我們的外掛系統新增新的內容源。","FAQ_03_P2":"這使得Stremio可以無限擴充套件,因此當您使用Stremio時,您永遠不會侷限於Netflix決定許可的內容。例如,您可以透過Stremio觀看${1}中的內容電影電視${2}, ${3} Twitch.tv${4},${5}YouTube${6},${7}Vodo${8}甚至${9}Netflix${10}本身!","FAQ_04_H1":"Stremio與Flipboard相比如何?","FAQ_04_P1":"我們不常聽到這個問題,除非與初創企業的人交談:)","FAQ_04_P2":"Stremio是透過設計一個內容聚合器來實現的,它本質上就是影片的Flipboard。這一點在我們的首頁部分非常明顯,它為您提供目錄和新的插曲/新的影片通知,讓您瞭解您所關注的內容,就像Flipboard一樣。","FAQ_05_H1":"Stremio與Popcorn Time相比如何?","FAQ_05_P1":"Stremio和Popcorn Time在使用者介面上很相似,因為沒有很多方法可以正確製作影片娛樂目錄:)","FAQ_05_P2":"Popcorn Time主要集中在特定來源的流媒體上,但Stremio是不受限制的,只是一個內容聚合器,它沒有鎖定到特定的內容源。","FAQ_05_P3":"此外,我們預設不提供任何Torrent外掛,因此Stremio不提供官方功能的Popcorn Time用例。","FAQ_05_P4":"另一個顯著的區別是Popcorn Time是完全開源的,而Stremio是${1}部分開源的${2}。","FAQ_06_H1":"是否要新增此電影/系列?","FAQ_06_P1":"不,對不起 :(","FAQ_06_P2":"正如大多數其他問題中提到的,Stremio本身不提供任何內容,所有內容都是透過外掛系統新增的。如果您有內容請求,您可以使用播放器中的“報告”按鈕,它將向您當前使用的外掛的作者傳送電子郵件。","FAQ_07_H1":"","FAQ_07_P1":"","FAQ_07_P2":"","FAQ_08_H1":"能否為X建立外掛?","FAQ_08_P1":"完全有可能。","FAQ_08_P2":"如果您有一個外掛的想法,請在${1}office@stremio.com${2}給我們留言,但請確保您的外掛想法不會侵犯任何版權或使用條款。","FAQ_08_P3":"目前,我們路線圖上的下一件事是FandangoNOW,Filmon.tv video on demand和Crunchyroll的外掛。","FAQ_09_H1":"Stremio是否使用BitTorrent?","FAQ_09_P1":"是的,Stremio支援BitTorrent作為流媒體協議。您可以將其與Torrent外掛一起使用,也可以將.Torrent檔案拖放到Stremio中,或者將磁鐵鏈接貼上到搜尋欄中。","FAQ_09_P2":"請注意,使用BitTorrent的唯一官方外掛是${1}Vodo${2},它提供獨立內容,所有內容都允許與BitTorrent一起分發。","FAQ_09_P3":"我們不支援使用任何可能導致版權侵權的第三方外掛。","FAQ_10_H1":"我可以在Stremio中透過官方外掛觀看什麼節目?","FAQ_10_P1":"預設情況下,您可以在Stremio與它的嵌入式播放器觀看Filmon.tv,YouTube和Vodo的內容。另外,我們還有一個Twitch.tv外掛,以及其他一些外掛。","FAQ_10_P2":"此組合提供以下選項:","FAQ_10_L1":"Filmon.tv上的熱門電影片道,例如E4、BBC、Bollyworld TV","FAQ_10_L2":"YouTube上的所有內容,例如BBC News、Top Gear、Vevo、PewDiePie","FAQ_10_L3":"Vodo上的獨立電影","FAQ_10_L4":"Twitch.tv上的線上遊戲廣播","FAQ_10_P3":"此外,Guidebox和Netflix外掛提供了許多內容源,它們不完全在Stremio中播放,而是重定向到給定的服務。例如,Guidebox外掛將為您提供可在美國免費播放的精選電影,這些電影來自TubiTV和Crackle等服務。","FAQ_11_H1":"Stremio無法安裝,我該怎麼辦?","FAQ_11_P1":"如果您在Windows上,請嘗試${1}此替代安裝程式${2}。","FAQ_11_P2":"如果您使用的是Mac OS X,請注意,我們不支援任何比OS X Mavericks(10.9)更舊的版本。","FAQ_11_P3":"如果您使用的是Linux,請注意,我們目前只支援64位(x64)Linux。","FAQ_11_P4":"如果您仍然無法解決您的問題,請寫信給我們的${1}Facebook群組${2}。","FAQ_12_H1":"為什麼我的防毒軟體會報毒?Stremio安全嗎?","FAQ_12_P1":"我們向您保證Stremio是${1}100%安全的${2}。","FAQ_12_P2":"您的防毒軟體報毒是因為我們的安裝程式中包含廣告,一些防毒軟體將其識別為廣告軟體。","FAQ_12_P3":"如果您仍然不確定,可以嘗試我們的${1}替代安裝程式${2}。","FAQ_13_H1":"如何製作外掛?","FAQ_13_P1":"對於初學者,我們建議您檢視GitHub上的${1}外掛系統模組${2}。","FAQ_13_P2":"之後,您可以按照${1}Hello World教程${2}進行操作。","FAQ_13_P3":"如果您沒有任何程式設計技能,請在${1}Reddit社群${2}上釋出您的想法,並在${3}office@stremio.com${4}上與我們聯絡您的外掛想法。","FAQ_14_H1":"外掛是如何釋出的?","FAQ_14_P1":"當您建立一個外掛和主機,並在清單中放置一個指向工作外掛地址的終端節點欄位時,該外掛將自動釋出到我們的${1}外掛目錄${2}。","FAQ_14_P2":"發生這種情況是因為Stremio外掛模組的伺服器部分會自動呼叫我們的API來宣告外掛。當我們的API驗證您的終端節點為有效的外掛時,它將開始顯示在目錄中。","FAQ_15_H1":"我可以在瀏覽器中執行Stremio嗎?","FAQ_15_P1":"目前還沒有,但即將到來!","FAQ_15_P2":"如果您想看到Alpha版本,可以在這裡看到:${1}alpha4.strem.io${2}. 請記住,此Alpha版本上已禁用流式處理。我們支援Chrome、Firefox、Opera和Edge","FAQ_16_H1":"電視投屏不起作用/字幕不起作用","FAQ_16_P1":"電視投屏使用DLNA技術,這在不同的電視品牌和型號之間非常不一致。由於這個原因,我們沒有能力在每種情況下都測試它,所以它還遠遠不夠完美。儘管如此,我們仍在不斷改進,但我們無法為您提供DLNA能夠在您的電視上開始正常工作的預計時間。","FAQ_16_P2":"如果您在“投屏”選單中看不到您的電視,請嘗試禁用網路連線並重新啟用它(在Windows上,右鍵單擊網路並使用“啟用/禁用”),以及重新啟動路由器、電視和PC。","FAQ_16_P3":"如果您仍然遇到問題,您可以透過將您的電視品牌和型號資訊傳送到${1}來幫助我們”office@stremio.com${2}。","FAQ_16_P4":"同時,我們推薦Chromecast,我們非常支援Chromecast,或者直接用HDMI線將電視與PC連線。","FAQ_17_H1":"Stremio卡死和/或崩潰,我能做什麼?","FAQ_17_P1":"首先,如果您使用的是帶有AVG防毒軟體的Windows 7,這種組合會產生問題。問題出在AVG本身,我們這邊沒有合理的辦法解決。不幸的是,去除或禁用防毒軟體將不起作用。唯一的解決辦法是用別的東西代替AVG","FAQ_17_P2":"如果不是這個問題,但您仍在使用Windows,請更新到最新的service pack並更新/重新安裝您的GPU驅動程式,然後重試。","FAQ_17_P3":"如果您的問題仍未解決,或者您使用的是Mac或Linux,請寫信給我們,在${1}我們的Facebook群組${2}報告問題的確切細節。","FAQ_18_H1":"如何製作外掛?","FAQ_18_P1":"對於初學者,我們建議您檢視GitHub上的${1}外掛系統模組${2}。","FAQ_18_P2":"之後,您可以按照${1}Hello World教程${2}進行操作。","FAQ_18_P3":"如果您沒有任何程式設計技能,請在${1}Reddit社群${2}上釋出您的想法,並在${3}上與我們聯絡您的外掛想法。”office@stremio.com${4}。","FAQ_19_H1":"為什麼Stremio佔用磁碟空間?","FAQ_19_P1":"Stremio有一個本地快取來臨時儲存您流式傳輸的影片檔案。","FAQ_19_P2":"這有兩個好處:第一,它允許Stremio預先緩衝影片,以確保流媒體更流暢。其次,它將影片儲存在本地快取中,以便您可以繼續離線觀看。","FAQ_19_P3":"Stremio保留了多少取決於“設定”面板中的快取設定。Stremio可能會在您的磁碟上保留到設定的數量(例如2GB),除非當前流式傳輸的影片大於該數量,在這種情況下,必須分配足夠的儲存來保留它,直到您結束流式傳輸。","FAQ_20_H1":"快取資料夾在哪裡?","FAQ_20_P1":"在Windows上,Stremio快取位於您在設定中選擇的驅動器中(例如\\"E:\\\\stremio-cache\\")","FAQ_20_P2":"在MacOS上,它位於\\"~/Library/Application Support/Stremio/stremio-cache\\"","FAQ_20_P3":"在Linux上,它位於\\"~/.stremio/stremio-cache\\"或\\"~/stremio-cache\\"","FAQ_21_H1":"我得到\\"流媒體伺服器未找到\\"錯誤,我能做什麼?","FAQ_21_P1":"如果出現此錯誤,則表示以下幾點之一:","FAQ_21_P2":"1)您正試圖透過我們的${1}web版本${2}使用一個由YouTube/BitTorrent原始碼支援的外掛。在這種情況下,您應該從${3}我們的網站${4}安裝我們的桌面版本","FAQ_21_P3":"2)Stremio安裝有問題。在這種情況下,請嘗試從${1}網站${2}重新安裝我們的最新桌面版本。如果這沒有幫助,請嘗試禁用防毒軟體和防火牆,重新啟動電腦,然後重試。如果這依然不起作用,請寫信給我們的${3}Facebook群組${4}","FAQ_22_H1":"我無法在iOS上看到/使用大多數外掛","FAQ_22_P1":"由於Apple App Store條款和條件中的限制,我們限制iOS應用程式只能使用一組特定的外掛。","FAQ_22_P2":"不過,請放心,將來會有更多的iOS外掛,我們還可能新增一個整合,透過將iOS應用程式連線到Stremio流媒體伺服器,您將可以使用所有Stremio外掛。"}')},5232:e=>{"use strict";e.exports=JSON.parse('[{"name":"العربية","codes":["ar-AR","ara"]},{"name":"български език","codes":["bg-BG","bul"]},{"name":"català","codes":["ca-CA","cat"]},{"name":"čeština","codes":["cs-CZ","ces"]},{"name":"dansk","codes":["da-DK","dan"]},{"name":"Deutsch","codes":["de-DE","deu"]},{"name":"ελληνικά","codes":["el-GR","ell"]},{"name":"English","codes":["en-US","eng"]},{"name":"Esperanto","codes":["eo-EO","epo"]},{"name":"español","codes":["es-ES","spa"]},{"name":"euskara","codes":["eu-ES","eus"]},{"name":"فارسی","codes":["fa-IR","fas"]},{"name":"Français","codes":["fr-FR","fre"]},{"name":"עברית","codes":["he-IL","heb"]},{"name":"हिन्दी","codes":["hi-IN","hin"]},{"name":"hrvatski jezik","codes":["hr-HR","hrv"]},{"name":"magyar","codes":["hu-HU","hun"]},{"name":"Bahasa Indonesia","codes":["id-ID","ind"]},{"name":"italiano","codes":["it-IT","ita"]},{"name":"македонски јазик","codes":["mk-MK","mkd"]},{"name":"ဗမာစာ","codes":["my-BM","mya"]},{"name":"Norsk bokmål","codes":["nb-NO","nob"]},{"name":"Nederlands","codes":["nl-NL","nld"]},{"name":"Norsk nynorsk","codes":["nn-NO","nno"]},{"name":"język polski","codes":["pl-PL","pol"]},{"name":"português Brazil","codes":["pt-BR","por"]},{"name":"português","codes":["pt-PT","por"]},{"name":"русский язык","codes":["ru-RU","rus"]},{"name":"Svenska","codes":["sv-SE","swe"]},{"name":"slovenski jezik","codes":["sl-SL","slv"]},{"name":"српски језик","codes":["sr-RS","srp"]},{"name":"తెలుగు","codes":["te-IN","tel"]},{"name":"Türkçe","codes":["tr-TR","tur"]},{"name":"українська мова","codes":["uk-UA","ukr"]},{"name":"中文(中华人民共和国)","codes":["zh-CN","zho"]},{"name":"中文(香港特别行政區)","codes":["zh-HK","zho"]},{"name":"中文(台灣)","codes":["zh-TW","zho"]}]')},8832:e=>{"use strict";e.exports=JSON.parse('{"abk":"аҧсуа бызшәа","aar":"Afaraf","afr":"Afrikaans","aka":"Akan","sqi":"gjuha shqipe","amh":"አማርኛ","ara":"العربية","arg":"aragonés","hye":"Հայերեն","asm":"অসমীয়া","ava":"авар мацӀ","ave":"avesta","aym":"aymar aru","aze":"azərbaycan dili","bam":"bamanankan","bak":"башҡорт теле","eus":"euskara","bel":"беларуская мова","ben":"বাংলা","bih":"भोजपुरी","bis":"Bislama","bos":"bosanski jezik","bre":"brezhoneg","bul":"български език","mya":"ဗမာစာ","cat":"català","cha":"Chamoru","che":"нохчийн мотт","nya":"chiCheŵa","zho":"中文 (Zhōngwén)","chv":"чӑваш чӗлхи","cor":"Kernewek","cos":"corsu","cre":"ᓀᐦᐃᔭᐍᐏᐣ","hrv":"hrvatski jezik","ces":"čeština","dan":"dansk","div":"ދިވެހި","nld":"Nederlands","dzo":"རྫོང་ཁ","eng":"English","epo":"Esperanto","est":"eesti","ewe":"Eʋegbe","fao":"føroyskt","fij":"vosa Vakaviti","fin":"suomi","fre":"français","ful":"Fulfulde","glg":"galego","kat":"ქართული","ger":"Deutsch","ell":"ελληνικά","grn":"Avañe\'ẽ","guj":"ગુજરાતી","hat":"Kreyòl ayisyen","hau":"Hausa","heb":"עברית","her":"Otjiherero","hin":"हिन्दी","hmo":"Hiri Motu","hun":"magyar","ina":"Interlingua","ind":"Bahasa Indonesia","ile":"Interlingue","gle":"Gaeilge","ibo":"Asụsụ Igbo","ipk":"Iñupiaq","ido":"Ido","isl":"Íslenska","ita":"italiano","iku":"ᐃᓄᒃᑎᑐᑦ","jpn":"日本語 (にほんご)","jav":"basa Jawa","kal":"kalaallisut","kan":"ಕನ್ನಡ","kau":"Kanuri","kas":"कश्मीरी","kaz":"қазақ тілі","khm":"ខ្មែរ","kik":"Gĩkũyũ","kin":"Ikinyarwanda","kir":"Кыргызча","kom":"коми кыв","kon":"KiKongo","kor":"한국어 (韓國語)","kur":"Kurdî","kua":"Kuanyama","lat":"latine","ltz":"Lëtzebuergesch","lug":"Luganda","lim":"Limburgs","lin":"Lingála","lao":"ພາສາລາວ","lit":"lietuvių kalba","lub":"Tshiluba","lav":"latviešu valoda","glv":"Gaelg","mkd":"македонски јазик","mlg":"fiteny malagasy","msa":"bahasa Melayu","mal":"മലയാളം","mlt":"Malti","mri":"te reo Māori","mar":"मराठी","mah":"Kajin M̧ajeļ","mon":"монгол","nau":"Ekakairũ Naoero","nav":"Diné bizaad","nob":"Norsk bokmål","nde":"isiNdebele","nep":"नेपाली","ndo":"Owambo","nno":"Norsk nynorsk","nor":"Norsk","iii":"ꆈꌠ꒿ Nuosuhxop","nbl":"isiNdebele","oci":"occitan","oji":"ᐊᓂᔑᓈᐯᒧᐎᓐ","chu":"ѩзыкъ словѣньскъ","orm":"Afaan Oromoo","ori":"ଓଡ଼ିଆ","oss":"ирон æвзаг","pan":"ਪੰਜਾਬੀ","pli":"पाऴि","fas":"فارسی","pol":"język polski","pus":"پښتو","por":"português","pob":"português Brazil","que":"Runa Simi","roh":"rumantsch grischun","run":"Ikirundi","ron":"limba română","rus":"русский язык","san":"संस्कृतम्","srd":"sardu","snd":"सिन्धी","sme":"Davvisámegiella","smo":"gagana fa\'a Samoa","sag":"yângâ tî sängö","srp":"српски језик","gla":"Gàidhlig","sna":"chiShona","sin":"සිංහල","slk":"slovenčina","slv":"slovenski jezik","som":"Soomaaliga","sot":"Sesotho","spa":"español","sun":"Basa Sunda","swa":"Kiswahili","ssw":"SiSwati","swe":"Svenska","tam":"தமிழ்","tel":"తెలుగు","tgk":"тоҷикӣ","tha":"ไทย","tir":"ትግርኛ","bod":"བོད་ཡིག","tuk":"Türkmen","tgl":"Wikang Tagalog","tsn":"Setswana","ton":"faka Tonga","tur":"Türkçe","tso":"Xitsonga","tat":"татар теле","twi":"Twi","tah":"Reo Tahiti","uig":"Uyƣurqə","ukr":"українська мова","urd":"اردو","uzb":"O\'zbek","ven":"Tshivenḓa","vie":"Tiếng Việt","vol":"Volapük","wln":"walon","cym":"Cymraeg","wol":"Wollof","fry":"Frysk","xho":"isiXhosa","yid":"ייִדיש","yor":"Yorùbá","zha":"Saɯ cueŋƅ","zul":"isiZulu"}')}},t={};function o(a){var n=t[a];if(void 0!==n)return n.exports;var r=t[a]={id:a,loaded:!1,exports:{}};return e[a].call(r.exports,r,r.exports,o),r.loaded=!0,r.exports}o.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return o.d(t,{a:t}),t},o.d=(e,t)=>{for(var a in t)o.o(t,a)&&!o.o(e,a)&&Object.defineProperty(e,a,{enumerable:!0,get:t[a]})},o.g=(function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(e){if("object"==typeof window)return window}})(),o.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t),o.r=e=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.nmd=e=>(e.paths=[],e.children||(e.children=[]),e),(()=>{var e;o.g.importScripts&&(e=o.g.location+"");var t=o.g.document;if(!e&&t&&(t.currentScript&&(e=t.currentScript.src),!e)){var a=t.getElementsByTagName("script");a.length&&(e=a[a.length-1].src)}if(!e)throw new Error("Automatic publicPath is not supported in this browser");e=e.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),o.p=e+"../../"})(),(()=>{var e,t;function a(e,t){return(function(e){if(Array.isArray(e))return e})(e)||(function(e,t){var o=null==e?null:"undefined"!=typeof Symbol&&e[Symbol.iterator]||e["@@iterator"];if(null==o)return;var a,n,r=[],i=!0,s=!1;try{for(o=o.call(e);!(i=(a=o.next()).done)&&(r.push(a.value),!t||r.length!==t);i=!0);}catch(e){s=!0,n=e}finally{try{i||null==o.return||o.return()}finally{if(s)throw n}}return r})(e,t)||(function(e,t){if(!e)return;if("string"==typeof e)return n(e,t);var o=Object.prototype.toString.call(e).slice(8,-1);"Object"===o&&e.constructor&&(o=e.constructor.name);if("Map"===o||"Set"===o)return Array.from(e);if("Arguments"===o||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(o))return n(e,t)})(e,t)||(function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")})()}function n(e,t){(null==t||t>e.length)&&(t=e.length);for(var o=0,a=new Array(t);o arr.length) len = arr.length;\n\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n\n return arr2;\n}\n\nmodule.exports = _arrayLikeToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\n\nmodule.exports = _arrayWithHoles;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nmodule.exports = _createClass;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _iterableToArrayLimit(arr, i) {\n var _i = arr == null ? null : typeof Symbol !== \"undefined\" && arr[Symbol.iterator] || arr[\"@@iterator\"];\n\n if (_i == null) return;\n var _arr = [];\n var _n = true;\n var _d = false;\n\n var _s, _e;\n\n try {\n for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {\n _arr.push(_s.value);\n\n if (i && _arr.length === i) break;\n }\n } catch (err) {\n _d = true;\n _e = err;\n } finally {\n try {\n if (!_n && _i[\"return\"] != null) _i[\"return\"]();\n } finally {\n if (_d) throw _e;\n }\n }\n\n return _arr;\n}\n\nmodule.exports = _iterableToArrayLimit;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\n\nmodule.exports = _nonIterableRest;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var objectWithoutPropertiesLoose = require(\"./objectWithoutPropertiesLoose.js\");\n\nfunction _objectWithoutProperties(source, excluded) {\n if (source == null) return {};\n var target = objectWithoutPropertiesLoose(source, excluded);\n var key, i;\n\n if (Object.getOwnPropertySymbols) {\n var sourceSymbolKeys = Object.getOwnPropertySymbols(source);\n\n for (i = 0; i < sourceSymbolKeys.length; i++) {\n key = sourceSymbolKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;\n target[key] = source[key];\n }\n }\n\n return target;\n}\n\nmodule.exports = _objectWithoutProperties;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit.js\");\n\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\n\nvar nonIterableRest = require(\"./nonIterableRest.js\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || unsupportedIterableToArray(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\n\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\n\nmodule.exports = _unsupportedIterableToArray;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","module.exports = require(\"regenerator-runtime\");\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nfunction getId() {\n return Math.random().toString(32).slice(2);\n}\n\nfunction Bridge(scope, handler) {\n handler.addEventListener('message', /*#__PURE__*/function () {\n var _ref2 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee(_ref) {\n var request, id, path, args, value, data, thisArg;\n return _regenerator[\"default\"].wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n request = _ref.data.request;\n\n if (request) {\n _context.next = 3;\n break;\n }\n\n return _context.abrupt(\"return\");\n\n case 3:\n id = request.id, path = request.path, args = request.args;\n _context.prev = 4;\n value = path.reduce(function (value, prop) {\n return value[prop];\n }, scope);\n\n if (!(typeof value === 'function')) {\n _context.next = 13;\n break;\n }\n\n thisArg = path.slice(0, path.length - 1).reduce(function (value, prop) {\n return value[prop];\n }, scope);\n _context.next = 10;\n return value.apply(thisArg, args);\n\n case 10:\n data = _context.sent;\n _context.next = 16;\n break;\n\n case 13:\n _context.next = 15;\n return value;\n\n case 15:\n data = _context.sent;\n\n case 16:\n handler.postMessage({\n response: {\n id: id,\n result: {\n data: data\n }\n }\n });\n _context.next = 22;\n break;\n\n case 19:\n _context.prev = 19;\n _context.t0 = _context[\"catch\"](4);\n handler.postMessage({\n response: {\n id: id,\n result: {\n error: _context.t0\n }\n }\n });\n\n case 22:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[4, 19]]);\n }));\n\n return function (_x) {\n return _ref2.apply(this, arguments);\n };\n }());\n\n this.call = /*#__PURE__*/function () {\n var _ref3 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee2(path, args) {\n var id;\n return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n id = getId();\n return _context2.abrupt(\"return\", new Promise(function (resolve, reject) {\n var onMessage = function onMessage(_ref4) {\n var response = _ref4.data.response;\n if (!response || response.id !== id) return;\n handler.removeEventListener('message', onMessage);\n\n if ('error' in response.result) {\n reject(response.result.error);\n } else {\n resolve(response.result.data);\n }\n };\n\n handler.addEventListener('message', onMessage);\n handler.postMessage({\n request: {\n id: id,\n path: path,\n args: args\n }\n });\n }));\n\n case 2:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n\n return function (_x2, _x3) {\n return _ref3.apply(this, arguments);\n };\n }();\n}\n\nmodule.exports = Bridge;\n","var React = require('react');\nvar PropTypes = require('prop-types');\nvar icons = require('./icons.json');\n\nvar Icon = React.forwardRef(function(props, ref) {\n var icon = icons[props.icon];\n if (!icon) {\n return null;\n }\n\n return React.createElement('svg', Object.assign({ viewBox: icon.viewBox }, props, { ref: ref }),\n icon.paths.map(function(path, index) {\n return React.createElement('path', { key: index, d: path });\n })\n );\n});\n\nIcon.displayName = 'Icon';\nIcon.propTypes = {\n icon: PropTypes.oneOf(Object.keys(icons))\n};\n\nmodule.exports = Icon;\n","var Icon = require('./Icon');\n\nmodule.exports = Icon;\n","var EventEmitter = require('eventemitter3');\nvar ERROR = require('../error');\n\nfunction ChromecastSenderVideo(options) {\n options = options || {};\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var chromecastTransport = options.chromecastTransport;\n if (!chromecastTransport) {\n throw new Error('Chromecast transport required');\n }\n\n var device = chromecastTransport.getCastDevice();\n if (device === null) {\n throw new Error('Chromecast session must be started');\n }\n\n var deviceNameContainerElement = document.createElement('div');\n deviceNameContainerElement.style.display = 'flex';\n deviceNameContainerElement.style.flexDirection = 'row';\n deviceNameContainerElement.style.alignItems = 'center';\n deviceNameContainerElement.style.justifyContent = 'center';\n deviceNameContainerElement.style.width = '100%';\n deviceNameContainerElement.style.height = '100%';\n deviceNameContainerElement.style.backgroundColor = 'black';\n var deviceNameLabelElement = document.createElement('div');\n deviceNameLabelElement.style.flex = 'none';\n deviceNameLabelElement.style.maxWidth = '80%';\n deviceNameLabelElement.style.fontSize = '5vmin';\n deviceNameLabelElement.style.lineHeight = '1.2em';\n deviceNameLabelElement.style.maxHeight = '3.6em';\n deviceNameLabelElement.style.textAlign = 'center';\n deviceNameLabelElement.style.color = '#FFFFFF90';\n deviceNameLabelElement.innerText = 'Casting to ' + device.friendlyName;\n deviceNameContainerElement.appendChild(deviceNameLabelElement);\n containerElement.appendChild(deviceNameContainerElement);\n chromecastTransport.on('message', onMessage);\n chromecastTransport.on('message-error', onMessageReceivedError);\n\n var events = new EventEmitter();\n var destroyed = false;\n var observedProps = {\n stream: false,\n loaded: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n buffered: false,\n audioTracks: false,\n selectedAudioTrackId: false,\n subtitlesTracks: false,\n selectedSubtitlesTrackId: false,\n subtitlesOffset: false,\n subtitlesSize: false,\n subtitlesTextColor: false,\n subtitlesBackgroundColor: false,\n subtitlesOutlineColor: false,\n volume: false,\n muted: false,\n playbackSpeed: false,\n extraSubtitlesTracks: false,\n selectedExtraSubtitlesTrackId: false,\n extraSubtitlesDelay: false,\n extraSubtitlesSize: false,\n extraSubtitlesOffset: false,\n extraSubtitlesTextColor: false,\n extraSubtitlesBackgroundColor: false,\n extraSubtitlesOutlineColor: false\n };\n\n function onMessageSendError(error, action) {\n events.emit('error', Object.assign({}, ERROR.CHROMECAST_SENDER_VIDEO.MESSAGE_SEND_FAILED, {\n error: error,\n action: action\n }));\n }\n function onMessageReceivedError(error) {\n events.emit('error', Object.assign({}, ERROR.CHROMECAST_SENDER_VIDEO.INVALID_MESSAGE_RECEIVED, {\n error: error\n }));\n }\n function onMessage(message) {\n if (!message || typeof message.event !== 'string') {\n onMessageReceivedError(new Error('Invalid message: ' + message));\n return;\n }\n\n var args = Array.isArray(message.args) ? message.args : [];\n events.emit.apply(events, [message.event].concat(args));\n }\n function onPropChanged(propName, propValue) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, propValue);\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n observedProps[propName] = true;\n }\n }\n function command(commandName) {\n switch (commandName) {\n case 'destroy': {\n destroyed = true;\n onPropChanged('stream', null);\n onPropChanged('loaded', null);\n onPropChanged('paused', null);\n onPropChanged('time', null);\n onPropChanged('duration', null);\n onPropChanged('buffering', null);\n onPropChanged('buffered', null);\n onPropChanged('audioTracks', []);\n onPropChanged('selectedAudioTrackId', []);\n onPropChanged('subtitlesTracks', []);\n onPropChanged('selectedSubtitlesTrackId', null);\n onPropChanged('subtitlesOffset', null);\n onPropChanged('subtitlesSize', null);\n onPropChanged('subtitlesTextColor', null);\n onPropChanged('subtitlesBackgroundColor', null);\n onPropChanged('subtitlesOutlineColor', null);\n onPropChanged('volume', null);\n onPropChanged('muted', null);\n onPropChanged('playbackSpeed', null);\n onPropChanged('extraSubtitlesTracks', []);\n onPropChanged('selectedExtraSubtitlesTrackId', null);\n onPropChanged('extraSubtitlesDelay', null);\n onPropChanged('extraSubtitlesSize', null);\n onPropChanged('extraSubtitlesOffset', null);\n onPropChanged('extraSubtitlesTextColor', null);\n onPropChanged('extraSubtitlesBackgroundColor', null);\n onPropChanged('extraSubtitlesOutlineColor', null);\n events.removeAllListeners();\n chromecastTransport.off('message', onMessage);\n containerElement.removeChild(deviceNameContainerElement);\n break;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n chromecastTransport.sendMessage(action).catch(function(error) {\n onMessageSendError(error, action);\n });\n return;\n }\n case 'setProp': {\n chromecastTransport.sendMessage(action).catch(function(error) {\n onMessageSendError(error, action);\n });\n return;\n }\n case 'command': {\n command(action.commandName, action.commandArgs);\n chromecastTransport.sendMessage(action).catch(function(error) {\n onMessageSendError(error, action);\n });\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nChromecastSenderVideo.canPlayStream = function() {\n return Promise.resolve(true);\n};\n\nChromecastSenderVideo.manifest = {\n name: 'ChromecastSenderVideo',\n external: true,\n props: ['stream', 'loaded', 'paused', 'time', 'duration', 'buffering', 'buffered', 'audioTracks', 'selectedAudioTrackId', 'subtitlesTracks', 'selectedSubtitlesTrackId', 'subtitlesOffset', 'subtitlesSize', 'subtitlesTextColor', 'subtitlesBackgroundColor', 'subtitlesOutlineColor', 'volume', 'muted', 'playbackSpeed', 'extraSubtitlesTracks', 'selectedExtraSubtitlesTrackId', 'extraSubtitlesDelay', 'extraSubtitlesSize', 'extraSubtitlesOffset', 'extraSubtitlesTextColor', 'extraSubtitlesBackgroundColor', 'extraSubtitlesOutlineColor'],\n commands: ['load', 'unload', 'destroy', 'addExtraSubtitlesTracks'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded', 'audioTrackLoaded', 'extraSubtitlesTrackLoaded', 'implementationChanged']\n};\n\nmodule.exports = ChromecastSenderVideo;\n","var ChromecastSenderVideo = require('./ChromecastSenderVideo');\n\nmodule.exports = ChromecastSenderVideo;\n","var EventEmitter = require('eventemitter3');\nvar Hls = require('hls.js');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar Color = require('color');\nvar ERROR = require('../error');\nvar getContentType = require('./getContentType');\nvar HLS_CONFIG = require('./hlsConfig');\n\nfunction HTMLVideo(options) {\n options = options || {};\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var styleElement = document.createElement('style');\n containerElement.appendChild(styleElement);\n styleElement.sheet.insertRule('video::cue { font-size: 4vmin; color: rgb(255, 255, 255); background-color: rgba(0, 0, 0, 0); text-shadow: rgb(34, 34, 34) 1px 1px 0.1em; }');\n var videoElement = document.createElement('video');\n videoElement.style.width = '100%';\n videoElement.style.height = '100%';\n videoElement.style.backgroundColor = 'black';\n videoElement.controls = false;\n videoElement.onerror = function() {\n onVideoError();\n };\n videoElement.onended = function() {\n onEnded();\n };\n videoElement.onpause = function() {\n onPropChanged('paused');\n };\n videoElement.onplay = function() {\n onPropChanged('paused');\n };\n videoElement.ontimeupdate = function() {\n onPropChanged('time');\n onPropChanged('buffered');\n };\n videoElement.ondurationchange = function() {\n onPropChanged('duration');\n };\n videoElement.onwaiting = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onseeking = function() {\n onPropChanged('time');\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onseeked = function() {\n onPropChanged('time');\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onstalled = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onplaying = function() {\n onPropChanged('time');\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.oncanplay = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.canplaythrough = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onloadedmetadata = function() {\n onPropChanged('loaded');\n };\n videoElement.onloadeddata = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onvolumechange = function() {\n onPropChanged('volume');\n onPropChanged('muted');\n };\n videoElement.onratechange = function() {\n onPropChanged('playbackSpeed');\n };\n videoElement.textTracks.onchange = function() {\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onCueChange();\n Array.from(videoElement.textTracks).forEach(function(track) {\n track.oncuechange = onCueChange;\n });\n };\n containerElement.appendChild(videoElement);\n\n var hls = null;\n var events = new EventEmitter();\n var destroyed = false;\n var stream = null;\n var subtitlesOffset = 0;\n var observedProps = {\n stream: false,\n loaded: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n buffered: false,\n subtitlesTracks: false,\n selectedSubtitlesTrackId: false,\n subtitlesOffset: false,\n subtitlesSize: false,\n subtitlesTextColor: false,\n subtitlesBackgroundColor: false,\n subtitlesOutlineColor: false,\n audioTracks: false,\n selectedAudioTrackId: false,\n volume: false,\n muted: false,\n playbackSpeed: false\n };\n\n function getProp(propName) {\n switch (propName) {\n case 'stream': {\n return stream;\n }\n case 'loaded': {\n if (stream === null) {\n return null;\n }\n\n return videoElement.readyState >= videoElement.HAVE_METADATA;\n }\n case 'paused': {\n if (stream === null) {\n return null;\n }\n\n return !!videoElement.paused;\n }\n case 'time': {\n if (stream === null || videoElement.currentTime === null || !isFinite(videoElement.currentTime)) {\n return null;\n }\n\n return Math.floor(videoElement.currentTime * 1000);\n }\n case 'duration': {\n if (stream === null || videoElement.duration === null || !isFinite(videoElement.duration)) {\n return null;\n }\n\n return Math.floor(videoElement.duration * 1000);\n }\n case 'buffering': {\n if (stream === null) {\n return null;\n }\n\n return videoElement.readyState < videoElement.HAVE_FUTURE_DATA;\n }\n case 'buffered': {\n if (stream === null) {\n return null;\n }\n\n var time = videoElement.currentTime !== null && isFinite(videoElement.currentTime) ? videoElement.currentTime : 0;\n for (var i = 0; i < videoElement.buffered.length; i++) {\n if (videoElement.buffered.start(i) <= time && time <= videoElement.buffered.end(i)) {\n return Math.floor(videoElement.buffered.end(i) * 1000);\n }\n }\n\n return Math.floor(time * 1000);\n }\n case 'subtitlesTracks': {\n if (stream === null) {\n return [];\n }\n\n return Array.from(videoElement.textTracks)\n .map(function(track, index) {\n return Object.freeze({\n id: 'EMBEDDED_' + String(index),\n lang: track.language,\n label: track.label,\n origin: 'EMBEDDED',\n embedded: true\n });\n });\n }\n case 'selectedSubtitlesTrackId': {\n if (stream === null) {\n return null;\n }\n\n return Array.from(videoElement.textTracks)\n .reduce(function(result, track, index) {\n if (result === null && track.mode === 'showing') {\n return 'EMBEDDED_' + String(index);\n }\n\n return result;\n }, null);\n }\n case 'subtitlesOffset': {\n if (destroyed) {\n return null;\n }\n\n return subtitlesOffset;\n }\n case 'subtitlesSize': {\n if (destroyed) {\n return null;\n }\n\n return parseInt(styleElement.sheet.cssRules[0].style.fontSize, 10) * 25;\n }\n case 'subtitlesTextColor': {\n if (destroyed) {\n return null;\n }\n\n return styleElement.sheet.cssRules[0].style.color;\n }\n case 'subtitlesBackgroundColor': {\n if (destroyed) {\n return null;\n }\n\n return styleElement.sheet.cssRules[0].style.backgroundColor;\n }\n case 'subtitlesOutlineColor': {\n if (destroyed) {\n return null;\n }\n\n return styleElement.sheet.cssRules[0].style.textShadow.slice(0, styleElement.sheet.cssRules[0].style.textShadow.indexOf(')') + 1);\n }\n case 'audioTracks': {\n if (hls === null || !Array.isArray(hls.audioTracks)) {\n return [];\n }\n\n return hls.audioTracks\n .map(function(track) {\n return Object.freeze({\n id: 'EMBEDDED_' + String(track.id),\n lang: typeof track.lang === 'string' && track.lang.length > 0 ?\n track.lang\n :\n typeof track.name === 'string' && track.name.length > 0 ?\n track.name\n :\n String(track.id),\n label: typeof track.name === 'string' && track.name.length > 0 ?\n track.name\n :\n typeof track.lang === 'string' && track.lang.length > 0 ?\n track.lang\n :\n String(track.id),\n origin: 'EMBEDDED',\n embedded: true\n });\n });\n }\n case 'selectedAudioTrackId': {\n if (hls === null || hls.audioTrack === null || !isFinite(hls.audioTrack) || hls.audioTrack === -1) {\n return null;\n }\n\n return 'EMBEDDED_' + String(hls.audioTrack);\n }\n case 'volume': {\n if (destroyed || videoElement.volume === null || !isFinite(videoElement.volume)) {\n return null;\n }\n\n return Math.floor(videoElement.volume * 100);\n }\n case 'muted': {\n if (destroyed) {\n return null;\n }\n\n return !!videoElement.muted;\n }\n case 'playbackSpeed': {\n if (destroyed || videoElement.playbackRate === null || !isFinite(videoElement.playbackRate)) {\n return null;\n }\n\n return videoElement.playbackRate;\n }\n default: {\n return null;\n }\n }\n }\n function onCueChange() {\n Array.from(videoElement.textTracks).forEach(function(track) {\n Array.from(track.cues || []).forEach(function(cue) {\n cue.snapToLines = false;\n cue.line = 100 - subtitlesOffset;\n });\n });\n }\n function onVideoError() {\n if (destroyed) {\n return;\n }\n\n var error;\n switch (videoElement.error.code) {\n case 1: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_ABORTED;\n break;\n }\n case 2: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_NETWORK;\n break;\n }\n case 3: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_DECODE;\n break;\n }\n case 4: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_SRC_NOT_SUPPORTED;\n break;\n }\n default: {\n error = ERROR.UNKNOWN_ERROR;\n }\n }\n onError(Object.assign({}, error, {\n critical: true,\n error: videoElement.error\n }));\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onEnded() {\n events.emit('ended');\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName));\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n events.emit('propValue', propName, getProp(propName));\n observedProps[propName] = true;\n }\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'paused': {\n if (stream !== null) {\n propValue ? videoElement.pause() : videoElement.play();\n onPropChanged('paused');\n }\n\n break;\n }\n case 'time': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n videoElement.currentTime = parseInt(propValue, 10) / 1000;\n onPropChanged('time');\n }\n\n break;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream !== null) {\n Array.from(videoElement.textTracks)\n .forEach(function(track, index) {\n track.mode = 'EMBEDDED_' + String(index) === propValue ? 'showing' : 'disabled';\n });\n var selecterdSubtitlesTrack = getProp('subtitlesTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n if (selecterdSubtitlesTrack) {\n onPropChanged('selectedSubtitlesTrackId');\n events.emit('subtitlesTrackLoaded', selecterdSubtitlesTrack);\n }\n }\n\n break;\n }\n case 'subtitlesOffset': {\n if (propValue !== null && isFinite(propValue)) {\n subtitlesOffset = Math.max(0, Math.min(100, parseInt(propValue, 10)));\n onCueChange();\n onPropChanged('subtitlesOffset');\n }\n\n break;\n }\n case 'subtitlesSize': {\n if (propValue !== null && isFinite(propValue)) {\n styleElement.sheet.cssRules[0].style.fontSize = Math.floor(Math.max(0, parseInt(propValue, 10)) / 25) + 'vmin';\n onPropChanged('subtitlesSize');\n }\n\n break;\n }\n case 'subtitlesTextColor': {\n if (typeof propValue === 'string') {\n try {\n styleElement.sheet.cssRules[0].style.color = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('HTMLVideo', error);\n }\n\n onPropChanged('subtitlesTextColor');\n }\n\n break;\n }\n case 'subtitlesBackgroundColor': {\n if (typeof propValue === 'string') {\n try {\n styleElement.sheet.cssRules[0].style.backgroundColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('HTMLVideo', error);\n }\n\n onPropChanged('subtitlesBackgroundColor');\n }\n\n break;\n }\n case 'subtitlesOutlineColor': {\n if (typeof propValue === 'string') {\n try {\n styleElement.sheet.cssRules[0].style.textShadow = Color(propValue).rgb().string() + ' 1px 1px 0.1em';\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('HTMLVideo', error);\n }\n\n onPropChanged('subtitlesOutlineColor');\n }\n\n break;\n }\n case 'selectedAudioTrackId': {\n if (hls !== null) {\n var selecterdAudioTrack = getProp('audioTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n hls.audioTrack = selecterdAudioTrack ? parseInt(selecterdAudioTrack.id.split('_').pop(), 10) : -1;\n if (selecterdAudioTrack) {\n onPropChanged('selectedAudioTrackId');\n events.emit('audioTrackLoaded', selecterdAudioTrack);\n }\n }\n\n break;\n }\n case 'volume': {\n if (propValue !== null && isFinite(propValue)) {\n videoElement.muted = false;\n videoElement.volume = Math.max(0, Math.min(100, parseInt(propValue, 10))) / 100;\n onPropChanged('muted');\n onPropChanged('volume');\n }\n\n break;\n }\n case 'muted': {\n videoElement.muted = !!propValue;\n onPropChanged('muted');\n break;\n }\n case 'playbackSpeed': {\n if (propValue !== null && isFinite(propValue)) {\n videoElement.playbackRate = parseFloat(propValue);\n onPropChanged('playbackSpeed');\n }\n\n break;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n command('unload');\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.url === 'string') {\n stream = commandArgs.stream;\n onPropChanged('stream');\n onPropChanged('loaded');\n videoElement.autoplay = typeof commandArgs.autoplay === 'boolean' ? commandArgs.autoplay : true;\n videoElement.currentTime = commandArgs.time !== null && isFinite(commandArgs.time) ? parseInt(commandArgs.time, 10) / 1000 : 0;\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('buffered');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n getContentType(stream)\n .then(function(contentType) {\n if (stream !== commandArgs.stream) {\n return;\n }\n\n if (contentType === 'application/vnd.apple.mpegurl' && Hls.isSupported()) {\n hls = new Hls(HLS_CONFIG);\n hls.on(Hls.Events.AUDIO_TRACKS_UPDATED, function() {\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n });\n hls.on(Hls.Events.AUDIO_TRACK_SWITCHED, function() {\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n });\n hls.loadSource(stream.url);\n hls.attachMedia(videoElement);\n } else {\n videoElement.src = stream.url;\n }\n })\n .catch(function() {\n if (stream !== commandArgs.stream) {\n return;\n }\n\n videoElement.src = stream.url;\n });\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n break;\n }\n case 'unload': {\n stream = null;\n Array.from(videoElement.textTracks).forEach(function(track) {\n track.oncuechange = null;\n });\n if (hls !== null) {\n hls.removeAllListeners();\n hls.detachMedia(videoElement);\n hls.destroy();\n hls = null;\n }\n videoElement.removeAttribute('src');\n videoElement.load();\n videoElement.currentTime = 0;\n onPropChanged('stream');\n onPropChanged('loaded');\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('buffered');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n break;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n onPropChanged('subtitlesOffset');\n onPropChanged('subtitlesSize');\n onPropChanged('subtitlesTextColor');\n onPropChanged('subtitlesBackgroundColor');\n onPropChanged('subtitlesOutlineColor');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('playbackSpeed');\n events.removeAllListeners();\n videoElement.onerror = null;\n videoElement.onended = null;\n videoElement.onpause = null;\n videoElement.onplay = null;\n videoElement.ontimeupdate = null;\n videoElement.ondurationchange = null;\n videoElement.onwaiting = null;\n videoElement.onseeking = null;\n videoElement.onseeked = null;\n videoElement.onstalled = null;\n videoElement.onplaying = null;\n videoElement.oncanplay = null;\n videoElement.canplaythrough = null;\n videoElement.onloadeddata = null;\n videoElement.onvolumechange = null;\n videoElement.onratechange = null;\n videoElement.textTracks.onchange = null;\n containerElement.removeChild(videoElement);\n containerElement.removeChild(styleElement);\n break;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n return;\n }\n case 'setProp': {\n setProp(action.propName, action.propValue);\n return;\n }\n case 'command': {\n command(action.commandName, action.commandArgs);\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nHTMLVideo.canPlayStream = function(stream) {\n if (!stream || (stream.behaviorHints && stream.behaviorHints.notWebReady)) {\n return Promise.resolve(false);\n }\n\n return getContentType(stream)\n .then(function(contentType) {\n var video = document.createElement('video');\n return !!video.canPlayType(contentType) || (contentType === 'application/vnd.apple.mpegurl' && Hls.isSupported());\n })\n .catch(function() {\n return false;\n });\n};\n\nHTMLVideo.manifest = {\n name: 'HTMLVideo',\n external: false,\n props: ['stream', 'loaded', 'paused', 'time', 'duration', 'buffering', 'buffered', 'audioTracks', 'selectedAudioTrackId', 'subtitlesTracks', 'selectedSubtitlesTrackId', 'subtitlesOffset', 'subtitlesSize', 'subtitlesTextColor', 'subtitlesBackgroundColor', 'subtitlesOutlineColor', 'volume', 'muted', 'playbackSpeed'],\n commands: ['load', 'unload', 'destroy'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded', 'audioTrackLoaded']\n};\n\nmodule.exports = HTMLVideo;\n","function getContentType(stream) {\n if (!stream || typeof stream.url !== 'string') {\n return Promise.reject(new Error('Invalid stream parameter!'));\n }\n\n if (stream.behaviorHints && stream.behaviorHints.proxyHeaders && stream.behaviorHints.proxyHeaders.response && typeof stream.behaviorHints.proxyHeaders.response['content-type'] === 'string') {\n return Promise.resolve(stream.behaviorHints.proxyHeaders.response['content-type']);\n }\n\n return fetch(stream.url, { method: 'HEAD' })\n .then(function(resp) {\n if (resp.ok) {\n return resp.headers.get('content-type');\n }\n\n throw new Error(resp.status + ' (' + resp.statusText + ')');\n });\n}\n\nmodule.exports = getContentType;\n","module.exports = {\n debug: false,\n enableWorker: true,\n lowLatencyMode: false,\n backBufferLength: 30,\n maxBufferLength: 50,\n maxMaxBufferLength: 80,\n maxFragLookUpTolerance: 0,\n maxBufferHole: 0,\n appendErrorMaxRetry: 20,\n nudgeMaxRetry: 20,\n manifestLoadingTimeOut: 30000,\n manifestLoadingMaxRetry: 10,\n // liveDurationInfinity: false\n};\n","var HTMLVideo = require('./HTMLVideo');\n\nmodule.exports = HTMLVideo;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar ERROR = require('../error');\n\nfunction IFrameVideo(options) {\n options = options || {};\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var iframeElement = document.createElement('iframe');\n iframeElement.style.width = '100%';\n iframeElement.style.height = '100%';\n iframeElement.style.border = 0;\n iframeElement.style.backgroundColor = 'black';\n iframeElement.allowFullscreen = false;\n iframeElement.allow = 'autoplay';\n containerElement.appendChild(iframeElement);\n\n var events = new EventEmitter();\n var destroyed = false;\n var observedProps = {\n stream: false,\n loaded: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n buffered: false,\n volume: false,\n muted: false,\n playbackSpeed: false\n };\n\n function onMessage(event) {\n if (event.source !== iframeElement.contentWindow) {\n return;\n }\n\n var data = event.data || event.message;\n if (!data || typeof data.event !== 'string') {\n return;\n }\n\n var eventName = data.event;\n var args = Array.isArray(data.args) ? data.args : [];\n events.emit.apply(events, [eventName].concat(args));\n }\n function sendMessage(action) {\n iframeElement.contentWindow.postMessage(action, '*');\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onPropChanged(propName, propValue) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, propValue);\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n observedProps[propName] = true;\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n command('unload');\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.playerFrameUrl === 'string') {\n window.addEventListener('message', onMessage, false);\n iframeElement.onload = function() {\n sendMessage({\n type: 'command',\n commandName: commandName,\n commandArgs: commandArgs\n });\n };\n iframeElement.src = commandArgs.stream.playerFrameUrl;\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n\n return true;\n }\n case 'unload': {\n window.removeEventListener('message', onMessage);\n iframeElement.onload = null;\n iframeElement.removeAttribute('src');\n onPropChanged('stream', null);\n onPropChanged('loaded', null);\n onPropChanged('paused', null);\n onPropChanged('time', null);\n onPropChanged('duration', null);\n onPropChanged('buffering', null);\n onPropChanged('buffered', null);\n onPropChanged('volume', null);\n onPropChanged('muted', null);\n onPropChanged('playbackSpeed', null);\n return true;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n events.removeAllListeners();\n containerElement.removeChild(iframeElement);\n return true;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n sendMessage(action);\n return;\n }\n case 'setProp': {\n sendMessage(action);\n return;\n }\n case 'command': {\n if (!command(action.commandName, action.commandArgs)) {\n sendMessage(action);\n }\n\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nIFrameVideo.canPlayStream = function(stream) {\n return Promise.resolve(stream && typeof stream.playerFrameUrl === 'string');\n};\n\nIFrameVideo.manifest = {\n name: 'IFrameVideo',\n external: true,\n props: ['stream', 'loaded', 'paused', 'time', 'duration', 'buffering', 'buffered', 'audioTracks', 'selectedAudioTrackId', 'subtitlesTracks', 'selectedSubtitlesTrackId', 'subtitlesOffset', 'subtitlesSize', 'subtitlesTextColor', 'subtitlesBackgroundColor', 'subtitlesOutlineColor', 'volume', 'muted', 'playbackSpeed', 'extraSubtitlesTracks', 'selectedExtraSubtitlesTrackId', 'extraSubtitlesDelay', 'extraSubtitlesSize', 'extraSubtitlesOffset', 'extraSubtitlesTextColor', 'extraSubtitlesBackgroundColor', 'extraSubtitlesOutlineColor'],\n commands: ['load', 'unload', 'destroy', 'addExtraSubtitlesTracks'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded', 'audioTrackLoaded', 'extraSubtitlesTrackLoaded', 'implementationChanged']\n};\n\nmodule.exports = IFrameVideo;\n","var IFrameVideo = require('./IFrameVideo');\n\nmodule.exports = IFrameVideo;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar ERROR = require('../error');\n\nvar SUBS_SCALE_FACTOR = 0.0066;\n\nvar stremioToMPVProps = {\n 'stream': null,\n 'paused': 'pause',\n 'time': 'time-pos',\n 'duration': 'duration',\n 'buffering': 'buffering',\n 'volume': 'volume',\n 'muted': 'mute',\n 'playbackSpeed': 'speed',\n 'audioTracks': 'audioTracks',\n 'selectedAudioTrackId': 'aid',\n 'subtitlesTracks': 'subtitlesTracks',\n 'selectedSubtitlesTrackId': 'sid',\n 'subtitlesSize': 'sub-scale',\n 'subtitlesTextColor': 'sub-color',\n 'subtitlesBackgroundColor': 'sub-back-color',\n 'subtitlesOutlineColor': 'sub-border-color',\n};\n\nfunction ShellVideo(options) {\n options = options || {};\n\n var ipc = options.shellTransport;\n\n var stremioProps = {};\n Object.keys(stremioToMPVProps).forEach(function(key) {\n if(stremioToMPVProps[key]) {\n stremioProps[stremioToMPVProps[key]] = key;\n }\n });\n\n ipc.send('mpv-command', ['stop']);\n ipc.send('mpv-observe-prop', 'path');\n\n ipc.send('mpv-observe-prop', 'time-pos');\n ipc.send('mpv-observe-prop', 'volume');\n ipc.send('mpv-observe-prop', 'pause');\n ipc.send('mpv-observe-prop', 'seeking');\n ipc.send('mpv-observe-prop', 'eof-reached');\n\n ipc.send('mpv-observe-prop', 'duration');\n ipc.send('mpv-observe-prop', 'metadata');\n ipc.send('mpv-observe-prop', 'video-params'); // video width/height\n ipc.send('mpv-observe-prop', 'track-list');\n\n ipc.send('mpv-observe-prop', 'paused-for-cache');\n ipc.send('mpv-observe-prop', 'cache-buffering-state');\n\n ipc.send('mpv-observe-prop', 'aid');\n ipc.send('mpv-observe-prop', 'vid');\n ipc.send('mpv-observe-prop', 'sid');\n ipc.send('mpv-observe-prop', 'sub-scale');\n ipc.send('mpv-observe-prop', 'sub-pos');\n ipc.send('mpv-observe-prop', 'speed');\n\n ipc.send('mpv-observe-prop', 'mpv-version');\n ipc.send('mpv-observe-prop', 'ffmpeg-version');\n\n var events = new EventEmitter();\n var destroyed = false;\n var stream = null;\n // var selectedSubtitlesTrackId = null;\n var observedProps = {};\n var continueFrom = 0;\n\n var avgDuration = 0;\n var minClipDuration = 30;\n var props = { };\n\n function setBackground(visible) {\n // This is a bit of a hack but there is no better way so far\n var bg = visible ? '' : 'transparent';\n for(var container = options.containerElement; container; container = container.parentElement) {\n container.style.background = bg;\n }\n }\n function logProp(args) {\n // eslint-disable-next-line no-console\n console.log(args.name+': '+args.data);\n }\n function embeddedProp(args) {\n return args.data ? 'EMBEDDED_' + args.data.toString() : null;\n }\n\n var last_time = 0;\n ipc.on('mpv-prop-change', function(args) {\n switch (args.name) {\n case 'mpv-version':\n case 'ffmpeg-version': {\n props[args.name] = logProp(args);\n break;\n }\n case 'duration': {\n var intDuration = args.data | 0;\n // Accumulate average duration over time. if it is greater than minClipDuration\n // and equal to the currently reported duration, it is returned as video length.\n // If the reported duration changes over time the average duration is always\n // smaller than the currently reported one so we set the video length to 0 as\n // this is a live stream.\n props[args.name] = args.data >= minClipDuration && (!avgDuration || intDuration === avgDuration) ? Math.round(args.data * 1000) : null;\n // The average duration is calculated using right bit shifting by one of the sum of\n // the previous average and the currently reported value. This method is not very precise\n // as we get integer value but we avoid floating point errors. JS uses 32 bit values\n // for bitwise maths so the maximum supported video duration is 1073741823 (2 ^ 30 - 1)\n // which is around 34 years of playback time.\n avgDuration = avgDuration ? (avgDuration + intDuration) >> 1 : intDuration;\n break;\n }\n case 'time-pos': {\n props[args.name] = Math.round(args.data*1000);\n if(continueFrom) {\n ipc.send('mpv-set-prop', ['time-pos', continueFrom]);\n props[args.name] = Math.round(continueFrom);\n continueFrom = 0;\n }\n break;\n }\n case 'sub-scale': {\n props[args.name] = Math.round(args.data / SUBS_SCALE_FACTOR);\n break;\n }\n case 'paused-for-cache':\n case 'seeking':\n {\n if(props.buffering !== args.data) {\n props.buffering = args.data;\n onPropChanged('buffering');\n }\n break;\n }\n case 'aid':\n case 'sid':\n case 'vid': {\n props[args.name] = embeddedProp(args);\n break;\n }\n // In that case onPropChanged() is manually invoked as track-list contains all\n // the tracks but we have different event for each track type\n case 'track-list': {\n props.audioTracks = args.data.filter(function(x) { return x.type === 'audio'; })\n .map(function(x, index) {\n return {\n id: 'EMBEDDED_' + x.id,\n lang: x.lang === undefined ? 'Track' + (index + 1) : x.lang,\n label: x.title === undefined || x.lang === undefined ? '' : x.title || x.lang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: x.id === props.aid ? 'showing' : 'disabled',\n };\n });\n onPropChanged('audioTracks');\n\n props.subtitlesTracks = args.data\n .filter(function(x) { return x.type === 'sub'; })\n .map(function(x, index) {\n return {\n id: 'EMBEDDED_' + x.id,\n lang: x.lang === undefined ? 'Track ' + (index + 1) : x.lang,\n label: x.title === undefined || x.lang === undefined ? '' : x.title || x.lang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: x.id === props.sid ? 'showing' : 'disabled',\n };\n });\n onPropChanged('subtitlesTracks');\n break;\n }\n default: {\n props[args.name] = args.data;\n break;\n }\n }\n\n // Cap time update to update only when a second passes\n var current_time = args.name === 'time-pos' ? Math.floor(props['time-pos'] / 1000) : null;\n if((!current_time || last_time !== current_time)&& stremioProps[args.name]) {\n if(current_time) {\n last_time = current_time;\n }\n onPropChanged(stremioProps[args.name]);\n }\n });\n ipc.on('mpv-event-ended', function(args) {\n if (args.error) onError(args.error);\n else onEnded();\n });\n\n function getProp(propName) {\n if(stremioToMPVProps[propName]) return props[stremioToMPVProps[propName]];\n // eslint-disable-next-line no-console\n console.log('Unsupported prop requested', propName);\n return null;\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onEnded() {\n events.emit('ended');\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName));\n }\n }\n function observeProp(propName) {\n events.emit('propValue', propName, getProp(propName));\n observedProps[propName] = true;\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'paused': {\n if (stream !== null) {\n ipc.send('mpv-set-prop', ['pause', propValue]);\n }\n\n break;\n }\n case 'time': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n ipc.send('mpv-set-prop', ['time-pos', propValue/1000]);\n }\n\n break;\n }\n case 'playbackSpeed': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n ipc.send('mpv-set-prop', ['speed', propValue]);\n }\n break;\n }\n case 'volume': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n props.mute = false;\n ipc.send('mpv-set-prop', ['mute', 'no']);\n ipc.send('mpv-set-prop', ['volume', propValue]);\n onPropChanged('muted');\n onPropChanged('volume');\n }\n break;\n }\n case 'muted': {\n if (stream !== null) {\n ipc.send('mpv-set-prop', ['mute', propValue ? 'yes' : 'no']);\n props.mute = propValue;\n onPropChanged('muted');\n }\n break;\n }\n case 'selectedAudioTrackId': {\n if (stream !== null) {\n var actualId = propValue.slice('EMBEDDED_'.length);\n ipc.send('mpv-set-prop', ['aid', actualId]);\n }\n break;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream !== null) {\n if(propValue) {\n var actualId = propValue.slice('EMBEDDED_'.length);\n ipc.send('mpv-set-prop', ['sid', actualId]);\n events.emit('subtitlesTrackLoaded', propValue);\n } else {\n // turn off subs\n ipc.send('mpv-set-prop', ['sid', 'no']);\n props.sid = null;\n }\n }\n onPropChanged('selectedSubtitlesTrackId');\n break;\n }\n case 'subtitlesSize': {\n ipc.send('mpv-set-prop', [stremioToMPVProps[propName], propValue * SUBS_SCALE_FACTOR]);\n break;\n }\n case 'subtitlesOffset': {\n ipc.send('mpv-set-prop', [stremioToMPVProps[propName], propValue]);\n break;\n }\n case 'subtitlesTextColor':\n case 'subtitlesBackgroundColor':\n case 'subtitlesOutlineColor':\n {\n // MPV accepts color in #AARRGGBB\n var argb = propValue.replace(/^#(\\w{6})(\\w{2})$/, '#$2$1');\n ipc.send('mpv-set-prop', [stremioToMPVProps[propName], argb]);\n break;\n }\n default: {\n // eslint-disable-next-line no-console\n console.log('Unhandled setProp for', propName);\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n command('unload');\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.url === 'string') {\n stream = commandArgs.stream;\n onPropChanged('stream');\n continueFrom = commandArgs.time !== null && isFinite(commandArgs.time) ? parseInt(commandArgs.time, 10) / 1000 : 0;\n\n setBackground(false);\n\n ipc.send('mpv-set-prop', ['no-sub-ass']);\n\n // opengl-cb is an alias for the new name \"libmpv\", as shown in mpv's video/out/vo.c aliases\n // opengl is an alias for the new name \"gpu\"\n // When on Windows we use d3d for the rendering in separate window\n var windowRenderer = navigator.platform === 'Win32' ? 'direct3d' : 'opengl';\n var videoOutput = options.mpvSeparateWindow ? windowRenderer : 'opengl-cb';\n var separateWindow = options.mpvSeparateWindow ? 'yes' : 'no';\n ipc.send('mpv-set-prop', ['vo', videoOutput]);\n ipc.send('mpv-set-prop', ['osc', separateWindow]);\n ipc.send('mpv-set-prop', ['input-defalt-bindings', separateWindow]);\n ipc.send('mpv-set-prop', ['input-vo-keyboard', separateWindow]);\n\n ipc.send('mpv-command', ['loadfile', stream.url]);\n ipc.send('mpv-set-prop', ['pause', false]);\n ipc.send('mpv-set-prop', ['speed', props.speed]);\n ipc.send('mpv-set-prop', ['aid', props.aid]);\n ipc.send('mpv-set-prop', ['mute', 'no']);\n\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n\n break;\n }\n case 'unload': {\n props = {\n mute: false,\n speed: 1,\n subtitlesTracks: [],\n buffering: true,\n aid: null,\n sid: null,\n };\n continueFrom = 0;\n avgDuration = 0;\n ipc.send('mpv-command', ['stop']);\n onPropChanged('stream');\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n setBackground(true);\n break;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n events.removeAllListeners();\n break;\n }\n }\n }\n\n this.on = function (eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function (action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n break;\n }\n case 'setProp': {\n setProp(action.propName, action.propValue);\n return;\n }\n case 'command': {\n command(\n action.commandName,\n action.commandArgs\n );\n return;\n }\n }\n }\n };\n}\nShellVideo.canPlayStream = function() {\n return Promise.resolve(true);\n};\n\nShellVideo.manifest = {\n name: 'ShellVideo',\n external: false,\n props: Object.keys(stremioToMPVProps),\n commands: ['load', 'unload', 'destroy'],\n events: [\n 'propValue',\n 'propChanged',\n 'ended',\n 'error',\n 'subtitlesTrackLoaded',\n ],\n};\n\nmodule.exports = ShellVideo;\n","var ShellVideo = require('./ShellVideo');\n\nmodule.exports = ShellVideo;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar selectVideoImplementation = require('./selectVideoImplementation');\nvar ERROR = require('../error');\n\nfunction StremioVideo() {\n var video = null;\n var events = new EventEmitter();\n var destroyed = false;\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action, options) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n options = options || {};\n if (action.type === 'command' && action.commandName === 'load' && action.commandArgs) {\n var Video = selectVideoImplementation(action.commandArgs, options);\n if (video !== null && video.constructor !== Video) {\n video.dispatch({ type: 'command', commandName: 'destroy' });\n video = null;\n }\n if (video === null) {\n if (Video === null) {\n events.emit('error', Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n error: new Error('No video implementation was selected'),\n critical: true,\n stream: action.commandArgs.stream\n }));\n return;\n }\n\n video = new Video(options);\n video.on('ended', function() {\n events.emit('ended');\n });\n video.on('error', function(args) {\n events.emit('error', args);\n });\n video.on('propValue', function(propName, propValue) {\n events.emit('propValue', propName, propValue);\n });\n video.on('propChanged', function(propName, propValue) {\n events.emit('propChanged', propName, propValue);\n });\n video.on('subtitlesTrackLoaded', function(track) {\n events.emit('subtitlesTrackLoaded', track);\n });\n video.on('audioTrackLoaded', function(track) {\n events.emit('audioTrackLoaded', track);\n });\n video.on('extraSubtitlesTrackLoaded', function(track) {\n events.emit('extraSubtitlesTrackLoaded', track);\n });\n if (Video.manifest.external) {\n video.on('implementationChanged', function(manifest) {\n events.emit('implementationChanged', manifest);\n });\n } else {\n events.emit('implementationChanged', Video.manifest);\n }\n }\n }\n\n if (video !== null) {\n try {\n video.dispatch(action);\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error(video.constructor.manifest.name, error);\n }\n }\n\n if (action.type === 'command' && action.commandName === 'destroy') {\n video = null;\n }\n\n return;\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n this.destroy = function() {\n destroyed = true;\n if (video !== null) {\n video.dispatch({ type: 'command', commandName: 'destroy' });\n video = null;\n }\n\n events.removeAllListeners();\n };\n}\n\nStremioVideo.ERROR = ERROR;\n\nmodule.exports = StremioVideo;\n","var StremioVideo = require('./StremioVideo');\n\nmodule.exports = StremioVideo;\n","var ChromecastSenderVideo = require('../ChromecastSenderVideo');\nvar ShellVideo = require('../ShellVideo');\nvar HTMLVideo = require('../HTMLVideo');\nvar TizenVideo = require('../TizenVideo');\nvar WebOsVideo = require('../WebOsVideo');\nvar IFrameVideo = require('../IFrameVideo');\nvar YouTubeVideo = require('../YouTubeVideo');\nvar withStreamingServer = require('../withStreamingServer');\nvar withHTMLSubtitles = require('../withHTMLSubtitles');\n\nfunction selectVideoImplementation(commandArgs, options) {\n if (!commandArgs.stream || typeof commandArgs.stream.externalUrl === 'string') {\n return null;\n }\n\n if (options.chromecastTransport && options.chromecastTransport.getCastState() === cast.framework.CastState.CONNECTED) {\n return ChromecastSenderVideo;\n }\n\n if (typeof commandArgs.stream.ytId === 'string') {\n return withHTMLSubtitles(YouTubeVideo);\n }\n\n if (typeof commandArgs.stream.playerFrameUrl === 'string') {\n return IFrameVideo;\n }\n\n if (options.shellTransport) {\n return withStreamingServer(withHTMLSubtitles(ShellVideo));\n }\n\n if (typeof commandArgs.streamingServerURL === 'string') {\n if (typeof global.tizen !== 'undefined') {\n return withStreamingServer(withHTMLSubtitles(TizenVideo));\n }\n if (typeof global.webOS !== 'undefined') {\n return withStreamingServer(withHTMLSubtitles(WebOsVideo));\n }\n return withStreamingServer(withHTMLSubtitles(HTMLVideo));\n }\n\n if (typeof commandArgs.stream.url === 'string') {\n if (typeof global.webOS !== 'undefined') {\n return withHTMLSubtitles(WebOsVideo);\n }\n if (typeof global.tizen !== 'undefined') {\n return withHTMLSubtitles(TizenVideo);\n }\n return withHTMLSubtitles(HTMLVideo);\n }\n\n return null;\n}\n\nmodule.exports = selectVideoImplementation;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar Color = require('color');\nvar ERROR = require('../error');\n\nfunction TizenVideo(options) {\n options = options || {};\n\n var isBuffering = true;\n var videoSpeed = 1;\n var currentSubTrack = null;\n var currentAudioTrack = null;\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var promiseAudioTrackChange = false;\n\n var size = 100;\n var offset = 0;\n var textColor = 'rgb(255, 255, 255)';\n var backgroundColor = 'rgba(0, 0, 0, 0)';\n var outlineColor = 'rgb(34, 34, 34)';\n\n var objElement = document.createElement('object');\n objElement.type = 'application/avplayer';\n objElement.style.width = '100%';\n objElement.style.height = '100%';\n objElement.style.backgroundColor = 'black';\n\n var lastSub;\n var disabledSubs = false;\n\n function refreshSubtitle() {\n if (lastSub) {\n var lastSubDurationDiff = lastSub.duration - (getProp('time') - lastSub.now);\n if (lastSubDurationDiff > 0) renderSubtitle(lastSubDurationDiff, lastSub.text);\n }\n }\n\n function renderSubtitle(duration, text) {\n if (disabledSubs) return;\n // we ignore custom delay here, it's not needed for embedded subs\n lastSub = {\n duration: duration,\n text: text,\n now: getProp('time'),\n };\n if (subtitleTimeout) {\n clearTimeout(subtitleTimeout);\n subtitleTimeout = false;\n }\n\n while (subtitlesElement.hasChildNodes()) {\n subtitlesElement.removeChild(subtitlesElement.lastChild);\n }\n\n subtitlesElement.style.bottom = offset + '%';\n var cueNode = document.createElement('span');\n cueNode.innerHTML = text;\n cueNode.style.display = 'inline-block';\n cueNode.style.padding = '0.2em';\n cueNode.style.fontSize = Math.floor(size / 25) + 'vmin';\n cueNode.style.color = textColor;\n cueNode.style.backgroundColor = backgroundColor;\n cueNode.style.textShadow = '1px 1px 0.1em ' + outlineColor;\n\n subtitlesElement.appendChild(cueNode);\n subtitlesElement.appendChild(document.createElement('br'));\n\n if (duration) {\n subtitleTimeout = setTimeout(function() {\n while (subtitlesElement.hasChildNodes()) {\n subtitlesElement.removeChild(subtitlesElement.lastChild);\n }\n }, parseInt(duration * videoSpeed));\n }\n }\n\n var subtitleTimeout = false;\n var Listener = {\n onbufferingstart: function() {\n isBuffering = true;\n onPropChanged('buffering');\n },\n onbufferingprogress: function() {\n isBuffering = true;\n onPropChanged('buffering');\n },\n onbufferingcomplete: function() {\n isBuffering = false;\n onPropChanged('buffering');\n },\n oncurrentplaytime: function() {\n onPropChanged('time');\n },\n onerror: function() {\n onVideoError();\n },\n onsubtitlechange: function(duration, text) {\n renderSubtitle(duration, text);\n },\n onstreamcompleted: function() {\n onEnded();\n }\n };\n window.webapis.avplay.setListener(Listener);\n\n containerElement.appendChild(objElement);\n\n var subtitlesElement = document.createElement('div');\n subtitlesElement.style.position = 'absolute';\n subtitlesElement.style.right = '0';\n subtitlesElement.style.bottom = '0';\n subtitlesElement.style.left = '0';\n subtitlesElement.style.zIndex = '1';\n subtitlesElement.style.textAlign = 'center';\n containerElement.style.position = 'relative';\n containerElement.style.zIndex = '0';\n containerElement.appendChild(subtitlesElement);\n\n var events = new EventEmitter();\n var destroyed = false;\n var stream = null;\n var observedProps = {\n stream: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n subtitlesTracks: false,\n selectedSubtitlesTrackId: false,\n subtitlesOffset: false,\n subtitlesSize: false,\n subtitlesTextColor: false,\n subtitlesBackgroundColor: false,\n subtitlesOutlineColor: false,\n audioTracks: false,\n selectedAudioTrackId: false,\n playbackSpeed: false\n };\n\n function getProp(propName) {\n switch (propName) {\n case 'stream': {\n return stream;\n }\n case 'paused': {\n if (stream === null) {\n return null;\n }\n\n var isPaused = !!(window.webapis.avplay.getState() === 'PAUSED');\n\n if (!isPaused && promiseAudioTrackChange) {\n window.webapis.avplay.setSelectTrack('AUDIO', parseInt(promiseAudioTrackChange.replace('EMBEDDED_', '')));\n promiseAudioTrackChange = false;\n }\n\n return isPaused;\n }\n case 'time': {\n var currentTime = window.webapis.avplay.getCurrentTime();\n if (stream === null || currentTime === null || !isFinite(currentTime)) {\n return null;\n }\n\n return Math.floor(currentTime);\n }\n case 'duration': {\n var duration = window.webapis.avplay.getDuration();\n if (stream === null || duration === null || !isFinite(duration)) {\n return null;\n }\n\n return Math.floor(duration);\n }\n case 'buffering': {\n if (stream === null) {\n return null;\n }\n\n return isBuffering;\n }\n case 'subtitlesTracks': {\n if (stream === null) {\n return [];\n }\n\n var totalTrackInfo = window.webapis.avplay.getTotalTrackInfo();\n var textTracks = [];\n\n for (var i = 0; i < totalTrackInfo.length; i++) {\n if (totalTrackInfo[i].type === 'TEXT') {\n var textTrack = totalTrackInfo[i];\n var textTrackId = 'EMBEDDED_' + String(textTrack.index);\n if (!currentSubTrack && !textTracks.length) {\n currentSubTrack = textTrackId;\n }\n var extra = {};\n try {\n extra = JSON.parse(textTrack.extra_info);\n } catch(e) {}\n var textTrackLang = (extra.track_lang || '').trim();\n textTracks.push({\n id: textTrackId,\n lang: textTrackLang,\n label: textTrackLang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: !disabledSubs && textTrackId === currentSubTrack ? 'showing' : 'disabled',\n });\n }\n }\n\n return textTracks;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream === null || disabledSubs) {\n return null;\n }\n\n var currentTracks = window.webapis.avplay.getCurrentStreamInfo();\n var currentIndex;\n\n for (var i = 0; i < currentTracks.length; i++) {\n if (currentTracks[i].type === 'TEXT') {\n currentIndex = currentTracks[i].index;\n\n break;\n }\n }\n\n return currentIndex ? 'EMBEDDED_' + String(currentIndex) : null;\n\n }\n case 'subtitlesOffset': {\n if (destroyed) {\n return null;\n }\n\n return offset;\n }\n case 'subtitlesSize': {\n if (destroyed) {\n return null;\n }\n\n return size;\n }\n case 'subtitlesTextColor': {\n if (destroyed) {\n return null;\n }\n\n return textColor;\n }\n case 'subtitlesBackgroundColor': {\n if (destroyed) {\n return null;\n }\n\n return backgroundColor;\n }\n case 'subtitlesOutlineColor': {\n if (destroyed) {\n return null;\n }\n\n return outlineColor;\n }\n case 'audioTracks': {\n if (stream === null) {\n return [];\n }\n\n var totalTrackInfo = window.webapis.avplay.getTotalTrackInfo();\n var audioTracks = [];\n\n for (var i = 0; i < totalTrackInfo.length; i++) {\n if (totalTrackInfo[i].type === 'AUDIO') {\n var audioTrack = totalTrackInfo[i];\n var audioTrackId = 'EMBEDDED_' + String(audioTrack.index);\n if (!currentAudioTrack && !audioTracks.length) {\n currentAudioTrack = audioTrackId;\n }\n var extra = {};\n try {\n extra = JSON.parse(audioTrack.extra_info);\n } catch(e) {}\n var audioTrackLang = extra.language || '';\n audioTracks.push({\n id: audioTrackId,\n lang: audioTrackLang,\n label: audioTrackLang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: audioTrackId === currentAudioTrack ? 'showing' : 'disabled',\n });\n }\n }\n\n return audioTracks;\n }\n case 'selectedAudioTrackId': {\n if (stream === null) {\n return null;\n }\n\n if (promiseAudioTrackChange) {\n return promiseAudioTrackChange;\n }\n\n var currentTracks = window.webapis.avplay.getCurrentStreamInfo();\n var currentIndex = false;\n\n for (var i = 0; i < currentTracks.length; i++) {\n if (currentTracks[i].type === 'AUDIO') {\n currentIndex = currentTracks[i].index;\n\n break;\n }\n }\n\n return currentIndex !== false ? 'EMBEDDED_' + String(currentIndex) : null;\n }\n case 'playbackSpeed': {\n if (destroyed || videoSpeed === null || !isFinite(videoSpeed)) {\n return null;\n }\n\n return videoSpeed;\n }\n default: {\n return null;\n }\n }\n }\n function onVideoError() {\n if (destroyed) {\n return;\n }\n\n var error;\n error = ERROR.UNKNOWN_ERROR;\n onError(Object.assign({}, error, {\n critical: true,\n error: error\n }));\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onEnded() {\n events.emit('ended');\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName));\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n events.emit('propValue', propName, getProp(propName));\n observedProps[propName] = true;\n }\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'paused': {\n if (stream !== null) {\n var willPause = !!propValue;\n willPause ? window.webapis.avplay.pause() : window.webapis.avplay.play();\n if (willPause) {\n if (subtitleTimeout) {\n clearTimeout(subtitleTimeout);\n }\n } else {\n refreshSubtitle();\n }\n }\n\n onPropChanged('paused');\n\n // the paused state is usually correct, but i have seen it not change on tizen 3\n // which causes all kinds of issues in the UI: (only happens with some videos)\n var lastKnownProp = getProp('paused');\n\n setTimeout(function() {\n if (getProp('paused') !== lastKnownProp) {\n onPropChanged('paused');\n }\n }, 1000);\n\n break;\n }\n case 'time': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n window.webapis.avplay.seekTo(parseInt(propValue, 10));\n renderSubtitle(1, '');\n }\n\n break;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream !== null) {\n if ((currentSubTrack || '').indexOf('EMBEDDED_') === 0) {\n if ((propValue || '').indexOf('EMBEDDED_') === -1) {\n renderSubtitle(1, '');\n disabledSubs = true;\n onPropChanged('selectedSubtitlesTrackId');\n return;\n }\n disabledSubs = false;\n\n currentSubTrack = propValue;\n\n var selectedSubtitlesTrack = getProp('subtitlesTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n\n window.webapis.avplay.setSelectTrack('TEXT', parseInt(currentSubTrack.replace('EMBEDDED_', '')));\n\n if (selectedSubtitlesTrack) {\n events.emit('subtitlesTrackLoaded', selectedSubtitlesTrack);\n onPropChanged('selectedSubtitlesTrackId');\n }\n } else if (!propValue) {\n renderSubtitle(1, '');\n disabledSubs = true;\n onPropChanged('selectedSubtitlesTrackId');\n }\n }\n\n break;\n }\n case 'subtitlesOffset': {\n if (propValue !== null && isFinite(propValue)) {\n offset = Math.max(0, Math.min(100, parseInt(propValue, 10)));\n refreshSubtitle();\n onPropChanged('subtitlesOffset');\n }\n\n break;\n }\n case 'subtitlesSize': {\n if (propValue !== null && isFinite(propValue)) {\n size = Math.max(0, parseInt(propValue, 10));\n refreshSubtitle();\n onPropChanged('subtitlesSize');\n }\n\n break;\n }\n case 'subtitlesTextColor': {\n if (typeof propValue === 'string') {\n try {\n textColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('Tizen player with HTML Subtitles', error);\n }\n\n refreshSubtitle();\n onPropChanged('subtitlesTextColor');\n }\n\n break;\n }\n case 'subtitlesBackgroundColor': {\n if (typeof propValue === 'string') {\n try {\n backgroundColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('Tizen player with HTML Subtitles', error);\n }\n\n refreshSubtitle();\n\n onPropChanged('subtitlesBackgroundColor');\n }\n\n break;\n }\n case 'subtitlesOutlineColor': {\n if (typeof propValue === 'string') {\n try {\n outlineColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('Tizen player with HTML Subtitles', error);\n }\n\n refreshSubtitle();\n\n onPropChanged('subtitlesOutlineColor');\n }\n\n break;\n }\n case 'selectedAudioTrackId': {\n if (stream !== null) {\n\n currentAudioTrack = propValue;\n\n var selectedAudioTrack = getProp('audioTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n\n if (getProp('paused')) {\n // issues before this logic:\n // tizen 3 does not allow changing audio track when paused\n // tizen 5 does, but it will only change getProp('selectedAudioTrackId') after playback starts\n\n // will be changed on next play event, until then we will overwrite the result of getProp('selectedAudioTrackId')\n promiseAudioTrackChange = propValue;\n onPropChanged('selectedAudioTrackId');\n } else {\n window.webapis.avplay.setSelectTrack('AUDIO', parseInt(currentAudioTrack.replace('EMBEDDED_', '')));\n }\n if (selectedAudioTrack) {\n events.emit('audioTrackLoaded', selectedAudioTrack);\n onPropChanged('selectedAudioTrackId');\n }\n }\n\n break;\n }\n case 'playbackSpeed': {\n if (propValue !== null && isFinite(propValue)) {\n videoSpeed = parseFloat(propValue);\n\n try {\n window.webapis.avplay.setSpeed(videoSpeed);\n } catch (e) {}\n\n onPropChanged('playbackSpeed');\n }\n\n break;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.url === 'string') {\n stream = commandArgs.stream;\n\n if (stream !== commandArgs.stream) {\n return;\n }\n onPropChanged('buffering');\n\n window.webapis.avplay.open(stream.url);\n window.webapis.avplay.setDisplayRect(0, 0, window.innerWidth, window.innerHeight);\n window.webapis.avplay.setDisplayMethod('PLAYER_DISPLAY_MODE_LETTER_BOX');\n window.webapis.avplay.seekTo(commandArgs.time !== null && isFinite(commandArgs.time) ? parseInt(commandArgs.time, 10) : 0);\n window.webapis.avplay.prepare();\n onPropChanged('duration');\n window.webapis.avplay.play();\n\n onPropChanged('stream');\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n break;\n }\n case 'unload': {\n stream = null;\n window.webapis.avplay.stop();\n onPropChanged('stream');\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n break;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n onPropChanged('subtitlesOffset');\n onPropChanged('subtitlesSize');\n onPropChanged('subtitlesTextColor');\n onPropChanged('subtitlesBackgroundColor');\n onPropChanged('subtitlesOutlineColor');\n onPropChanged('playbackSpeed');\n events.removeAllListeners();\n containerElement.removeChild(objElement);\n break;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n return;\n }\n case 'setProp': {\n setProp(action.propName, action.propValue);\n return;\n }\n case 'command': {\n command(action.commandName, action.commandArgs);\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nTizenVideo.canPlayStream = function() {\n return Promise.resolve(true);\n};\n\nTizenVideo.manifest = {\n name: 'TizenVideo',\n external: false,\n props: ['stream', 'paused', 'time', 'duration', 'buffering', 'audioTracks', 'selectedAudioTrackId', 'subtitlesTracks', 'selectedSubtitlesTrackId', 'subtitlesOffset', 'subtitlesSize', 'subtitlesTextColor', 'subtitlesBackgroundColor', 'subtitlesOutlineColor', 'playbackSpeed'],\n commands: ['load', 'unload', 'destroy'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded', 'audioTrackLoaded']\n};\n\nmodule.exports = TizenVideo;\n","var TizenVideo = require('./TizenVideo');\n\nmodule.exports = TizenVideo;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar ERROR = require('../error');\n\nfunction luna(params, call, fail, method) {\n if (call) params.onSuccess = call || function() {};\n\n params.onFailure = function () { // function(result)\n // console.log('WebOS',(params.method || method) + ' [fail][' + result.errorCode + '] ' + result.errorText );\n\n if (fail) fail();\n };\n\n window.webOS.service.request(method || 'luna://com.webos.media', params);\n}\n\nfunction runWebOS(params, failed) {\n // console.log('run web os', params);\n window.webOS.service.request('luna://com.webos.applicationManager', {\n method: 'launch',\n parameters: {\n 'id': params.need,\n 'params': {\n 'payload':[\n {\n 'fullPath': params.url,\n 'artist':'',\n 'subtitle':'',\n 'dlnaInfo':{\n 'flagVal':4096,\n 'cleartextSize':'-1',\n 'contentLength':'-1',\n 'opVal':1,\n 'protocolInfo':'http-get:*:video/x-matroska:DLNA.ORG_OP=01;DLNA.ORG_CI=0;DLNA.ORG_FLAGS=01700000000000000000000000000000',\n 'duration':0\n },\n 'mediaType':'VIDEO',\n 'thumbnail':'',\n 'deviceType':'DMR',\n 'album':'',\n 'fileName': params.name,\n 'lastPlayPosition': params.position\n }\n ]\n }\n },\n onSuccess: function () {\n // console.log('The app is launched');\n },\n onFailure: function () { // function(inError)\n // console.log('Player', 'Failed to launch the app ('+params.need+'): ', '[' + inError.errorCode + ']: ' + inError.errorText);\n\n if (params.need === 'com.webos.app.photovideo') {\n params.need = 'com.webos.app.smartshare';\n runWebOS(params);\n } else if(params.need === 'com.webos.app.smartshare') {\n params.need = 'com.webos.app.mediadiscovery';\n runWebOS(params);\n } else if (params.need === 'com.webos.app.mediadiscovery') {\n failed();\n }\n }\n });\n}\n\nvar webOsColors = ['black', 'white', 'yellow', 'red', 'green', 'blue'];\nvar stremioColors = {\n // rgba\n 'rgba(0, 0, 0, 255)': 'black',\n 'rgba(255, 255, 255, 255)': 'white',\n 'rgba(255, 255, 0, 255)': 'yellow',\n 'rgba(255, 0, 0, 255)': 'red',\n 'rgba(0, 255, 0, 255)': 'green',\n 'rgba(0, 0, 255, 255)': 'blue',\n // rgba case 2\n 'rgba(0, 0, 0, 1)': 'black',\n 'rgba(255, 255, 255, 1)': 'white',\n 'rgba(255, 255, 0, 1)': 'yellow',\n 'rgba(255, 0, 0, 1)': 'red',\n 'rgba(0, 255, 0, 1)': 'green',\n 'rgba(0, 0, 255, 1)': 'blue',\n // rgb\n 'rgba(0, 0, 0)': 'black',\n 'rgba(255, 255, 255)': 'white',\n 'rgba(255, 255, 0)': 'yellow',\n 'rgba(255, 0, 0)': 'red',\n 'rgba(0, 255, 0)': 'green',\n 'rgba(0, 0, 255)': 'blue',\n // 8-digit hex\n '#000000FF': 'black',\n '#FFFFFFFF': 'white',\n '#FFFF00FF': 'yellow',\n '#FF0000FF': 'red',\n '#00FF00FF': 'green',\n '#0000FFFF': 'blue',\n // 6-digit hex\n '#000000': 'black',\n '#FFFFFF': 'white',\n '#FFFF00': 'yellow',\n '#FF0000': 'red',\n '#00FF00': 'green',\n '#0000FF': 'blue'\n};\n\nfunction stremioSubOffsets(offset) {\n if (offset === 0) {\n return -3;\n } else if (offset <= 2) {\n return -2;\n } else if (offset <= 3) {\n return -1;\n } else if (offset <= 5) {\n return 0;\n } else if (offset <= 10) {\n return 1;\n } else if (offset <= 25) {\n return 2;\n } else if (offset <= 50) {\n return 3;\n } else if (offset <= 100) {\n return 4;\n }\n return false;\n}\n\nfunction stremioSubSizes(size) {\n // there is also: 0 (tiny)\n // adding zero will break the logic\n if (size <= 75) {\n return 1;\n } else if (size <= 100) {\n return 2;\n } else if (size <= 150) {\n return 3;\n } else if (size <= 250) {\n return 4;\n }\n return false;\n}\n\nfunction WebOsVideo(options) {\n\n options = options || {};\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var knownMediaId = false;\n\n var subSize = 75;\n\n var disabledSubs = true;\n\n var subscribed = false;\n\n var currentSubTrack = false;\n\n var currentAudioTrack = false;\n\n var textTracks = [];\n\n var audioTracks = [];\n\n var count_message = 0;\n\n var subtitleOffset = 5;\n\n var setSubs = function (info) {\n textTracks = [];\n // console.log('sub tracks 1, nr of sub tracks: ', info.numSubtitleTracks);\n if (info.numSubtitleTracks) {\n\n // console.log('sub tracks 2');\n\n // try {\n // console.log('got sub info', JSON.stringify(info.subtitleTrackInfo));\n // } catch(e) {};\n for (var i = 0; i < info.subtitleTrackInfo.length; i++) {\n var textTrack = info.subtitleTrackInfo[i];\n textTrack.index = i;\n var textTrackLang = textTrack.language === '(null)' ? '' : textTrack.language;\n\n var textTrackId = 'EMBEDDED_' + textTrack.index;\n\n if (!currentSubTrack && !textTracks.length) {\n currentSubTrack = textTrackId;\n }\n\n textTracks.push({\n id: textTrackId,\n lang: textTrackLang,\n label: textTrackLang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: textTrackId === currentSubTrack ? 'showing' : 'disabled',\n });\n\n }\n\n // console.log('sub tracks all', textTracks);\n\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n\n }\n };\n\n var setTracks = function (info) {\n audioTracks = [];\n // console.log('audio tracks 1, nr of audio tracks: ', info.numAudioTracks);\n if (info.numAudioTracks) {\n\n //console.log('audio tracks 2');\n\n // try {\n // console.log('got audio info', JSON.stringify(info.audioTrackInfo));\n // } catch(e) {};\n for (var i = 0; i < info.audioTrackInfo.length; i++) {\n var audioTrack = info.audioTrackInfo[i];\n audioTrack.index = i;\n var audioTrackId = 'EMBEDDED_' + audioTrack.index;\n if (!currentAudioTrack && !audioTracks.length) {\n currentAudioTrack = audioTrackId;\n }\n var audioTrackLang = audioTrack.language === '(null)' ? '' : audioTrack.language;\n audioTracks.push({\n id: audioTrackId,\n lang: audioTrackLang,\n label: audioTrackLang,\n origin: 'EMBEDDED',\n embedded: true,\n mode: audioTrackId === currentAudioTrack ? 'showing' : 'disabled',\n });\n }\n // console.log('audio tracks all', audioTracks);\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n\n }\n };\n\n var subscribe = function (cb) {\n if (subscribed) return;\n subscribed = true;\n var answered = false;\n // console.log('subscribing');\n luna({\n method: 'subscribe',\n parameters: {\n 'mediaId': knownMediaId,\n 'subscribe': true\n }\n }, function (result) {\n if (result.sourceInfo && !answered) {\n answered = true;\n // try {\n // console.log('got source info', JSON.stringify(result.sourceInfo.programInfo[0]));\n // } catch(e) {};\n var info = result.sourceInfo.programInfo[0];\n\n setSubs(info);\n\n setTracks(info);\n\n unsubscribe(cb);\n }\n\n if ((result.error || {}).errorCode) {\n answered = true;\n // console.error('luna playback error', result.error);\n unsubscribe(cb);\n // unsubscribe();\n // onVideoError();\n return;\n }\n\n if ((result.unloadCompleted || {}).mediaId === knownMediaId && (result.unloadCompleted || {}).state) {\n // strange case where it just.. ends? without ever getting result.sourceInfo\n // onEnded();\n // console.log('strange case of end');\n // unsubscribe(cb);\n return;\n }\n\n // console.log('WebOS', 'subscribe', JSON.stringify(result));\n count_message++;\n\n if (count_message === 30 && !answered) {\n // cb();\n unsubscribe(cb);\n }\n }, function() { // function(err)\n // console.log('luna error log 2');\n // console.error(err);\n });\n };\n\n var unsubscribe = function (cb) {\n if (!subscribed) return;\n subscribed = false;\n luna({\n method: 'unsubscribe',\n parameters: {\n 'mediaId': knownMediaId\n }\n }, function () { // function(result)\n // console.log('unsubscribe result', JSON.stringify(result));\n cb();\n }, function () { // function(err)\n // console.log('unsubscribe error', JSON.stringify(err));\n cb();\n });\n cb();\n };\n\n // var unload = function (cb) {\n // luna({\n // method: 'unload',\n // parameters: {\n // 'mediaId': knownMediaId\n // }\n // }, cb, cb);\n // };\n\n var toggleSubtitles = function (status) {\n if (!knownMediaId) return;\n\n disabledSubs = !status;\n\n // console.log('enable subs: ' + status);\n\n luna({\n method: 'setSubtitleEnable',\n parameters: {\n 'mediaId': knownMediaId,\n 'enable': status\n }\n });\n };\n\n var styleElement = document.createElement('style');\n containerElement.appendChild(styleElement);\n styleElement.sheet.insertRule('video::cue { font-size: 4vmin; color: rgb(255, 255, 255); background-color: rgba(0, 0, 0, 0); text-shadow: rgb(34, 34, 34) 1px 1px 0.1em; }');\n var videoElement = document.createElement('video');\n videoElement.style.width = '100%';\n videoElement.style.height = '100%';\n videoElement.style.backgroundColor = 'black';\n // videoElement.crossOrigin = 'anonymous';\n videoElement.controls = false;\n videoElement.onerror = function() {\n onVideoError();\n };\n videoElement.onended = function() {\n onEnded();\n };\n videoElement.onpause = function() {\n onPropChanged('paused');\n };\n videoElement.onplay = function() {\n onPropChanged('paused');\n };\n videoElement.ontimeupdate = function() {\n onPropChanged('time');\n onPropChanged('buffered');\n };\n videoElement.ondurationchange = function() {\n onPropChanged('duration');\n };\n videoElement.onwaiting = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onseeking = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onseeked = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onstalled = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onplaying = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.oncanplay = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.canplaythrough = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onloadeddata = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n };\n videoElement.onloadedmetadata = function() {\n onPropChanged('buffering');\n onPropChanged('buffered');\n setProp('time', startTime);\n };\n videoElement.onvolumechange = function() {\n onPropChanged('volume');\n onPropChanged('muted');\n };\n videoElement.onratechange = function() {\n onPropChanged('playbackSpeed');\n };\n videoElement.textTracks.onchange = function() {\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onCueChange();\n Array.from(videoElement.textTracks).forEach(function(track) {\n track.oncuechange = onCueChange;\n });\n };\n containerElement.appendChild(videoElement);\n\n var lastSubColor = null;\n var lastSubBgColor = null;\n var lastSubBgOpacity = 0;\n var lastPlaybackSpeed = 1;\n\n var events = new EventEmitter();\n var destroyed = false;\n var stream = null;\n var startTime = null;\n var subtitlesOffset = 0;\n var observedProps = {\n stream: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n buffered: false,\n subtitlesTracks: false,\n selectedSubtitlesTrackId: false,\n subtitlesOffset: false,\n subtitlesSize: false,\n subtitlesTextColor: false,\n subtitlesBackgroundColor: false,\n audioTracks: false,\n selectedAudioTrackId: false,\n volume: false,\n muted: false,\n playbackSpeed: false\n };\n\n function getProp(propName) {\n switch (propName) {\n case 'stream': {\n return stream;\n }\n case 'paused': {\n if (stream === null) {\n return null;\n }\n\n return !!videoElement.paused;\n }\n case 'time': {\n if (stream === null || videoElement.currentTime === null || !isFinite(videoElement.currentTime)) {\n return null;\n }\n\n return Math.floor(videoElement.currentTime * 1000);\n }\n case 'duration': {\n if (stream === null || videoElement.duration === null || !isFinite(videoElement.duration)) {\n return null;\n }\n\n return Math.floor(videoElement.duration * 1000);\n }\n case 'buffering': {\n if (stream === null) {\n return null;\n }\n\n return videoElement.readyState < videoElement.HAVE_FUTURE_DATA;\n }\n case 'buffered': {\n if (stream === null) {\n return null;\n }\n\n var time = videoElement.currentTime !== null && isFinite(videoElement.currentTime) ? videoElement.currentTime : 0;\n for (var i = 0; i < videoElement.buffered.length; i++) {\n if (videoElement.buffered.start(i) <= time && time <= videoElement.buffered.end(i)) {\n return Math.floor(videoElement.buffered.end(i) * 1000);\n }\n }\n\n return Math.floor(time * 1000);\n }\n case 'subtitlesTracks': {\n if (stream === null) {\n return [];\n }\n\n return textTracks;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream === null || disabledSubs) {\n return null;\n }\n\n return currentSubTrack;\n }\n case 'subtitlesOffset': {\n if (destroyed) {\n return null;\n }\n\n return subtitlesOffset;\n }\n case 'subtitlesSize': {\n if (destroyed) {\n return null;\n }\n\n return subSize;\n }\n case 'subtitlesTextColor': {\n if (destroyed) {\n return null;\n }\n\n return lastSubColor || 'rgba(255, 255, 255, 255)';\n }\n case 'subtitlesBackgroundColor': {\n if (destroyed) {\n return null;\n }\n\n return lastSubBgColor || 'rgba(255, 255, 255, 0)';\n }\n case 'audioTracks': {\n return audioTracks;\n }\n case 'selectedAudioTrackId': {\n return currentAudioTrack;\n }\n case 'volume': {\n if (destroyed || videoElement.volume === null || !isFinite(videoElement.volume)) {\n return null;\n }\n\n return Math.floor(videoElement.volume * 100);\n }\n case 'muted': {\n if (destroyed) {\n return null;\n }\n\n return !!videoElement.muted;\n }\n case 'playbackSpeed': {\n if (destroyed || lastPlaybackSpeed === null || !isFinite(lastPlaybackSpeed)) {\n return null;\n }\n\n return lastPlaybackSpeed;\n }\n default: {\n return null;\n }\n }\n }\n function onCueChange() {\n Array.from(videoElement.textTracks).forEach(function(track) {\n Array.from(track.cues || []).forEach(function(cue) {\n cue.snapToLines = false;\n cue.line = 100 - subtitlesOffset;\n });\n });\n }\n function onVideoError() {\n if (destroyed) {\n return;\n }\n\n var error;\n switch ((videoElement.error || {}).code) {\n case 1: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_ABORTED;\n break;\n }\n case 2: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_NETWORK;\n break;\n }\n case 3: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_DECODE;\n runWebOS({\n need: 'com.webos.app.photovideo',\n url: stream.url,\n name: 'Stremio',\n position: -1,\n });\n break;\n }\n case 4: {\n error = ERROR.HTML_VIDEO.MEDIA_ERR_SRC_NOT_SUPPORTED;\n runWebOS({\n need: 'com.webos.app.photovideo',\n url: stream.url,\n name: 'Stremio',\n position: -1,\n });\n break;\n }\n default: {\n error = ERROR.UNKNOWN_ERROR;\n }\n }\n onError(Object.assign({}, error, {\n critical: true,\n error: videoElement.error\n }));\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onEnded() {\n events.emit('ended');\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName));\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n events.emit('propValue', propName, getProp(propName));\n observedProps[propName] = true;\n }\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'paused': {\n if (stream !== null) {\n propValue ? videoElement.pause() : videoElement.play();\n }\n\n break;\n }\n case 'time': {\n if (stream !== null && videoElement.readyState >= videoElement.HAVE_METADATA && propValue !== null && isFinite(propValue)) {\n try {\n videoElement.currentTime = parseInt(propValue, 10) / 1000;\n } catch(e) {\n // console.log('webos video change time error');\n // console.error(e);\n }\n }\n\n break;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream !== null) {\n if ((propValue || '').indexOf('EMBEDDED_') === 0) {\n if (disabledSubs) {\n toggleSubtitles(true);\n }\n\n // console.log('WebOS', 'change subtitles for id: ', knownMediaId, ' index:', propValue);\n\n currentSubTrack = propValue;\n var trackIndex = parseInt(propValue.replace('EMBEDDED_', ''));\n // console.log('set subs to track idx: ' + trackIndex);\n luna({\n method: 'selectTrack',\n parameters: {\n 'type': 'text',\n 'mediaId': knownMediaId,\n 'index': trackIndex\n }\n }, function() {\n // console.log('changed subs track successfully');\n var selectedSubtitlesTrack = getProp('subtitlesTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n textTracks = textTracks.map(function(track) {\n track.mode = track.id === currentSubTrack ? 'showing' : 'disabled';\n return track;\n });\n if (selectedSubtitlesTrack) {\n events.emit('subtitlesTrackLoaded', selectedSubtitlesTrack);\n onPropChanged('selectedSubtitlesTrackId');\n }\n });\n } else if (!propValue) {\n toggleSubtitles(false);\n }\n }\n\n break;\n }\n case 'subtitlesOffset': {\n if (propValue !== null && isFinite(propValue)) {\n subtitlesOffset = Math.max(0, Math.min(100, parseInt(propValue, 10)));\n var nextOffset = stremioSubOffsets(subtitleOffset);\n if (nextOffset === false) { // use default\n nextOffset = 0;\n }\n luna({\n method: 'setSubtitlePosition',\n parameters: {\n 'mediaId': knownMediaId,\n 'position': nextOffset,\n }\n }, function() {\n // console.log('successfully changed sub offset to: ' + nextOffset);\n });\n\n onPropChanged('subtitlesOffset');\n }\n\n break;\n }\n case 'subtitlesSize': {\n if (propValue !== null && isFinite(propValue)) {\n subSize = Math.max(0, parseInt(propValue, 10));\n var nextSubSize = stremioSubSizes(subSize);\n if (nextSubSize === false) { // use default\n nextSubSize = 2;\n }\n luna({\n method: 'setSubtitleFontSize',\n parameters: {\n 'mediaId': knownMediaId,\n 'fontSize': nextSubSize,\n }\n }, function() {\n // console.log('successfully changed sub size to: ' + nextSubSize);\n });\n\n onPropChanged('subtitlesSize');\n }\n\n break;\n }\n case 'subtitlesTextColor': {\n if (typeof propValue === 'string') {\n // we use setSubtitleCharacterColor instead of setSubtitleColor\n // because it has the same color options as the sub background\n var nextColor = 'white';\n if (stremioColors[propValue] && webOsColors.indexOf(stremioColors[propValue]) > -1) {\n nextColor = stremioColors[propValue];\n }\n luna({\n method: 'setSubtitleCharacterColor',\n parameters: {\n 'mediaId': knownMediaId,\n 'charColor': nextColor,\n }\n }, function() {\n // console.log('changed subtitle color successfully to: ' + nextColor);\n });\n lastSubColor = propValue;\n onPropChanged('subtitlesTextColor');\n }\n\n break;\n }\n case 'subtitlesBackgroundColor': {\n if (typeof propValue === 'string') {\n if (stremioColors[propValue] && webOsColors.indexOf(stremioColors[propValue]) > -1) {\n luna({\n method: 'setSubtitleBackgroundColor',\n parameters: {\n 'mediaId': knownMediaId,\n 'color': stremioColors[propValue],\n }\n }, function() {\n // console.log('changed subtitle background color successfully to: ' + stremioColors[propValue]);\n if (!lastSubBgOpacity) {\n luna({\n method: 'setSubtitleBackgroundOpacity',\n parameters: {\n 'mediaId': knownMediaId,\n 'bgOpacity': 255,\n }\n }, function() {\n // console.log('changed subtitle background opacity successfully to: ' + 255);\n lastSubBgOpacity = 255;\n });\n }\n });\n } else {\n // we don't know this color, set sub background opacity to 0\n luna({\n method: 'setSubtitleBackgroundOpacity',\n parameters: {\n 'mediaId': knownMediaId,\n 'bgOpacity': 0,\n }\n }, function() {\n // console.log('changed subtitle background opacity successfully to: ' + 0);\n lastSubBgOpacity = 0;\n });\n }\n lastSubBgColor = propValue;\n onPropChanged('subtitlesBackgroundColor');\n }\n\n break;\n }\n case 'selectedAudioTrackId': {\n // console.log('WebOS', 'change audio track for id: ', knownMediaId, ' index:', propValue);\n\n if ((propValue || '').indexOf('EMBEDDED_') === 0) {\n currentAudioTrack = propValue;\n var trackIndex = parseInt(propValue.replace('EMBEDDED_', ''));\n luna({\n method: 'selectTrack',\n parameters: {\n 'type': 'audio',\n 'mediaId': knownMediaId,\n 'index': trackIndex\n }\n }, function() {\n // console.log('changed audio track successfully');\n var selectedAudioTrack = getProp('audioTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n\n audioTracks = audioTracks.map(function(track) {\n track.mode = track.id === currentAudioTrack ? 'showing' : 'disabled';\n return track;\n });\n\n if (selectedAudioTrack) {\n events.emit('audioTrackLoaded', selectedAudioTrack);\n onPropChanged('selectedAudioTrackId');\n }\n });\n if (videoElement.audioTracks) {\n for (var i = 0; i < videoElement.audioTracks.length; i++) {\n videoElement.audioTracks[i].enabled = false;\n }\n\n if(videoElement.audioTracks[trackIndex]) {\n videoElement.audioTracks[trackIndex].enabled = true;\n\n // console.log('WebOS', 'change audio two method:', trackIndex);\n }\n }\n\n }\n\n break;\n }\n case 'volume': {\n if (propValue !== null && isFinite(propValue)) {\n videoElement.muted = false;\n videoElement.volume = Math.max(0, Math.min(100, parseInt(propValue, 10))) / 100;\n }\n\n break;\n }\n case 'muted': {\n videoElement.muted = !!propValue;\n break;\n }\n case 'playbackSpeed': {\n // console.log('start change play rate to: ' + propValue);\n // console.log(typeof propValue);\n if (propValue !== null && isFinite(propValue)) {\n lastPlaybackSpeed = parseFloat(propValue);\n luna({\n method: 'setPlayRate',\n parameters: {\n 'mediaId': knownMediaId,\n 'playRate': lastPlaybackSpeed,\n 'audioOutput': true,\n }\n }, function() {\n // console.log('set playback rate success: ', lastPlaybackSpeed);\n }, function() {\n // console.log('failed setting playback rate success: ', lastPlaybackSpeed);\n });\n onPropChanged('playbackSpeed');\n }\n\n break;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n // not sure about this\n // command('unload');\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.url === 'string') {\n stream = commandArgs.stream;\n startTime = commandArgs.time;\n\n onPropChanged('stream');\n videoElement.autoplay = typeof commandArgs.autoplay === 'boolean' ? commandArgs.autoplay : true;\n\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('buffered');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n\n var count = 0;\n\n var initMediaId = function (cb) {\n function retrieveMediaId() {\n if (videoElement.mediaId) {\n knownMediaId = videoElement.mediaId;\n // console.log('got media id: ', videoElement.mediaId);\n clearInterval(timer);\n subscribe(cb);\n return;\n }\n count++;\n if (count > 4) {\n // console.log('failed to get media id');\n clearInterval(timer);\n cb();\n }\n }\n var timer = setInterval(retrieveMediaId, 300);\n };\n\n var startVideo = function () {\n // console.log('startVideo');\n // not needed?\n // videoElement.src = stream.url;\n\n try {\n videoElement.load();\n } catch(e) {\n // console.log('can\\'t load video');\n // console.error(e);\n }\n\n try {\n // console.log('try play');\n videoElement.play();\n } catch(e) {\n // console.log('can\\'t start video');\n // console.error(e);\n }\n };\n\n videoElement.src = stream.url;\n\n initMediaId(startVideo);\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n break;\n }\n case 'unload': {\n stream = null;\n startTime = null;\n Array.from(videoElement.textTracks).forEach(function(track) {\n track.oncuechange = null;\n });\n videoElement.removeAttribute('src');\n videoElement.load();\n // not sure about this:\n // try {\n // videoElement.currentTime = 0;\n // } catch(e) {\n // console.log('webos video unload error');\n // console.error(e);\n // }\n onPropChanged('stream');\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('buffered');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n onPropChanged('audioTracks');\n onPropChanged('selectedAudioTrackId');\n // not sure about this:\n // unload(function() {});\n break;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n onPropChanged('subtitlesOffset');\n onPropChanged('subtitlesSize');\n onPropChanged('subtitlesTextColor');\n onPropChanged('subtitlesBackgroundColor');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('playbackSpeed');\n events.removeAllListeners();\n videoElement.onerror = null;\n videoElement.onended = null;\n videoElement.onpause = null;\n videoElement.onplay = null;\n videoElement.ontimeupdate = null;\n videoElement.ondurationchange = null;\n videoElement.onwaiting = null;\n videoElement.onseeking = null;\n videoElement.onseeked = null;\n videoElement.onstalled = null;\n videoElement.onplaying = null;\n videoElement.oncanplay = null;\n videoElement.canplaythrough = null;\n videoElement.onloadeddata = null;\n videoElement.onloadedmetadata = null;\n videoElement.onvolumechange = null;\n videoElement.onratechange = null;\n videoElement.textTracks.onchange = null;\n containerElement.removeChild(videoElement);\n containerElement.removeChild(styleElement);\n break;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n return;\n }\n case 'setProp': {\n setProp(action.propName, action.propValue);\n return;\n }\n case 'command': {\n command(action.commandName, action.commandArgs);\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nWebOsVideo.canPlayStream = function() { // function(stream)\n return Promise.resolve(true);\n};\n\nWebOsVideo.manifest = {\n name: 'WebOsVideo',\n external: false,\n props: ['stream', 'paused', 'time', 'duration', 'buffering', 'buffered', 'audioTracks', 'selectedAudioTrackId', 'subtitlesTracks', 'selectedSubtitlesTrackId', 'subtitlesOffset', 'subtitlesSize', 'subtitlesTextColor', 'subtitlesBackgroundColor', 'volume', 'muted', 'playbackSpeed'],\n commands: ['load', 'unload', 'destroy'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded', 'audioTrackLoaded']\n};\n\nmodule.exports = WebOsVideo;\n","var WebOsVideo = require('./WebOsVideo');\n\nmodule.exports = WebOsVideo;\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar ERROR = require('../error');\n\nfunction YouTubeVideo(options) {\n options = options || {};\n\n var timeChangedTimeout = options.timeChangedTimeout !== null && isFinite(options.timeChangedTimeout) ? parseInt(options.timeChangedTimeout, 10) : 100;\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var apiScriptElement = document.createElement('script');\n apiScriptElement.type = 'text/javascript';\n apiScriptElement.src = 'https://www.youtube.com/iframe_api';\n apiScriptElement.onload = onAPILoaded;\n apiScriptElement.onerror = onAPIError;\n containerElement.appendChild(apiScriptElement);\n var videoContainerElement = document.createElement('div');\n videoContainerElement.style.width = '100%';\n videoContainerElement.style.height = '100%';\n videoContainerElement.style.backgroundColor = 'black';\n containerElement.appendChild(videoContainerElement);\n var timeChangedIntervalId = window.setInterval(function() {\n onPropChanged('time');\n onPropChanged('volume');\n onPropChanged('muted');\n }, timeChangedTimeout);\n\n var video = null;\n var ready = false;\n var pendingLoadArgs = null;\n var events = new EventEmitter();\n var destroyed = false;\n var stream = null;\n var selectedSubtitlesTrackId = null;\n var observedProps = {\n stream: false,\n loaded: false,\n paused: false,\n time: false,\n duration: false,\n buffering: false,\n volume: false,\n muted: false,\n subtitlesTracks: false,\n selectedSubtitlesTrackId: false\n };\n\n function onAPIError() {\n if (destroyed) {\n return;\n }\n\n onError(Object.assign({}, ERROR.YOUTUBE_VIDEO.API_LOAD_FAILED, {\n critical: true\n }));\n }\n function onAPILoaded() {\n if (destroyed) {\n return;\n }\n\n if (!YT || typeof YT.ready !== 'function') {\n onAPIError();\n return;\n }\n\n YT.ready(function() {\n if (destroyed) {\n return;\n }\n\n if (!YT || !YT.PlayerState || typeof YT.Player !== 'function') {\n onAPIError();\n return;\n }\n\n video = new YT.Player(videoContainerElement, {\n width: '100%',\n height: '100%',\n playerVars: {\n autoplay: 1,\n cc_load_policy: 3,\n controls: 0,\n disablekb: 1,\n enablejsapi: 1,\n fs: 0,\n iv_load_policy: 3,\n loop: 0,\n modestbranding: 1,\n playsinline: 1,\n rel: 0\n },\n events: {\n onError: onVideoError,\n onReady: onVideoReady,\n onApiChange: onVideoAPIChange,\n onStateChange: onVideoStateChange\n }\n });\n });\n }\n function onVideoError(videoError) {\n if (destroyed) {\n return;\n }\n\n var error;\n switch (videoError.data) {\n case 2: {\n error = ERROR.YOUTUBE_VIDEO.INVALID_PARAMETER;\n break;\n }\n case 5: {\n error = ERROR.YOUTUBE_VIDEO.HTML5_VIDEO;\n break;\n }\n case 100: {\n error = ERROR.YOUTUBE_VIDEO.VIDEO_NOT_FOUND;\n break;\n }\n case 101:\n case 150: {\n error = ERROR.YOUTUBE_VIDEO.VIDEO_NOT_EMBEDDABLE;\n break;\n }\n default: {\n error = ERROR.UNKNOWN_ERROR;\n }\n }\n onError(Object.assign({}, error, {\n critical: true,\n error: videoError\n }));\n }\n function onVideoReady() {\n if (destroyed) {\n return;\n }\n\n ready = true;\n if (pendingLoadArgs !== null) {\n command('load', pendingLoadArgs);\n pendingLoadArgs = null;\n }\n }\n function onVideoAPIChange() {\n if (destroyed) {\n return;\n }\n\n if (typeof video.loadModule === 'function') {\n video.loadModule('captions');\n }\n if (typeof video.setOption === 'function') {\n video.setOption('captions', 'track', {});\n }\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n }\n function onVideoStateChange(state) {\n onPropChanged('buffering');\n switch (state.data) {\n case YT.PlayerState.ENDED: {\n onEnded();\n break;\n }\n case YT.PlayerState.CUED:\n case YT.PlayerState.UNSTARTED:\n case YT.PlayerState.PAUSED:\n case YT.PlayerState.PLAYING: {\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n break;\n }\n }\n }\n function getProp(propName) {\n switch (propName) {\n case 'stream': {\n return stream;\n }\n case 'loaded': {\n if (stream === null) {\n return null;\n }\n\n return true;\n }\n case 'paused': {\n if (stream === null || typeof video.getPlayerState !== 'function') {\n return null;\n }\n\n return video.getPlayerState() !== YT.PlayerState.PLAYING;\n }\n case 'time': {\n if (stream === null || typeof video.getCurrentTime !== 'function' || video.getCurrentTime() === null || !isFinite(video.getCurrentTime())) {\n return null;\n }\n\n return Math.floor(video.getCurrentTime() * 1000);\n }\n case 'duration': {\n if (stream === null || typeof video.getDuration !== 'function' || video.getDuration() === null || !isFinite(video.getDuration())) {\n return null;\n }\n\n return Math.floor(video.getDuration() * 1000);\n }\n case 'buffering': {\n if (stream === null || typeof video.getPlayerState !== 'function') {\n return null;\n }\n\n return video.getPlayerState() === YT.PlayerState.BUFFERING;\n }\n case 'volume': {\n if (stream === null || typeof video.getVolume !== 'function' || video.getVolume() === null || !isFinite(video.getVolume())) {\n return null;\n }\n\n return video.getVolume();\n }\n case 'muted': {\n if (stream === null || typeof video.isMuted !== 'function') {\n return null;\n }\n\n return video.isMuted();\n }\n case 'subtitlesTracks': {\n if (stream === null || typeof video.getOption !== 'function') {\n return [];\n }\n\n return (video.getOption('captions', 'tracklist') || [])\n .filter(function(track) {\n return track && typeof track.languageCode === 'string';\n })\n .map(function(track, index) {\n return Object.freeze({\n id: 'EMBEDDED_' + String(index),\n lang: track.languageCode,\n label: typeof track.displayName === 'string' ? track.displayName : track.languageCode,\n origin: 'EMBEDDED',\n embedded: true\n });\n });\n }\n case 'selectedSubtitlesTrackId': {\n if (stream === null) {\n return null;\n }\n\n return selectedSubtitlesTrackId;\n }\n default: {\n return null;\n }\n }\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onEnded() {\n events.emit('ended');\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName));\n }\n }\n function observeProp(propName) {\n if (observedProps.hasOwnProperty(propName)) {\n events.emit('propValue', propName, getProp(propName));\n observedProps[propName] = true;\n }\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'paused': {\n if (stream !== null) {\n propValue ?\n typeof video.pauseVideo === 'function' && video.pauseVideo()\n :\n typeof video.playVideo === 'function' && video.playVideo();\n }\n\n break;\n }\n case 'time': {\n if (stream !== null && typeof video.seekTo === 'function' && propValue !== null && isFinite(propValue)) {\n video.seekTo(parseInt(propValue, 10) / 1000);\n }\n\n break;\n }\n case 'volume': {\n if (stream !== null && propValue !== null && isFinite(propValue)) {\n if (typeof video.unMute === 'function') {\n video.unMute();\n }\n if (typeof video.setVolume === 'function') {\n video.setVolume(Math.max(0, Math.min(100, parseInt(propValue, 10))));\n }\n onPropChanged('muted');\n onPropChanged('volume');\n }\n\n break;\n }\n case 'muted': {\n if (stream !== null) {\n propValue ?\n typeof video.mute === 'function' && video.mute()\n :\n typeof video.unMute === 'function' && video.unMute();\n onPropChanged('muted');\n }\n\n break;\n }\n case 'selectedSubtitlesTrackId': {\n if (stream !== null) {\n selectedSubtitlesTrackId = null;\n var selecterdTrack = getProp('subtitlesTracks')\n .find(function(track) {\n return track.id === propValue;\n });\n if (typeof video.setOption === 'function') {\n if (selecterdTrack) {\n selectedSubtitlesTrackId = selecterdTrack.id;\n video.setOption('captions', 'track', {\n languageCode: selecterdTrack.lang\n });\n events.emit('subtitlesTrackLoaded', selecterdTrack);\n } else {\n video.setOption('captions', 'track', {});\n }\n }\n onPropChanged('selectedSubtitlesTrackId');\n }\n\n break;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n command('unload');\n if (commandArgs && commandArgs.stream && typeof commandArgs.stream.ytId === 'string') {\n if (ready) {\n stream = commandArgs.stream;\n onPropChanged('stream');\n onPropChanged('loaded');\n var autoplay = typeof commandArgs.autoplay === 'boolean' ? commandArgs.autoplay : true;\n var time = commandArgs.time !== null && isFinite(commandArgs.time) ? parseInt(commandArgs.time, 10) / 1000 : 0;\n if (autoplay && typeof video.loadVideoById === 'function') {\n video.loadVideoById({\n videoId: commandArgs.stream.ytId,\n startSeconds: time\n });\n } else if (typeof video.cueVideoById === 'function') {\n video.cueVideoById({\n videoId: commandArgs.stream.ytId,\n startSeconds: time\n });\n }\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n } else {\n pendingLoadArgs = commandArgs;\n }\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null\n }));\n }\n\n break;\n }\n case 'unload': {\n pendingLoadArgs = null;\n stream = null;\n onPropChanged('stream');\n onPropChanged('loaded');\n selectedSubtitlesTrackId = null;\n if (ready && typeof video.stopVideo === 'function') {\n video.stopVideo();\n }\n onPropChanged('paused');\n onPropChanged('time');\n onPropChanged('duration');\n onPropChanged('buffering');\n onPropChanged('volume');\n onPropChanged('muted');\n onPropChanged('subtitlesTracks');\n onPropChanged('selectedSubtitlesTrackId');\n break;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n events.removeAllListeners();\n clearInterval(timeChangedIntervalId);\n if (ready && typeof video.destroy === 'function') {\n video.destroy();\n }\n containerElement.removeChild(apiScriptElement);\n containerElement.removeChild(videoContainerElement);\n break;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n observeProp(action.propName);\n return;\n }\n case 'setProp': {\n setProp(action.propName, action.propValue);\n return;\n }\n case 'command': {\n command(action.commandName, action.commandArgs);\n return;\n }\n }\n }\n\n throw new Error('Invalid action dispatched: ' + JSON.stringify(action));\n };\n}\n\nYouTubeVideo.canPlayStream = function(stream) {\n return Promise.resolve(stream && typeof stream.ytId === 'string');\n};\n\nYouTubeVideo.manifest = {\n name: 'YouTubeVideo',\n external: false,\n props: ['stream', 'loaded', 'paused', 'time', 'duration', 'buffering', 'volume', 'muted', 'subtitlesTracks', 'selectedSubtitlesTrackId'],\n commands: ['load', 'unload', 'destroy'],\n events: ['propValue', 'propChanged', 'ended', 'error', 'subtitlesTrackLoaded']\n};\n\nmodule.exports = YouTubeVideo;\n","var YouTubeVideo = require('./YouTubeVideo');\n\nmodule.exports = YouTubeVideo;\n","var ERROR = {\n CHROMECAST_SENDER_VIDEO: {\n INVALID_MESSAGE_RECEIVED: {\n code: 100,\n message: 'Invalid message received'\n },\n MESSAGE_SEND_FAILED: {\n code: 101,\n message: 'Failed to send message'\n }\n },\n YOUTUBE_VIDEO: {\n API_LOAD_FAILED: {\n code: 90,\n message: 'YouTube player iframe API failed to load',\n },\n INVALID_PARAMETER: {\n code: 91,\n message: 'The request contains an invalid parameter value'\n },\n HTML5_VIDEO: {\n code: 92,\n message: 'The requested content cannot be played in an HTML5 player'\n },\n VIDEO_NOT_FOUND: {\n code: 93,\n message: 'The video requested was not found'\n },\n VIDEO_NOT_EMBEDDABLE: {\n code: 94,\n message: 'The owner of the requested video does not allow it to be played in embedded players'\n }\n },\n HTML_VIDEO: {\n MEDIA_ERR_ABORTED: {\n code: 80,\n message: 'Fetching process aborted'\n },\n MEDIA_ERR_NETWORK: {\n code: 81,\n message: 'Error occurred when downloading'\n },\n MEDIA_ERR_DECODE: {\n code: 82,\n message: 'Error occurred when decoding'\n },\n MEDIA_ERR_SRC_NOT_SUPPORTED: {\n code: 83,\n message: 'Video is not supported'\n }\n },\n WITH_HTML_SUBTITLES: {\n LOAD_FAILED: {\n code: 70,\n message: 'Failed to load external subtitles'\n }\n },\n WITH_STREAMING_SERVER: {\n CONVERT_FAILED: {\n code: 60,\n message: 'Streaming server failed to convert torrent stream'\n }\n },\n UNKNOWN_ERROR: {\n code: 1,\n message: 'Unknown error'\n },\n UNSUPPORTED_STREAM: {\n code: 2,\n message: 'Stream is not supported'\n }\n};\n\nmodule.exports = ERROR;\n","var StremioVideo = require('./StremioVideo');\n\nmodule.exports = StremioVideo;\n","var VIDEO_CODEC_CONFIGS = [\n {\n codec: 'h264',\n mime: 'video/mp4; codecs=\"avc1.42E01E\"',\n },\n {\n codec: 'h265',\n mime: 'video/mp4; codecs=\"hev1.1.6.L150.B0\"',\n aliases: ['hevc']\n },\n {\n codec: 'vp8',\n mime: 'video/mp4; codecs=\"vp8\"'\n },\n {\n codec: 'vp9',\n mime: 'video/mp4; codecs=\"vp9\"'\n }\n];\n\nvar AUDIO_CODEC_CONFIGS = [\n {\n codec: 'aac',\n mime: 'audio/mp4; codecs=\"mp4a.40.2\"'\n },\n {\n codec: 'mp3',\n mime: 'audio/mp4; codecs=\"mp3\"'\n },\n {\n codec: 'ac3',\n mime: 'audio/mp4; codecs=\"ac-3\"'\n },\n {\n codec: 'eac3',\n mime: 'audio/mp4; codecs=\"ec-3\"'\n },\n {\n codec: 'vorbis',\n mime: 'audio/mp4; codecs=\"vorbis\"'\n },\n {\n codec: 'opus',\n mime: 'audio/mp4; codecs=\"opus\"'\n }\n];\n\nfunction canPlay(config, options) {\n return options.mediaElement.canPlayType(config.mime) ?\n [config.codec].concat(config.aliases || [])\n :\n [];\n}\n\nfunction getMaxAudioChannels() {\n if (/firefox/i.test(window.navigator.userAgent)) {\n return 6;\n }\n\n if (!window.AudioContext) {\n return 2;\n }\n\n var maxChannelCount = new AudioContext().destination.maxChannelCount;\n return maxChannelCount > 0 ? maxChannelCount : 2;\n}\n\nfunction getMediaCapabilities() {\n var mediaElement = document.createElement('video');\n var formats = ['mp4'];\n var videoCodecs = VIDEO_CODEC_CONFIGS\n .map(function(config) {\n return canPlay(config, { mediaElement: mediaElement });\n })\n .reduce(function(result, value) {\n return result.concat(value);\n }, []);\n var audioCodecs = AUDIO_CODEC_CONFIGS\n .map(function(config) {\n return canPlay(config, { mediaElement: mediaElement });\n })\n .reduce(function(result, value) {\n return result.concat(value);\n }, []);\n var maxAudioChannels = getMaxAudioChannels();\n return {\n formats: formats,\n videoCodecs: videoCodecs,\n audioCodecs: audioCodecs,\n maxAudioChannels: maxAudioChannels\n };\n}\n\nmodule.exports = getMediaCapabilities();\n","function binarySearchUpperBound(array, value) {\n if (value < array[0] || array[array.length - 1] < value) {\n return -1;\n }\n\n var left = 0;\n var right = array.length - 1;\n var index = -1;\n while (left <= right) {\n var middle = Math.floor((left + right) / 2);\n if (array[middle] > value) {\n right = middle - 1;\n } else if (array[middle] < value) {\n left = middle + 1;\n } else {\n index = middle;\n left = middle + 1;\n }\n }\n\n return index !== -1 ? index : right;\n}\n\nmodule.exports = binarySearchUpperBound;\n","var withHTMLSubtitles = require('./withHTMLSubtitles');\n\nmodule.exports = withHTMLSubtitles;\n","// from: https://github.com/silviapfeiffer/silviapfeiffer.github.io/blob/master/index.html#L150-L216\n\nfunction srt2webvtt(data) {\n // remove dos newlines\n var srt = data.replace(/\\r+/g, '');\n // trim white space start and end\n srt = srt.replace(/^\\s+|\\s+$/g, '');\n // get cues\n var cuelist = srt.split('\\n\\n');\n var result = '';\n if (cuelist.length > 0) {\n result += 'WEBVTT\\n\\n';\n for (var i = 0; i < cuelist.length; i = i + 1) {\n result += convertSrtCue(cuelist[i]);\n }\n }\n return result;\n}\n\nfunction convertSrtCue(caption) {\n // remove all html tags for security reasons\n caption = caption.replace(/<[a-zA-Z/][^>]*>/g, '');\n\n var cue = '';\n var s = caption.split(/\\n/);\n // concatenate muilt-line string separated in array into one\n while (s.length > 3) {\n for (var i = 3; i < s.length; i++) {\n s[2] += '\\n' + s[i];\n }\n s.splice(3, s.length - 3);\n }\n var line = 0;\n // detect identifier\n if (!s[0].match(/\\d+:\\d+:\\d+/) && s[1].match(/\\d+:\\d+:\\d+/)) {\n cue += s[0].match(/\\w+/) + '\\n';\n line += 1;\n }\n // get time strings\n if (s[line].match(/\\d+:\\d+:\\d+/)) {\n // convert time string\n var m = s[1].match(/(\\d+):(\\d+):(\\d+)(?:,(\\d+))?\\s*--?>\\s*(\\d+):(\\d+):(\\d+)(?:,(\\d+))?/);\n if (m) {\n cue += m[1] + ':' + m[2] + ':' + m[3] + '.' + m[4] + ' --> '\n + m[5] + ':' + m[6] + ':' + m[7] + '.' + m[8] + '\\n';\n line += 1;\n } else {\n // Unrecognized timestring\n return '';\n }\n } else {\n // file format error or comment lines\n return '';\n }\n // get cue text\n if (s[line]) {\n cue += s[line] + '\\n\\n';\n }\n return cue;\n}\n\nmodule.exports = {\n convert: function(text) {\n // presume all to be SRT if not WEBVTT\n if (text.includes('WEBVTT')) {\n return text;\n }\n\n try {\n return srt2webvtt(text);\n } catch (error) {\n throw new Error('Failed to convert srt to webvtt: ' + error.message);\n }\n }\n};\n","var VTTJS = require('vtt.js');\nvar binarySearchUpperBound = require('./binarySearchUpperBound');\n\nvar CRITICAL_ERROR_CODE = 0;\n\nfunction parse(text) {\n return new Promise(function(resolve, reject) {\n var parser = new VTTJS.WebVTT.Parser(window, VTTJS.WebVTT.StringDecoder());\n var errors = [];\n var cues = [];\n var cuesByTime = {};\n\n parser.oncue = function(c) {\n var cue = {\n startTime: (c.startTime * 1000) | 0,\n endTime: (c.endTime * 1000) | 0,\n text: c.text\n };\n cues.push(cue);\n cuesByTime[cue.startTime] = cuesByTime[cue.startTime] || [];\n cuesByTime[cue.endTime] = cuesByTime[cue.endTime] || [];\n };\n\n parser.onparsingerror = function(error) {\n if (error.code === CRITICAL_ERROR_CODE) {\n parser.oncue = null;\n parser.onparsingerror = null;\n parser.onflush = null;\n reject(error);\n } else {\n console.warn('Subtitles parsing error', error);\n errors.push(error);\n }\n };\n\n parser.onflush = function() {\n cuesByTime.times = Object.keys(cuesByTime)\n .map(function(time) {\n return parseInt(time, 10);\n })\n .sort(function(t1, t2) {\n return t1 - t2;\n });\n for (var i = 0; i < cues.length; i++) {\n cuesByTime[cues[i].startTime].push(cues[i]);\n var startTimeIndex = binarySearchUpperBound(cuesByTime.times, cues[i].startTime);\n for (var j = startTimeIndex + 1; j < cuesByTime.times.length; j++) {\n if (cues[i].endTime <= cuesByTime.times[j]) {\n break;\n }\n\n cuesByTime[cuesByTime.times[j]].push(cues[i]);\n }\n }\n\n for (var k = 0; k < cuesByTime.times.length; k++) {\n cuesByTime[cuesByTime.times[k]].sort(function(c1, c2) {\n return c1.startTime - c2.startTime ||\n c1.endTime - c2.endTime;\n });\n }\n\n parser.oncue = null;\n parser.onparsingerror = null;\n parser.onflush = null;\n // we may have multiple parsing errors here, but will only respond with the first\n // if subtitle cues are available, we will not reject the promise\n if (cues.length === 0 && errors.length) {\n reject(errors[0]);\n } else if (cuesByTime.times.length === 0) {\n reject(new Error('Missing subtitle track cues'));\n } else {\n resolve(cuesByTime);\n }\n };\n\n parser.parse(text);\n });\n}\n\nmodule.exports = {\n parse: parse\n};\n","var VTTJS = require('vtt.js');\nvar binarySearchUpperBound = require('./binarySearchUpperBound');\n\nfunction render(cuesByTime, time) {\n var nodes = [];\n var timeIndex = binarySearchUpperBound(cuesByTime.times, time);\n if (timeIndex !== -1) {\n var cuesForTime = cuesByTime[cuesByTime.times[timeIndex]];\n for (var i = 0; i < cuesForTime.length; i++) {\n var node = VTTJS.WebVTT.convertCueToDOMTree(window, cuesForTime[i].text);\n nodes.push(node);\n }\n }\n\n return nodes;\n}\n\nmodule.exports = {\n render: render\n};\n","var EventEmitter = require('eventemitter3');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar Color = require('color');\nvar ERROR = require('../error');\nvar subtitlesParser = require('./subtitlesParser');\nvar subtitlesRenderer = require('./subtitlesRenderer');\nvar subtitlesConverter = require('./subtitlesConverter');\n\nfunction withHTMLSubtitles(Video) {\n function VideoWithHTMLSubtitles(options) {\n options = options || {};\n\n var video = new Video(options);\n video.on('error', onVideoError);\n video.on('propValue', onVideoPropEvent.bind(null, 'propValue'));\n video.on('propChanged', onVideoPropEvent.bind(null, 'propChanged'));\n Video.manifest.events\n .filter(function(eventName) {\n return !['error', 'propValue', 'propChanged'].includes(eventName);\n })\n .forEach(function(eventName) {\n video.on(eventName, onOtherVideoEvent(eventName));\n });\n\n var containerElement = options.containerElement;\n if (!(containerElement instanceof HTMLElement)) {\n throw new Error('Container element required to be instance of HTMLElement');\n }\n\n var subtitlesElement = document.createElement('div');\n subtitlesElement.style.position = 'absolute';\n subtitlesElement.style.right = '0';\n subtitlesElement.style.bottom = '0';\n subtitlesElement.style.left = '0';\n subtitlesElement.style.zIndex = '1';\n subtitlesElement.style.textAlign = 'center';\n containerElement.style.position = 'relative';\n containerElement.style.zIndex = '0';\n containerElement.appendChild(subtitlesElement);\n\n var videoState = {\n time: null\n };\n var cuesByTime = null;\n var events = new EventEmitter();\n var destroyed = false;\n var tracks = [];\n var selectedTrackId = null;\n var delay = null;\n var size = 100;\n var offset = 0;\n var textColor = 'rgb(255, 255, 255)';\n var backgroundColor = 'rgba(0, 0, 0, 0)';\n var outlineColor = 'rgb(34, 34, 34)';\n var observedProps = {\n extraSubtitlesTracks: false,\n selectedExtraSubtitlesTrackId: false,\n extraSubtitlesDelay: false,\n extraSubtitlesSize: false,\n extraSubtitlesOffset: false,\n extraSubtitlesTextColor: false,\n extraSubtitlesBackgroundColor: false,\n extraSubtitlesOutlineColor: false\n };\n\n function renderSubtitles() {\n while (subtitlesElement.hasChildNodes()) {\n subtitlesElement.removeChild(subtitlesElement.lastChild);\n }\n\n if (cuesByTime === null || videoState.time === null || !isFinite(videoState.time)) {\n return;\n }\n\n subtitlesElement.style.bottom = offset + '%';\n subtitlesRenderer.render(cuesByTime, videoState.time + delay).forEach(function(cueNode) {\n cueNode.style.display = 'inline-block';\n cueNode.style.padding = '0.2em';\n cueNode.style.fontSize = Math.floor(size / 25) + 'vmin';\n cueNode.style.color = textColor;\n cueNode.style.backgroundColor = backgroundColor;\n cueNode.style.textShadow = '1px 1px 0.1em ' + outlineColor;\n subtitlesElement.appendChild(cueNode);\n subtitlesElement.appendChild(document.createElement('br'));\n });\n }\n function onVideoError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onVideoPropEvent(eventName, propName, propValue) {\n switch (propName) {\n case 'time': {\n videoState.time = propValue;\n renderSubtitles();\n break;\n }\n }\n\n events.emit(eventName, propName, getProp(propName, propValue));\n }\n function onOtherVideoEvent(eventName) {\n return function() {\n events.emit.apply(events, [eventName].concat(Array.from(arguments)));\n };\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName, null));\n }\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n video.dispatch({ type: 'command', commandName: 'unload' });\n }\n }\n function getProp(propName, videoPropValue) {\n switch (propName) {\n case 'extraSubtitlesTracks': {\n if (destroyed) {\n return [];\n }\n\n return tracks.slice();\n }\n case 'selectedExtraSubtitlesTrackId': {\n if (destroyed) {\n return null;\n }\n\n return selectedTrackId;\n }\n case 'extraSubtitlesDelay': {\n if (destroyed) {\n return null;\n }\n\n return delay;\n }\n case 'extraSubtitlesSize': {\n if (destroyed) {\n return null;\n }\n\n return size;\n }\n case 'extraSubtitlesOffset': {\n if (destroyed) {\n return null;\n }\n\n return offset;\n }\n case 'extraSubtitlesTextColor': {\n if (destroyed) {\n return null;\n }\n\n return textColor;\n }\n case 'extraSubtitlesBackgroundColor': {\n if (destroyed) {\n return null;\n }\n\n return backgroundColor;\n }\n case 'extraSubtitlesOutlineColor': {\n if (destroyed) {\n return null;\n }\n\n return outlineColor;\n }\n default: {\n return videoPropValue;\n }\n }\n }\n function observeProp(propName) {\n switch (propName) {\n case 'extraSubtitlesTracks':\n case 'selectedExtraSubtitlesTrackId':\n case 'extraSubtitlesDelay':\n case 'extraSubtitlesSize':\n case 'extraSubtitlesOffset':\n case 'extraSubtitlesTextColor':\n case 'extraSubtitlesBackgroundColor':\n case 'extraSubtitlesOutlineColor': {\n events.emit('propValue', propName, getProp(propName, null));\n observedProps[propName] = true;\n return true;\n }\n default: {\n return false;\n }\n }\n }\n function setProp(propName, propValue) {\n switch (propName) {\n case 'selectedExtraSubtitlesTrackId': {\n cuesByTime = null;\n selectedTrackId = null;\n delay = null;\n var selectedTrack = tracks.find(function(track) {\n return track.id === propValue;\n });\n if (selectedTrack) {\n selectedTrackId = selectedTrack.id;\n delay = 0;\n fetch(selectedTrack.url)\n .then(function(resp) {\n if (resp.ok) {\n return resp.text();\n }\n\n throw new Error(resp.status + ' (' + resp.statusText + ')');\n })\n .then(function(text) {\n return subtitlesConverter.convert(text);\n })\n .then(function(text) {\n return subtitlesParser.parse(text);\n })\n .then(function(result) {\n if (selectedTrackId !== selectedTrack.id) {\n return;\n }\n\n cuesByTime = result;\n renderSubtitles();\n events.emit('extraSubtitlesTrackLoaded', selectedTrack);\n })\n .catch(function(error) {\n if (selectedTrackId !== selectedTrack.id) {\n return;\n }\n\n onError(Object.assign({}, ERROR.WITH_HTML_SUBTITLES.LOAD_FAILED, {\n error: error,\n track: selectedTrack,\n critical: false\n }));\n });\n }\n renderSubtitles();\n onPropChanged('selectedExtraSubtitlesTrackId');\n onPropChanged('extraSubtitlesDelay');\n return true;\n }\n case 'extraSubtitlesDelay': {\n if (selectedTrackId !== null && propValue !== null && isFinite(propValue)) {\n delay = parseInt(propValue, 10);\n renderSubtitles();\n onPropChanged('extraSubtitlesDelay');\n }\n\n return true;\n }\n case 'extraSubtitlesSize': {\n if (propValue !== null && isFinite(propValue)) {\n size = Math.max(0, parseInt(propValue, 10));\n renderSubtitles();\n onPropChanged('extraSubtitlesSize');\n }\n\n return true;\n }\n case 'extraSubtitlesOffset': {\n if (propValue !== null && isFinite(propValue)) {\n offset = Math.max(0, Math.min(100, parseInt(propValue, 10)));\n renderSubtitles();\n onPropChanged('extraSubtitlesOffset');\n }\n\n return true;\n }\n case 'extraSubtitlesTextColor': {\n if (typeof propValue === 'string') {\n try {\n textColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('withHTMLSubtitles', error);\n }\n\n renderSubtitles();\n onPropChanged('extraSubtitlesTextColor');\n }\n\n return true;\n }\n case 'extraSubtitlesBackgroundColor': {\n if (typeof propValue === 'string') {\n try {\n backgroundColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('withHTMLSubtitles', error);\n }\n\n renderSubtitles();\n onPropChanged('extraSubtitlesBackgroundColor');\n }\n\n return true;\n }\n case 'extraSubtitlesOutlineColor': {\n if (typeof propValue === 'string') {\n try {\n outlineColor = Color(propValue).rgb().string();\n } catch (error) {\n // eslint-disable-next-line no-console\n console.error('withHTMLSubtitles', error);\n }\n\n renderSubtitles();\n onPropChanged('extraSubtitlesOutlineColor');\n }\n\n return true;\n }\n default: {\n return false;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'addExtraSubtitlesTracks': {\n if (commandArgs && Array.isArray(commandArgs.tracks)) {\n tracks = tracks\n .concat(commandArgs.tracks)\n .filter(function(track, index, tracks) {\n return track &&\n typeof track.id === 'string' &&\n typeof track.url === 'string' &&\n typeof track.lang === 'string' &&\n typeof track.label === 'string' &&\n typeof track.origin === 'string' &&\n !track.embedded &&\n index === tracks.findIndex(function(t) { return t.id === track.id; });\n });\n onPropChanged('extraSubtitlesTracks');\n }\n\n return true;\n }\n case 'load': {\n command('unload');\n if (commandArgs.stream && Array.isArray(commandArgs.stream.subtitles)) {\n command('addExtraSubtitlesTracks', {\n tracks: commandArgs.stream.subtitles.map(function(track) {\n return Object.assign({}, track, {\n origin: 'EXCLUSIVE',\n exclusive: true,\n embedded: false\n });\n })\n });\n }\n\n return false;\n }\n case 'unload': {\n cuesByTime = null;\n tracks = [];\n selectedTrackId = null;\n delay = null;\n renderSubtitles();\n onPropChanged('extraSubtitlesTracks');\n onPropChanged('selectedExtraSubtitlesTrackId');\n onPropChanged('extraSubtitlesDelay');\n return false;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n onPropChanged('extraSubtitlesSize');\n onPropChanged('extraSubtitlesOffset');\n onPropChanged('extraSubtitlesTextColor');\n onPropChanged('extraSubtitlesBackgroundColor');\n onPropChanged('extraSubtitlesOutlineColor');\n video.dispatch({ type: 'command', commandName: 'destroy' });\n events.removeAllListeners();\n containerElement.removeChild(subtitlesElement);\n return true;\n }\n default: {\n return false;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n if (observeProp(action.propName)) {\n return;\n }\n\n break;\n }\n case 'setProp': {\n if (setProp(action.propName, action.propValue)) {\n return;\n }\n\n break;\n }\n case 'command': {\n if (command(action.commandName, action.commandArgs)) {\n return;\n }\n\n break;\n }\n }\n }\n\n video.dispatch(action);\n };\n }\n\n VideoWithHTMLSubtitles.canPlayStream = function(stream) {\n return Video.canPlayStream(stream);\n };\n\n VideoWithHTMLSubtitles.manifest = {\n name: Video.manifest.name + 'WithHTMLSubtitles',\n external: Video.manifest.external,\n props: Video.manifest.props.concat(['extraSubtitlesTracks', 'selectedExtraSubtitlesTrackId', 'extraSubtitlesDelay', 'extraSubtitlesSize', 'extraSubtitlesOffset', 'extraSubtitlesTextColor', 'extraSubtitlesBackgroundColor', 'extraSubtitlesOutlineColor'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; }),\n commands: Video.manifest.commands.concat(['load', 'unload', 'destroy', 'addExtraSubtitlesTracks'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; }),\n events: Video.manifest.events.concat(['propValue', 'propChanged', 'error', 'extraSubtitlesTrackLoaded'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; })\n };\n\n return VideoWithHTMLSubtitles;\n}\n\nmodule.exports = withHTMLSubtitles;\n","var magnet = require('magnet-uri');\nvar createTorrent = require('./createTorrent');\n\nfunction convertStream(streamingServerURL, stream, seriesInfo) {\n return new Promise(function(resolve, reject) {\n if (typeof stream.url === 'string') {\n if (stream.url.indexOf('magnet:') === 0) {\n var parsedMagnetURI;\n try {\n parsedMagnetURI = magnet.decode(stream.url);\n if (!parsedMagnetURI || typeof parsedMagnetURI.infoHash !== 'string') {\n throw new Error('Failed to decode magnet url');\n }\n } catch (error) {\n reject(error);\n return;\n }\n\n var sources = Array.isArray(parsedMagnetURI.announce) ?\n parsedMagnetURI.announce.map(function(source) {\n return 'tracker:' + source;\n })\n :\n [];\n createTorrent(streamingServerURL, parsedMagnetURI.infoHash, null, sources, seriesInfo)\n .then(function(url) {\n resolve(url);\n })\n .catch(function(error) {\n reject(error);\n });\n } else {\n resolve(stream.url);\n }\n\n return;\n }\n\n if (typeof stream.infoHash === 'string') {\n createTorrent(streamingServerURL, stream.infoHash, stream.fileIdx, stream.announce, seriesInfo)\n .then(function(url) {\n resolve(url);\n })\n .catch(function(error) {\n reject(error);\n });\n\n return;\n }\n\n reject(new Error('Stream cannot be converted'));\n });\n}\n\nmodule.exports = convertStream;\n","var url = require('url');\n\nfunction buildTorrentUrl(streamingServerURL, infoHash, fileIdx, sources) {\n var query = Array.isArray(sources) && sources.length > 0 ?\n '?' + new URLSearchParams(sources.map(function(source) {\n return ['tr', source];\n }))\n :\n '';\n return url.resolve(streamingServerURL, '/' + encodeURIComponent(infoHash) + '/' + encodeURIComponent(fileIdx)) + query;\n}\n\nfunction createTorrent(streamingServerURL, infoHash, fileIdx, sources, seriesInfo) {\n if ((!Array.isArray(sources) || sources.length === 0) && (fileIdx !== null && isFinite(fileIdx))) {\n return Promise.resolve(buildTorrentUrl(streamingServerURL, infoHash, fileIdx, sources));\n }\n\n var body = {\n torrent: {\n infoHash: infoHash,\n }\n };\n\n if (Array.isArray(sources) && sources.length > 0) {\n body.peerSearch = {\n sources: ['dht:' + infoHash].concat(sources).filter(function(source, index, sources) {\n return sources.indexOf(source) === index;\n }),\n min: 40,\n max: 200\n };\n }\n\n if (fileIdx === null || !isFinite(fileIdx)) {\n body.guessFileIdx = {};\n if (seriesInfo) {\n if (seriesInfo.season !== null && isFinite(seriesInfo.season)) {\n body.guessFileIdx.season = seriesInfo.season;\n }\n if (seriesInfo.episode !== null && isFinite(seriesInfo.episode)) {\n body.guessFileIdx.episode = seriesInfo.episode;\n }\n }\n } else {\n body.guessFileIdx = false;\n }\n\n return fetch(url.resolve(streamingServerURL, '/' + encodeURIComponent(infoHash) + '/create'), {\n method: 'POST',\n headers: {\n 'content-type': 'application/json'\n },\n body: JSON.stringify(body)\n }).then(function(resp) {\n if (resp.ok) {\n return resp.json();\n }\n\n throw new Error(resp.status + ' (' + resp.statusText + ')');\n }).then(function(resp) {\n return buildTorrentUrl(streamingServerURL, infoHash, body.guessFileIdx ? resp.guessedFileIdx : fileIdx, body.peerSearch ? body.peerSearch.sources : []);\n });\n}\n\nmodule.exports = createTorrent;\n","var withStreamingServer = require('./withStreamingServer');\n\nmodule.exports = withStreamingServer;\n","var EventEmitter = require('eventemitter3');\nvar url = require('url');\nvar hat = require('hat');\nvar cloneDeep = require('lodash.clonedeep');\nvar deepFreeze = require('deep-freeze');\nvar mediaCapabilities = require('../mediaCapabilities');\nvar convertStream = require('./convertStream');\nvar ERROR = require('../error');\n\nfunction withStreamingServer(Video) {\n function VideoWithStreamingServer(options) {\n options = options || {};\n\n var video = new Video(options);\n video.on('error', onVideoError);\n video.on('propValue', onVideoPropEvent.bind(null, 'propValue'));\n video.on('propChanged', onVideoPropEvent.bind(null, 'propChanged'));\n Video.manifest.events\n .filter(function(eventName) {\n return !['error', 'propValue', 'propChanged'].includes(eventName);\n })\n .forEach(function(eventName) {\n video.on(eventName, onOtherVideoEvent(eventName));\n });\n\n var self = this;\n var loadArgs = null;\n var loaded = false;\n var actionsQueue = [];\n var events = new EventEmitter();\n var destroyed = false;\n var observedProps = {\n stream: false\n };\n\n function flushActionsQueue() {\n while (actionsQueue.length > 0) {\n var action = actionsQueue.shift();\n self.dispatch.call(self, action);\n }\n }\n function onVideoError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n }\n }\n function onVideoPropEvent(eventName, propName, propValue) {\n events.emit(eventName, propName, getProp(propName, propValue));\n }\n function onOtherVideoEvent(eventName) {\n return function() {\n events.emit.apply(events, [eventName].concat(Array.from(arguments)));\n };\n }\n function onPropChanged(propName) {\n if (observedProps[propName]) {\n events.emit('propChanged', propName, getProp(propName, null));\n }\n }\n function onError(error) {\n events.emit('error', error);\n if (error.critical) {\n command('unload');\n video.dispatch({ type: 'command', commandName: 'unload' });\n }\n }\n function getProp(propName, videoPropValue) {\n switch (propName) {\n case 'stream': {\n return loadArgs !== null ? loadArgs.stream : null;\n }\n default: {\n return videoPropValue;\n }\n }\n }\n function observeProp(propName) {\n switch (propName) {\n case 'stream': {\n events.emit('propValue', propName, getProp(propName, null));\n observedProps[propName] = true;\n return true;\n }\n default: {\n return false;\n }\n }\n }\n function command(commandName, commandArgs) {\n switch (commandName) {\n case 'load': {\n if (commandArgs && commandArgs.stream && typeof commandArgs.streamingServerURL === 'string') {\n command('unload');\n video.dispatch({ type: 'command', commandName: 'unload' });\n loadArgs = commandArgs;\n onPropChanged('stream');\n convertStream(commandArgs.streamingServerURL, commandArgs.stream, commandArgs.seriesInfo)\n .then(function(mediaURL) {\n var formats = Array.isArray(commandArgs.formats) ?\n commandArgs.formats\n :\n mediaCapabilities.formats;\n var videoCodecs = Array.isArray(commandArgs.videoCodecs) ?\n commandArgs.videoCodecs\n :\n mediaCapabilities.videoCodecs;\n var audioCodecs = Array.isArray(commandArgs.audioCodecs) ?\n commandArgs.audioCodecs\n :\n mediaCapabilities.audioCodecs;\n var maxAudioChannels = commandArgs.maxAudioChannels !== null && isFinite(commandArgs.maxAudioChannels) ?\n commandArgs.maxAudioChannels\n :\n mediaCapabilities.maxAudioChannels;\n var canPlayStreamOptions = Object.assign({}, commandArgs, {\n formats: formats,\n videoCodecs: videoCodecs,\n audioCodecs: audioCodecs,\n maxAudioChannels: maxAudioChannels\n });\n return (commandArgs.forceTranscoding ? Promise.resolve(false) : VideoWithStreamingServer.canPlayStream({ url: mediaURL }, canPlayStreamOptions))\n .catch(function(error) {\n console.warn('Media probe error', error);\n return false;\n })\n .then(function(canPlay) {\n if (canPlay) {\n return {\n url: mediaURL\n };\n }\n\n var id = hat();\n var queryParams = new URLSearchParams([['mediaURL', mediaURL]]);\n if (commandArgs.forceTranscoding) {\n queryParams.set('forceTranscoding', '1');\n }\n\n videoCodecs.forEach(function(videoCodec) {\n queryParams.append('videoCodecs', videoCodec);\n });\n\n audioCodecs.forEach(function(audioCodec) {\n queryParams.append('audioCodecs', audioCodec);\n });\n\n queryParams.set('maxAudioChannels', maxAudioChannels);\n\n return {\n url: url.resolve(commandArgs.streamingServerURL, '/hlsv2/' + id + '/master.m3u8?' + queryParams.toString()),\n subtitles: Array.isArray(commandArgs.stream.subtitles) ?\n commandArgs.stream.subtitles.map(function(track) {\n return Object.assign({}, track, {\n url: typeof track.url === 'string' ?\n url.resolve(commandArgs.streamingServerURL, '/subtitles.vtt?' + new URLSearchParams([['from', track.url]]).toString())\n :\n track.url\n });\n })\n :\n [],\n behaviorHints: {\n headers: {\n 'content-type': 'application/vnd.apple.mpegurl'\n }\n }\n };\n });\n })\n .then(function(stream) {\n if (commandArgs !== loadArgs) {\n return;\n }\n\n video.dispatch({\n type: 'command',\n commandName: 'load',\n commandArgs: Object.assign({}, commandArgs, {\n stream: stream\n })\n });\n loaded = true;\n flushActionsQueue();\n })\n .catch(function(error) {\n if (commandArgs !== loadArgs) {\n return;\n }\n\n onError(Object.assign({}, ERROR.WITH_STREAMING_SERVER.CONVERT_FAILED, {\n error: error,\n critical: true,\n stream: commandArgs.stream,\n streamingServerURL: commandArgs.streamingServerURL\n }));\n });\n } else {\n onError(Object.assign({}, ERROR.UNSUPPORTED_STREAM, {\n critical: true,\n stream: commandArgs ? commandArgs.stream : null,\n streamingServerURL: commandArgs && typeof commandArgs.streamingServerURL === 'string' ? commandArgs.streamingServerURL : null\n }));\n }\n\n return true;\n }\n case 'addExtraSubtitlesTracks': {\n if (loadArgs && commandArgs && Array.isArray(commandArgs.tracks)) {\n if (loaded) {\n video.dispatch({\n type: 'command',\n commandName: 'addExtraSubtitlesTracks',\n commandArgs: Object.assign({}, commandArgs, {\n tracks: commandArgs.tracks.map(function(track) {\n return Object.assign({}, track, {\n url: typeof track.url === 'string' ?\n url.resolve(loadArgs.streamingServerURL, '/subtitles.vtt?' + new URLSearchParams([['from', track.url]]).toString())\n :\n track.url\n });\n })\n })\n });\n } else {\n actionsQueue.push({\n type: 'command',\n commandName: 'addExtraSubtitlesTracks',\n commandArgs: commandArgs\n });\n }\n }\n\n return true;\n }\n case 'unload': {\n loadArgs = null;\n loaded = false;\n actionsQueue = [];\n onPropChanged('stream');\n return false;\n }\n case 'destroy': {\n command('unload');\n destroyed = true;\n video.dispatch({ type: 'command', commandName: 'destroy' });\n events.removeAllListeners();\n return true;\n }\n default: {\n if (!loaded) {\n actionsQueue.push({\n type: 'command',\n commandName: commandName,\n commandArgs: commandArgs\n });\n\n return true;\n }\n\n return false;\n }\n }\n }\n\n this.on = function(eventName, listener) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n events.on(eventName, listener);\n };\n this.dispatch = function(action) {\n if (destroyed) {\n throw new Error('Video is destroyed');\n }\n\n if (action) {\n action = deepFreeze(cloneDeep(action));\n switch (action.type) {\n case 'observeProp': {\n if (observeProp(action.propName)) {\n return;\n }\n\n break;\n }\n case 'command': {\n if (command(action.commandName, action.commandArgs)) {\n return;\n }\n\n break;\n }\n }\n }\n\n video.dispatch(action);\n };\n }\n\n VideoWithStreamingServer.canPlayStream = function(stream, options) {\n return Video.canPlayStream(stream)\n .then(function(canPlay) {\n if (!canPlay) {\n throw new Error('Fallback using /hlsv2/probe');\n }\n\n return canPlay;\n })\n .catch(function() {\n var queryParams = new URLSearchParams([['mediaURL', stream.url]]);\n return fetch(url.resolve(options.streamingServerURL, '/hlsv2/probe?' + queryParams.toString()))\n .then(function(resp) {\n return resp.json();\n })\n .then(function(probe) {\n var isFormatSupported = options.formats.some(function(format) {\n return probe.format.name.indexOf(format) !== -1;\n });\n var areStreamsSupported = probe.streams.every(function(stream) {\n if (stream.track === 'audio') {\n return stream.channels <= options.maxAudioChannels &&\n options.audioCodecs.indexOf(stream.codec) !== -1;\n } else if (stream.track === 'video') {\n return options.videoCodecs.indexOf(stream.codec) !== -1;\n }\n\n return true;\n });\n return isFormatSupported && areStreamsSupported;\n });\n });\n };\n\n VideoWithStreamingServer.manifest = {\n name: Video.manifest.name + 'WithStreamingServer',\n external: Video.manifest.external,\n props: Video.manifest.props.concat(['stream'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; }),\n commands: Video.manifest.commands.concat(['load', 'unload', 'destroy', 'addExtraSubtitlesTracks'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; }),\n events: Video.manifest.events.concat(['propValue', 'propChanged', 'error'])\n .filter(function(value, index, array) { return array.indexOf(value) === index; })\n };\n\n return VideoWithStreamingServer;\n}\n\nmodule.exports = withStreamingServer;\n","/*!\n * a-color-picker (https://github.com/narsenico/a-color-picker)\n * \n * Copyright (c) 2017-2018, Gianfranco Caldi.\n * Released under the MIT License.\n */\n!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define(\"AColorPicker\",[],t):\"object\"==typeof exports?exports.AColorPicker=t():e.AColorPicker=t()}(\"undefined\"!=typeof self?self:this,function(){return function(e){var t={};function r(i){if(t[i])return t[i].exports;var o=t[i]={i:i,l:!1,exports:{}};return e[i].call(o.exports,o,o.exports,r),o.l=!0,o.exports}return r.m=e,r.c=t,r.d=function(e,t,i){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:i})},r.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(r.r(i),Object.defineProperty(i,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var o in e)r.d(i,o,function(t){return e[t]}.bind(null,o));return i},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,\"a\",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p=\"\",r(r.s=1)}([function(e,t,r){\"use strict\";\n/*!\n * is-plain-object \n *\n * Copyright (c) 2014-2017, Jon Schlinkert.\n * Released under the MIT License.\n */var i=r(3);function o(e){return!0===i(e)&&\"[object Object]\"===Object.prototype.toString.call(e)}e.exports=function(e){var t,r;return!1!==o(e)&&\"function\"==typeof(t=e.constructor)&&!1!==o(r=t.prototype)&&!1!==r.hasOwnProperty(\"isPrototypeOf\")}},function(e,t,r){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0}),t.VERSION=t.PALETTE_MATERIAL_CHROME=t.PALETTE_MATERIAL_500=t.COLOR_NAMES=t.getLuminance=t.intToRgb=t.rgbToInt=t.rgbToHsv=t.rgbToHsl=t.hslToRgb=t.rgbToHex=t.parseColor=t.parseColorToHsla=t.parseColorToHsl=t.parseColorToRgba=t.parseColorToRgb=t.from=t.createPicker=void 0;var i=function(){function e(e,t){for(var r=0;r-1,p=\"undefined\"!=typeof window&&window.navigator.userAgent.indexOf(\"rv:\")>-1,d={id:null,attachTo:\"body\",showHSL:!0,showRGB:!0,showHEX:!0,showAlpha:!1,color:\"#ff0000\",palette:null,paletteEditable:!1,useAlphaInPalette:\"auto\",slBarSize:[232,150],hueBarSize:[150,11],alphaBarSize:[150,11]},f=\"COLOR\",g=\"RGBA_USER\",b=\"HSLA_USER\";function v(e,t,r){return e?e instanceof HTMLElement?e:e instanceof NodeList?e[0]:\"string\"==typeof e?document.querySelector(e):e.jquery?e.get(0):r?t:null:t}function m(e){var t=e.getContext(\"2d\"),r=+e.width,i=+e.height,s=t.createLinearGradient(1,1,1,i-1);return s.addColorStop(0,\"white\"),s.addColorStop(1,\"black\"),{setHue:function(e){var o=t.createLinearGradient(1,0,r-1,0);o.addColorStop(0,\"hsla(\"+e+\", 100%, 50%, 0)\"),o.addColorStop(1,\"hsla(\"+e+\", 100%, 50%, 1)\"),t.fillStyle=s,t.fillRect(0,0,r,i),t.fillStyle=o,t.globalCompositeOperation=\"multiply\",t.fillRect(0,0,r,i),t.globalCompositeOperation=\"source-over\"},grabColor:function(e,r){return t.getImageData(e,r,1,1).data},findColor:function(e,t,s){var a=(0,n.rgbToHsv)(e,t,s),l=o(a,3),c=l[1],u=l[2];return[c*r,i-u*i]}}}function A(e,t,r){return null===e?t:/^\\s*$/.test(e)?r:!!/true|yes|1/i.test(e)||!/false|no|0/i.test(e)&&t}function y(e,t,r){if(null===e)return t;if(/^\\s*$/.test(e))return r;var i=e.split(\",\").map(Number);return 2===i.length&&i[0]&&i[1]?i:t}var k=function(){function e(t,r){if(c(this,e),r?(t=v(t),this.options=Object.assign({},d,r)):t&&(0,s.default)(t)?(this.options=Object.assign({},d,t),t=v(this.options.attachTo)):(this.options=Object.assign({},d),t=v((0,n.nvl)(t,this.options.attachTo))),!t)throw new Error(\"Container not found: \"+this.options.attachTo);!function(e,t){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:\"acp-\";if(t.hasAttribute(r+\"show-hsl\")&&(e.showHSL=A(t.getAttribute(r+\"show-hsl\"),d.showHSL,!0)),t.hasAttribute(r+\"show-rgb\")&&(e.showRGB=A(t.getAttribute(r+\"show-rgb\"),d.showRGB,!0)),t.hasAttribute(r+\"show-hex\")&&(e.showHEX=A(t.getAttribute(r+\"show-hex\"),d.showHEX,!0)),t.hasAttribute(r+\"show-alpha\")&&(e.showAlpha=A(t.getAttribute(r+\"show-alpha\"),d.showAlpha,!0)),t.hasAttribute(r+\"palette-editable\")&&(e.paletteEditable=A(t.getAttribute(r+\"palette-editable\"),d.paletteEditable,!0)),t.hasAttribute(r+\"sl-bar-size\")&&(e.slBarSize=y(t.getAttribute(r+\"sl-bar-size\"),d.slBarSize,[232,150])),t.hasAttribute(r+\"hue-bar-size\")&&(e.hueBarSize=y(t.getAttribute(r+\"hue-bar-size\"),d.hueBarSize,[150,11]),e.alphaBarSize=e.hueBarSize),t.hasAttribute(r+\"palette\")){var i=t.getAttribute(r+\"palette\");switch(i){case\"PALETTE_MATERIAL_500\":e.palette=n.PALETTE_MATERIAL_500;break;case\"PALETTE_MATERIAL_CHROME\":case\"\":e.palette=n.PALETTE_MATERIAL_CHROME;break;default:e.palette=i.split(/[;|]/)}}t.hasAttribute(r+\"color\")&&(e.color=t.getAttribute(r+\"color\"))}(this.options,t),this.H=0,this.S=0,this.L=0,this.R=0,this.G=0,this.B=0,this.A=1,this.palette={},this.element=document.createElement(\"div\"),this.options.id&&(this.element.id=this.options.id),this.element.className=\"a-color-picker\",this.element.innerHTML=a.default,t.appendChild(this.element);var i=this.element.querySelector(\".a-color-picker-h\");this.setupHueCanvas(i),this.hueBarHelper=m(i),this.huePointer=this.element.querySelector(\".a-color-picker-h+.a-color-picker-dot\");var o=this.element.querySelector(\".a-color-picker-sl\");this.setupSlCanvas(o),this.slBarHelper=m(o),this.slPointer=this.element.querySelector(\".a-color-picker-sl+.a-color-picker-dot\"),this.preview=this.element.querySelector(\".a-color-picker-preview\"),this.setupClipboard(this.preview.querySelector(\".a-color-picker-clipbaord\")),this.options.showHSL?(this.setupInput(this.inputH=this.element.querySelector(\".a-color-picker-hsl>input[nameref=H]\")),this.setupInput(this.inputS=this.element.querySelector(\".a-color-picker-hsl>input[nameref=S]\")),this.setupInput(this.inputL=this.element.querySelector(\".a-color-picker-hsl>input[nameref=L]\"))):this.element.querySelector(\".a-color-picker-hsl\").remove(),this.options.showRGB?(this.setupInput(this.inputR=this.element.querySelector(\".a-color-picker-rgb>input[nameref=R]\")),this.setupInput(this.inputG=this.element.querySelector(\".a-color-picker-rgb>input[nameref=G]\")),this.setupInput(this.inputB=this.element.querySelector(\".a-color-picker-rgb>input[nameref=B]\"))):this.element.querySelector(\".a-color-picker-rgb\").remove(),this.options.showHEX?this.setupInput(this.inputRGBHEX=this.element.querySelector(\"input[nameref=RGBHEX]\")):this.element.querySelector(\".a-color-picker-rgbhex\").remove(),this.options.paletteEditable||this.options.palette&&this.options.palette.length>0?this.setPalette(this.paletteRow=this.element.querySelector(\".a-color-picker-palette\")):(this.paletteRow=this.element.querySelector(\".a-color-picker-palette\"),this.paletteRow.remove()),this.options.showAlpha?(this.setupAlphaCanvas(this.element.querySelector(\".a-color-picker-a\")),this.alphaPointer=this.element.querySelector(\".a-color-picker-a+.a-color-picker-dot\")):this.element.querySelector(\".a-color-picker-alpha\").remove(),this.element.style.width=this.options.slBarSize[0]+\"px\",this.onValueChanged(f,this.options.color)}return i(e,[{key:\"setupHueCanvas\",value:function(e){var t=this;e.width=this.options.hueBarSize[0],e.height=this.options.hueBarSize[1];for(var r=e.getContext(\"2d\"),i=r.createLinearGradient(0,0,this.options.hueBarSize[0],0),o=0;o<=1;o+=1/360)i.addColorStop(o,\"hsl(\"+360*o+\", 100%, 50%)\");r.fillStyle=i,r.fillRect(0,0,this.options.hueBarSize[0],this.options.hueBarSize[1]);var s=function(r){var i=(0,n.limit)(r.clientX-e.getBoundingClientRect().left,0,t.options.hueBarSize[0]),o=Math.round(360*i/t.options.hueBarSize[0]);t.huePointer.style.left=i-7+\"px\",t.onValueChanged(\"H\",o)},a=function e(){document.removeEventListener(\"mousemove\",s),document.removeEventListener(\"mouseup\",e)};e.addEventListener(\"mousedown\",function(e){s(e),document.addEventListener(\"mousemove\",s),document.addEventListener(\"mouseup\",a)})}},{key:\"setupSlCanvas\",value:function(e){var t=this;e.width=this.options.slBarSize[0],e.height=this.options.slBarSize[1];var r=function(r){var i=(0,n.limit)(r.clientX-e.getBoundingClientRect().left,0,t.options.slBarSize[0]-1),o=(0,n.limit)(r.clientY-e.getBoundingClientRect().top,0,t.options.slBarSize[1]-1),s=t.slBarHelper.grabColor(i,o);t.slPointer.style.left=i-7+\"px\",t.slPointer.style.top=o-7+\"px\",t.onValueChanged(\"RGB\",s)},i=function e(){document.removeEventListener(\"mousemove\",r),document.removeEventListener(\"mouseup\",e)};e.addEventListener(\"mousedown\",function(e){r(e),document.addEventListener(\"mousemove\",r),document.addEventListener(\"mouseup\",i)})}},{key:\"setupAlphaCanvas\",value:function(e){var t=this;e.width=this.options.alphaBarSize[0],e.height=this.options.alphaBarSize[1];var r=e.getContext(\"2d\"),i=r.createLinearGradient(0,0,e.width-1,0);i.addColorStop(0,\"hsla(0, 0%, 50%, 0)\"),i.addColorStop(1,\"hsla(0, 0%, 50%, 1)\"),r.fillStyle=i,r.fillRect(0,0,this.options.alphaBarSize[0],this.options.alphaBarSize[1]);var o=function(r){var i=(0,n.limit)(r.clientX-e.getBoundingClientRect().left,0,t.options.alphaBarSize[0]),o=+(i/t.options.alphaBarSize[0]).toFixed(2);t.alphaPointer.style.left=i-7+\"px\",t.onValueChanged(\"ALPHA\",o)},s=function e(){document.removeEventListener(\"mousemove\",o),document.removeEventListener(\"mouseup\",e)};e.addEventListener(\"mousedown\",function(e){o(e),document.addEventListener(\"mousemove\",o),document.addEventListener(\"mouseup\",s)})}},{key:\"setupInput\",value:function(e){var t=this,r=+e.min,i=+e.max,o=e.getAttribute(\"nameref\");e.hasAttribute(\"select-on-focus\")&&e.addEventListener(\"focus\",function(){e.select()}),\"text\"===e.type?e.addEventListener(\"change\",function(){t.onValueChanged(o,e.value)}):((h||p)&&e.addEventListener(\"keydown\",function(s){\"Up\"===s.key?(e.value=(0,n.limit)(+e.value+1,r,i),t.onValueChanged(o,e.value),s.returnValue=!1):\"Down\"===s.key&&(e.value=(0,n.limit)(+e.value-1,r,i),t.onValueChanged(o,e.value),s.returnValue=!1)}),e.addEventListener(\"change\",function(){var s=+e.value;t.onValueChanged(o,(0,n.limit)(s,r,i))}))}},{key:\"setupClipboard\",value:function(e){var t=this;e.title=\"click to copy\",e.addEventListener(\"click\",function(){e.value=(0,n.parseColor)([t.R,t.G,t.B,t.A],\"hexcss4\"),e.select(),document.execCommand(\"copy\")})}},{key:\"setPalette\",value:function(e){var t=this,r=\"auto\"===this.options.useAlphaInPalette?this.options.showAlpha:this.options.useAlphaInPalette,i=null;switch(this.options.palette){case\"PALETTE_MATERIAL_500\":i=n.PALETTE_MATERIAL_500;break;case\"PALETTE_MATERIAL_CHROME\":i=n.PALETTE_MATERIAL_CHROME;break;default:i=(0,n.ensureArray)(this.options.palette)}if(this.options.paletteEditable||i.length>0){var o=function(r,i,o){var n=e.querySelector('.a-color-picker-palette-color[data-color=\"'+r+'\"]')||document.createElement(\"div\");n.className=\"a-color-picker-palette-color\",n.style.backgroundColor=r,n.setAttribute(\"data-color\",r),n.title=r,e.insertBefore(n,i),t.palette[r]=!0,o&&t.onPaletteColorAdd(r)},s=function(r,i){r?(e.removeChild(r),t.palette[r.getAttribute(\"data-color\")]=!1,i&&t.onPaletteColorRemove(r.getAttribute(\"data-color\"))):(e.querySelectorAll(\".a-color-picker-palette-color[data-color]\").forEach(function(t){e.removeChild(t)}),Object.keys(t.palette).forEach(function(e){t.palette[e]=!1}),i&&t.onPaletteColorRemove())};if(i.map(function(e){return(0,n.parseColor)(e,r?\"rgbcss4\":\"hex\")}).filter(function(e){return!!e}).forEach(function(e){return o(e)}),this.options.paletteEditable){var a=document.createElement(\"div\");a.className=\"a-color-picker-palette-color a-color-picker-palette-add\",a.innerHTML=\"+\",e.appendChild(a),e.addEventListener(\"click\",function(e){/a-color-picker-palette-add/.test(e.target.className)?e.shiftKey?s(null,!0):o(r?(0,n.parseColor)([t.R,t.G,t.B,t.A],\"rgbcss4\"):(0,n.rgbToHex)(t.R,t.G,t.B),e.target,!0):/a-color-picker-palette-color/.test(e.target.className)&&(e.shiftKey?s(e.target,!0):t.onValueChanged(f,e.target.getAttribute(\"data-color\")))})}else e.addEventListener(\"click\",function(e){/a-color-picker-palette-color/.test(e.target.className)&&t.onValueChanged(f,e.target.getAttribute(\"data-color\"))})}else e.style.display=\"none\"}},{key:\"updatePalette\",value:function(e){this.paletteRow.innerHTML=\"\",this.palette={},this.paletteRow.parentElement||this.element.appendChild(this.paletteRow),this.options.palette=e,this.setPalette(this.paletteRow)}},{key:\"onValueChanged\",value:function(e,t){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{silent:!1};switch(e){case\"H\":this.H=t;var i=(0,n.hslToRgb)(this.H,this.S,this.L),s=o(i,3);this.R=s[0],this.G=s[1],this.B=s[2],this.slBarHelper.setHue(t),this.updatePointerH(this.H),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"S\":this.S=t;var a=(0,n.hslToRgb)(this.H,this.S,this.L),l=o(a,3);this.R=l[0],this.G=l[1],this.B=l[2],this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"L\":this.L=t;var c=(0,n.hslToRgb)(this.H,this.S,this.L),u=o(c,3);this.R=u[0],this.G=u[1],this.B=u[2],this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"R\":this.R=t;var h=(0,n.rgbToHsl)(this.R,this.G,this.B),p=o(h,3);this.H=p[0],this.S=p[1],this.L=p[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"G\":this.G=t;var d=(0,n.rgbToHsl)(this.R,this.G,this.B),v=o(d,3);this.H=v[0],this.S=v[1],this.L=v[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"B\":this.B=t;var m=(0,n.rgbToHsl)(this.R,this.G,this.B),A=o(m,3);this.H=A[0],this.S=A[1],this.L=A[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGBHEX(this.R,this.G,this.B);break;case\"RGB\":var y=o(t,3);this.R=y[0],this.G=y[1],this.B=y[2];var k=(0,n.rgbToHsl)(this.R,this.G,this.B),F=o(k,3);this.H=F[0],this.S=F[1],this.L=F[2],this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B);break;case g:var E=o(t,4);this.R=E[0],this.G=E[1],this.B=E[2],this.A=E[3];var H=(0,n.rgbToHsl)(this.R,this.G,this.B),B=o(H,3);this.H=B[0],this.S=B[1],this.L=B[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case b:var R=o(t,4);this.H=R[0],this.S=R[1],this.L=R[2],this.A=R[3];var C=(0,n.hslToRgb)(this.H,this.S,this.L),S=o(C,3);this.R=S[0],this.G=S[1],this.B=S[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case\"RGBHEX\":var L=(0,n.cssColorToRgb)(t)||[this.R,this.G,this.B],w=o(L,3);this.R=w[0],this.G=w[1],this.B=w[2];var T=(0,n.rgbToHsl)(this.R,this.G,this.B),x=o(T,3);this.H=x[0],this.S=x[1],this.L=x[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B);break;case f:var G=(0,n.parseColor)(t,\"rgba\")||[0,0,0,1],I=o(G,4);this.R=I[0],this.G=I[1],this.B=I[2],this.A=I[3];var P=(0,n.rgbToHsl)(this.R,this.G,this.B),D=o(P,3);this.H=D[0],this.S=D[1],this.L=D[2],this.slBarHelper.setHue(this.H),this.updatePointerH(this.H),this.updatePointerSL(this.H,this.S,this.L),this.updateInputHSL(this.H,this.S,this.L),this.updateInputRGB(this.R,this.G,this.B),this.updateInputRGBHEX(this.R,this.G,this.B),this.updatePointerA(this.A);break;case\"ALPHA\":this.A=t}1===this.A?this.preview.style.backgroundColor=\"rgb(\"+this.R+\",\"+this.G+\",\"+this.B+\")\":this.preview.style.backgroundColor=\"rgba(\"+this.R+\",\"+this.G+\",\"+this.B+\",\"+this.A+\")\",r&&r.silent||this.onchange&&this.onchange(this.preview.style.backgroundColor)}},{key:\"onPaletteColorAdd\",value:function(e){this.oncoloradd&&this.oncoloradd(e)}},{key:\"onPaletteColorRemove\",value:function(e){this.oncolorremove&&this.oncolorremove(e)}},{key:\"updateInputHSL\",value:function(e,t,r){this.options.showHSL&&(this.inputH.value=e,this.inputS.value=t,this.inputL.value=r)}},{key:\"updateInputRGB\",value:function(e,t,r){this.options.showRGB&&(this.inputR.value=e,this.inputG.value=t,this.inputB.value=r)}},{key:\"updateInputRGBHEX\",value:function(e,t,r){this.options.showHEX&&(this.inputRGBHEX.value=(0,n.rgbToHex)(e,t,r))}},{key:\"updatePointerH\",value:function(e){var t=this.options.hueBarSize[0]*e/360;this.huePointer.style.left=t-7+\"px\"}},{key:\"updatePointerSL\",value:function(e,t,r){var i=(0,n.hslToRgb)(e,t,r),s=o(i,3),a=s[0],l=s[1],c=s[2],u=this.slBarHelper.findColor(a,l,c),h=o(u,2),p=h[0],d=h[1];p>=0&&(this.slPointer.style.left=p-7+\"px\",this.slPointer.style.top=d-7+\"px\")}},{key:\"updatePointerA\",value:function(e){if(this.options.showAlpha){var t=this.options.alphaBarSize[0]*e;this.alphaPointer.style.left=t-7+\"px\"}}}]),e}(),F=function(){function e(t){c(this,e),this.name=t,this.listeners=[]}return i(e,[{key:\"on\",value:function(e){e&&this.listeners.push(e)}},{key:\"off\",value:function(e){this.listeners=e?this.listeners.filter(function(t){return t!==e}):[]}},{key:\"emit\",value:function(e,t){for(var r=this.listeners.slice(0),i=0;i1&&void 0!==arguments[1]&&arguments[1];r.onValueChanged(f,e,{silent:t})},get all(){if(s){var e=[r.R,r.G,r.B,r.A],t=r.A<1?\"rgba(\"+r.R+\",\"+r.G+\",\"+r.B+\",\"+r.A+\")\":n.rgbToHex.apply(void 0,e);(a=(0,n.parseColor)(e,a)).toString=function(){return t},s=!1}return Object.assign({},a)},get onchange(){return i.change&&i.change.listeners[0]},set onchange(e){this.off(\"change\").on(\"change\",e)},get oncoloradd(){return i.coloradd&&i.coloradd.listeners[0]},set oncoloradd(e){this.off(\"coloradd\").on(\"coloradd\",e)},get oncolorremove(){return i.colorremove&&i.colorremove.listeners[0]},set oncolorremove(e){this.off(\"colorremove\").on(\"colorremove\",e)},get palette(){return Object.keys(r.palette).filter(function(e){return r.palette[e]})},set palette(e){r.updatePalette(e)},show:function(){r.element.classList.remove(\"hidden\")},hide:function(){r.element.classList.add(\"hidden\")},toggle:function(){r.element.classList.toggle(\"hidden\")},on:function(e,t){return e&&i[e]&&i[e].on(t),this},off:function(e,t){return e&&i[e]&&i[e].off(t),this},destroy:function(){i.change.off(),i.coloradd.off(),i.colorremove.off(),r.element.remove(),i=null,r=null}};return r.onchange=function(){for(var e=arguments.length,t=Array(e),r=0;rstyle[data-source=\"a-color-picker\"]')){var H=r(5).toString(),B=document.createElement(\"style\");B.setAttribute(\"type\",\"text/css\"),B.setAttribute(\"data-source\",\"a-color-picker\"),B.innerHTML=H,document.querySelector(\"head\").appendChild(B)}t.createPicker=E,t.from=function(e,t){var r=function(e){return e?Array.isArray(e)?e:e instanceof HTMLElement?[e]:e instanceof NodeList?[].concat(u(e)):\"string\"==typeof e?[].concat(u(document.querySelectorAll(e))):e.jquery?e.get():[]:[]}(e).map(function(e,r){var i=E(e,t);return i.index=r,i});return r.on=function(e,t){return r.forEach(function(r){return r.on(e,t)}),this},r.off=function(e){return r.forEach(function(t){return t.off(e)}),this},r},t.parseColorToRgb=n.parseColorToRgb,t.parseColorToRgba=n.parseColorToRgba,t.parseColorToHsl=n.parseColorToHsl,t.parseColorToHsla=n.parseColorToHsla,t.parseColor=n.parseColor,t.rgbToHex=n.rgbToHex,t.hslToRgb=n.hslToRgb,t.rgbToHsl=n.rgbToHsl,t.rgbToHsv=n.rgbToHsv,t.rgbToInt=n.rgbToInt,t.intToRgb=n.intToRgb,t.getLuminance=n.getLuminance,t.COLOR_NAMES=n.COLOR_NAMES,t.PALETTE_MATERIAL_500=n.PALETTE_MATERIAL_500,t.PALETTE_MATERIAL_CHROME=n.PALETTE_MATERIAL_CHROME,t.VERSION=\"1.2.1\"},function(e,t,r){\"use strict\";Object.defineProperty(t,\"__esModule\",{value:!0}),t.nvl=t.ensureArray=t.limit=t.getLuminance=t.parseColor=t.parseColorToHsla=t.parseColorToHsl=t.cssHslaToHsla=t.cssHslToHsl=t.parseColorToRgba=t.parseColorToRgb=t.cssRgbaToRgba=t.cssRgbToRgb=t.cssColorToRgba=t.cssColorToRgb=t.intToRgb=t.rgbToInt=t.rgbToHsv=t.rgbToHsl=t.hslToRgb=t.rgbToHex=t.PALETTE_MATERIAL_CHROME=t.PALETTE_MATERIAL_500=t.COLOR_NAMES=void 0;var i=function(e,t){if(Array.isArray(e))return e;if(Symbol.iterator in Object(e))return function(e,t){var r=[],i=!0,o=!1,n=void 0;try{for(var s,a=e[Symbol.iterator]();!(i=(s=a.next()).done)&&(r.push(s.value),!t||r.length!==t);i=!0);}catch(e){o=!0,n=e}finally{try{!i&&a.return&&a.return()}finally{if(o)throw n}}return r}(e,t);throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")},o=function(e){return e&&e.__esModule?e:{default:e}}(r(0));function n(e){if(Array.isArray(e)){for(var t=0,r=Array(e.length);tr?r:e}function l(e,t){return null==e?t:e}function c(e,t,r){var i=[a(e,0,255),a(t,0,255),a(r,0,255)];return\"#\"+(\"000000\"+((e=i[0])<<16|(t=i[1])<<8|(r=i[2])).toString(16)).slice(-6)}function u(e,t,r){var i=void 0,o=void 0,n=void 0,s=[a(e,0,360)/360,a(t,0,100)/100,a(r,0,100)/100];if(e=s[0],r=s[2],0==(t=s[1]))i=o=n=r;else{var l=function(e,t,r){return r<0&&(r+=1),r>1&&(r-=1),r<1/6?e+6*(t-e)*r:r<.5?t:r<2/3?e+(t-e)*(2/3-r)*6:e},c=r<.5?r*(1+t):r+t-r*t,u=2*r-c;i=l(u,c,e+1/3),o=l(u,c,e),n=l(u,c,e-1/3)}return[255*i,255*o,255*n].map(Math.round)}function h(e,t,r){var i=[a(e,0,255)/255,a(t,0,255)/255,a(r,0,255)/255];e=i[0],t=i[1],r=i[2];var o=Math.max(e,t,r),n=Math.min(e,t,r),s=void 0,l=void 0,c=(o+n)/2;if(o==n)s=l=0;else{var u=o-n;switch(l=c>.5?u/(2-o-n):u/(o+n),o){case e:s=(t-r)/u+(t>16&255,e>>8&255,255&e]},t.cssColorToRgb=d,t.cssColorToRgba=f,t.cssRgbToRgb=g,t.cssRgbaToRgba=b,t.parseColorToRgb=function(e){return Array.isArray(e)?e=[a(e[0],0,255),a(e[1],0,255),a(e[2],0,255)]:d(e)||g(e)},t.parseColorToRgba=v,t.cssHslToHsl=m,t.cssHslaToHsla=A,t.parseColorToHsl=function(e){return Array.isArray(e)?e=[a(e[0],0,360),a(e[1],0,100),a(e[2],0,100)]:m(e)},t.parseColorToHsla=y,t.parseColor=function(e,t){if(t=t||\"rgb\",null!=e){var r=void 0;if((r=v(e))||(r=y(e))&&(r=[].concat(n(u.apply(void 0,n(r))),[r[3]])))return(0,o.default)(t)?[\"rgb\",\"rgbcss\",\"rgbcss4\",\"rgba\",\"rgbacss\",\"hsl\",\"hslcss\",\"hslcss4\",\"hsla\",\"hslacss\",\"hex\",\"hexcss4\",\"int\"].reduce(function(e,t){return e[t]=k(r,t),e},t||{}):k(r,t.toString().toLowerCase())}},t.getLuminance=function(e,t,r){return.2126*(e=(e/=255)<.03928?e/12.92:Math.pow((e+.055)/1.055,2.4))+.7152*(t=(t/=255)<.03928?t/12.92:Math.pow((t+.055)/1.055,2.4))+.0722*((r/=255)<.03928?r/12.92:Math.pow((r+.055)/1.055,2.4))},t.limit=a,t.ensureArray=function(e){return e?Array.from(e):[]},t.nvl=l},function(e,t,r){\"use strict\";\n/*!\n * isobject \n *\n * Copyright (c) 2014-2017, Jon Schlinkert.\n * Released under the MIT License.\n */e.exports=function(e){return null!=e&&\"object\"==typeof e&&!1===Array.isArray(e)}},function(e,t){e.exports='
'},function(e,t,r){var i=r(6);e.exports=\"string\"==typeof i?i:i.toString()},function(e,t,r){(e.exports=r(7)(!1)).push([e.i,\"/*!\\n * a-color-picker\\n * https://github.com/narsenico/a-color-picker\\n *\\n * Copyright (c) 2017-2018, Gianfranco Caldi.\\n * Released under the MIT License.\\n */.a-color-picker{background-color:#fff;padding:0;display:inline-flex;flex-direction:column;user-select:none;width:232px;font:400 10px Helvetica,Arial,sans-serif;border-radius:3px;box-shadow:0 0 0 1px rgba(0,0,0,.05),0 2px 4px rgba(0,0,0,.25)}.a-color-picker,.a-color-picker-row,.a-color-picker input{box-sizing:border-box}.a-color-picker-row{padding:15px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;user-select:none}.a-color-picker-row-top{padding:0}.a-color-picker-row:not(:first-child){border-top:1px solid #f5f5f5}.a-color-picker-column{display:flex;flex-direction:column}.a-color-picker-cell{flex:1 1 auto;margin-bottom:4px}.a-color-picker-cell:last-child{margin-bottom:0}.a-color-picker-stack{position:relative}.a-color-picker-dot{position:absolute;width:14px;height:14px;top:0;left:0;background:#fff;pointer-events:none;border-radius:50px;z-index:1000;box-shadow:0 1px 2px rgba(0,0,0,.75)}.a-color-picker-a,.a-color-picker-h,.a-color-picker-sl{cursor:cell}.a-color-picker-a+.a-color-picker-dot,.a-color-picker-h+.a-color-picker-dot{top:-2px}.a-color-picker-a,.a-color-picker-h{border-radius:2px}.a-color-picker-preview{box-sizing:border-box;width:30px;height:30px;user-select:none;border-radius:15px}.a-color-picker-circle{border-radius:50px;border:1px solid #eee}.a-color-picker-hsl,.a-color-picker-rgb,.a-color-picker-single-input{justify-content:space-evenly}.a-color-picker-hsl>label,.a-color-picker-rgb>label,.a-color-picker-single-input>label{padding:0 8px;flex:0 0 auto;color:#969696}.a-color-picker-hsl>input,.a-color-picker-rgb>input,.a-color-picker-single-input>input{text-align:center;padding:2px 0;width:0;flex:1 1 auto;border:1px solid #e0e0e0;line-height:20px}.a-color-picker-hsl>input::-webkit-inner-spin-button,.a-color-picker-rgb>input::-webkit-inner-spin-button,.a-color-picker-single-input>input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.a-color-picker-hsl>input:focus,.a-color-picker-rgb>input:focus,.a-color-picker-single-input>input:focus{border-color:#04a9f4;outline:none}.a-color-picker-transparent{background-image:linear-gradient(-45deg,#cdcdcd 25%,transparent 0),linear-gradient(45deg,#cdcdcd 25%,transparent 0),linear-gradient(-45deg,transparent 75%,#cdcdcd 0),linear-gradient(45deg,transparent 75%,#cdcdcd 0);background-size:11px 11px;background-position:0 0,0 -5.5px,-5.5px 5.5px,5.5px 0}.a-color-picker-sl{border-radius:3px 3px 0 0}.a-color-picker.hide-alpha [show-on-alpha],.a-color-picker.hide-hsl [show-on-hsl],.a-color-picker.hide-rgb [show-on-rgb],.a-color-picker.hide-single-input [show-on-single-input]{display:none}.a-color-picker-clipbaord{width:100%;height:100%;opacity:0;cursor:pointer}.a-color-picker-palette{flex-flow:wrap;flex-direction:row;justify-content:flex-start;padding:10px}.a-color-picker-palette-color{width:15px;height:15px;flex:0 1 15px;margin:3px;box-sizing:border-box;cursor:pointer;border-radius:3px;box-shadow:inset 0 0 0 1px rgba(0,0,0,.1)}.a-color-picker-palette-add{text-align:center;line-height:13px;color:#607d8b}.a-color-picker.hidden{display:none}\",\"\"])},function(e,t){e.exports=function(e){var t=[];return t.toString=function(){return this.map(function(t){var r=function(e,t){var r=e[1]||\"\",i=e[3];if(!i)return r;if(t&&\"function\"==typeof btoa){var o=function(e){return\"/*# sourceMappingURL=data:application/json;charset=utf-8;base64,\"+btoa(unescape(encodeURIComponent(JSON.stringify(e))))+\" */\"}(i),n=i.sources.map(function(e){return\"/*# sourceURL=\"+i.sourceRoot+e+\" */\"});return[r].concat(n).concat([o]).join(\"\\n\")}return[r].join(\"\\n\")}(t,e);return t[2]?\"@media \"+t[2]+\"{\"+r+\"}\":r}).join(\"\")},t.i=function(e,r){\"string\"==typeof e&&(e=[[null,e,\"\"]]);for(var i={},o=0;o {\n const { i18n } = useTranslation();\n const onPathNotMatch = React.useCallback(() => {\n return NotFound;\n }, []);\n const services = React.useMemo(() => {\n const core = new Core({\n appVersion: process.env.VERSION,\n shellVersion: null\n });\n return {\n core,\n shell: new Shell(),\n chromecast: new Chromecast(),\n keyboardShortcuts: new KeyboardShortcuts(),\n dragAndDrop: new DragAndDrop({ core })\n };\n }, []);\n const [initialized, setInitialized] = React.useState(false);\n React.useEffect(() => {\n let prevPath = window.location.hash.slice(1);\n const onLocationHashChange = () => {\n if (services.core.active) {\n services.core.transport.analytics({\n event: 'LocationPathChanged',\n args: { prevPath }\n });\n }\n prevPath = window.location.hash.slice(1);\n };\n window.addEventListener('hashchange', onLocationHashChange);\n return () => {\n window.removeEventListener('hashchange', onLocationHashChange);\n };\n }, []);\n React.useEffect(() => {\n const onCoreStateChanged = () => {\n setInitialized(\n (services.core.active || services.core.error instanceof Error) &&\n (services.shell.active || services.shell.error instanceof Error)\n );\n };\n const onShellStateChanged = () => {\n setInitialized(\n (services.core.active || services.core.error instanceof Error) &&\n (services.shell.active || services.shell.error instanceof Error)\n );\n };\n const onChromecastStateChange = () => {\n if (services.chromecast.active) {\n services.chromecast.transport.setOptions({\n receiverApplicationId: CONSTANTS.CHROMECAST_RECEIVER_APP_ID,\n autoJoinPolicy: chrome.cast.AutoJoinPolicy.PAGE_SCOPED,\n resumeSavedSession: false,\n language: null\n });\n }\n };\n services.core.on('stateChanged', onCoreStateChanged);\n services.shell.on('stateChanged', onShellStateChanged);\n services.chromecast.on('stateChanged', onChromecastStateChange);\n services.core.start();\n services.shell.start();\n services.chromecast.start();\n services.keyboardShortcuts.start();\n services.dragAndDrop.start();\n window.services = services;\n return () => {\n services.core.stop();\n services.shell.stop();\n services.chromecast.stop();\n services.keyboardShortcuts.stop();\n services.dragAndDrop.stop();\n services.core.off('stateChanged', onCoreStateChanged);\n services.shell.off('stateChanged', onShellStateChanged);\n services.chromecast.off('stateChanged', onChromecastStateChange);\n };\n }, []);\n React.useEffect(() => {\n const onCoreEvent = ({ event, args }) => {\n switch (event) {\n case 'SettingsUpdated': {\n if (args && args.settings && typeof args.settings.interfaceLanguage === 'string') {\n i18n.changeLanguage(args.settings.interfaceLanguage);\n }\n break;\n }\n }\n };\n const onCtxState = (state) => {\n if (state && state.profile && state.profile.settings && typeof state.profile.settings.interfaceLanguage === 'string') {\n i18n.changeLanguage(state.profile.settings.interfaceLanguage);\n }\n };\n const onWindowFocus = () => {\n services.core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'PullAddonsFromAPI'\n }\n });\n services.core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'PullUserFromAPI'\n }\n });\n services.core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'SyncLibraryWithAPI'\n }\n });\n };\n if (services.core.active) {\n onWindowFocus();\n window.addEventListener('focus', onWindowFocus);\n services.core.transport.on('CoreEvent', onCoreEvent);\n services.core.transport\n .getState('ctx')\n .then(onCtxState)\n .catch((e) => console.error(e));\n }\n return () => {\n window.removeEventListener('focus', onWindowFocus);\n services.core.transport.off('CoreEvent', onCoreEvent);\n };\n }, [initialized]);\n return (\n \n \n {\n initialized ?\n services.core.error instanceof Error ?\n \n :\n \n \n \n \n \n :\n
\n }\n \n \n );\n};\n\nmodule.exports = App;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { withCoreSuspender, useStreamingServer } = require('stremio/common');\n\nconst DeepLinkHandler = () => {\n const streamingServer = useStreamingServer();\n React.useEffect(() => {\n if (streamingServer.torrent !== null) {\n const [, { type, content }] = streamingServer.torrent;\n if (type === 'Ready') {\n const [, deepLinks] = content;\n if (typeof deepLinks.metaDetailsVideos === 'string') {\n window.location = deepLinks.metaDetailsVideos;\n }\n }\n }\n }, [streamingServer.torrent]);\n return null;\n};\n\nmodule.exports = withCoreSuspender(DeepLinkHandler);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { Button, Image } = require('stremio/common');\nconst styles = require('./styles');\n\nconst ErrorDialog = ({ className }) => {\n const [dataCleared, setDataCleared] = React.useState(false);\n const reload = React.useCallback(() => {\n window.location.reload();\n }, []);\n const clearData = React.useCallback(() => {\n window.localStorage.clear();\n setDataCleared(true);\n }, []);\n return (\n
\n \n
Something went wrong!
\n
\n \n \n
\n
\n );\n};\n\nErrorDialog.displayName = 'ErrorDialog';\n\nErrorDialog.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = ErrorDialog;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ErrorDialog = require('./ErrorDialog');\n\nmodule.exports = ErrorDialog;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst { useToast } = require('stremio/common');\n\nconst ServicesToaster = () => {\n const { core, dragAndDrop } = useServices();\n const toast = useToast();\n React.useEffect(() => {\n const onCoreEvent = ({ event, args }) => {\n switch (event) {\n case 'Error': {\n if (args.source.event === 'UserPulledFromAPI' && args.source.args.uid === null) {\n break;\n }\n\n if (args.source.event === 'LibrarySyncWithAPIPlanned' && args.source.args.uid === null) {\n break;\n }\n\n if (args.error.type === 'Other' && args.error.code === 3 && args.source.event === 'AddonInstalled' && args.source.args.transport_url.startsWith('https://www.strem.io/trakt/addon')) {\n break;\n }\n\n toast.show({\n type: 'error',\n title: args.source.event,\n message: args.error.message,\n timeout: 4000,\n dataset: {\n type: 'CoreEvent'\n }\n });\n break;\n }\n case 'TorrentParsed': {\n toast.show({\n type: 'success',\n title: 'Torrent file parsed',\n timeout: 4000\n });\n break;\n }\n case 'MagnetParsed': {\n toast.show({\n type: 'success',\n title: 'Magnet link parsed',\n timeout: 4000\n });\n break;\n }\n case 'PlayingOnDevice': {\n toast.show({\n type: 'success',\n title: `Stream opened in ${args.device}`,\n timeout: 4000\n });\n break;\n }\n }\n };\n const onDragAndDropError = (error) => {\n toast.show({\n type: 'error',\n title: error.message,\n message: error.file?.name,\n timeout: 4000\n });\n };\n core.transport.on('CoreEvent', onCoreEvent);\n dragAndDrop.on('error', onDragAndDropError);\n return () => {\n core.transport.off('CoreEvent', onCoreEvent);\n dragAndDrop.off('error', onDragAndDropError);\n };\n }, []);\n return null;\n};\n\nmodule.exports = ServicesToaster;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst App = require('./App');\n\nmodule.exports = App;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst routes = require('stremio/routes');\nconst { routesRegexp } = require('stremio/common');\n\nconst routerViewsConfig = [\n [\n {\n ...routesRegexp.board,\n component: routes.Board\n }\n ],\n [\n {\n ...routesRegexp.intro,\n component: routes.Intro\n },\n {\n ...routesRegexp.discover,\n component: routes.Discover\n },\n {\n ...routesRegexp.library,\n component: routes.Library\n },\n {\n ...routesRegexp.continuewatching,\n component: routes.Library\n },\n {\n ...routesRegexp.search,\n component: routes.Search\n }\n ],\n [\n {\n ...routesRegexp.metadetails,\n component: routes.MetaDetails\n }\n ],\n [\n {\n ...routesRegexp.addons,\n component: routes.Addons\n },\n {\n ...routesRegexp.settings,\n component: routes.Settings\n }\n ],\n [\n {\n ...routesRegexp.player,\n component: routes.Player\n }\n ]\n];\n\nmodule.exports = routerViewsConfig;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Image = require('stremio/common/Image');\nconst styles = require('./styles');\n\nconst AddonDetails = ({ className, id, name, version, logo, description, types, transportUrl, official }) => {\n const renderLogoFallback = React.useCallback(() => (\n \n ), []);\n return (\n
\n
\n \n
\n {typeof name === 'string' && name.length > 0 ? name : id}\n {\n typeof version === 'string' && version.length > 0 ?\n v. {version}\n :\n null\n }\n
\n
\n {\n typeof description === 'string' && description.length > 0 ?\n
\n {description}\n
\n :\n null\n }\n {\n typeof transportUrl === 'string' && transportUrl.length > 0 ?\n
\n URL: \n {transportUrl}\n
\n :\n null\n }\n {\n Array.isArray(types) && types.length > 0 ?\n
\n Supported types: \n \n {\n types.length === 1 ?\n types[0]\n :\n types.slice(0, -1).join(', ') + ' & ' + types[types.length - 1]\n }\n \n
\n :\n null\n }\n {\n !official ?\n
\n
Using third-party add-ons will always be subject to your responsibility and the governing law of the jurisdiction you are located.
\n
\n :\n null\n }\n
\n );\n};\n\nAddonDetails.propTypes = {\n className: PropTypes.string,\n id: PropTypes.string,\n name: PropTypes.string,\n version: PropTypes.string,\n logo: PropTypes.string,\n description: PropTypes.string,\n types: PropTypes.arrayOf(PropTypes.string),\n transportUrl: PropTypes.string,\n official: PropTypes.bool,\n};\n\nmodule.exports = AddonDetails;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst AddonDetails = require('./AddonDetails');\n\nmodule.exports = AddonDetails;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst ModalDialog = require('stremio/common/ModalDialog');\nconst { withCoreSuspender } = require('stremio/common/CoreSuspender');\nconst { useServices } = require('stremio/services');\nconst AddonDetailsWithRemoteAndLocalAddon = withRemoteAndLocalAddon(require('./AddonDetails'));\nconst useAddonDetails = require('./useAddonDetails');\nconst styles = require('./styles');\n\nfunction withRemoteAndLocalAddon(AddonDetails) {\n const withRemoteAndLocalAddon = ({ remoteAddon, localAddon, ...props }) => {\n const addon = remoteAddon !== null && remoteAddon.content.type === 'Ready' ?\n remoteAddon.content.content\n :\n localAddon !== null ?\n localAddon\n :\n null;\n if (addon === null) {\n return null;\n }\n\n return (\n \n );\n };\n withRemoteAndLocalAddon.displayName = 'withRemoteAndLocalAddon';\n return withRemoteAndLocalAddon;\n}\n\nconst AddonDetailsModal = ({ transportUrl, onCloseRequest }) => {\n const { core } = useServices();\n const addonDetails = useAddonDetails(transportUrl);\n const modalButtons = React.useMemo(() => {\n const cancelButton = {\n className: styles['cancel-button'],\n label: 'Cancel',\n props: {\n onClick: (event) => {\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'cancel',\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }\n }\n };\n const configureButton = addonDetails.remoteAddon !== null &&\n addonDetails.remoteAddon.content.type === 'Ready' &&\n addonDetails.remoteAddon.content.content.manifest.behaviorHints.configurable ?\n {\n className: styles['configure-button'],\n label: 'Configure',\n props: {\n onClick: (event) => {\n window.open(transportUrl.replace('manifest.json', 'configure'));\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'configure',\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }\n }\n }\n :\n null;\n const toggleButton = addonDetails.localAddon !== null ?\n {\n className: styles['uninstall-button'],\n label: 'Uninstall',\n props: {\n onClick: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UninstallAddon',\n args: addonDetails.localAddon\n }\n });\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'uninstall',\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }\n }\n }\n :\n addonDetails.remoteAddon !== null && addonDetails.remoteAddon.content.type === 'Ready' ?\n {\n\n className: styles['install-button'],\n label: 'Install',\n props: {\n onClick: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'InstallAddon',\n args: addonDetails.remoteAddon.content.content\n }\n });\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'install',\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }\n }\n }\n :\n null;\n return toggleButton !== null ? configureButton ? [cancelButton, configureButton, toggleButton] : [cancelButton, toggleButton] : [cancelButton];\n }, [addonDetails, onCloseRequest]);\n return (\n \n {\n addonDetails.selected === null ?\n
\n Loading addon manifest\n
\n :\n addonDetails.remoteAddon === null || addonDetails.remoteAddon.content.type === 'Loading' ?\n
\n Loading addon manifest from {addonDetails.selected.transportUrl}\n
\n :\n addonDetails.remoteAddon.content.type === 'Err' && addonDetails.localAddon === null ?\n
\n Failed to get addon manifest from {addonDetails.selected.transportUrl}\n
{addonDetails.remoteAddon.content.content.message}
\n
\n :\n \n }\n
\n );\n};\n\nAddonDetailsModal.propTypes = {\n transportUrl: PropTypes.string,\n onCloseRequest: PropTypes.func\n};\n\nconst AddonDetailsModalFallback = ({ onCloseRequest }) => (\n \n
\n Loading addon manifest\n
\n \n);\n\nAddonDetailsModalFallback.propTypes = AddonDetailsModal.propTypes;\n\nmodule.exports = withCoreSuspender(AddonDetailsModal, AddonDetailsModalFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst AddonDetailsModal = require('./AddonDetailsModal');\n\nmodule.exports = AddonDetailsModal;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst useModelState = require('stremio/common/useModelState');\n\nconst useAddonDetails = (transportUrl) => {\n const action = React.useMemo(() => {\n if (typeof transportUrl === 'string') {\n return {\n action: 'Load',\n args: {\n model: 'AddonDetails',\n args: {\n transportUrl\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [transportUrl]);\n return useModelState({ model: 'addon_details', action });\n};\n\nmodule.exports = useAddonDetails;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst styles = require('./styles');\n\nconst Button = React.forwardRef(({ className, href, disabled, children, ...props }, ref) => {\n const onKeyDown = React.useCallback((event) => {\n if (typeof props.onKeyDown === 'function') {\n props.onKeyDown(event);\n }\n\n if (event.key === 'Enter' && !event.nativeEvent.buttonClickPrevented) {\n event.currentTarget.click();\n }\n }, [props.onKeyDown]);\n const onMouseDown = React.useCallback((event) => {\n if (typeof props.onMouseDown === 'function') {\n props.onMouseDown(event);\n }\n\n if (!event.nativeEvent.buttonBlurPrevented) {\n event.preventDefault();\n if (document.activeElement instanceof HTMLElement) {\n document.activeElement.blur();\n }\n }\n }, [props.onMouseDown]);\n return React.createElement(\n typeof href === 'string' && href.length > 0 ? 'a' : 'div',\n {\n tabIndex: 0,\n ...props,\n ref,\n className: classnames(className, styles['button-container'], { 'disabled': disabled }),\n href,\n onKeyDown,\n onMouseDown\n },\n children\n );\n});\n\nButton.displayName = 'Button';\n\nButton.propTypes = {\n className: PropTypes.string,\n href: PropTypes.string,\n disabled: PropTypes.bool,\n children: PropTypes.node,\n onKeyDown: PropTypes.func,\n onMouseDown: PropTypes.func\n};\n\nmodule.exports = Button;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Button = require('./Button');\n\nmodule.exports = Button;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst CHROMECAST_RECEIVER_APP_ID = '1634F54B';\nconst SUBTITLES_SIZES = [75, 100, 125, 150, 175, 200, 250];\nconst SUBTITLES_FONTS = ['Roboto', 'Arial', 'Halvetica', 'Times New Roman', 'Verdana', 'Courier', 'Lucida Console', 'sans-serif', 'serif', 'monospace'];\nconst SEEK_TIME_DURATIONS = [5000, 10000, 15000, 20000, 25000, 30000];\nconst NEXT_VIDEO_POPUP_DURATIONS = [0, 5000, 10000, 15000, 20000, 25000, 30000, 35000, 40000, 45000, 50000];\nconst CATALOG_PREVIEW_SIZE = 10;\nconst CATALOG_PAGE_SIZE = 100;\nconst NONE_EXTRA_VALUE = 'None';\nconst SKIP_EXTRA_NAME = 'skip';\nconst META_LINK_CATEGORY = 'meta';\nconst IMDB_LINK_CATEGORY = 'imdb';\nconst SHARE_LINK_CATEGORY = 'share';\nconst WRITERS_LINK_CATEGORY = 'Writers';\nconst TYPE_PRIORITIES = {\n movie: 10,\n series: 9,\n channel: 8,\n tv: 7,\n music: 6,\n radio: 5,\n podcast: 4,\n game: 3,\n book: 2,\n adult: 1,\n other: -Infinity\n};\nconst ICON_FOR_TYPE = new Map([\n ['movie', 'ic_movies'],\n ['series', 'ic_series'],\n ['channel', 'ic_channels'],\n ['tv', 'ic_tv'],\n ['book', 'ic_book'],\n ['game', 'ic_games'],\n ['music', 'ic_music'],\n ['adult', 'ic_adult'],\n ['radio', 'ic_radio'],\n ['podcast', 'ic_podcast'],\n ['other', 'ic_movies'],\n]);\n\nmodule.exports = {\n CHROMECAST_RECEIVER_APP_ID,\n SUBTITLES_SIZES,\n SUBTITLES_FONTS,\n SEEK_TIME_DURATIONS,\n NEXT_VIDEO_POPUP_DURATIONS,\n CATALOG_PREVIEW_SIZE,\n CATALOG_PAGE_SIZE,\n NONE_EXTRA_VALUE,\n SKIP_EXTRA_NAME,\n META_LINK_CATEGORY,\n IMDB_LINK_CATEGORY,\n SHARE_LINK_CATEGORY,\n WRITERS_LINK_CATEGORY,\n TYPE_PRIORITIES,\n ICON_FOR_TYPE\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst styles = require('./styles');\n\nconst Checkbox = React.forwardRef(({ className, checked, children, ...props }, ref) => {\n return (\n \n );\n});\n\nCheckbox.displayName = 'Checkbox';\n\nCheckbox.propTypes = {\n className: PropTypes.string,\n checked: PropTypes.bool,\n children: PropTypes.node\n};\n\nmodule.exports = Checkbox;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Checkbox = require('./Checkbox');\n\nmodule.exports = Checkbox;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst AColorPicker = require('a-color-picker');\nconst { useTranslation } = require('react-i18next');\nconst Button = require('stremio/common/Button');\nconst ModalDialog = require('stremio/common/ModalDialog');\nconst useBinaryState = require('stremio/common/useBinaryState');\nconst ColorPicker = require('./ColorPicker');\nconst styles = require('./styles');\n\nconst parseColor = (value) => {\n const color = AColorPicker.parseColor(value, 'hexcss4');\n return typeof color === 'string' ? color : '#ffffffff';\n};\n\nconst ColorInput = ({ className, value, dataset, onChange, ...props }) => {\n const { t } = useTranslation();\n const [modalOpen, openModal, closeModal] = useBinaryState(false);\n const [tempValue, setTempValue] = React.useState(() => {\n return parseColor(value);\n });\n const labelButtonStyle = React.useMemo(() => ({\n backgroundColor: value\n }), [value]);\n const isTransparent = React.useMemo(() => {\n return parseColor(value).endsWith('00');\n }, [value]);\n const labelButtonOnClick = React.useCallback((event) => {\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n\n if (!event.nativeEvent.openModalPrevented) {\n openModal();\n }\n }, [props.onClick]);\n const modalDialogOnClick = React.useCallback((event) => {\n event.nativeEvent.openModalPrevented = true;\n }, []);\n const modalButtons = React.useMemo(() => {\n const selectButtonOnClick = (event) => {\n if (typeof onChange === 'function') {\n onChange({\n type: 'change',\n value: tempValue,\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n\n closeModal();\n };\n return [\n {\n label: 'Select',\n props: {\n 'data-autofocus': true,\n onClick: selectButtonOnClick\n }\n }\n ];\n }, [tempValue, dataset, onChange]);\n const colorPickerOnInput = React.useCallback((event) => {\n setTempValue(parseColor(event.value));\n }, []);\n React.useLayoutEffect(() => {\n setTempValue(parseColor(value));\n }, [value, modalOpen]);\n return (\n \n );\n};\n\nColorInput.propTypes = {\n className: PropTypes.string,\n value: PropTypes.string,\n dataset: PropTypes.object,\n onChange: PropTypes.func,\n onClick: PropTypes.func\n};\n\nmodule.exports = ColorInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst AColorPicker = require('a-color-picker');\nconst styles = require('./styles');\n\nconst parseColor = (value) => {\n return AColorPicker.parseColor(value, 'hexcss4');\n};\n\nconst ColorPicker = ({ className, value, onInput }) => {\n const pickerRef = React.useRef(null);\n const pickerElementRef = React.useRef(null);\n React.useLayoutEffect(() => {\n pickerRef.current = AColorPicker.createPicker(pickerElementRef.current, {\n color: parseColor(value),\n showHSL: false,\n showHEX: false,\n showRGB: false,\n showAlpha: true\n });\n const pickerClipboard = pickerElementRef.current.querySelector('.a-color-picker-clipbaord');\n if (pickerClipboard instanceof HTMLElement) {\n pickerClipboard.tabIndex = -1;\n }\n }, []);\n React.useLayoutEffect(() => {\n if (typeof onInput === 'function') {\n pickerRef.current.on('change', (picker, value) => {\n onInput({\n type: 'input',\n value: parseColor(value)\n });\n });\n }\n return () => {\n pickerRef.current.off('change');\n };\n }, [onInput]);\n React.useLayoutEffect(() => {\n const nextValue = parseColor(value);\n if (nextValue !== parseColor(pickerRef.current.color)) {\n pickerRef.current.color = nextValue;\n }\n }, [value]);\n return (\n
\n );\n};\n\nColorPicker.propTypes = {\n className: PropTypes.string,\n value: PropTypes.string,\n onInput: PropTypes.func\n};\n\nmodule.exports = ColorPicker;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ColorPicker = require('./ColorPicker');\n\nmodule.exports = ColorPicker;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ColorInput = require('./ColorInput');\n\nmodule.exports = ColorInput;\n\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\n\nconst CoreSuspenderContext = React.createContext(null);\n\nCoreSuspenderContext.displayName = 'CoreSuspenderContext';\n\nfunction wrapPromise(promise) {\n let status = 'pending';\n let result;\n const suspender = promise.then(\n (resp) => {\n status = 'success';\n result = resp;\n },\n (error) => {\n status = 'error';\n result = error;\n }\n );\n return {\n read() {\n if (status === 'pending') {\n throw suspender;\n } else if (status === 'error') {\n throw result;\n } else if (status === 'success') {\n return result;\n }\n }\n };\n}\n\nconst useCoreSuspender = () => {\n return React.useContext(CoreSuspenderContext);\n};\n\nconst withCoreSuspender = (Component, Fallback = () => { }) => {\n return function withCoreSuspender(props) {\n const { core } = useServices();\n const parentSuspender = useCoreSuspender();\n const [render, setRender] = React.useState(parentSuspender === null);\n const statesRef = React.useRef({});\n const streamsRef = React.useRef({});\n const getState = React.useCallback((model) => {\n if (!statesRef.current[model]) {\n statesRef.current[model] = wrapPromise(core.transport.getState(model));\n }\n\n return statesRef.current[model].read();\n }, []);\n const decodeStream = React.useCallback((stream) => {\n if (!streamsRef.current[stream]) {\n streamsRef.current[stream] = wrapPromise(core.transport.decodeStream(stream));\n }\n\n return streamsRef.current[stream].read();\n }, []);\n const suspender = React.useMemo(() => ({ getState, decodeStream }), []);\n React.useLayoutEffect(() => {\n if (!render) {\n setRender(true);\n }\n }, []);\n return render ?\n }>\n \n \n \n \n :\n null;\n };\n};\n\nmodule.exports = { withCoreSuspender, useCoreSuspender };\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\n\nconst DelayedRenderer = ({ children, delay }) => {\n const [render, setRender] = React.useState(false);\n React.useEffect(() => {\n const timeout = setTimeout(() => {\n setRender(true);\n }, delay);\n return () => {\n clearTimeout(timeout);\n };\n }, []);\n return render ? children : null;\n};\n\nDelayedRenderer.propTypes = {\n children: PropTypes.node\n};\n\nmodule.exports = DelayedRenderer;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst DelayedRenderer = require('./DelayedRenderer');\n\nmodule.exports = DelayedRenderer;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\n\nconst Image = ({ className, src, alt, fallbackSrc, renderFallback, ...props }) => {\n const [broken, setBroken] = React.useState(false);\n const onError = React.useCallback((event) => {\n if (typeof props.onError === 'function') {\n props.onError(event);\n }\n\n setBroken(true);\n }, [props.onError]);\n React.useLayoutEffect(() => {\n setBroken(false);\n }, [src]);\n return (broken || typeof src !== 'string' || src.length === 0) && (typeof renderFallback === 'function' || typeof fallbackSrc === 'string') ?\n typeof renderFallback === 'function' ?\n renderFallback()\n :\n {alt}\n :\n {alt};\n};\n\nImage.propTypes = {\n className: PropTypes.string,\n src: PropTypes.string,\n alt: PropTypes.string,\n fallbackSrc: PropTypes.string,\n renderFallback: PropTypes.func,\n onError: PropTypes.func\n};\n\nmodule.exports = Image;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Image = require('./Image');\n\nmodule.exports = Image;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst PropTypes = require('prop-types');\nconst MetaItem = require('stremio/common/MetaItem');\nconst { t } = require('i18next');\n\nconst OPTIONS = [\n { label: 'LIBRARY_PLAY', value: 'play' },\n { label: 'LIBRARY_DETAILS', value: 'details' },\n { label: 'LIBRARY_RESUME_DISMISS', value: 'dismiss' },\n { label: 'LIBRARY_REMOVE', value: 'remove' },\n];\n\nconst LibItem = ({ _id, removable, ...props }) => {\n const { core } = useServices();\n const options = React.useMemo(() => {\n return OPTIONS\n .filter(({ value }) => {\n switch (value) {\n case 'play':\n return props.deepLinks && typeof props.deepLinks.player === 'string';\n case 'details':\n return props.deepLinks && (typeof props.deepLinks.metaDetailsVideos === 'string' || typeof props.deepLinks.metaDetailsStreams === 'string');\n case 'dismiss':\n return typeof _id === 'string' && props.progress !== null && !isNaN(props.progress);\n case 'remove':\n return typeof _id === 'string' && removable;\n }\n })\n .map((option) => ({\n ...option,\n label: t(option.label)\n }));\n }, [_id, removable, props.progress, props.deepLinks]);\n const optionOnSelect = React.useCallback((event) => {\n if (typeof props.optionOnSelect === 'function') {\n props.optionOnSelect(event);\n }\n\n if (!event.nativeEvent.optionSelectPrevented) {\n switch (event.value) {\n case 'play': {\n if (props.deepLinks && typeof props.deepLinks.player === 'string') {\n window.location = props.deepLinks.player;\n }\n\n break;\n }\n case 'details': {\n if (props.deepLinks) {\n if (typeof props.deepLinks.metaDetailsVideos === 'string') {\n window.location = props.deepLinks.metaDetailsVideos;\n } else if (typeof props.deepLinks.metaDetailsStreams === 'string') {\n window.location = props.deepLinks.metaDetailsStreams;\n }\n }\n\n break;\n }\n case 'dismiss': {\n if (typeof _id === 'string') {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'RewindLibraryItem',\n args: _id\n }\n });\n }\n\n break;\n }\n case 'remove': {\n if (typeof _id === 'string') {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'RemoveFromLibrary',\n args: _id\n }\n });\n }\n\n break;\n }\n }\n }\n }, [_id, props.deepLinks, props.optionOnSelect]);\n return (\n \n );\n};\n\nLibItem.propTypes = {\n _id: PropTypes.string,\n removable: PropTypes.bool,\n progress: PropTypes.number,\n deepLinks: PropTypes.shape({\n metaDetailsVideos: PropTypes.string,\n metaDetailsStreams: PropTypes.string,\n player: PropTypes.string\n }),\n optionOnSelect: PropTypes.func\n};\n\nmodule.exports = LibItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst LibItem = require('./LibItem');\n\nmodule.exports = LibItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { VerticalNavBar, HorizontalNavBar } = require('stremio/common/NavBar');\nconst styles = require('./styles');\n\nconst TABS = [\n { id: 'board', label: 'Board', icon: 'ic_board', href: '#/' },\n { id: 'discover', label: 'Discover', icon: 'ic_discover', href: '#/discover' },\n { id: 'library', label: 'Library', icon: 'ic_library', href: '#/library' },\n { id: 'settings', label: 'SETTINGS', icon: 'ic_settings', href: '#/settings' },\n { id: 'addons', label: 'ADDONS', icon: 'ic_addons', href: '#/addons' }\n];\n\nconst MainNavBars = React.memo(({ className, route, query, children }) => {\n return (\n
\n \n \n
{children}
\n
\n );\n});\n\nMainNavBars.displayName = 'MainNavBars';\n\nMainNavBars.propTypes = {\n className: PropTypes.string,\n route: PropTypes.string,\n query: PropTypes.string,\n children: PropTypes.node\n};\n\nmodule.exports = MainNavBars;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MainNavBars = require('./MainNavBars');\n\nmodule.exports = MainNavBars;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst filterInvalidDOMProps = require('filter-invalid-dom-props').default;\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst Image = require('stremio/common/Image');\nconst Multiselect = require('stremio/common/Multiselect');\nconst PlayIconCircleCentered = require('stremio/common/PlayIconCircleCentered');\nconst useBinaryState = require('stremio/common/useBinaryState');\nconst { ICON_FOR_TYPE } = require('stremio/common/CONSTANTS');\nconst styles = require('./styles');\n\nconst MetaItem = React.memo(({ className, type, name, poster, posterShape, playIcon, progress, options, deepLinks, dataset, optionOnSelect, ...props }) => {\n const [menuOpen, onMenuOpen, onMenuClose] = useBinaryState(false);\n const href = React.useMemo(() => {\n return deepLinks ?\n typeof deepLinks.player === 'string' ?\n deepLinks.player\n :\n typeof deepLinks.metaDetailsStreams === 'string' ?\n deepLinks.metaDetailsStreams\n :\n typeof deepLinks.metaDetailsVideos === 'string' ?\n deepLinks.metaDetailsVideos\n :\n null\n :\n null;\n }, [deepLinks]);\n const metaItemOnClick = React.useCallback((event) => {\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n\n if (event.nativeEvent.selectPrevented) {\n event.preventDefault();\n }\n }, [props.onClick]);\n const menuOnClick = React.useCallback((event) => {\n event.nativeEvent.selectPrevented = true;\n }, []);\n const menuOnSelect = React.useCallback((event) => {\n if (typeof optionOnSelect === 'function') {\n optionOnSelect({\n type: 'select-option',\n value: event.value,\n dataset: dataset,\n reactEvent: event.reactEvent,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, optionOnSelect]);\n const renderPosterFallback = React.useCallback(() => (\n \n ), [type]);\n const renderMenuLabelContent = React.useCallback(() => (\n \n ), []);\n return (\n \n );\n});\n\nMetaItem.displayName = 'MetaItem';\n\nMetaItem.propTypes = {\n className: PropTypes.string,\n type: PropTypes.string,\n name: PropTypes.string,\n poster: PropTypes.string,\n posterShape: PropTypes.oneOf(['poster', 'landscape', 'square']),\n playIcon: PropTypes.bool,\n progress: PropTypes.number,\n options: PropTypes.array,\n deepLinks: PropTypes.shape({\n metaDetailsVideos: PropTypes.string,\n metaDetailsStreams: PropTypes.string,\n player: PropTypes.string\n }),\n dataset: PropTypes.object,\n optionOnSelect: PropTypes.func,\n onClick: PropTypes.func\n};\n\nmodule.exports = MetaItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaItem = require('./MetaItem');\n\nmodule.exports = MetaItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst styles = require('./styles');\n\nconst ActionButton = ({ className, icon, label, ...props }) => {\n return (\n \n );\n};\n\nActionButton.propTypes = {\n className: PropTypes.string,\n icon: PropTypes.string,\n label: PropTypes.string\n};\n\nmodule.exports = ActionButton;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ActionButton = require('./ActionButton');\n\nmodule.exports = ActionButton;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Button = require('stremio/common/Button');\nconst styles = require('./styles');\n\nconst MetaLinks = ({ className, label, links }) => {\n const { t } = useTranslation();\n return (\n
\n {\n typeof label === 'string' && label.length > 0 ?\n
\n {t(`LINKS_${label.toUpperCase()}`)}\n
\n :\n null\n }\n {\n Array.isArray(links) && links.length > 0 ?\n
\n {links.map(({ label, href }, index) => (\n \n ))}\n
\n :\n null\n }\n
\n );\n};\n\nMetaLinks.propTypes = {\n className: PropTypes.string,\n label: PropTypes.string,\n links: PropTypes.arrayOf(PropTypes.shape({\n label: PropTypes.string,\n href: PropTypes.string\n }))\n};\n\nmodule.exports = MetaLinks;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaLinks = require('./MetaLinks');\n\nmodule.exports = MetaLinks;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst UrlUtils = require('url');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst Image = require('stremio/common/Image');\nconst ModalDialog = require('stremio/common/ModalDialog');\nconst SharePrompt = require('stremio/common/SharePrompt');\nconst CONSTANTS = require('stremio/common/CONSTANTS');\nconst routesRegexp = require('stremio/common/routesRegexp');\nconst useBinaryState = require('stremio/common/useBinaryState');\nconst ActionButton = require('./ActionButton');\nconst MetaLinks = require('./MetaLinks');\nconst MetaPreviewPlaceholder = require('./MetaPreviewPlaceholder');\nconst styles = require('./styles');\n\nconst ALLOWED_LINK_REDIRECTS = [\n routesRegexp.search.regexp,\n routesRegexp.discover.regexp,\n routesRegexp.metadetails.regexp\n];\n\nconst MetaPreview = ({ className, compact, name, logo, background, runtime, releaseInfo, released, description, deepLinks, links, trailerStreams, inLibrary, toggleInLibrary }) => {\n const { t } = useTranslation();\n const [shareModalOpen, openShareModal, closeShareModal] = useBinaryState(false);\n const linksGroups = React.useMemo(() => {\n return Array.isArray(links) ?\n links\n .filter((link) => link && typeof link.category === 'string' && typeof link.url === 'string')\n .reduce((linksGroups, { category, name, url }) => {\n const { protocol, path, pathname, hostname } = UrlUtils.parse(url);\n if (category === CONSTANTS.IMDB_LINK_CATEGORY) {\n if (hostname === 'imdb.com') {\n linksGroups.set(category, {\n label: name,\n href: `https://www.stremio.com/warning#${encodeURIComponent(url)}`\n });\n }\n } else if (category === CONSTANTS.SHARE_LINK_CATEGORY) {\n linksGroups.set(category, {\n label: name,\n href: url\n });\n } else {\n if (protocol === 'stremio:') {\n if (pathname !== null && ALLOWED_LINK_REDIRECTS.some((regexp) => pathname.match(regexp))) {\n if (!linksGroups.has(category)) {\n linksGroups.set(category, []);\n }\n linksGroups.get(category).push({\n label: name,\n href: `#${path}`\n });\n }\n } else if (typeof hostname === 'string' && hostname.length > 0) {\n if (!linksGroups.has(category)) {\n linksGroups.set(category, []);\n }\n linksGroups.get(category).push({\n label: name,\n href: `https://www.stremio.com/warning#${encodeURIComponent(url)}`\n });\n }\n }\n\n return linksGroups;\n }, new Map())\n :\n new Map();\n }, [links]);\n const showHref = React.useMemo(() => {\n return deepLinks ?\n typeof deepLinks.player === 'string' ?\n deepLinks.player\n :\n typeof deepLinks.metaDetailsStreams === 'string' ?\n deepLinks.metaDetailsStreams\n :\n typeof deepLinks.metaDetailsVideos === 'string' ?\n deepLinks.metaDetailsVideos\n :\n null\n :\n null;\n }, [deepLinks]);\n const trailerHref = React.useMemo(() => {\n if (!Array.isArray(trailerStreams) || trailerStreams.length === 0) {\n return null;\n }\n\n return trailerStreams[0].deepLinks.player;\n }, [trailerStreams]);\n const renderLogoFallback = React.useCallback(() => (\n
{!compact ? name : null}
\n ), [compact, name]);\n return (\n
\n {\n typeof background === 'string' && background.length > 0 ?\n
\n {'\n
\n :\n null\n }\n
\n {\n typeof logo === 'string' && logo.length > 0 ?\n \n :\n renderLogoFallback()\n }\n {\n (typeof releaseInfo === 'string' && releaseInfo.length > 0) || (released instanceof Date && !isNaN(released.getTime())) || (typeof runtime === 'string' && runtime.length > 0) || linksGroups.has(CONSTANTS.IMDB_LINK_CATEGORY) ?\n
\n {\n typeof runtime === 'string' && runtime.length > 0 ?\n
{runtime}
\n :\n null\n }\n {\n typeof releaseInfo === 'string' && releaseInfo.length > 0 ?\n
{releaseInfo}
\n :\n released instanceof Date && !isNaN(released.getTime()) ?\n
{released.getFullYear()}
\n :\n null\n }\n {\n linksGroups.has(CONSTANTS.IMDB_LINK_CATEGORY) ?\n \n \n
{linksGroups.get(CONSTANTS.IMDB_LINK_CATEGORY).label}
\n \n :\n null\n }\n
\n :\n null\n }\n {\n compact && typeof name === 'string' && name.length > 0 ?\n
\n {name}\n
\n :\n null\n }\n {\n compact && typeof description === 'string' && description.length > 0 ?\n
{description}
\n :\n null\n }\n {\n Array.from(linksGroups.keys())\n .filter((category) => {\n return category !== CONSTANTS.IMDB_LINK_CATEGORY &&\n category !== CONSTANTS.SHARE_LINK_CATEGORY &&\n category !== CONSTANTS.WRITERS_LINK_CATEGORY;\n })\n .map((category, index) => (\n \n ))\n }\n
\n
\n {\n typeof toggleInLibrary === 'function' ?\n \n :\n null\n }\n {\n typeof trailerHref === 'string' ?\n \n :\n null\n }\n {\n typeof showHref === 'string' && compact ?\n \n :\n null\n }\n {\n linksGroups.has(CONSTANTS.SHARE_LINK_CATEGORY) && !compact ?\n \n \n {\n shareModalOpen ?\n \n \n \n :\n null\n }\n \n :\n null\n }\n
\n
\n );\n};\n\nMetaPreview.Placeholder = MetaPreviewPlaceholder;\n\nMetaPreview.propTypes = {\n className: PropTypes.string,\n compact: PropTypes.bool,\n name: PropTypes.string,\n logo: PropTypes.string,\n background: PropTypes.string,\n runtime: PropTypes.string,\n releaseInfo: PropTypes.string,\n released: PropTypes.instanceOf(Date),\n description: PropTypes.string,\n deepLinks: PropTypes.shape({\n metaDetailsVideos: PropTypes.string,\n metaDetailsStreams: PropTypes.string,\n player: PropTypes.string\n }),\n links: PropTypes.arrayOf(PropTypes.shape({\n category: PropTypes.string,\n name: PropTypes.string,\n url: PropTypes.string\n })),\n trailerStreams: PropTypes.array,\n inLibrary: PropTypes.bool,\n toggleInLibrary: PropTypes.func\n};\n\nmodule.exports = MetaPreview;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst styles = require('./styles');\n\nconst MetaPreviewPlaceholder = ({ className }) => {\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n );\n};\n\nMetaPreviewPlaceholder.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = MetaPreviewPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaPreviewPlaceholder = require('./MetaPreviewPlaceholder');\n\nmodule.exports = MetaPreviewPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaPreview = require('./MetaPreview');\n\nmodule.exports = MetaPreview;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ReactIs = require('react-is');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst CONSTANTS = require('stremio/common/CONSTANTS');\nconst MetaRowPlaceholder = require('./MetaRowPlaceholder');\nconst styles = require('./styles');\n\nconst MetaRow = ({ className, title, message, items, itemComponent, deepLinks }) => {\n const { t } = useTranslation();\n return (\n
\n {\n (typeof title === 'string' && title.length > 0) || (deepLinks && (typeof deepLinks.discover === 'string' || typeof deepLinks.library === 'string')) ?\n
\n {\n typeof title === 'string' && title.length > 0 ?\n
{title}
\n :\n null\n }\n {\n deepLinks && (typeof deepLinks.discover === 'string' || typeof deepLinks.library === 'string') ?\n \n :\n null\n }\n
\n :\n null\n }\n {\n typeof message === 'string' && message.length > 0 ?\n
{message}
\n :\n
\n {\n ReactIs.isValidElementType(itemComponent) ?\n items.slice(0, CONSTANTS.CATALOG_PREVIEW_SIZE).map((item, index) => {\n return React.createElement(itemComponent, {\n ...item,\n key: index,\n className: classnames(styles['meta-item'], styles['poster-shape-poster'], styles[`poster-shape-${item.posterShape}`])\n });\n })\n :\n null\n }\n {Array(Math.max(0, CONSTANTS.CATALOG_PREVIEW_SIZE - items.length)).fill(null).map((_, index) => (\n
\n ))}\n
\n }\n
\n );\n};\n\nMetaRow.Placeholder = MetaRowPlaceholder;\n\nMetaRow.propTypes = {\n className: PropTypes.string,\n title: PropTypes.string,\n message: PropTypes.string,\n items: PropTypes.arrayOf(PropTypes.shape({\n posterShape: PropTypes.string\n })),\n itemComponent: PropTypes.elementType,\n deepLinks: PropTypes.shape({\n discover: PropTypes.string,\n library: PropTypes.string\n })\n};\n\nmodule.exports = MetaRow;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst CONSTANTS = require('stremio/common/CONSTANTS');\nconst styles = require('./styles');\n\nconst MetaRowPlaceholder = ({ className, title, deepLinks }) => {\n const { t } = useTranslation();\n return (\n
\n
\n
0 ? title : null}>\n {typeof title === 'string' && title.length > 0 ? title : null}\n
\n {\n deepLinks && typeof deepLinks.discover === 'string' ?\n \n :\n null\n }\n
\n
\n {Array(CONSTANTS.CATALOG_PREVIEW_SIZE).fill(null).map((_, index) => (\n
\n
\n
\n
\n
\n
\n ))}\n
\n
\n );\n};\n\nMetaRowPlaceholder.propTypes = {\n className: PropTypes.string,\n title: PropTypes.string,\n deepLinks: PropTypes.shape({\n discover: PropTypes.string\n })\n};\n\nmodule.exports = MetaRowPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaRowPlaceholder = require('./MetaRowPlaceholder');\n\nmodule.exports = MetaRowPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaRow = require('./MetaRow');\n\nmodule.exports = MetaRow;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useRouteFocused, useModalsContainer } = require('stremio-router');\nconst Button = require('stremio/common/Button');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Modal } = require('stremio-router');\nconst styles = require('./styles');\n\nconst ModalDialog = ({ className, title, buttons, children, dataset, onCloseRequest, ...props }) => {\n const routeFocused = useRouteFocused();\n const modalsContainer = useModalsContainer();\n const modalContainerRef = React.useRef(null);\n const closeButtonOnClick = React.useCallback((event) => {\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'close',\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onCloseRequest]);\n const onModalContainerMouseDown = React.useCallback((event) => {\n if (!event.nativeEvent.closeModalDialogPrevented && typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'close',\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onCloseRequest]);\n const onModalDialogContainerMouseDown = React.useCallback((event) => {\n event.nativeEvent.closeModalDialogPrevented = true;\n }, []);\n React.useEffect(() => {\n const onKeyDown = (event) => {\n // its `-2` because focus lock render locking divs around its content\n if (event.code === 'Escape' && modalsContainer.childNodes[modalsContainer.childElementCount - 2] === modalContainerRef.current) {\n if (typeof onCloseRequest === 'function') {\n onCloseRequest({\n type: 'close',\n dataset: dataset,\n nativeEvent: event\n });\n }\n }\n };\n if (routeFocused) {\n window.addEventListener('keydown', onKeyDown);\n }\n return () => {\n window.removeEventListener('keydown', onKeyDown);\n };\n }, [routeFocused, dataset, onCloseRequest]);\n return (\n \n
\n \n {\n typeof title === 'string' && title.length > 0 ?\n
{title}
\n :\n null\n }\n
\n {children}\n
\n {\n Array.isArray(buttons) && buttons.length > 0 ?\n
\n {buttons.map(({ className, label, icon, props }, index) => (\n \n ))}\n
\n :\n null\n }\n
\n
\n );\n};\n\nModalDialog.propTypes = {\n className: PropTypes.string,\n title: PropTypes.string,\n buttons: PropTypes.arrayOf(PropTypes.shape({\n className: PropTypes.string,\n label: PropTypes.string,\n icon: PropTypes.string,\n props: PropTypes.object\n })),\n children: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.node),\n PropTypes.node\n ]),\n dataset: PropTypes.object,\n onCloseRequest: PropTypes.func\n};\n\nmodule.exports = ModalDialog;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ModalDialog = require('./ModalDialog');\n\nmodule.exports = ModalDialog;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst Popup = require('stremio/common/Popup');\nconst ModalDialog = require('stremio/common/ModalDialog');\nconst useBinaryState = require('stremio/common/useBinaryState');\nconst styles = require('./styles');\n\nconst Multiselect = ({ className, mode, direction, title, disabled, dataset, renderLabelContent, renderLabelText, onOpen, onClose, onSelect, ...props }) => {\n const [menuOpen, , closeMenu, toggleMenu] = useBinaryState(false);\n const options = React.useMemo(() => {\n return Array.isArray(props.options) ?\n props.options.filter((option) => {\n return option && typeof option.value === 'string';\n })\n :\n [];\n }, [props.options]);\n const selected = React.useMemo(() => {\n return Array.isArray(props.selected) ?\n props.selected.filter((value) => {\n return typeof value === 'string';\n })\n :\n [];\n }, [props.selected]);\n const labelOnClick = React.useCallback((event) => {\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n\n if (!event.nativeEvent.toggleMenuPrevented) {\n toggleMenu();\n }\n }, [props.onClick, toggleMenu]);\n const menuOnClick = React.useCallback((event) => {\n event.nativeEvent.toggleMenuPrevented = true;\n }, []);\n const menuOnKeyDown = React.useCallback((event) => {\n event.nativeEvent.buttonClickPrevented = true;\n }, []);\n const optionOnClick = React.useCallback((event) => {\n if (typeof onSelect === 'function') {\n onSelect({\n type: 'select',\n value: event.currentTarget.dataset.value,\n reactEvent: event,\n nativeEvent: event.nativeEvent,\n dataset: dataset\n });\n }\n\n if (!event.nativeEvent.closeMenuPrevented) {\n closeMenu();\n }\n }, [dataset, onSelect]);\n const mountedRef = React.useRef(false);\n React.useLayoutEffect(() => {\n if (mountedRef.current) {\n if (menuOpen) {\n if (typeof onOpen === 'function') {\n onOpen({\n type: 'open',\n dataset: dataset\n });\n }\n } else {\n if (typeof onClose === 'function') {\n onClose({\n type: 'close',\n dataset: dataset\n });\n }\n }\n }\n\n mountedRef.current = true;\n }, [menuOpen]);\n const renderLabel = React.useCallback(({ children, className, ...props }) => (\n \n ), [menuOpen, title, disabled, options, selected, labelOnClick, renderLabelContent, renderLabelText]);\n const renderMenu = React.useCallback(() => (\n
\n {\n options.length > 0 ?\n options.map(({ label, title, value }) => (\n \n ))\n :\n
\n
No options available
\n
\n }\n
\n ), [options, selected, menuOnKeyDown, menuOnClick, optionOnClick]);\n const renderPopupLabel = React.useMemo(() => (labelProps) => {\n return renderLabel({\n ...labelProps,\n ...props,\n className: classnames(className, labelProps.className)\n });\n }, [props, className, renderLabel]);\n return mode === 'modal' ?\n renderLabel({\n ...props,\n className,\n children: menuOpen ?\n \n {renderMenu()}\n \n :\n null\n })\n :\n ;\n};\n\nMultiselect.propTypes = {\n className: PropTypes.string,\n mode: PropTypes.oneOf(['popup', 'modal']),\n direction: PropTypes.any,\n title: PropTypes.string,\n options: PropTypes.arrayOf(PropTypes.shape({\n value: PropTypes.string.isRequired,\n title: PropTypes.string,\n label: PropTypes.string\n })),\n selected: PropTypes.arrayOf(PropTypes.string),\n disabled: PropTypes.bool,\n dataset: PropTypes.object,\n renderLabelContent: PropTypes.func,\n renderLabelText: PropTypes.func,\n onOpen: PropTypes.func,\n onClose: PropTypes.func,\n onSelect: PropTypes.func,\n onClick: PropTypes.func\n};\n\nmodule.exports = Multiselect;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Multiselect = require('./Multiselect');\n\nmodule.exports = Multiselect;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst Image = require('stremio/common/Image');\nconst useFullscreen = require('stremio/common/useFullscreen');\nconst SearchBar = require('./SearchBar');\nconst NavMenu = require('./NavMenu');\nconst styles = require('./styles');\nconst { t } = require('i18next');\n\nconst HorizontalNavBar = React.memo(({ className, route, query, title, backButton, searchBar, addonsButton, fullscreenButton, navMenu, ...props }) => {\n const backButtonOnClick = React.useCallback(() => {\n window.history.back();\n }, []);\n const [fullscreen, requestFullscreen, exitFullscreen] = useFullscreen();\n const renderNavMenuLabel = React.useCallback(({ ref, className, onClick, children, }) => (\n \n ), []);\n return (\n \n );\n});\n\nHorizontalNavBar.displayName = 'HorizontalNavBar';\n\nHorizontalNavBar.propTypes = {\n className: PropTypes.string,\n route: PropTypes.string,\n query: PropTypes.string,\n title: PropTypes.string,\n backButton: PropTypes.bool,\n searchBar: PropTypes.bool,\n addonsButton: PropTypes.bool,\n fullscreenButton: PropTypes.bool,\n navMenu: PropTypes.bool\n};\n\nmodule.exports = HorizontalNavBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useRouteFocused } = require('stremio-router');\nconst Popup = require('stremio/common/Popup');\nconst useBinaryState = require('stremio/common/useBinaryState');\nconst NavMenuContent = require('./NavMenuContent');\n\nconst NavMenu = (props) => {\n const routeFocused = useRouteFocused();\n const [menuOpen, , closeMenu, toggleMenu] = useBinaryState(false);\n const popupLabelOnClick = React.useCallback((event) => {\n if (!event.nativeEvent.togglePopupPrevented) {\n toggleMenu();\n }\n }, [toggleMenu]);\n const popupMenuOnClick = React.useCallback((event) => {\n event.nativeEvent.togglePopupPrevented = true;\n }, []);\n const renderLabel = React.useMemo(() => ({ ref, className, children }) => (\n props.renderLabel({\n ref,\n className: classnames(className, { 'active': menuOpen }),\n onClick: popupLabelOnClick,\n children,\n })\n ), [menuOpen, popupLabelOnClick, props.renderLabel]);\n const renderMenu = React.useCallback(() => (\n \n ), []);\n React.useEffect(() => {\n if (!routeFocused) {\n closeMenu();\n }\n }, [routeFocused]);\n return (\n \n );\n};\n\nNavMenu.propTypes = {\n renderLabel: PropTypes.func\n};\n\nmodule.exports = NavMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { useServices } = require('stremio/services');\nconst Button = require('stremio/common/Button');\nconst useFullscreen = require('stremio/common/useFullscreen');\nconst useProfile = require('stremio/common/useProfile');\nconst useTorrent = require('stremio/common/useTorrent');\nconst { withCoreSuspender } = require('stremio/common/CoreSuspender');\nconst styles = require('./styles');\n\nconst NavMenuContent = ({ onClick }) => {\n const { t } = useTranslation();\n const { core } = useServices();\n const profile = useProfile();\n const { createTorrentFromMagnet } = useTorrent();\n const [fullscreen, requestFullscreen, exitFullscreen] = useFullscreen();\n const logoutButtonOnClick = React.useCallback(() => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Logout'\n }\n });\n }, []);\n const onPlayMagnetLinkClick = React.useCallback(async () => {\n try {\n const clipboardText = await navigator.clipboard.readText();\n createTorrentFromMagnet(clipboardText);\n } catch(e) {\n console.error(e);\n }\n }, []);\n return (\n
\n
\n \n
\n
{profile.auth === null ? t('ANONYMOUS_USER') : profile.auth.user.email}
\n
\n \n
\n
\n \n
\n
\n \n \n \n \n
\n
\n \n \n \n
\n
\n );\n};\n\nNavMenuContent.propTypes = {\n onClick: PropTypes.func\n};\n\nconst NavMenuContentFallback = () => (\n
\n);\n\nmodule.exports = withCoreSuspender(NavMenuContent, NavMenuContentFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst NavMenu = require('./NavMenu');\n\nmodule.exports = NavMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { useRouteFocused } = require('stremio-router');\nconst Button = require('stremio/common/Button');\nconst TextInput = require('stremio/common/TextInput');\nconst useTorrent = require('stremio/common/useTorrent');\nconst { withCoreSuspender } = require('stremio/common/CoreSuspender');\nconst styles = require('./styles');\n\nconst SearchBar = ({ className, query, active }) => {\n const { t } = useTranslation();\n const routeFocused = useRouteFocused();\n const { createTorrentFromMagnet } = useTorrent();\n const searchInputRef = React.useRef(null);\n const searchBarOnClick = React.useCallback(() => {\n if (!active) {\n window.location = '#/search';\n }\n }, [active]);\n const queryInputOnChange = React.useCallback(() => {\n try {\n createTorrentFromMagnet(searchInputRef.current.value);\n // eslint-disable-next-line no-empty\n } catch { }\n }, []);\n const queryInputOnSubmit = React.useCallback(() => {\n if (searchInputRef.current !== null) {\n const queryParams = new URLSearchParams([['search', searchInputRef.current.value]]);\n window.location = `#/search?${queryParams.toString()}`;\n }\n }, []);\n React.useEffect(() => {\n if (routeFocused && active) {\n searchInputRef.current.focus();\n }\n }, [routeFocused, active, query]);\n return (\n \n );\n};\n\nSearchBar.propTypes = {\n className: PropTypes.string,\n query: PropTypes.string,\n active: PropTypes.bool\n};\n\nconst SearchBarFallback = ({ className }) => {\n const { t } = useTranslation();\n return (\n \n );\n};\n\nSearchBarFallback.propTypes = SearchBar.propTypes;\n\nmodule.exports = withCoreSuspender(SearchBar, SearchBarFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SearchBar = require('./SearchBar');\n\nmodule.exports = SearchBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst HorizontalNavBar = require('./HorizontalNavBar');\n\nmodule.exports = HorizontalNavBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst Image = require('stremio/common/Image');\nconst styles = require('./styles');\n\nconst NavTabButton = ({ className, logo, icon, label, href, selected, onClick }) => {\n const renderLogoFallback = React.useCallback(() => (\n typeof icon === 'string' && icon.length > 0 ?\n \n :\n null\n ), [icon]);\n return (\n \n );\n};\n\nNavTabButton.propTypes = {\n className: PropTypes.string,\n logo: PropTypes.string,\n icon: PropTypes.string,\n label: PropTypes.string,\n href: PropTypes.string,\n selected: PropTypes.bool,\n onClick: PropTypes.func\n};\n\nmodule.exports = NavTabButton;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst NavTabButton = require('./NavTabButton');\n\nmodule.exports = NavTabButton;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst NavTabButton = require('./NavTabButton');\nconst styles = require('./styles');\n\nconst VerticalNavBar = React.memo(({ className, selected, tabs }) => {\n const { t } = useTranslation();\n return (\n \n );\n});\n\nVerticalNavBar.displayName = 'VerticalNavBar';\n\nVerticalNavBar.propTypes = {\n className: PropTypes.string,\n selected: PropTypes.string,\n tabs: PropTypes.arrayOf(PropTypes.shape({\n id: PropTypes.string,\n label: PropTypes.string,\n logo: PropTypes.string,\n icon: PropTypes.string,\n href: PropTypes.string,\n onClick: PropTypes.func\n }))\n};\n\nmodule.exports = VerticalNavBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst VerticalNavBar = require('./VerticalNavBar');\n\nmodule.exports = VerticalNavBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst HorizontalNavBar = require('./HorizontalNavBar');\nconst VerticalNavBar = require('./VerticalNavBar');\n\nmodule.exports = {\n HorizontalNavBar,\n VerticalNavBar\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst styles = require('./styles');\n\nconst PaginationInput = ({ className, label, dataset, onSelect, ...props }) => {\n const prevNextButtonOnClick = React.useCallback((event) => {\n if (typeof onSelect === 'function') {\n onSelect({\n type: 'change-page',\n value: event.currentTarget.dataset.value,\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onSelect]);\n return (\n
\n \n
\n
{label}
\n
\n \n
\n );\n};\n\nPaginationInput.propTypes = {\n className: PropTypes.string,\n label: PropTypes.string,\n dataset: PropTypes.object,\n onSelect: PropTypes.func\n};\n\nmodule.exports = PaginationInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst PaginationInput = require('./PaginationInput');\n\nmodule.exports = PaginationInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst styles = require('./styles');\n\nconst PlayIconCircleCentered = ({ className }) => {\n return (\n \n \n \n \n \n \n );\n};\n\nPlayIconCircleCentered.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = PlayIconCircleCentered;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst PlayIconCircleCentered = require('./PlayIconCircleCentered');\n\nmodule.exports = PlayIconCircleCentered;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst FocusLock = require('react-focus-lock').default;\nconst { useRouteFocused } = require('stremio-router');\nconst styles = require('./styles');\n\nconst getAnchorElement = (element) => {\n if (element === document.documentElement) {\n return element;\n }\n\n const style = window.getComputedStyle(element);\n if (style.overflowY.indexOf('auto') !== -1 || style.overflowY.indexOf('scroll') !== -1) {\n return element;\n }\n\n return getAnchorElement(element.parentElement);\n};\n\nconst Popup = ({ open, direction, renderLabel, renderMenu, dataset, onCloseRequest, ...props }) => {\n const routeFocused = useRouteFocused();\n const labelRef = React.useRef(null);\n const menuRef = React.useRef(null);\n const [autoDirection, setAutoDirection] = React.useState(null);\n const menuOnMouseDown = React.useCallback((event) => {\n event.nativeEvent.closePopupPrevented = true;\n }, []);\n React.useEffect(() => {\n const onCloseEvent = (event) => {\n if (!event.closePopupPrevented && typeof onCloseRequest === 'function') {\n const closeEvent = {\n type: 'close',\n nativeEvent: event,\n dataset: dataset\n };\n switch (event.type) {\n case 'keydown':\n if (event.code === 'Escape') {\n onCloseRequest(closeEvent);\n }\n break;\n case 'mousedown':\n if (event.target !== document.documentElement && !labelRef.current.contains(event.target)) {\n onCloseRequest(closeEvent);\n }\n break;\n }\n }\n };\n if (routeFocused && open) {\n window.addEventListener('keydown', onCloseEvent);\n window.addEventListener('mousedown', onCloseEvent);\n }\n return () => {\n window.removeEventListener('keydown', onCloseEvent);\n window.removeEventListener('mousedown', onCloseEvent);\n };\n }, [routeFocused, open, onCloseRequest, dataset]);\n React.useLayoutEffect(() => {\n if (open) {\n const autoDirection = [];\n const anchor = getAnchorElement(labelRef.current);\n const anchorRect = anchor.getBoundingClientRect();\n\n const labelRect = labelRef.current.getBoundingClientRect();\n const menuRect = menuRef.current.getBoundingClientRect();\n const labelPosition = {\n left: labelRect.left - anchorRect.left,\n top: labelRect.top - anchorRect.top,\n right: (anchorRect.width + anchorRect.left) - (labelRect.left + labelRect.width),\n bottom: (anchorRect.height + anchorRect.top) - (labelRect.top + labelRect.height)\n };\n\n if (menuRect.height <= labelPosition.bottom) {\n autoDirection.push('bottom');\n } else if (menuRect.height <= labelPosition.top) {\n autoDirection.push('top');\n } else if (labelPosition.bottom >= labelPosition.top) {\n autoDirection.push('bottom');\n } else {\n autoDirection.push('top');\n }\n\n if (menuRect.width <= (labelPosition.right + labelRect.width)) {\n autoDirection.push('right');\n } else if (menuRect.width <= (labelPosition.left + labelRect.width)) {\n autoDirection.push('left');\n } else if (labelPosition.right > labelPosition.left) {\n autoDirection.push('right');\n } else {\n autoDirection.push('left');\n }\n\n setAutoDirection(autoDirection.join('-'));\n } else {\n setAutoDirection(null);\n }\n }, [open]);\n return renderLabel({\n ...props,\n ref: labelRef,\n className: classnames(styles['label-container'], props.className, { 'active': open }),\n children: open ?\n \n {renderMenu()}\n \n :\n null\n });\n};\n\nPopup.propTypes = {\n open: PropTypes.bool,\n direction: PropTypes.oneOf(['top-left', 'bottom-left', 'top-right', 'bottom-right']),\n renderLabel: PropTypes.func.isRequired,\n renderMenu: PropTypes.func.isRequired,\n dataset: PropTypes.object,\n onCloseRequest: PropTypes.func\n};\n\nmodule.exports = Popup;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Popup = require('./Popup');\n\nmodule.exports = Popup;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst TextInput = require('stremio/common/TextInput');\nconst SearchBarPlaceholder = require('./SearchBarPlaceholder');\nconst styles = require('./styles');\n\nconst SearchBar = ({ className, title, value, onChange }) => {\n return (\n \n );\n};\n\nSearchBar.Placeholder = SearchBarPlaceholder;\n\nSearchBar.propTypes = {\n className: PropTypes.string,\n title: PropTypes.string,\n value: PropTypes.string,\n onChange: PropTypes.func\n};\n\nmodule.exports = SearchBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst styles = require('./styles');\n\nconst SearchBarPlaceholder = ({ className, title }) => {\n return (\n
\n
{title}
\n \n
\n );\n};\n\nSearchBarPlaceholder.propTypes = {\n className: PropTypes.string,\n title: PropTypes.string\n};\n\nmodule.exports = SearchBarPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SearchBarPlaceholder = require('./SearchBarPlaceholder');\n\nmodule.exports = SearchBarPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SearchBar = require('./SearchBar');\n\nmodule.exports = SearchBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { useRouteFocused } = require('stremio-router');\nconst { useServices } = require('stremio/services');\nconst Button = require('stremio/common/Button');\nconst TextInput = require('stremio/common/TextInput');\nconst styles = require('./styles');\n\nconst SharePrompt = ({ className, url }) => {\n const { t } = useTranslation();\n const { core } = useServices();\n const inputRef = React.useRef(null);\n const routeFocused = useRouteFocused();\n const selectInputContent = React.useCallback(() => {\n if (inputRef.current !== null) {\n inputRef.current.select();\n }\n }, []);\n const copyToClipboard = React.useCallback(() => {\n if (inputRef.current !== null) {\n inputRef.current.select();\n document.execCommand('copy');\n }\n }, []);\n React.useEffect(() => {\n if (routeFocused && inputRef.current !== null) {\n inputRef.current.select();\n }\n }, [routeFocused]);\n React.useEffect(() => {\n core.transport.analytics({\n event: 'Share',\n args: {\n url: url\n }\n });\n }, [url]);\n return (\n
\n
\n \n \n
\n
\n \n \n
\n
\n );\n};\n\nSharePrompt.propTypes = {\n className: PropTypes.string,\n url: PropTypes.string\n};\n\nmodule.exports = SharePrompt;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SharePrompt = require('./SharePrompt');\n\nmodule.exports = SharePrompt;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useRouteFocused } = require('stremio-router');\nconst useAnimationFrame = require('stremio/common/useAnimationFrame');\nconst useLiveRef = require('stremio/common/useLiveRef');\nconst styles = require('./styles');\n\nconst Slider = ({ className, value, minimumValue, maximumValue, disabled, onSlide, onComplete }) => {\n const minimumValueRef = useLiveRef(minimumValue !== null && !isNaN(minimumValue) ? minimumValue : 0);\n const maximumValueRef = useLiveRef(maximumValue !== null && !isNaN(maximumValue) ? maximumValue : 100);\n const valueRef = useLiveRef(value !== null && !isNaN(value) ? Math.min(maximumValueRef.current, Math.max(minimumValueRef.current, value)) : 0);\n const onSlideRef = useLiveRef(onSlide);\n const onCompleteRef = useLiveRef(onComplete);\n const sliderContainerRef = React.useRef(null);\n const routeFocused = useRouteFocused();\n const [requestThumbAnimation, cancelThumbAnimation] = useAnimationFrame();\n const calculateValueForMouseX = React.useCallback((mouseX) => {\n if (sliderContainerRef.current === null) {\n return 0;\n }\n\n const { x: sliderX, width: sliderWidth } = sliderContainerRef.current.getBoundingClientRect();\n const thumbStart = Math.min(Math.max(mouseX - sliderX, 0), sliderWidth);\n const value = (thumbStart / sliderWidth) * (maximumValueRef.current - minimumValueRef.current) + minimumValueRef.current;\n return value;\n }, []);\n const retainThumb = React.useCallback(() => {\n window.addEventListener('blur', onBlur);\n window.addEventListener('mouseup', onMouseUp);\n window.addEventListener('mousemove', onMouseMove);\n document.documentElement.className = classnames(document.documentElement.className, styles['active-slider-within']);\n }, []);\n const releaseThumb = React.useCallback(() => {\n cancelThumbAnimation();\n window.removeEventListener('blur', onBlur);\n window.removeEventListener('mouseup', onMouseUp);\n window.removeEventListener('mousemove', onMouseMove);\n const classList = document.documentElement.className.split(' ');\n const classIndex = classList.indexOf(styles['active-slider-within']);\n if (classIndex !== -1) {\n classList.splice(classIndex, 1);\n document.documentElement.className = classnames(classList);\n }\n }, []);\n const onBlur = React.useCallback(() => {\n if (typeof onSlideRef.current === 'function') {\n onSlideRef.current(valueRef.current);\n }\n\n if (typeof onCompleteRef.current === 'function') {\n onCompleteRef.current(valueRef.current);\n }\n\n releaseThumb();\n }, []);\n const onMouseUp = React.useCallback((event) => {\n const value = calculateValueForMouseX(event.clientX);\n if (typeof onCompleteRef.current === 'function') {\n onCompleteRef.current(value);\n }\n\n releaseThumb();\n }, []);\n const onMouseMove = React.useCallback((event) => {\n requestThumbAnimation(() => {\n const value = calculateValueForMouseX(event.clientX);\n if (typeof onSlideRef.current === 'function') {\n onSlideRef.current(value);\n }\n });\n }, []);\n const onMouseDown = React.useCallback((event) => {\n if (event.button !== 0) {\n return;\n }\n\n const value = calculateValueForMouseX(event.clientX);\n if (typeof onSlideRef.current === 'function') {\n onSlideRef.current(value);\n }\n\n retainThumb();\n }, []);\n React.useLayoutEffect(() => {\n if (!routeFocused || disabled) {\n releaseThumb();\n }\n }, [routeFocused, disabled]);\n React.useLayoutEffect(() => {\n return () => {\n releaseThumb();\n };\n }, []);\n const thumbPosition = Math.max(0, Math.min(1, (valueRef.current - minimumValueRef.current) / (maximumValueRef.current - minimumValueRef.current)));\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n \n \n \n
\n
\n );\n};\n\nSlider.propTypes = {\n className: PropTypes.string,\n value: PropTypes.number,\n minimumValue: PropTypes.number,\n maximumValue: PropTypes.number,\n disabled: PropTypes.bool,\n onSlide: PropTypes.func,\n onComplete: PropTypes.func\n};\n\nmodule.exports = Slider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Slider = require('./Slider');\n\nmodule.exports = Slider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Button = require('stremio/common/Button');\nconst useProfile = require('stremio/common/useProfile');\nconst { withCoreSuspender } = require('stremio/common/CoreSuspender');\nconst styles = require('./styles');\n\nconst StreamingServerWarning = ({ className }) => {\n const { t } = useTranslation();\n const { core } = useServices();\n const profile = useProfile();\n const onLaterClick = React.useCallback(() => {\n const streamingServerWarningDismissed = new Date();\n streamingServerWarningDismissed.setMonth(streamingServerWarningDismissed.getMonth() + 1);\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n streamingServerWarningDismissed\n }\n }\n });\n }, [profile.settings]);\n const onDismissClick = React.useCallback(() => {\n const streamingServerWarningDismissed = new Date();\n streamingServerWarningDismissed.setFullYear(streamingServerWarningDismissed.getFullYear() + 50);\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n streamingServerWarningDismissed\n }\n }\n });\n }, [profile.settings]);\n\n if (!isNaN(profile.settings.streamingServerWarningDismissed.getTime()) &&\n profile.settings.streamingServerWarningDismissed.getTime() > Date.now()) {\n return null;\n }\n\n return (\n
\n
{ t('SETTINGS_SERVER_UNAVAILABLE') }
\n \n \n
\n );\n};\n\nStreamingServerWarning.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = withCoreSuspender(StreamingServerWarning);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst StreamingServerWarning = require('./StreamingServerWarning');\n\nmodule.exports = StreamingServerWarning;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst styles = require('./styles');\n\nconst TextInput = React.forwardRef((props, ref) => {\n const onKeyDown = React.useCallback((event) => {\n if (typeof props.onKeyDown === 'function') {\n props.onKeyDown(event);\n }\n\n if (event.key === 'Enter' && !event.nativeEvent.submitPrevented && typeof props.onSubmit === 'function') {\n props.onSubmit(event);\n }\n }, [props.onKeyDown, props.onSubmit]);\n return (\n \n );\n});\n\nTextInput.displayName = 'TextInput';\n\nTextInput.propTypes = {\n className: PropTypes.string,\n disabled: PropTypes.bool,\n onKeyDown: PropTypes.func,\n onSubmit: PropTypes.func\n};\n\nmodule.exports = TextInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst TextInput = require('./TextInput');\n\nmodule.exports = TextInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst ToastContext = React.createContext({\n show: () => { },\n clear: () => { }\n});\n\nToastContext.displayName = 'ToastContext';\n\nmodule.exports = ToastContext;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst Button = require('stremio/common/Button');\nconst styles = require('./styles');\n\nconst ToastItem = ({ title, message, dataset, onSelect, onClose, ...props }) => {\n const type = React.useMemo(() => {\n return ['success', 'alert', 'error'].includes(props.type) ?\n props.type\n :\n 'success';\n }, [props.type]);\n const icon = React.useMemo(() => {\n return typeof props.icon === 'string' ? props.icon :\n type === 'success' ? 'ic_check' :\n type === 'error' ? 'ic_warning' :\n null;\n }, [type, props.icon]);\n const toastOnClick = React.useCallback((event) => {\n if (!event.nativeEvent.selectToastPrevented && typeof onSelect === 'function') {\n onSelect({\n type: 'select',\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n if (!event.nativeEvent.closeToastPrevented && typeof onClose === 'function') {\n onClose({\n type: 'close',\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onSelect, onClose]);\n const closeButtonOnClick = React.useCallback((event) => {\n event.nativeEvent.selectToastPrevented = true;\n if (typeof onClose === 'function') {\n onClose({\n type: 'close',\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onClose]);\n return (\n \n \n );\n};\n\nToastItem.propTypes = {\n type: PropTypes.oneOf(['success', 'alert', 'error']),\n title: PropTypes.string,\n message: PropTypes.string,\n icon: PropTypes.string,\n dataset: PropTypes.object,\n onSelect: PropTypes.func,\n onClose: PropTypes.func\n};\n\nmodule.exports = ToastItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ToastItem = require('./ToastItem');\n\nmodule.exports = ToastItem;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst ToastItem = require('./ToastItem');\nconst ToastContext = require('./ToastContext');\n\nconst DEFAULT_TIMEOUT = 3000;\n\nconst ToastProvider = ({ className, children }) => {\n const [container, setContainer] = React.useState(null);\n const [items, dispatch] = React.useReducer(\n (items, action) => {\n switch (action.type) {\n case 'add':\n return items.concat(action.item);\n case 'remove':\n return items.filter((item) => item.id !== action.id);\n case 'clear':\n return [];\n default:\n return items;\n }\n },\n []\n );\n const itemOnClose = React.useCallback((event) => {\n clearTimeout(event.dataset.id);\n dispatch({ type: 'remove', id: event.dataset.id });\n }, []);\n const toast = React.useMemo(() => {\n const filters = [];\n return {\n addFilter: (filter) => {\n filters.push(filter);\n },\n removeFilter: (filter) => {\n const index = filters.indexOf(filter);\n if (index > -1) {\n filters.splice(index, 1);\n }\n },\n show: (item) => {\n if (filters.some((filter) => filter(item))) {\n return;\n }\n\n const timeout = typeof item.timeout === 'number' && !isNaN(item.timeout) ?\n item.timeout\n :\n DEFAULT_TIMEOUT;\n const id = setTimeout(() => {\n dispatch({ type: 'remove', id });\n }, timeout);\n dispatch({\n type: 'add',\n item: {\n ...item,\n id,\n dataset: {\n ...item.dataset,\n id\n },\n onClose: itemOnClose\n }\n });\n },\n clear: () => {\n dispatch({ type: 'clear' });\n }\n };\n }, []);\n return (\n \n {container instanceof HTMLElement ? children : null}\n
\n {items.map((item, index) => (\n \n ))}\n
\n
\n );\n};\n\nToastProvider.propTypes = {\n className: PropTypes.string,\n children: PropTypes.node\n};\n\nmodule.exports = ToastProvider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ToastProvider = require('./ToastProvider');\nconst useToast = require('./useToast');\n\nmodule.exports = {\n ToastProvider,\n useToast\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ToastContext = require('./ToastContext');\n\nconst useToast = () => {\n return React.useContext(ToastContext);\n};\n\nmodule.exports = useToast;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst comparatorWithPriorities = (priorities) => {\n return (a, b) => {\n if (isNaN(priorities[a]) && isNaN(priorities[b])) {\n return a.localeCompare(b);\n } else if (isNaN(priorities[a])) {\n if (priorities[b] === Number.NEGATIVE_INFINITY) {\n return -1;\n } else {\n return 1;\n }\n } else if (isNaN(priorities[b])) {\n if (priorities[a] === Number.NEGATIVE_INFINITY) {\n return 1;\n } else {\n return -1;\n }\n } else {\n return priorities[b] - priorities[a];\n }\n };\n};\n\nmodule.exports = comparatorWithPriorities;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst isChildVisible = (container, element) => {\n const elementTop = element.offsetTop;\n const elementBottom = element.offsetTop + element.clientHeight;\n const containerTop = container.scrollTop;\n const containerBottom = container.scrollTop + container.clientHeight;\n return (elementTop >= containerTop && elementBottom <= containerBottom) ||\n (elementTop < containerTop && containerTop < elementBottom) ||\n (elementTop < containerBottom && containerBottom < elementBottom);\n};\n\nconst getVisibleChildrenRange = (container) => {\n return Array.from(container.children).reduce((result, child, index) => {\n if (isChildVisible(container, child)) {\n if (result === null) {\n result = {\n start: index,\n end: index\n };\n } else {\n result.end = index;\n }\n }\n\n return result;\n }, null);\n};\n\nmodule.exports = getVisibleChildrenRange;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst AddonDetailsModal = require('./AddonDetailsModal');\nconst Button = require('./Button');\nconst Checkbox = require('./Checkbox');\nconst ColorInput = require('./ColorInput');\nconst DelayedRenderer = require('./DelayedRenderer');\nconst Image = require('./Image');\nconst LibItem = require('./LibItem');\nconst MainNavBars = require('./MainNavBars');\nconst MetaItem = require('./MetaItem');\nconst MetaPreview = require('./MetaPreview');\nconst MetaRow = require('./MetaRow');\nconst ModalDialog = require('./ModalDialog');\nconst Multiselect = require('./Multiselect');\nconst { HorizontalNavBar, VerticalNavBar } = require('./NavBar');\nconst PaginationInput = require('./PaginationInput');\nconst PlayIconCircleCentered = require('./PlayIconCircleCentered');\nconst Popup = require('./Popup');\nconst SearchBar = require('./SearchBar');\nconst StreamingServerWarning = require('./StreamingServerWarning');\nconst SharePrompt = require('./SharePrompt');\nconst Slider = require('./Slider');\nconst TextInput = require('./TextInput');\nconst { ToastProvider, useToast } = require('./Toast');\nconst comparatorWithPriorities = require('./comparatorWithPriorities');\nconst CONSTANTS = require('./CONSTANTS');\nconst { withCoreSuspender, useCoreSuspender } = require('./CoreSuspender');\nconst getVisibleChildrenRange = require('./getVisibleChildrenRange');\nconst interfaceLanguages = require('./interfaceLanguages');\nconst languageNames = require('./languageNames');\nconst routesRegexp = require('./routesRegexp');\nconst translateOption = require('./translateOption');\nconst useAnimationFrame = require('./useAnimationFrame');\nconst useBinaryState = require('./useBinaryState');\nconst useFullscreen = require('./useFullscreen');\nconst useLiveRef = require('./useLiveRef');\nconst useModelState = require('./useModelState');\nconst useOnScrollToBottom = require('./useOnScrollToBottom');\nconst useProfile = require('./useProfile');\nconst useStreamingServer = require('./useStreamingServer');\nconst useTorrent = require('./useTorrent');\n\nmodule.exports = {\n AddonDetailsModal,\n Button,\n Checkbox,\n ColorInput,\n DelayedRenderer,\n Image,\n LibItem,\n MainNavBars,\n MetaItem,\n MetaPreview,\n MetaRow,\n ModalDialog,\n Multiselect,\n HorizontalNavBar,\n VerticalNavBar,\n PaginationInput,\n PlayIconCircleCentered,\n Popup,\n SearchBar,\n StreamingServerWarning,\n SharePrompt,\n Slider,\n TextInput,\n ToastProvider,\n useToast,\n comparatorWithPriorities,\n CONSTANTS,\n withCoreSuspender,\n useCoreSuspender,\n getVisibleChildrenRange,\n interfaceLanguages,\n languageNames,\n routesRegexp,\n translateOption,\n useAnimationFrame,\n useBinaryState,\n useFullscreen,\n useLiveRef,\n useModelState,\n useOnScrollToBottom,\n useProfile,\n useStreamingServer,\n useTorrent\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst routesRegexp = {\n intro: {\n regexp: /^\\/intro$/,\n urlParamsNames: []\n },\n board: {\n regexp: /^\\/?$/,\n urlParamsNames: []\n },\n discover: {\n regexp: /^\\/discover(?:\\/([^/]*)\\/([^/]*)\\/([^/]*))?$/,\n urlParamsNames: ['transportUrl', 'type', 'catalogId']\n },\n library: {\n regexp: /^\\/library(?:\\/([^/]*))?$/,\n urlParamsNames: ['type']\n },\n continuewatching: {\n regexp: /^\\/continuewatching(?:\\/([^/]*))?$/,\n urlParamsNames: ['type']\n },\n search: {\n regexp: /^\\/search$/,\n urlParamsNames: []\n },\n metadetails: {\n regexp: /^\\/(?:metadetails|detail)\\/([^/]*)\\/([^/]*)(?:\\/([^/]*))?$/,\n urlParamsNames: ['type', 'id', 'videoId']\n },\n addons: {\n regexp: /^\\/addons(?:\\/([^/]*)(?:\\/([^/]*)\\/([^/]*))?)?$/,\n urlParamsNames: ['type', 'transportUrl', 'catalogId']\n },\n settings: {\n regexp: /^\\/settings$/,\n urlParamsNames: []\n },\n player: {\n regexp: /^\\/player\\/([^/]*)(?:\\/([^/]*)\\/([^/]*)\\/([^/]*)\\/([^/]*)\\/([^/]*))?$/,\n urlParamsNames: ['stream', 'streamTransportUrl', 'metaTransportUrl', 'type', 'id', 'videoId']\n }\n};\n\nmodule.exports = routesRegexp;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst { t } = require('i18next');\n\nconst translateOption = (option, translateKeyPrefix = '') => {\n const translateKey = `${translateKeyPrefix}${option}`;\n const translateValue = t(translateKey, {\n defaultValue: t(translateKey.toUpperCase(), {\n defaultValue: null\n })\n });\n return translateValue ?? option.charAt(0).toUpperCase() + option.slice(1);\n};\n\nmodule.exports = translateOption;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useAnimationFrame = () => {\n const animationFrameId = React.useRef(null);\n const cancel = React.useCallback(() => {\n cancelAnimationFrame(animationFrameId.current);\n animationFrameId.current = null;\n }, []);\n const request = React.useCallback((cb) => {\n cancel();\n animationFrameId.current = requestAnimationFrame(() => {\n cb();\n animationFrameId.current = null;\n });\n }, []);\n return [request, cancel];\n};\n\nmodule.exports = useAnimationFrame;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useBinaryState = (initialValue) => {\n const [value, setValue] = React.useState(!!initialValue);\n const on = React.useCallback(() => {\n setValue(true);\n }, []);\n const off = React.useCallback(() => {\n setValue(false);\n }, []);\n const toggle = React.useCallback(() => {\n setValue(!value);\n }, [value]);\n return [value, on, off, toggle];\n};\n\nmodule.exports = useBinaryState;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useFullscreen = () => {\n const [fullscreen, setFullscreen] = React.useState(document.fullscreenElement === document.documentElement);\n const requestFullscreen = React.useCallback(() => {\n document.documentElement.requestFullscreen();\n }, []);\n const exitFullscreen = React.useCallback(() => {\n document.exitFullscreen();\n }, []);\n const toggleFullscreen = React.useCallback(() => {\n if (fullscreen) {\n exitFullscreen();\n } else {\n requestFullscreen();\n }\n }, [fullscreen]);\n React.useEffect(() => {\n const onFullscreenChange = () => {\n setFullscreen(document.fullscreenElement === document.documentElement);\n };\n document.addEventListener('fullscreenchange', onFullscreenChange);\n return () => {\n document.removeEventListener('fullscreenchange', onFullscreenChange);\n };\n }, []);\n return [fullscreen, requestFullscreen, exitFullscreen, toggleFullscreen];\n};\n\nmodule.exports = useFullscreen;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useLiveRef = (value) => {\n const ref = React.useRef();\n ref.current = value;\n return ref;\n};\n\nmodule.exports = useLiveRef;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst throttle = require('lodash.throttle');\nconst isEqual = require('lodash.isequal');\nconst intersection = require('lodash.intersection');\nconst { useCoreSuspender } = require('stremio/common/CoreSuspender');\nconst { useRouteFocused } = require('stremio-router');\nconst { useServices } = require('stremio/services');\n\nconst useModelState = ({ action, ...args }) => {\n const { core } = useServices();\n const routeFocused = useRouteFocused();\n const mountedRef = React.useRef(false);\n const [model, timeout, map, deps] = React.useMemo(() => {\n return [args.model, args.timeout, args.map, args.deps];\n }, []);\n const { getState } = useCoreSuspender();\n const [state, setState] = React.useReducer(\n (prevState, nextState) => {\n return Object.keys(prevState).reduce((result, key) => {\n result[key] = isEqual(prevState[key], nextState[key]) ? prevState[key] : nextState[key];\n return result;\n }, {});\n },\n undefined,\n () => {\n if (typeof map === 'function') {\n return map(getState(model));\n } else {\n return getState(model);\n }\n }\n );\n React.useInsertionEffect(() => {\n if (action) {\n core.transport.dispatch(action, model);\n }\n }, [action]);\n React.useInsertionEffect(() => {\n return () => {\n core.transport.dispatch({ action: 'Unload' }, model);\n };\n }, []);\n React.useInsertionEffect(() => {\n const onNewState = async (models) => {\n if (models.indexOf(model) === -1 && (!Array.isArray(deps) || intersection(deps, models).length === 0)) {\n return;\n }\n\n const state = await core.transport.getState(model);\n if (typeof map === 'function') {\n setState(map(state));\n } else {\n setState(state);\n }\n };\n const onNewStateThrottled = throttle(onNewState, timeout);\n if (routeFocused) {\n core.transport.on('NewState', onNewStateThrottled);\n if (mountedRef.current) {\n onNewState([model]);\n }\n }\n return () => {\n onNewStateThrottled.cancel();\n core.transport.off('NewState', onNewStateThrottled);\n };\n }, [routeFocused]);\n React.useInsertionEffect(() => {\n mountedRef.current = true;\n }, []);\n return state;\n};\n\nmodule.exports = useModelState;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useOnScrollToBottom = (cb, threshold = 0) => {\n const triggeredRef = React.useRef(false);\n const onScroll = React.useCallback((event) => {\n if (event.target.scrollTop + event.target.clientHeight >= event.target.scrollHeight - threshold) {\n if (!triggeredRef.current) {\n triggeredRef.current = true;\n if (typeof cb === 'function') {\n cb(event);\n }\n }\n } else {\n triggeredRef.current = false;\n }\n }, [cb]);\n return onScroll;\n};\n\nmodule.exports = useOnScrollToBottom;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst useModelState = require('stremio/common/useModelState');\n\nconst map = (ctx) => ({\n ...ctx.profile,\n settings: {\n ...ctx.profile.settings,\n streamingServerWarningDismissed: new Date(\n typeof ctx.profile.settings.streamingServerWarningDismissed === 'string' ?\n ctx.profile.settings.streamingServerWarningDismissed\n :\n NaN\n )\n }\n});\n\nconst useProfile = () => {\n return useModelState({ model: 'ctx', map });\n};\n\nmodule.exports = useProfile;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst useModelState = require('stremio/common/useModelState');\n\nconst useStreamingServer = () => {\n return useModelState({ model: 'streaming_server' });\n};\n\nmodule.exports = useStreamingServer;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst magnet = require('magnet-uri');\nconst { useServices } = require('stremio/services');\nconst useToast = require('stremio/common/Toast/useToast');\nconst useStreamingServer = require('stremio/common/useStreamingServer');\n\nconst useTorrent = () => {\n const { core } = useServices();\n const streamingServer = useStreamingServer();\n const toast = useToast();\n const createTorrentTimeout = React.useRef(null);\n const createTorrentFromMagnet = React.useCallback((text) => {\n const parsed = magnet.decode(text);\n if (parsed && typeof parsed.infoHash === 'string') {\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'CreateTorrent',\n args: text\n }\n });\n clearTimeout(createTorrentTimeout.current);\n createTorrentTimeout.current = setTimeout(() => {\n toast.show({\n type: 'error',\n title: 'It\\'s taking a long time to get metadata from the torrent.',\n timeout: 10000\n });\n }, 10000);\n }\n }, []);\n React.useEffect(() => {\n if (streamingServer.torrent !== null) {\n const [, { type }] = streamingServer.torrent;\n if (type === 'Ready') {\n clearTimeout(createTorrentTimeout.current);\n }\n }\n }, [streamingServer.torrent]);\n React.useEffect(() => {\n return () => clearTimeout(createTorrentTimeout.current);\n }, []);\n return {\n createTorrentFromMagnet\n };\n};\n\nmodule.exports = useTorrent;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ReactDOM = require('react-dom');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst FocusLock = require('react-focus-lock').default;\nconst { useModalsContainer } = require('../ModalsContainerContext');\n\nconst Modal = React.forwardRef(({ className, autoFocus, disabled, children, ...props }, ref) => {\n const modalsContainer = useModalsContainer();\n return ReactDOM.createPortal(\n \n {children}\n ,\n modalsContainer\n );\n});\n\nModal.displayName = 'Modal';\n\nModal.propTypes = {\n className: PropTypes.string,\n autoFocus: PropTypes.bool,\n disabled: PropTypes.bool,\n children: PropTypes.node\n};\n\nmodule.exports = Modal;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Modal = require('./Modal');\n\nmodule.exports = Modal;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst ModalsContainerContext = React.createContext(null);\n\nModalsContainerContext.displayName = 'ModalsContainerContext';\n\nmodule.exports = ModalsContainerContext;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst ModalsContainerContext = require('./ModalsContainerContext');\n\nconst ModalsContainerProvider = ({ children }) => {\n const [container, setContainer] = React.useState(null);\n return (\n \n {container instanceof HTMLElement ? children : null}\n
\n \n );\n};\n\nModalsContainerProvider.propTypes = {\n children: PropTypes.node\n};\n\nmodule.exports = ModalsContainerProvider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ModalsContainerProvider = require('./ModalsContainerProvider');\nconst useModalsContainer = require('./useModalsContainer');\n\nmodule.exports = {\n ModalsContainerProvider,\n useModalsContainer\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ModalsContainerContext = require('./ModalsContainerContext');\n\nconst useModalsContainer = () => {\n return React.useContext(ModalsContainerContext);\n};\n\nmodule.exports = useModalsContainer;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst { ModalsContainerProvider } = require('../ModalsContainerContext');\n\nconst Route = ({ children }) => {\n return (\n
\n \n
\n {children}\n
\n
\n
\n );\n};\n\nRoute.propTypes = {\n children: PropTypes.node\n};\n\nmodule.exports = Route;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Route = require('./Route');\n\nmodule.exports = Route;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst RouteFocusedContext = React.createContext(true);\n\nRouteFocusedContext.displayName = 'RouteFocusedContext';\n\nmodule.exports = RouteFocusedContext;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst RouteFocusedContext = require('./RouteFocusedContext');\nconst useRouteFocused = require('./useRouteFocused');\n\nmodule.exports = {\n RouteFocusedProvider: RouteFocusedContext.Provider,\n useRouteFocused\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst RouteFocusedContext = require('./RouteFocusedContext');\n\nconst useRouteFocused = () => {\n return React.useContext(RouteFocusedContext);\n};\n\nmodule.exports = useRouteFocused;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ReactIs = require('react-is');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst UrlUtils = require('url');\nconst isEqual = require('lodash.isequal');\nconst { RouteFocusedProvider } = require('../RouteFocusedContext');\nconst Route = require('../Route');\nconst routeConfigForPath = require('./routeConfigForPath');\nconst urlParamsForPath = require('./urlParamsForPath');\n\nconst Router = ({ className, onPathNotMatch, ...props }) => {\n const viewsConfig = React.useMemo(() => props.viewsConfig, []);\n const [views, setViews] = React.useState(() => {\n return Array(viewsConfig.length).fill(null);\n });\n React.useLayoutEffect(() => {\n const onLocationHashChange = () => {\n const { pathname, query } = UrlUtils.parse(window.location.hash.slice(1));\n const queryParams = new URLSearchParams(typeof query === 'string' ? query : '');\n const routeConfig = routeConfigForPath(viewsConfig, typeof pathname === 'string' ? pathname : '');\n if (routeConfig === null) {\n if (typeof onPathNotMatch === 'function') {\n const component = onPathNotMatch();\n if (ReactIs.isValidElementType(component)) {\n setViews((views) => {\n return views\n .slice(0, viewsConfig.length)\n .concat({\n key: '-1',\n component\n });\n });\n }\n }\n\n return;\n }\n\n const urlParams = urlParamsForPath(routeConfig, typeof pathname === 'string' ? pathname : '');\n const routeViewIndex = viewsConfig.findIndex((vc) => vc.includes(routeConfig));\n const routeIndex = viewsConfig[routeViewIndex].findIndex((rc) => rc === routeConfig);\n setViews((views) => {\n return views\n .slice(0, viewsConfig.length)\n .map((view, index) => {\n if (index < routeViewIndex) {\n return view;\n } else if (index === routeViewIndex) {\n return {\n key: `${routeViewIndex}${routeIndex}`,\n component: routeConfig.component,\n urlParams: view !== null && isEqual(view.urlParams, urlParams) ?\n view.urlParams\n :\n urlParams,\n queryParams: view !== null && isEqual(Array.from(view.queryParams.entries()), Array.from(queryParams.entries())) ?\n view.queryParams\n :\n queryParams\n };\n } else {\n return null;\n }\n });\n });\n };\n window.addEventListener('hashchange', onLocationHashChange);\n onLocationHashChange();\n return () => {\n window.removeEventListener('hashchange', onLocationHashChange);\n };\n }, [onPathNotMatch]);\n return (\n
\n {\n views\n .filter((view) => view !== null)\n .map(({ key, component, urlParams, queryParams }, index, views) => (\n \n \n {React.createElement(component, { urlParams, queryParams })}\n \n \n ))\n }\n
\n );\n};\n\nRouter.propTypes = {\n className: PropTypes.string,\n onPathNotMatch: PropTypes.func,\n viewsConfig: PropTypes.arrayOf(PropTypes.arrayOf(PropTypes.exact({\n regexp: PropTypes.instanceOf(RegExp).isRequired,\n urlParamsNames: PropTypes.arrayOf(PropTypes.string).isRequired,\n component: PropTypes.elementType.isRequired\n }))).isRequired\n};\n\nmodule.exports = Router;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Router = require('./Router');\n\nmodule.exports = Router;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst routeConfigForPath = (viewsConfig, path) => {\n for (const viewConfig of viewsConfig) {\n for (const routeConfig of viewConfig) {\n if (path.match(routeConfig.regexp)) {\n return routeConfig;\n }\n }\n }\n\n return null;\n};\n\nmodule.exports = routeConfigForPath;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst urlParamsForPath = (routeConfig, path) => {\n const matches = path.match(routeConfig.regexp);\n return routeConfig.urlParamsNames.reduce((urlParams, name, index) => {\n if (Array.isArray(matches) && typeof matches[index + 1] === 'string') {\n urlParams[name] = decodeURIComponent(matches[index + 1]);\n } else {\n urlParams[name] = null;\n }\n\n return urlParams;\n }, { path });\n};\n\nmodule.exports = urlParamsForPath;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst { useRouteFocused } = require('./RouteFocusedContext');\nconst { useModalsContainer } = require('./ModalsContainerContext');\nconst Modal = require('./Modal');\nconst Router = require('./Router');\n\nmodule.exports = {\n useRouteFocused,\n useModalsContainer,\n Modal,\n Router\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button, Image } = require('stremio/common');\nconst styles = require('./styles');\n\nconst Addon = ({ className, id, name, version, logo, description, types, behaviorHints, installed, onToggle, onConfigure, onShare, dataset }) => {\n const { t } = useTranslation();\n const toggleButtonOnClick = React.useCallback((event) => {\n if (typeof onToggle === 'function') {\n onToggle({\n type: 'toggle',\n nativeEvent: event.nativeEvent,\n reactEvent: event,\n dataset: dataset\n });\n }\n }, [onToggle, dataset]);\n const configureButtonOnClick = React.useCallback((event) => {\n if (typeof onConfigure === 'function') {\n onConfigure({\n type: 'configure',\n nativeEvent: event.nativeEvent,\n reactEvent: event,\n dataset: dataset\n });\n }\n }, [onConfigure, dataset]);\n const shareButtonOnClick = React.useCallback((event) => {\n if (typeof onShare === 'function') {\n onShare({\n type: 'share',\n nativeEvent: event.nativeEvent,\n reactEvent: event,\n dataset: dataset\n });\n }\n }, [onShare, dataset]);\n const onKeyDown = React.useCallback((event) => {\n if (event.key === 'Enter' && typeof onToggle === 'function') {\n onToggle({\n type: 'toggle',\n nativeEvent: event.nativeEvent,\n reactEvent: event,\n dataset: dataset\n });\n }\n }, [onToggle, dataset]);\n const renderLogoFallback = React.useCallback(() => (\n \n ), []);\n return (\n \n :\n null\n }\n \n
{installed ? t('ADDON_UNINSTALL') : behaviorHints.configurationRequired ? t('ADDON_CONFIGURE') : t('ADDON_INSTALL')}
\n \n
\n \n
\n \n );\n};\n\nAddon.propTypes = {\n className: PropTypes.string,\n id: PropTypes.string,\n name: PropTypes.string,\n version: PropTypes.string,\n logo: PropTypes.string,\n description: PropTypes.string,\n types: PropTypes.arrayOf(PropTypes.string),\n behaviorHints: PropTypes.shape({\n adult: PropTypes.bool,\n configurable: PropTypes.bool,\n configurationRequired: PropTypes.bool,\n p2p: PropTypes.bool,\n }),\n installed: PropTypes.bool,\n onToggle: PropTypes.func,\n onConfigure: PropTypes.func,\n onShare: PropTypes.func,\n dataset: PropTypes.object\n};\n\nmodule.exports = Addon;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Addon = require('./Addon');\n\nmodule.exports = Addon;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { AddonDetailsModal, Button, Image, Multiselect, MainNavBars, TextInput, SearchBar, SharePrompt, ModalDialog, useBinaryState, withCoreSuspender } = require('stremio/common');\nconst Addon = require('./Addon');\nconst useInstalledAddons = require('./useInstalledAddons');\nconst useRemoteAddons = require('./useRemoteAddons');\nconst useAddonDetailsTransportUrl = require('./useAddonDetailsTransportUrl');\nconst useSelectableInputs = require('./useSelectableInputs');\nconst styles = require('./styles');\n\nconst Addons = ({ urlParams, queryParams }) => {\n const { t } = useTranslation();\n const installedAddons = useInstalledAddons(urlParams);\n const remoteAddons = useRemoteAddons(urlParams);\n const [addonDetailsTransportUrl, setAddonDetailsTransportUrl] = useAddonDetailsTransportUrl(urlParams, queryParams);\n const selectInputs = useSelectableInputs(installedAddons, remoteAddons);\n const [filtersModalOpen, openFiltersModal, closeFiltersModal] = useBinaryState(false);\n const [addAddonModalOpen, openAddAddonModal, closeAddAddonModal] = useBinaryState(false);\n const addAddonUrlInputRef = React.useRef(null);\n const addAddonOnSubmit = React.useCallback(() => {\n if (addAddonUrlInputRef.current !== null) {\n setAddonDetailsTransportUrl(addAddonUrlInputRef.current.value);\n }\n }, [setAddonDetailsTransportUrl]);\n const addAddonModalButtons = React.useMemo(() => {\n return [\n {\n className: styles['cancel-button'],\n label: t('BUTTON_CANCEL'),\n props: {\n onClick: closeAddAddonModal\n }\n },\n {\n label: t('ADDON_ADD'),\n props: {\n onClick: addAddonOnSubmit\n }\n }\n ];\n }, [addAddonOnSubmit]);\n const [search, setSearch] = React.useState('');\n const searchInputOnChange = React.useCallback((event) => {\n setSearch(event.currentTarget.value);\n }, []);\n const [sharedAddon, setSharedAddon] = React.useState(null);\n const clearSharedAddon = React.useCallback(() => {\n setSharedAddon(null);\n }, []);\n const onAddonShare = React.useCallback((event) => {\n setSharedAddon(event.dataset.addon);\n }, []);\n const onAddonToggle = React.useCallback((event) => {\n setAddonDetailsTransportUrl(event.dataset.addon.transportUrl);\n }, [setAddonDetailsTransportUrl]);\n const onAddonConfigure = React.useCallback((event) => {\n window.open(event.dataset.addon.transportUrl.replace('manifest.json', 'configure'));\n }, []);\n const closeAddonDetails = React.useCallback(() => {\n setAddonDetailsTransportUrl(null);\n }, [setAddonDetailsTransportUrl]);\n const searchFilterPredicate = React.useCallback((addon) => {\n return search.length === 0 ||\n (\n (typeof addon.manifest.name === 'string' && addon.manifest.name.toLowerCase().includes(search.toLowerCase())) ||\n (typeof addon.manifest.description === 'string' && addon.manifest.description.toLowerCase().includes(search.toLowerCase()))\n );\n }, [search]);\n const renderLogoFallback = React.useCallback(() => (\n \n ), []);\n React.useLayoutEffect(() => {\n closeAddAddonModal();\n setSearch('');\n clearSharedAddon();\n }, [urlParams, queryParams]);\n return (\n \n
\n
\n \n {selectInputs.map((selectInput, index) => (\n \n ))}\n
\n \n \n
\n {\n installedAddons.selected !== null ?\n installedAddons.selectable.types.length === 0 ?\n
\n No addons ware installed!\n
\n :\n installedAddons.catalog.length === 0 ?\n
\n No addons ware installed for that type!\n
\n :\n
\n {\n installedAddons.catalog\n .filter(searchFilterPredicate)\n .map((addon, index) => (\n \n ))\n }\n
\n :\n remoteAddons.selected !== null ?\n remoteAddons.catalog.content.type === 'Err' ?\n
\n {remoteAddons.catalog.content.content}\n
\n :\n remoteAddons.catalog.content.type === 'Loading' ?\n
\n Loading!\n
\n :\n
\n {\n remoteAddons.catalog.content.content\n .filter(searchFilterPredicate)\n .map((addon, index) => (\n \n ))\n }\n
\n :\n
\n No select\n
\n }\n
\n {\n filtersModalOpen ?\n \n {selectInputs.map((selectInput, index) => (\n \n ))}\n \n :\n null\n }\n {\n addAddonModalOpen ?\n \n
{ t('ADD_ADDON_DESCRIPTION') }
\n \n \n :\n null\n }\n {\n sharedAddon !== null ?\n \n
\n \n
\n {typeof sharedAddon.manifest.name === 'string' && sharedAddon.manifest.name.length > 0 ? sharedAddon.manifest.name : sharedAddon.manifest.id}\n {\n typeof sharedAddon.manifest.version === 'string' && sharedAddon.manifest.version.length > 0 ?\n v. {sharedAddon.manifest.version}\n :\n null\n }\n
\n
\n \n \n :\n null\n }\n {\n typeof addonDetailsTransportUrl === 'string' ?\n \n :\n null\n }\n \n );\n};\n\nAddons.propTypes = {\n urlParams: PropTypes.shape({\n path: PropTypes.string,\n transportUrl: PropTypes.string,\n catalogId: PropTypes.string,\n type: PropTypes.string\n }),\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst AddonsFallback = () => (\n \n);\n\nmodule.exports = withCoreSuspender(Addons, AddonsFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Addons = require('./Addons');\n\nmodule.exports = Addons;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useAddonDetailsTransportUrl = (urlParams, queryParams) => {\n const transportUrl = React.useMemo(() => {\n return queryParams.get('addon');\n }, [queryParams]);\n const setTransportUrl = React.useCallback((transportUrl) => {\n const nextQueryParams = new URLSearchParams(queryParams);\n if (typeof transportUrl === 'string') {\n nextQueryParams.set('addon', transportUrl);\n } else {\n nextQueryParams.delete('addon');\n }\n\n window.location.replace(`#${urlParams.path}?${nextQueryParams}`);\n }, [urlParams, queryParams]);\n return [transportUrl, setTransportUrl];\n};\n\nmodule.exports = useAddonDetailsTransportUrl;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useModelState } = require('stremio/common');\n\nconst useInstalledAddons = (urlParams) => {\n const action = React.useMemo(() => {\n if (typeof urlParams.transportUrl !== 'string' && typeof urlParams.catalogId !== 'string') {\n return {\n action: 'Load',\n args: {\n model: 'InstalledAddonsWithFilters',\n args: {\n request: {\n type: typeof urlParams.type === 'string' ? urlParams.type : null\n }\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [urlParams]);\n return useModelState({ model: 'installed_addons', action });\n};\n\nmodule.exports = useInstalledAddons;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useModelState } = require('stremio/common');\n\nconst useRemoteAddons = (urlParams) => {\n const action = React.useMemo(() => {\n if (typeof urlParams.type === 'string' && typeof urlParams.transportUrl === 'string' && typeof urlParams.catalogId === 'string') {\n return {\n action: 'Load',\n args: {\n model: 'CatalogWithFilters',\n args: {\n request: {\n base: urlParams.transportUrl,\n path: {\n resource: 'addon_catalog',\n type: urlParams.type,\n id: urlParams.catalogId,\n extra: []\n }\n }\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [urlParams]);\n return useModelState({ model: 'remote_addons', action, deps: ['ctx'] });\n};\n\nmodule.exports = useRemoteAddons;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { t } = require('i18next');\nconst { translateOption } = require('stremio/common');\n\nconst mapSelectableInputs = (installedAddons, remoteAddons) => {\n const catalogSelect = {\n title: t('SELECT_CATALOG'),\n options: remoteAddons.selectable.catalogs\n .concat(installedAddons.selectable.catalogs)\n .map(({ name, deepLinks }) => ({\n value: deepLinks.addons,\n label: translateOption(name, 'ADDON_'),\n title: translateOption(name, 'ADDON_'),\n })),\n selected: remoteAddons.selectable.catalogs\n .concat(installedAddons.selectable.catalogs)\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.addons),\n renderLabelText: remoteAddons.selected !== null ?\n () => {\n const selectableCatalog = remoteAddons.selectable.catalogs\n .find(({ id }) => id === remoteAddons.selected.request.path.id);\n return selectableCatalog ? translateOption(selectableCatalog.name, 'ADDON_') : remoteAddons.selected.request.path.id;\n }\n :\n null,\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n const typeSelect = {\n title: t('SELECT_TYPE'),\n options: installedAddons.selected !== null ?\n installedAddons.selectable.types.map(({ type, deepLinks }) => ({\n value: deepLinks.addons,\n label: type !== null ? translateOption(type, 'TYPE_') : t('TYPE_ALL')\n }))\n :\n remoteAddons.selectable.types.map(({ type, deepLinks }) => ({\n value: deepLinks.addons,\n label: translateOption(type, 'TYPE_')\n })),\n selected: installedAddons.selected !== null ?\n installedAddons.selectable.types\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.addons)\n :\n remoteAddons.selectable.types\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.addons),\n renderLabelText: () => {\n return installedAddons.selected !== null ?\n installedAddons.selected.request.type === null ?\n t('TYPE_ALL')\n :\n translateOption(installedAddons.selected.request.type, 'TYPE_')\n :\n remoteAddons.selected !== null ?\n translateOption(remoteAddons.selected.request.path.type, 'TYPE_')\n :\n typeSelect.title;\n },\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n return [catalogSelect, typeSelect];\n};\n\nconst useSelectableInputs = (installedAddons, remoteAddons) => {\n const selectableInputs = React.useMemo(() => {\n return mapSelectableInputs(installedAddons, remoteAddons);\n }, [installedAddons, remoteAddons]);\n return selectableInputs;\n};\n\nmodule.exports = useSelectableInputs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst classnames = require('classnames');\nconst debounce = require('lodash.debounce');\nconst { useTranslation } = require('react-i18next');\nconst { MainNavBars, MetaRow, LibItem, MetaItem, StreamingServerWarning, useStreamingServer, withCoreSuspender, getVisibleChildrenRange } = require('stremio/common');\nconst useBoard = require('./useBoard');\nconst useContinueWatchingPreview = require('./useContinueWatchingPreview');\nconst styles = require('./styles');\n\nconst THRESHOLD = 5;\n\nconst Board = () => {\n const { t } = useTranslation();\n const streamingServer = useStreamingServer();\n const continueWatchingPreview = useContinueWatchingPreview();\n const [board, loadBoardRows] = useBoard();\n const boardCatalogsOffset = continueWatchingPreview.libraryItems.length > 0 ? 1 : 0;\n const scrollContainerRef = React.useRef();\n const onVisibleRangeChange = React.useCallback(() => {\n const range = getVisibleChildrenRange(scrollContainerRef.current);\n if (range === null) {\n return;\n }\n\n const start = Math.max(0, range.start - boardCatalogsOffset - THRESHOLD);\n const end = range.end - boardCatalogsOffset + THRESHOLD;\n if (end < start) {\n return;\n }\n\n loadBoardRows({ start, end });\n }, [boardCatalogsOffset]);\n const onScroll = React.useCallback(debounce(onVisibleRangeChange, 250), [onVisibleRangeChange]);\n React.useLayoutEffect(() => {\n onVisibleRangeChange();\n }, [board.catalogs, onVisibleRangeChange]);\n return (\n
\n \n
\n {\n continueWatchingPreview.libraryItems.length > 0 ?\n \n :\n null\n }\n {board.catalogs.map((catalog, index) => {\n switch (catalog.content?.type) {\n case 'Ready': {\n return (\n \n );\n }\n case 'Err': {\n return (\n \n );\n }\n default: {\n return (\n \n );\n }\n }\n })}\n
\n
\n {\n streamingServer.settings !== null && streamingServer.settings.type === 'Err' ?\n \n :\n null\n }\n
\n );\n};\n\nconst BoardFallback = () => (\n
\n \n
\n);\n\nmodule.exports = withCoreSuspender(Board, BoardFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Board = require('./Board');\n\nmodule.exports = Board;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst { useModelState } = require('stremio/common');\n\nconst useBoard = () => {\n const { core } = useServices();\n const action = React.useMemo(() => ({\n action: 'Load',\n args: {\n model: 'CatalogsWithExtra',\n args: { extra: [] }\n }\n }), []);\n const loadRange = React.useCallback((range) => {\n core.transport.dispatch({\n action: 'CatalogsWithExtra',\n args: {\n action: 'LoadRange',\n args: range\n }\n }, 'board');\n }, []);\n const board = useModelState({ model: 'board', timeout: 1500, action });\n return [board, loadRange];\n};\n\nmodule.exports = useBoard;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst { useModelState } = require('stremio/common');\n\nconst useContinueWatchingPreview = () => {\n return useModelState({ model: 'continue_watching_preview' });\n};\n\nmodule.exports = useContinueWatchingPreview;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { useServices } = require('stremio/services');\nconst { AddonDetailsModal, DelayedRenderer, Button, MainNavBars, MetaItem, Image, MetaPreview, Multiselect, ModalDialog, CONSTANTS, useBinaryState, useOnScrollToBottom, withCoreSuspender } = require('stremio/common');\nconst useDiscover = require('./useDiscover');\nconst useSelectableInputs = require('./useSelectableInputs');\nconst styles = require('./styles');\n\nconst SCROLL_TO_BOTTOM_TRESHOLD = 400;\n\nconst Discover = ({ urlParams, queryParams }) => {\n const { core } = useServices();\n const [discover, loadNextPage] = useDiscover(urlParams, queryParams);\n const [selectInputs, hasNextPage] = useSelectableInputs(discover);\n const [inputsModalOpen, openInputsModal, closeInputsModal] = useBinaryState(false);\n const [addonModalOpen, openAddonModal, closeAddonModal] = useBinaryState(false);\n const [selectedMetaItemIndex, setSelectedMetaItemIndex] = React.useState(0);\n const selectedMetaItem = React.useMemo(() => {\n return discover.catalog !== null &&\n discover.catalog.content.type === 'Ready' &&\n discover.catalog.content.content[selectedMetaItemIndex] ?\n discover.catalog.content.content[selectedMetaItemIndex]\n :\n null;\n }, [discover.catalog, selectedMetaItemIndex]);\n const addToLibrary = React.useCallback(() => {\n if (selectedMetaItem === null) {\n return;\n }\n\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'AddToLibrary',\n args: selectedMetaItem\n }\n });\n }, [selectedMetaItem]);\n const removeFromLibrary = React.useCallback(() => {\n if (selectedMetaItem === null) {\n return;\n }\n\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'RemoveFromLibrary',\n args: selectedMetaItem.id\n }\n });\n }, [selectedMetaItem]);\n const metaItemsOnFocusCapture = React.useCallback((event) => {\n if (event.target.dataset.index !== null && !isNaN(event.target.dataset.index)) {\n setSelectedMetaItemIndex(parseInt(event.target.dataset.index, 10));\n }\n }, []);\n const metaItemOnClick = React.useCallback((event) => {\n if (event.currentTarget.dataset.index !== selectedMetaItemIndex.toString()) {\n event.preventDefault();\n event.currentTarget.focus();\n }\n }, [selectedMetaItemIndex]);\n const onScrollToBottom = React.useCallback(() => {\n if (hasNextPage) {\n loadNextPage();\n }\n }, [hasNextPage, loadNextPage]);\n const onScroll = useOnScrollToBottom(onScrollToBottom, SCROLL_TO_BOTTOM_TRESHOLD);\n React.useEffect(() => {\n closeInputsModal();\n closeAddonModal();\n setSelectedMetaItemIndex(0);\n }, [discover.selected]);\n return (\n \n
\n
\n
\n {selectInputs.map(({ title, options, selected, renderLabelText, onSelect }, index) => (\n \n ))}\n \n
\n {\n discover.catalog !== null && !discover.catalog.installed ?\n
\n
Addon is not installed. Install now?
\n \n
\n :\n null\n }\n {\n discover.catalog === null ?\n \n
\n {'\n
No catalog selected!
\n
\n
\n :\n discover.catalog.content.type === 'Err' ?\n
\n {'\n
{discover.catalog.content.content}
\n
\n :\n discover.catalog.content.type === 'Loading' ?\n
\n {Array(CONSTANTS.CATALOG_PAGE_SIZE).fill(null).map((_, index) => (\n
\n
\n
\n
\n
\n
\n ))}\n
\n :\n
\n {discover.catalog.content.content.map((metaItem, index) => (\n \n ))}\n
\n }\n
\n {\n selectedMetaItem !== null ?\n \n :\n discover.catalog !== null && discover.catalog.content.type === 'Loading' ?\n
\n :\n null\n }\n
\n {\n inputsModalOpen ?\n \n {selectInputs.map(({ title, options, selected, renderLabelText, onSelect }, index) => (\n \n ))}\n \n :\n null\n }\n {\n addonModalOpen && discover.selected !== null ?\n \n :\n null\n }\n \n );\n};\n\nDiscover.propTypes = {\n urlParams: PropTypes.shape({\n transportUrl: PropTypes.string,\n type: PropTypes.string,\n catalogId: PropTypes.string\n }),\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst DiscoverFallback = () => (\n \n);\n\nmodule.exports = withCoreSuspender(Discover, DiscoverFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Discover = require('./Discover');\n\nmodule.exports = Discover;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst UrlUtils = require('url');\nconst { useServices } = require('stremio/services');\nconst { useModelState } = require('stremio/common');\n\nconst map = (discover) => ({\n ...discover,\n catalog: discover.catalog !== null && discover.catalog.content.type === 'Ready' ?\n {\n ...discover.catalog,\n content: {\n ...discover.catalog.content,\n content: discover.catalog.content.content.map((metaItem) => ({\n ...metaItem,\n released: new Date(typeof metaItem.released === 'string' ? metaItem.released : NaN),\n }))\n }\n }\n :\n discover.catalog\n});\n\nconst useDiscover = (urlParams, queryParams) => {\n const { core } = useServices();\n const loadNextPage = React.useCallback(() => {\n core.transport.dispatch({\n action: 'CatalogWithFilters',\n args: {\n action: 'LoadNextPage'\n }\n }, 'discover');\n }, []);\n const action = React.useMemo(() => {\n if (typeof urlParams.transportUrl === 'string' && typeof urlParams.type === 'string' && typeof urlParams.catalogId === 'string') {\n const { hostname } = UrlUtils.parse(urlParams.transportUrl);\n if (typeof hostname === 'string' && hostname.length > 0) {\n return {\n action: 'Load',\n args: {\n model: 'CatalogWithFilters',\n args: {\n request: {\n base: urlParams.transportUrl,\n path: {\n resource: 'catalog',\n type: urlParams.type,\n id: urlParams.catalogId,\n extra: Array.from(queryParams.entries())\n }\n }\n }\n }\n };\n }\n } else {\n return {\n action: 'Load',\n args: {\n model: 'CatalogWithFilters',\n args: null\n }\n };\n }\n\n return {\n action: 'Unload'\n };\n }, [urlParams, queryParams]);\n const discover = useModelState({ model: 'discover', action, map, deps: ['ctx'] });\n return [discover, loadNextPage];\n};\n\nmodule.exports = useDiscover;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useTranslation } = require('react-i18next');\nconst { translateOption } = require('stremio/common');\n\nconst mapSelectableInputs = (discover, t) => {\n const typeSelect = {\n title: t('SELECT_TYPE'),\n options: discover.selectable.types\n .map(({ type, deepLinks }) => ({\n value: deepLinks.discover,\n label: translateOption(type, 'TYPE_')\n })),\n selected: discover.selectable.types\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.discover),\n renderLabelText: discover.selected !== null ?\n () => translateOption(discover.selected.request.path.type, 'TYPE_')\n :\n null,\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n const catalogSelect = {\n title: t('SELECT_CATALOG'),\n options: discover.selectable.catalogs\n .map(({ name, addon, deepLinks }) => ({\n value: deepLinks.discover,\n label: name,\n title: `${name} (${addon.manifest.name})`\n })),\n selected: discover.selectable.catalogs\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.discover),\n renderLabelText: discover.selected !== null ?\n () => {\n const selectableCatalog = discover.selectable.catalogs\n .find(({ id }) => id === discover.selected.request.path.id);\n return selectableCatalog ? selectableCatalog.name : discover.selected.request.path.id;\n }\n :\n null,\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n const extraSelects = discover.selectable.extra.map(({ name, isRequired, options }) => ({\n title: translateOption(name, 'SELECT_'),\n isRequired: isRequired,\n options: options.map(({ value, deepLinks }) => ({\n label: typeof value === 'string' ? translateOption(value) : t('NONE'),\n value: JSON.stringify({\n href: deepLinks.discover,\n value\n })\n })),\n selected: options\n .filter(({ selected }) => selected)\n .map(({ value, deepLinks }) => JSON.stringify({\n href: deepLinks.discover,\n value\n })),\n renderLabelText: options.some(({ selected, value }) => selected && value === null) ?\n () => translateOption(name, 'SELECT_')\n :\n null,\n onSelect: (event) => {\n const { href } = JSON.parse(event.value);\n window.location = href;\n }\n }));\n return [[typeSelect, catalogSelect, ...extraSelects], discover.selectable.nextPage];\n};\n\nconst useSelectableInputs = (discover) => {\n const { t } = useTranslation();\n const selectableInputs = React.useMemo(() => {\n return mapSelectableInputs(discover, t);\n }, [discover.selected, discover.selectable]);\n return selectableInputs;\n};\n\nmodule.exports = useSelectableInputs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { Button, Checkbox } = require('stremio/common');\nconst styles = require('./styles');\n\nconst ConsentCheckbox = React.forwardRef(({ className, label, link, href, onToggle, ...props }, ref) => {\n const checkboxOnClick = React.useCallback((event) => {\n if (typeof props.onClick === 'function') {\n props.onClick(event);\n }\n\n if (!event.nativeEvent.togglePrevented && typeof onToggle === 'function') {\n onToggle({\n type: 'toggle',\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [onToggle, props.onClick]);\n const linkOnClick = React.useCallback((event) => {\n event.nativeEvent.togglePrevented = true;\n }, []);\n return (\n \n
\n {label}\n {' '}\n {\n typeof link === 'string' && link.length > 0 && typeof href === 'string' && href.length > 0 ?\n \n :\n null\n }\n
\n
\n );\n});\n\nConsentCheckbox.displayName = 'ConsentCheckbox';\n\nConsentCheckbox.propTypes = {\n className: PropTypes.string,\n checked: PropTypes.bool,\n label: PropTypes.string,\n link: PropTypes.string,\n href: PropTypes.string,\n onToggle: PropTypes.func,\n onClick: PropTypes.func\n};\n\nmodule.exports = ConsentCheckbox;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ConsentCheckbox = require('./ConsentCheckbox');\n\nmodule.exports = ConsentCheckbox;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst { TextInput } = require('stremio/common');\n\nconst CredentialsTextInput = React.forwardRef((props, ref) => {\n const onKeyDown = React.useCallback((event) => {\n if (typeof props.onKeyDown === 'function') {\n props.onKeyDown(event);\n }\n\n if (!event.nativeEvent.navigationPrevented) {\n if (['ArrowUp', 'ArrowDown', 'ArrowLeft', 'ArrowRight'].includes(event.key)) {\n event.nativeEvent.spatialNavigationPrevented = true;\n }\n\n if (!event.shiftKey) {\n if (event.key === 'ArrowDown') {\n window.navigate('down');\n } else if (event.key === 'ArrowUp') {\n window.navigate('up');\n }\n }\n }\n }, [props.onKeyDown]);\n return (\n \n );\n});\n\nCredentialsTextInput.displayName = 'CredentialsTextInput';\n\nCredentialsTextInput.propTypes = {\n onKeyDown: PropTypes.func\n};\n\nmodule.exports = CredentialsTextInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst CredentialsTextInput = require('./CredentialsTextInput');\n\nmodule.exports = CredentialsTextInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Modal, useRouteFocused } = require('stremio-router');\nconst { useServices } = require('stremio/services');\nconst { Button, Image, useBinaryState } = require('stremio/common');\nconst CredentialsTextInput = require('./CredentialsTextInput');\nconst ConsentCheckbox = require('./ConsentCheckbox');\nconst PasswordResetModal = require('./PasswordResetModal');\nconst useFacebookToken = require('./useFacebookToken');\nconst styles = require('./styles');\n\nconst SIGNUP_FORM = 'signup';\nconst LOGIN_FORM = 'login';\n\nconst Intro = ({ queryParams }) => {\n const { core } = useServices();\n const routeFocused = useRouteFocused();\n const getFacebookToken = useFacebookToken();\n const emailRef = React.useRef(null);\n const passwordRef = React.useRef(null);\n const confirmPasswordRef = React.useRef(null);\n const termsRef = React.useRef(null);\n const privacyPolicyRef = React.useRef(null);\n const marketingRef = React.useRef(null);\n const errorRef = React.useRef(null);\n const [passwordRestModalOpen, openPasswordRestModal, closePasswordResetModal] = useBinaryState(false);\n const [loaderModalOpen, openLoaderModal, closeLoaderModal] = useBinaryState(false);\n const [state, dispatch] = React.useReducer(\n (state, action) => {\n switch (action.type) {\n case 'set-form':\n if (state.form !== action.form) {\n return {\n form: action.form,\n email: '',\n password: '',\n confirmPassword: '',\n termsAccepted: false,\n privacyPolicyAccepted: false,\n marketingAccepted: false,\n error: ''\n };\n }\n return state;\n case 'change-credentials':\n return {\n ...state,\n error: '',\n [action.name]: action.value\n };\n case 'toggle-checkbox':\n return {\n ...state,\n error: '',\n [action.name]: !state[action.name]\n };\n case 'error':\n return {\n ...state,\n error: action.error\n };\n default:\n return state;\n }\n },\n {\n form: [LOGIN_FORM, SIGNUP_FORM].includes(queryParams.get('form')) ? queryParams.get('form') : SIGNUP_FORM,\n email: '',\n password: '',\n confirmPassword: '',\n termsAccepted: false,\n privacyPolicyAccepted: false,\n marketingAccepted: false,\n error: ''\n }\n );\n const loginWithFacebook = React.useCallback(() => {\n openLoaderModal();\n getFacebookToken()\n .then((accessToken) => {\n return fetch('https://www.strem.io/fb-login-with-token/' + encodeURIComponent(accessToken))\n .then((resp) => resp.json())\n .catch(() => {\n throw new Error('Login failed at getting token from Stremio');\n })\n .then(({ user } = {}) => {\n if (!user || typeof user.email !== 'string' || typeof user.fbLoginToken !== 'string') {\n throw new Error('Login failed at getting token from Stremio');\n }\n\n return {\n email: user.email,\n password: user.fbLoginToken\n };\n });\n })\n .then(({ email, password }) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Authenticate',\n args: {\n type: 'Login',\n email,\n password,\n facebook: true\n }\n }\n });\n })\n .catch((error) => {\n closeLoaderModal();\n dispatch({ type: 'error', error: error.message });\n });\n }, []);\n const loginWithEmail = React.useCallback(() => {\n if (typeof state.email !== 'string' || state.email.length === 0 || !emailRef.current.validity.valid) {\n dispatch({ type: 'error', error: 'Invalid email' });\n return;\n }\n if (typeof state.password !== 'string' || state.password.length === 0) {\n dispatch({ type: 'error', error: 'Invalid password' });\n return;\n }\n openLoaderModal();\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Authenticate',\n args: {\n type: 'Login',\n email: state.email,\n password: state.password\n }\n }\n });\n }, [state.email, state.password]);\n const loginAsGuest = React.useCallback(() => {\n if (!state.termsAccepted) {\n dispatch({ type: 'error', error: 'You must accept the Terms of Service' });\n return;\n }\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Logout'\n }\n });\n window.location = '#/';\n }, [state.termsAccepted]);\n const signup = React.useCallback(() => {\n if (typeof state.email !== 'string' || state.email.length === 0 || !emailRef.current.validity.valid) {\n dispatch({ type: 'error', error: 'Invalid email' });\n return;\n }\n if (typeof state.password !== 'string' || state.password.length === 0) {\n dispatch({ type: 'error', error: 'Invalid password' });\n return;\n }\n if (state.password !== state.confirmPassword) {\n dispatch({ type: 'error', error: 'Passwords do not match' });\n return;\n }\n if (!state.termsAccepted) {\n dispatch({ type: 'error', error: 'You must accept the Terms of Service' });\n return;\n }\n if (!state.privacyPolicyAccepted) {\n dispatch({ type: 'error', error: 'You must accept the Privacy Policy' });\n return;\n }\n openLoaderModal();\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Authenticate',\n args: {\n type: 'Register',\n email: state.email,\n password: state.password,\n gdpr_consent: {\n tos: state.termsAccepted,\n privacy: state.privacyPolicyAccepted,\n marketing: state.marketingAccepted,\n from: 'web'\n }\n }\n }\n });\n }, [state.email, state.password, state.confirmPassword, state.termsAccepted, state.privacyPolicyAccepted, state.marketingAccepted]);\n const emailOnChange = React.useCallback((event) => {\n dispatch({\n type: 'change-credentials',\n name: 'email',\n value: event.currentTarget.value\n });\n }, []);\n const emailOnSubmit = React.useCallback(() => {\n passwordRef.current.focus();\n }, []);\n const passwordOnChange = React.useCallback((event) => {\n dispatch({\n type: 'change-credentials',\n name: 'password',\n value: event.currentTarget.value\n });\n }, []);\n const passwordOnSubmit = React.useCallback(() => {\n if (state.form === SIGNUP_FORM) {\n confirmPasswordRef.current.focus();\n } else {\n loginWithEmail();\n }\n }, [state.form, loginWithEmail]);\n const confirmPasswordOnChange = React.useCallback((event) => {\n dispatch({\n type: 'change-credentials',\n name: 'confirmPassword',\n value: event.currentTarget.value\n });\n }, []);\n const confirmPasswordOnSubmit = React.useCallback(() => {\n termsRef.current.focus();\n }, []);\n const toggleTermsAccepted = React.useCallback(() => {\n dispatch({ type: 'toggle-checkbox', name: 'termsAccepted' });\n }, []);\n const togglePrivacyPolicyAccepted = React.useCallback(() => {\n dispatch({ type: 'toggle-checkbox', name: 'privacyPolicyAccepted' });\n }, []);\n const toggleMarketingAccepted = React.useCallback(() => {\n dispatch({ type: 'toggle-checkbox', name: 'marketingAccepted' });\n }, []);\n const switchFormOnClick = React.useCallback(() => {\n const queryParams = new URLSearchParams([['form', state.form === SIGNUP_FORM ? LOGIN_FORM : SIGNUP_FORM]]);\n window.location = `#/intro?${queryParams.toString()}`;\n }, [state.form]);\n React.useEffect(() => {\n if ([LOGIN_FORM, SIGNUP_FORM].includes(queryParams.get('form'))) {\n dispatch({ type: 'set-form', form: queryParams.get('form') });\n }\n }, [queryParams]);\n React.useEffect(() => {\n if (routeFocused && typeof state.error === 'string' && state.error.length > 0) {\n errorRef.current.scrollIntoView();\n }\n }, [state.error]);\n React.useEffect(() => {\n if (routeFocused) {\n emailRef.current.focus();\n }\n }, [state.form, routeFocused]);\n React.useEffect(() => {\n const onCoreEvent = ({ event, args }) => {\n switch (event) {\n case 'UserAuthenticated': {\n closeLoaderModal();\n if (routeFocused) {\n window.location = '#/';\n }\n break;\n }\n case 'Error': {\n if (args.source.event === 'UserAuthenticated') {\n closeLoaderModal();\n }\n\n break;\n }\n }\n };\n core.transport.on('CoreEvent', onCoreEvent);\n return () => {\n core.transport.off('CoreEvent', onCoreEvent);\n };\n }, [routeFocused]);\n return (\n
\n
\n
\n {'\n \n
\n \n {\n state.form === SIGNUP_FORM ?\n \n :\n null\n }\n \n \n {\n state.form === SIGNUP_FORM ?\n \n \n \n \n \n \n :\n
\n \n
\n }\n {\n state.error.length > 0 ?\n
{state.error}
\n :\n null\n }\n \n {\n state.form === SIGNUP_FORM ?\n \n :\n null\n }\n {\n state.form === LOGIN_FORM ?\n \n :\n null\n }\n
\n {\n passwordRestModalOpen ?\n \n :\n null\n }\n {\n loaderModalOpen ?\n \n
\n \n
Authenticating...
\n
\n
\n :\n null\n }\n
\n );\n};\n\nIntro.propTypes = {\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nmodule.exports = Intro;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst { useRouteFocused } = require('stremio-router');\nconst { ModalDialog } = require('stremio/common');\nconst CredentialsTextInput = require('../CredentialsTextInput');\nconst styles = require('./styles');\n\nconst PasswordResetModal = ({ email, onCloseRequest }) => {\n const routeFocused = useRouteFocused();\n const [error, setError] = React.useState('');\n const emailRef = React.useRef(null);\n const goToPasswordReset = React.useCallback(() => {\n emailRef.current.value.length > 0 && emailRef.current.validity.valid ?\n window.open('https://www.strem.io/reset-password/' + emailRef.current.value, '_blank')\n :\n setError('Invalid email');\n }, []);\n const passwordResetModalButtons = React.useMemo(() => {\n return [\n {\n className: styles['cancel-button'],\n label: 'Cancel',\n props: {\n onClick: onCloseRequest\n }\n },\n {\n label: 'Send',\n props: {\n onClick: goToPasswordReset\n }\n }\n ];\n }, [onCloseRequest]);\n const emailOnChange = React.useCallback(() => {\n setError('');\n }, []);\n React.useEffect(() => {\n if (routeFocused) {\n emailRef.current.focus();\n }\n }, [routeFocused]);\n return (\n \n \n {\n error.length > 0 ?\n
{error}
\n :\n null\n }\n
\n );\n};\n\nPasswordResetModal.propTypes = {\n email: PropTypes.string,\n onCloseRequest: PropTypes.func\n};\n\nmodule.exports = PasswordResetModal;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst PasswordResetModal = require('./PasswordResetModal');\n\nmodule.exports = PasswordResetModal;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Intro = require('./Intro');\n\nmodule.exports = Intro;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useFacebookToken = () => {\n const getToken = React.useCallback(() => {\n return new Promise((resolve, reject) => {\n if (typeof FB === 'undefined') {\n reject(new Error('Failed to connect to Facebook'));\n return;\n }\n\n FB.getLoginStatus((resp) => {\n if (resp && resp.authResponse && typeof resp.authResponse.accessToken === 'string') {\n resolve(resp.authResponse.accessToken);\n return;\n }\n\n FB.login((resp) => {\n if (!resp || !resp.authResponse || typeof resp.authResponse.accessToken !== 'string') {\n reject(new Error('Failed to get token from Facebook'));\n return;\n }\n\n resolve(resp.authResponse.accessToken);\n });\n });\n });\n }, []);\n React.useEffect(() => {\n window.fbAsyncInit = function() {\n FB.init({\n appId: '1537119779906825',\n status: true,\n xfbml: false,\n version: 'v2.7'\n });\n };\n const sdkScriptElement = document.createElement('script');\n sdkScriptElement.src = 'https://connect.facebook.net/en_US/sdk.js';\n sdkScriptElement.async = true;\n sdkScriptElement.defer = true;\n document.body.appendChild(sdkScriptElement);\n return () => {\n document.body.removeChild(sdkScriptElement);\n };\n }, []);\n return getToken;\n};\n\nmodule.exports = useFacebookToken;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst NotFound = require('stremio/routes/NotFound');\nconst { Button, DelayedRenderer, Multiselect, MainNavBars, LibItem, Image, ModalDialog, PaginationInput, useProfile, routesRegexp, useBinaryState, withCoreSuspender } = require('stremio/common');\nconst useLibrary = require('./useLibrary');\nconst useSelectableInputs = require('./useSelectableInputs');\nconst styles = require('./styles');\n\nfunction withModel(Library) {\n const withModel = ({ urlParams, queryParams }) => {\n const model = React.useMemo(() => {\n return typeof urlParams.path === 'string' ?\n urlParams.path.match(routesRegexp.library.regexp) ?\n 'library'\n :\n urlParams.path.match(routesRegexp.continuewatching.regexp) ?\n 'continue_watching'\n :\n null\n :\n null;\n }, [urlParams.path]);\n if (model === null) {\n return (\n \n );\n }\n\n return (\n \n );\n };\n withModel.displayName = 'withModel';\n return withModel;\n}\n\nconst Library = ({ model, urlParams, queryParams }) => {\n const profile = useProfile();\n const library = useLibrary(model, urlParams, queryParams);\n const [typeSelect, sortSelect, paginationInput] = useSelectableInputs(library);\n const [inputsModalOpen, openInputsModal, closeInputsModal] = useBinaryState(false);\n return (\n \n
\n {\n model === 'continue_watching' || profile.auth !== null ?\n
\n \n \n
\n {\n paginationInput !== null ?\n \n :\n \n }\n \n
\n :\n null\n }\n {\n model === 'library' && profile.auth === null ?\n
\n \n \n
Library is only available for logged in users!
\n
\n :\n library.selected === null ?\n \n
\n \n
{model === 'library' ? 'Library' : 'Continue Watching'} not loaded!
\n
\n
\n :\n library.catalog.length === 0 ?\n
\n \n
Empty {model === 'library' ? 'Library' : 'Continue Watching'}
\n
\n :\n
\n {library.catalog.map((libItem, index) => (\n \n ))}\n
\n }\n
\n {\n inputsModalOpen ?\n \n \n \n \n :\n null\n }\n \n );\n};\n\nLibrary.propTypes = {\n model: PropTypes.oneOf(['library', 'continue_watching']),\n urlParams: PropTypes.shape({\n type: PropTypes.string\n }),\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst LibraryFallback = ({ model }) => (\n \n);\n\nLibraryFallback.propTypes = Library.propTypes;\n\nmodule.exports = withModel(withCoreSuspender(Library, LibraryFallback));\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Library = require('./Library');\n\nmodule.exports = Library;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useModelState } = require('stremio/common');\n\nconst useLibrary = (model, urlParams, queryParams) => {\n const action = React.useMemo(() => ({\n action: 'Load',\n args: {\n model: 'LibraryWithFilters',\n args: {\n request: {\n type: typeof urlParams.type === 'string' ? urlParams.type : null,\n sort: queryParams.has('sort') ? queryParams.get('sort') : undefined,\n page: queryParams.has('page') ? parseInt(queryParams.get('page'), 10) : undefined\n }\n }\n }\n }), [urlParams, queryParams]);\n return useModelState({ model, action });\n};\n\nmodule.exports = useLibrary;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useTranslation } = require('react-i18next');\nconst { translateOption } = require('stremio/common');\n\nconst mapSelectableInputs = (library, t) => {\n const typeSelect = {\n title: t('SELECT_TYPE'),\n options: library.selectable.types\n .map(({ type, deepLinks }) => ({\n value: deepLinks.library,\n label: type === null ? t('TYPE_ALL') : translateOption(type, 'TYPE_')\n })),\n selected: library.selectable.types\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.library),\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n const sortSelect = {\n title: t('SELECT_SORT'),\n options: library.selectable.sorts\n .map(({ sort, deepLinks }) => ({\n value: deepLinks.library,\n label: translateOption(sort, 'SORT_')\n })),\n selected: library.selectable.sorts\n .filter(({ selected }) => selected)\n .map(({ deepLinks }) => deepLinks.library),\n onSelect: (event) => {\n window.location = event.value;\n }\n };\n const paginationInput = library.selectable.prevPage || library.selectable.nextPage ?\n {\n label: library.selected.request.page.toString(),\n onSelect: (event) => {\n if (event.value === 'prev' && library.selectable.prevPage) {\n window.location = library.selectable.prevPage.deepLinks.library;\n }\n if (event.value === 'next' && library.selectable.nextPage) {\n window.location = library.selectable.nextPage.deepLinks.library;\n }\n }\n }\n :\n null;\n return [typeSelect, sortSelect, paginationInput];\n};\n\nconst useSelectableInputs = (library) => {\n const { t } = useTranslation();\n const selectableInputs = React.useMemo(() => {\n return mapSelectableInputs(library, t);\n }, [library]);\n return selectableInputs;\n};\n\nmodule.exports = useSelectableInputs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useServices } = require('stremio/services');\nconst { VerticalNavBar, HorizontalNavBar, MetaPreview, ModalDialog, Image, DelayedRenderer, withCoreSuspender } = require('stremio/common');\nconst StreamsList = require('./StreamsList');\nconst VideosList = require('./VideosList');\nconst useMetaDetails = require('./useMetaDetails');\nconst useSeason = require('./useSeason');\nconst useMetaExtensionTabs = require('./useMetaExtensionTabs');\nconst styles = require('./styles');\n\nconst MetaDetails = ({ urlParams, queryParams }) => {\n const { core } = useServices();\n const metaDetails = useMetaDetails(urlParams);\n const [season, setSeason] = useSeason(urlParams, queryParams);\n const [tabs, metaExtension, clearMetaExtension] = useMetaExtensionTabs(metaDetails.metaExtensions);\n const [metaPath, streamPath] = React.useMemo(() => {\n return metaDetails.selected !== null ?\n [metaDetails.selected.metaPath, metaDetails.selected.streamPath]\n :\n [null, null];\n }, [metaDetails.selected]);\n const video = React.useMemo(() => {\n return streamPath !== null && metaDetails.metaItem !== null && metaDetails.metaItem.content.type === 'Ready' ?\n metaDetails.metaItem.content.content.videos.reduce((result, video) => {\n if (video.id === streamPath.id) {\n return video;\n }\n\n return result;\n }, null)\n :\n null;\n }, [metaDetails.metaItem, streamPath]);\n const addToLibrary = React.useCallback(() => {\n if (metaDetails.metaItem === null || metaDetails.metaItem.content.type !== 'Ready') {\n return;\n }\n\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'AddToLibrary',\n args: metaDetails.metaItem.content.content\n }\n });\n }, [metaDetails]);\n const removeFromLibrary = React.useCallback(() => {\n if (metaDetails.metaItem === null || metaDetails.metaItem.content.type !== 'Ready') {\n return;\n }\n\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'RemoveFromLibrary',\n args: metaDetails.metaItem.content.content.id\n }\n });\n }, [metaDetails]);\n const seasonOnSelect = React.useCallback((event) => {\n setSeason(event.value);\n }, [setSeason]);\n const renderBackgroundImageFallback = React.useCallback(() => null, []);\n return (\n
\n \n
\n {\n tabs.length > 0 ?\n \n :\n null\n }\n {\n metaPath === null ?\n \n
\n {'\n
No meta was selected!
\n
\n
\n :\n metaDetails.metaItem === null ?\n
\n {'\n
No addons ware requested for this meta!
\n
\n :\n metaDetails.metaItem.content.type === 'Err' ?\n
\n {'\n
No metadata was found!
\n
\n :\n metaDetails.metaItem.content.type === 'Loading' ?\n \n :\n \n {\n typeof metaDetails.metaItem.content.content.background === 'string' &&\n metaDetails.metaItem.content.content.background.length > 0 ?\n
\n \n
\n :\n null\n }\n 0 ?\n video.overview\n :\n metaDetails.metaItem.content.content.description\n }\n links={metaDetails.metaItem.content.content.links}\n trailerStreams={metaDetails.metaItem.content.content.trailerStreams}\n inLibrary={metaDetails.metaItem.content.content.inLibrary}\n toggleInLibrary={metaDetails.metaItem.content.content.inLibrary ? removeFromLibrary : addToLibrary}\n />\n
\n }\n
\n {\n streamPath !== null ?\n \n :\n metaPath !== null ?\n \n :\n null\n }\n
\n {\n metaExtension !== null ?\n \n \n \n :\n null\n }\n
\n );\n};\n\nMetaDetails.propTypes = {\n urlParams: PropTypes.shape({\n type: PropTypes.string,\n id: PropTypes.string,\n videoId: PropTypes.string\n }),\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst MetaDetailsFallback = () => (\n
\n \n
\n);\n\nmodule.exports = withCoreSuspender(MetaDetails, MetaDetailsFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button, Image, PlayIconCircleCentered } = require('stremio/common');\nconst StreamPlaceholder = require('./StreamPlaceholder');\nconst styles = require('./styles');\n\nconst Stream = ({ className, addonName, name, description, thumbnail, progress, deepLinks, ...props }) => {\n const href = React.useMemo(() => {\n return deepLinks ?\n typeof deepLinks.player === 'string' ?\n deepLinks.player\n :\n null\n :\n null;\n }, [deepLinks]);\n const renderThumbnailFallback = React.useCallback(() => (\n \n ), []);\n return (\n \n );\n};\n\nStream.Placeholder = StreamPlaceholder;\n\nStream.propTypes = {\n className: PropTypes.string,\n addonName: PropTypes.string,\n name: PropTypes.string,\n description: PropTypes.string,\n thumbnail: PropTypes.string,\n progress: PropTypes.number,\n deepLinks: PropTypes.shape({\n player: PropTypes.string\n })\n};\n\nmodule.exports = Stream;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst PlayIconCircleCentered = require('stremio/common/PlayIconCircleCentered');\nconst styles = require('./styles');\n\nconst StreamPlaceholder = ({ className }) => {\n return (\n
\n
\n
\n
\n
\n
\n
\n
\n \n
\n );\n};\n\nStreamPlaceholder.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = StreamPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst StreamPlaceholder = require('./StreamPlaceholder');\n\nmodule.exports = StreamPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Stream = require('./Stream');\n\nmodule.exports = Stream;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button, Image, Multiselect } = require('stremio/common');\nconst { useServices } = require('stremio/services');\nconst Stream = require('./Stream');\nconst styles = require('./styles');\n\nconst ALL_ADDONS_KEY = 'ALL';\n\nconst StreamsList = ({ className, ...props }) => {\n const { t } = useTranslation();\n const { core } = useServices();\n const [selectedAddon, setSelectedAddon] = React.useState(ALL_ADDONS_KEY);\n const onAddonSelected = React.useCallback((event) => {\n setSelectedAddon(event.value);\n }, []);\n const streamsByAddon = React.useMemo(() => {\n return props.streams\n .filter((streams) => streams.content.type === 'Ready')\n .reduce((streamsByAddon, streams) => {\n streamsByAddon[streams.addon.transportUrl] = {\n addon: streams.addon,\n streams: streams.content.content.map((stream) => ({\n ...stream,\n onClick: () => {\n core.transport.analytics({\n event: 'StreamClicked',\n args: {\n stream\n }\n });\n },\n addonName: streams.addon.manifest.name\n }))\n };\n\n return streamsByAddon;\n }, {});\n }, [props.streams]);\n const filteredStreams = React.useMemo(() => {\n return selectedAddon === ALL_ADDONS_KEY ?\n Object.values(streamsByAddon).map(({ streams }) => streams).flat(1)\n :\n streamsByAddon[selectedAddon] ?\n streamsByAddon[selectedAddon].streams\n :\n [];\n }, [streamsByAddon, selectedAddon]);\n const selectableOptions = React.useMemo(() => {\n return {\n title: 'Select Addon',\n options: [\n {\n value: ALL_ADDONS_KEY,\n label: t('ALL_ADDONS'),\n title: t('ALL_ADDONS')\n },\n ...Object.keys(streamsByAddon).map((transportUrl) => ({\n value: transportUrl,\n label: streamsByAddon[transportUrl].addon.manifest.name,\n title: streamsByAddon[transportUrl].addon.manifest.name,\n }))\n ],\n selected: [selectedAddon],\n onSelect: onAddonSelected\n };\n }, [streamsByAddon, selectedAddon]);\n return (\n
\n {\n props.streams.length === 0 ?\n
\n {'\n
No addons were requested for streams!
\n
\n :\n props.streams.every((streams) => streams.content.type === 'Err') ?\n
\n {'\n
{t('NO_STREAM')}
\n
\n :\n filteredStreams.length === 0 ?\n
\n \n \n
\n :\n \n {\n Object.keys(streamsByAddon).length > 1 ?\n \n :\n null\n }\n
\n {filteredStreams.map((stream, index) => (\n \n ))}\n
\n
\n }\n \n
\n );\n};\n\nStreamsList.propTypes = {\n className: PropTypes.string,\n streams: PropTypes.arrayOf(PropTypes.object).isRequired\n};\n\nmodule.exports = StreamsList;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst StreamsList = require('./StreamsList');\n\nmodule.exports = StreamsList;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { t } = require('i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button, Multiselect } = require('stremio/common');\nconst SeasonsBarPlaceholder = require('./SeasonsBarPlaceholder');\nconst styles = require('./styles');\n\nconst SeasonsBar = ({ className, seasons, season, onSelect }) => {\n const options = React.useMemo(() => {\n return seasons.map((season) => ({\n value: String(season),\n label: season > 0 ? `${t('SEASON')} ${season}` : t('SPECIAL')\n }));\n }, [seasons]);\n const selected = React.useMemo(() => {\n return [String(season)];\n }, [season]);\n const prevNextButtonOnClick = React.useCallback((event) => {\n if (typeof onSelect === 'function') {\n const seasonIndex = seasons.indexOf(season);\n const valueIndex = event.currentTarget.dataset.action === 'next' ?\n seasonIndex + 1 < seasons.length ? seasonIndex + 1 : seasons.length - 1\n :\n seasonIndex - 1 >= 0 ? seasonIndex - 1 : 0;\n const value = seasons[valueIndex];\n onSelect({\n type: 'select',\n value: value,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [season, seasons, onSelect]);\n const seasonOnSelect = React.useCallback((event) => {\n const value = parseFloat(event.value);\n if (typeof onSelect === 'function') {\n onSelect({\n type: 'select',\n value: value,\n reactEvent: event.reactEvent,\n nativeEvent: event.nativeEvent\n });\n }\n }, [onSelect]);\n return (\n
\n \n 0 ? `${t('SEASON')} ${season}` : t('SPECIAL')}\n direction={'bottom-left'}\n options={options}\n selected={selected}\n onSelect={seasonOnSelect}\n />\n \n
\n );\n};\n\nSeasonsBar.Placeholder = SeasonsBarPlaceholder;\n\nSeasonsBar.propTypes = {\n className: PropTypes.string,\n seasons: PropTypes.arrayOf(PropTypes.number).isRequired,\n season: PropTypes.number.isRequired,\n onSelect: PropTypes.func\n};\n\nmodule.exports = SeasonsBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst styles = require('./styles');\n\nconst SeasonsBarPlaceholder = ({ className }) => {\n return (\n
\n
\n \n
Prev
\n
\n
\n
Season 1
\n \n
\n
\n
Next
\n \n
\n
\n );\n};\n\nSeasonsBarPlaceholder.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = SeasonsBarPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SeasonsBarPlaceholder = require('./SeasonsBarPlaceholder');\n\nmodule.exports = SeasonsBarPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SeasonsBar = require('./SeasonsBar');\n\nmodule.exports = SeasonsBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useServices } = require('stremio/services');\nconst { useRouteFocused } = require('stremio-router');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button, Image, Popup, useBinaryState } = require('stremio/common');\nconst VideoPlaceholder = require('./VideoPlaceholder');\nconst styles = require('./styles');\n\nconst Video = ({ className, id, title, thumbnail, episode, released, upcoming, watched, progress, scheduled, deepLinks, ...props }) => {\n const { core } = useServices();\n const routeFocused = useRouteFocused();\n const [menuOpen, , closeMenu, toggleMenu] = useBinaryState(false);\n const popupLabelOnClick = React.useCallback((event) => {\n if (!event.nativeEvent.togglePopupPrevented && event.nativeEvent.ctrlKey) {\n event.preventDefault();\n toggleMenu();\n }\n }, []);\n const popupLabelOnKeyDown = React.useCallback((event) => {\n event.nativeEvent.buttonClickPrevented = true;\n }, []);\n const popupLabelOnContextMenu = React.useCallback((event) => {\n if (!event.nativeEvent.togglePopupPrevented && !event.nativeEvent.ctrlKey) {\n event.preventDefault();\n toggleMenu();\n }\n }, [toggleMenu]);\n const popupMenuOnContextMenu = React.useCallback((event) => {\n event.nativeEvent.togglePopupPrevented = true;\n }, []);\n const popupMenuOnClick = React.useCallback((event) => {\n event.nativeEvent.togglePopupPrevented = true;\n }, []);\n const toggleWatchedOnClick = React.useCallback((event) => {\n event.preventDefault();\n closeMenu();\n core.transport.dispatch({\n action: 'MetaDetails',\n args: {\n action: 'MarkVideoAsWatched',\n args: [id, !watched]\n }\n });\n }, [id, watched]);\n const href = React.useMemo(() => {\n return deepLinks ?\n typeof deepLinks.player === 'string' ?\n deepLinks.player\n :\n typeof deepLinks.metaDetailsStreams === 'string' ?\n deepLinks.metaDetailsStreams\n :\n null\n :\n null;\n }, [deepLinks]);\n const renderLabel = React.useMemo(() => function renderLabel({ className, id, title, thumbnail, episode, released, upcoming, watched, progress, scheduled, children, ...props }) {\n return (\n \n );\n }, []);\n const renderMenu = React.useMemo(() => function renderMenu() {\n return (\n
\n \n \n
\n );\n }, [watched, toggleWatchedOnClick]);\n React.useEffect(() => {\n if (!routeFocused) {\n closeMenu();\n }\n }, [routeFocused]);\n return (\n \n );\n};\n\nVideo.Placeholder = VideoPlaceholder;\n\nVideo.propTypes = {\n className: PropTypes.string,\n id: PropTypes.string,\n title: PropTypes.string,\n thumbnail: PropTypes.string,\n episode: PropTypes.number,\n released: PropTypes.instanceOf(Date),\n upcoming: PropTypes.bool,\n watched: PropTypes.bool,\n progress: PropTypes.number,\n scheduled: PropTypes.bool,\n deepLinks: PropTypes.shape({\n metaDetailsStreams: PropTypes.string,\n player: PropTypes.string\n })\n};\n\nmodule.exports = Video;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst styles = require('./styles');\n\nconst VideoPlaceholder = ({ className }) => {\n return (\n
\n
\n
\n
\n
\n
\n );\n};\n\nVideoPlaceholder.propTypes = {\n className: PropTypes.string\n};\n\nmodule.exports = VideoPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst VideoPlaceholder = require('./VideoPlaceholder');\n\nmodule.exports = VideoPlaceholder;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Video = require('./Video');\n\nmodule.exports = Video;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { t } = require('i18next');\nconst Image = require('stremio/common/Image');\nconst SearchBar = require('stremio/common/SearchBar');\nconst SeasonsBar = require('./SeasonsBar');\nconst Video = require('./Video');\nconst styles = require('./styles');\n\nconst VideosList = ({ className, metaItem, season, seasonOnSelect }) => {\n const videos = React.useMemo(() => {\n return metaItem && metaItem.content.type === 'Ready' ?\n metaItem.content.content.videos\n :\n [];\n }, [metaItem]);\n const seasons = React.useMemo(() => {\n return videos\n .map(({ season }) => season)\n .filter((season, index, seasons) => {\n return season !== null &&\n !isNaN(season) &&\n typeof season === 'number' &&\n seasons.indexOf(season) === index;\n })\n .sort((a, b) => (a || Number.MAX_SAFE_INTEGER) - (b || Number.MAX_SAFE_INTEGER));\n }, [videos]);\n const selectedSeason = React.useMemo(() => {\n if (seasons.includes(season)) {\n return season;\n }\n\n const nonSpecialSeasons = seasons.filter((season) => season !== 0);\n if (nonSpecialSeasons.length > 0) {\n return nonSpecialSeasons[nonSpecialSeasons.length - 1];\n }\n\n if (seasons.length > 0) {\n return seasons[seasons.length - 1];\n }\n\n return null;\n }, [seasons, season]);\n const videosForSeason = React.useMemo(() => {\n return videos\n .filter((video) => {\n return selectedSeason === null || video.season === selectedSeason;\n })\n .sort((a, b) => {\n return a.episode - b.episode;\n });\n }, [videos, selectedSeason]);\n const [search, setSearch] = React.useState('');\n const searchInputOnChange = React.useCallback((event) => {\n setSearch(event.currentTarget.value);\n }, []);\n return (\n
\n {\n !metaItem || metaItem.content.type === 'Loading' ?\n \n \n \n
\n \n \n \n \n \n
\n
\n :\n metaItem.content.type === 'Err' || videosForSeason.length === 0 ?\n
\n {'\n
No videos found for this meta!
\n
\n :\n \n {\n seasons.length > 0 ?\n \n :\n null\n }\n \n
\n {\n videosForSeason\n .filter((video) => {\n return search.length === 0 ||\n (\n (typeof video.title === 'string' && video.title.toLowerCase().includes(search.toLowerCase())) ||\n (!isNaN(video.released.getTime()) && video.released.toLocaleString(undefined, { year: '2-digit', month: 'short', day: 'numeric' }).toLowerCase().includes(search.toLowerCase()))\n );\n })\n .map((video, index) => (\n \n ))\n }\n
\n
\n }\n
\n );\n};\n\nVideosList.propTypes = {\n className: PropTypes.string,\n metaItem: PropTypes.object,\n season: PropTypes.number,\n seasonOnSelect: PropTypes.func\n};\n\nmodule.exports = VideosList;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst VideosList = require('./VideosList');\n\nmodule.exports = VideosList;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst MetaDetails = require('./MetaDetails');\n\nmodule.exports = MetaDetails;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useModelState } = require('stremio/common');\n\nconst map = (metaDetails) => ({\n ...metaDetails,\n metaItem: metaDetails.metaItem !== null && metaDetails.metaItem.content.type === 'Ready' ?\n {\n ...metaDetails.metaItem,\n content: {\n ...metaDetails.metaItem.content,\n content: {\n ...metaDetails.metaItem.content.content,\n released: new Date(\n typeof metaDetails.metaItem.content.content.released === 'string' ?\n metaDetails.metaItem.content.content.released\n :\n NaN\n ),\n videos: metaDetails.metaItem.content.content.videos.map((video) => ({\n ...video,\n released: new Date(\n typeof video.released === 'string' ?\n video.released\n :\n NaN\n ),\n }))\n }\n }\n }\n :\n metaDetails.metaItem\n});\n\nconst useMetaDetails = (urlParams) => {\n const action = React.useMemo(() => {\n if (typeof urlParams.type === 'string' && typeof urlParams.id === 'string') {\n return {\n action: 'Load',\n args: {\n model: 'MetaDetails',\n args: {\n metaPath: {\n resource: 'meta',\n type: urlParams.type,\n id: urlParams.id,\n extra: []\n },\n streamPath: typeof urlParams.videoId === 'string' ?\n {\n resource: 'stream',\n type: urlParams.type,\n id: urlParams.videoId,\n extra: []\n }\n :\n null\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [urlParams]);\n return useModelState({ model: 'meta_details', action, map });\n};\n\nmodule.exports = useMetaDetails;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useMetaExtensionTabs = (metaExtensions) => {\n const tabs = React.useMemo(() => {\n return metaExtensions\n .map((extension) => ({\n id: extension.url,\n label: extension.addon.manifest.name,\n logo: extension.addon.manifest.logo,\n icon: 'ic_addons',\n onClick: () => setSelected(extension)\n }));\n }, [metaExtensions]);\n const [selected, setSelected] = React.useState(null);\n const clear = React.useCallback(() => {\n setSelected(null);\n }, []);\n return [tabs, selected, clear];\n};\n\nmodule.exports = useMetaExtensionTabs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst useSeason = (urlParams, queryParams) => {\n const season = React.useMemo(() => {\n return queryParams.has('season') && !isNaN(queryParams.get('season')) ?\n parseInt(queryParams.get('season'), 10)\n :\n null;\n }, [queryParams]);\n const setSeason = React.useCallback((season) => {\n const nextQueryParams = new URLSearchParams(queryParams);\n nextQueryParams.set('season', season);\n window.location.replace(`#${urlParams.path}?${nextQueryParams}`);\n }, [urlParams, queryParams]);\n return [season, setSeason];\n};\n\nmodule.exports = useSeason;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { Image, HorizontalNavBar } = require('stremio/common');\nconst styles = require('./styles');\n\nconst NotFound = () => {\n return (\n
\n \n
\n \n
Page not found!
\n
\n
\n );\n};\n\nmodule.exports = NotFound;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst NotFound = require('./NotFound');\n\nmodule.exports = NotFound;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { Image } = require('stremio/common');\nconst styles = require('./styles');\n\nconst BufferingLoader = ({ className, logo }) => {\n return (\n
\n \n
\n );\n};\n\nBufferingLoader.propTypes = {\n className: PropTypes.string,\n logo: PropTypes.string\n};\n\nmodule.exports = BufferingLoader;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst BufferingLoader = require('./BufferingLoader');\n\nmodule.exports = BufferingLoader;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button } = require('stremio/common');\nconst { useServices } = require('stremio/services');\nconst SeekBar = require('./SeekBar');\nconst VolumeSlider = require('./VolumeSlider');\nconst styles = require('./styles');\nconst { useBinaryState } = require('stremio/common');\nconst { t } = require('i18next');\n\nconst ControlBar = ({\n className,\n paused,\n time,\n duration,\n volume,\n muted,\n playbackSpeed,\n subtitlesTracks,\n audioTracks,\n metaItem,\n nextVideo,\n onPlayRequested,\n onPauseRequested,\n onMuteRequested,\n onUnmuteRequested,\n onVolumeChangeRequested,\n onSeekRequested,\n onToggleSubtitlesMenu,\n onToggleInfoMenu,\n onToggleSpeedMenu,\n onToggleVideosMenu,\n onToggleOptionsMenu,\n ...props\n}) => {\n const { chromecast } = useServices();\n const [chromecastServiceActive, setChromecastServiceActive] = React.useState(() => chromecast.active);\n const [buttonsMenuOpen, , , toogleButtonsMenu] = useBinaryState(false);\n const onSubtitlesButtonMouseDown = React.useCallback((event) => {\n event.nativeEvent.subtitlesMenuClosePrevented = true;\n }, []);\n const onInfoButtonMouseDown = React.useCallback((event) => {\n event.nativeEvent.infoMenuClosePrevented = true;\n }, []);\n const onSpeedButtonMouseDown = React.useCallback((event) => {\n event.nativeEvent.speedMenuClosePrevented = true;\n }, []);\n const onVideosButtonMouseDown = React.useCallback((event) => {\n event.nativeEvent.videosMenuClosePrevented = true;\n }, []);\n const onOptionsButtonMouseDown = React.useCallback((event) => {\n event.nativeEvent.optionsMenuClosePrevented = true;\n }, []);\n const onPlayPauseButtonClick = React.useCallback(() => {\n if (paused) {\n if (typeof onPlayRequested === 'function') {\n onPlayRequested();\n }\n } else {\n if (typeof onPauseRequested === 'function') {\n onPauseRequested();\n }\n }\n }, [paused, onPlayRequested, onPauseRequested]);\n const onNextVideoButtonClick = React.useCallback(() => {\n if (nextVideo !== null && typeof nextVideo.deepLinks === 'object') {\n if (nextVideo.deepLinks.player !== null) {\n window.location.replace(nextVideo.deepLinks.player);\n } else if (nextVideo.deepLinks.metaDetailsStreams !== null) {\n window.location.replace(nextVideo.deepLinks.metaDetailsStreams);\n }\n }\n }, [nextVideo]);\n const onMuteButtonClick = React.useCallback(() => {\n if (muted) {\n if (typeof onUnmuteRequested === 'function') {\n onUnmuteRequested();\n }\n } else {\n if (typeof onMuteRequested === 'function') {\n onMuteRequested();\n }\n }\n }, [muted, onMuteRequested, onUnmuteRequested]);\n const onSubtitlesButtonClick = React.useCallback(() => {\n if (typeof onToggleSubtitlesMenu === 'function') {\n onToggleSubtitlesMenu();\n }\n }, [onToggleSubtitlesMenu]);\n const onInfoButtonClick = React.useCallback(() => {\n if (typeof onToggleInfoMenu === 'function') {\n onToggleInfoMenu();\n }\n }, [onToggleInfoMenu]);\n const onSpeedButtonClick = React.useCallback(() => {\n if (typeof onToggleSpeedMenu === 'function') {\n onToggleSpeedMenu();\n }\n }, [onToggleSpeedMenu]);\n const onVideosButtonClick = React.useCallback(() => {\n if (typeof onToggleVideosMenu === 'function') {\n onToggleVideosMenu();\n }\n }, [onToggleVideosMenu]);\n const onOptionsButtonClick = React.useCallback(() => {\n if (typeof onToggleOptionsMenu === 'function') {\n onToggleOptionsMenu();\n }\n }, [onToggleOptionsMenu]);\n const onChromecastButtonClick = React.useCallback(() => {\n chromecast.transport.requestSession();\n }, []);\n React.useEffect(() => {\n const onStateChanged = () => {\n setChromecastServiceActive(chromecast.active);\n };\n chromecast.on('stateChanged', onStateChanged);\n return () => {\n chromecast.off('stateChanged', onStateChanged);\n };\n }, []);\n return (\n
\n \n
\n \n {\n nextVideo !== null ?\n \n :\n null\n }\n \n \n
\n \n
\n \n \n \n \n \n {\n metaItem?.content?.videos?.length > 0 ?\n \n :\n null\n }\n \n
\n
\n
\n );\n};\n\nControlBar.propTypes = {\n className: PropTypes.string,\n paused: PropTypes.bool,\n time: PropTypes.number,\n duration: PropTypes.number,\n volume: PropTypes.number,\n muted: PropTypes.bool,\n playbackSpeed: PropTypes.number,\n subtitlesTracks: PropTypes.array,\n audioTracks: PropTypes.array,\n metaItem: PropTypes.object,\n nextVideo: PropTypes.object,\n onPlayRequested: PropTypes.func,\n onPauseRequested: PropTypes.func,\n onMuteRequested: PropTypes.func,\n onUnmuteRequested: PropTypes.func,\n onVolumeChangeRequested: PropTypes.func,\n onSeekRequested: PropTypes.func,\n onToggleSubtitlesMenu: PropTypes.func,\n onToggleInfoMenu: PropTypes.func,\n onToggleSpeedMenu: PropTypes.func,\n onToggleVideosMenu: PropTypes.func,\n onToggleOptionsMenu: PropTypes.func,\n};\n\nmodule.exports = ControlBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst debounce = require('lodash.debounce');\nconst { useRouteFocused } = require('stremio-router');\nconst { Slider } = require('stremio/common');\nconst formatTime = require('./formatTime');\nconst styles = require('./styles');\n\nconst SeekBar = ({ className, time, duration, onSeekRequested }) => {\n const disabled = time === null || isNaN(time) || duration === null || isNaN(duration);\n const routeFocused = useRouteFocused();\n const [seekTime, setSeekTime] = React.useState(null);\n const resetTimeDebounced = React.useCallback(debounce(() => {\n setSeekTime(null);\n }, 1500), []);\n const onSlide = React.useCallback((time) => {\n resetTimeDebounced.cancel();\n setSeekTime(time);\n }, []);\n const onComplete = React.useCallback((time) => {\n resetTimeDebounced();\n setSeekTime(time);\n if (typeof onSeekRequested === 'function') {\n onSeekRequested(time);\n }\n }, [onSeekRequested]);\n React.useLayoutEffect(() => {\n if (!routeFocused || disabled) {\n resetTimeDebounced.cancel();\n setSeekTime(null);\n }\n }, [routeFocused, disabled]);\n React.useEffect(() => {\n return () => {\n resetTimeDebounced.cancel();\n };\n }, []);\n return (\n
\n
{formatTime(seekTime !== null ? seekTime : time)}
\n \n
{formatTime(duration)}
\n
\n );\n};\n\nSeekBar.propTypes = {\n className: PropTypes.string,\n time: PropTypes.number,\n duration: PropTypes.number,\n onSeekRequested: PropTypes.func\n};\n\nmodule.exports = SeekBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst formatUnit = (value) => {\n return ('0' + value).slice(-1 * Math.max(value.toString().length, 2));\n};\n\nconst formatTime = (time) => {\n if (time === null || isNaN(time)) {\n return '--:--:--';\n }\n\n const hours = Math.floor(time / (1000 * 60 * 60));\n const minutes = Math.floor((time / (1000 * 60)) % 60);\n const seconds = Math.floor((time / 1000) % 60);\n return `${formatUnit(hours)}:${formatUnit(minutes)}:${formatUnit(seconds)}`;\n};\n\nmodule.exports = formatTime;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SeekBar = require('./SeekBar');\n\nmodule.exports = SeekBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst debounce = require('lodash.debounce');\nconst { useRouteFocused } = require('stremio-router');\nconst { Slider } = require('stremio/common');\nconst styles = require('./styles');\n\nconst VolumeSlider = ({ className, volume, onVolumeChangeRequested }) => {\n const disabled = volume === null || isNaN(volume);\n const routeFocused = useRouteFocused();\n const [slidingVolume, setSlidingVolume] = React.useState(null);\n const resetVolumeDebounced = React.useCallback(debounce(() => {\n setSlidingVolume(null);\n }, 100), []);\n const onSlide = React.useCallback((volume) => {\n resetVolumeDebounced.cancel();\n setSlidingVolume(volume);\n if (typeof onVolumeChangeRequested === 'function') {\n onVolumeChangeRequested(volume);\n }\n }, [onVolumeChangeRequested]);\n const onComplete = React.useCallback((volume) => {\n resetVolumeDebounced();\n setSlidingVolume(volume);\n if (typeof onVolumeChangeRequested === 'function') {\n onVolumeChangeRequested(volume);\n }\n }, [onVolumeChangeRequested]);\n React.useLayoutEffect(() => {\n if (!routeFocused || disabled) {\n resetVolumeDebounced.cancel();\n setSlidingVolume(null);\n }\n }, [routeFocused, disabled]);\n React.useEffect(() => {\n return () => {\n resetVolumeDebounced.cancel();\n };\n }, []);\n return (\n \n );\n};\n\nVolumeSlider.propTypes = {\n className: PropTypes.string,\n volume: PropTypes.number,\n onVolumeChangeRequested: PropTypes.func\n};\n\nmodule.exports = VolumeSlider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst VolumeSlider = require('./VolumeSlider');\n\nmodule.exports = VolumeSlider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ControlBar = require('./ControlBar');\n\nmodule.exports = ControlBar;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\n// const Stream = require('stremio/routes/MetaDetails/StreamsList/Stream');\n// const AddonDetails = require('stremio/common/AddonDetailsModal/AddonDetails');\nconst { MetaPreview, CONSTANTS } = require('stremio/common');\nconst styles = require('./styles');\n\nconst InfoMenu = ({ className, ...props }) => {\n const metaItem = React.useMemo(() => {\n return props.metaItem !== null ?\n {\n ...props.metaItem,\n links: props.metaItem.links.filter(({ category }) => category === CONSTANTS.SHARE_LINK_CATEGORY)\n }\n :\n null;\n }, [props.metaItem]);\n const onMouseDown = React.useCallback((event) => {\n event.nativeEvent.infoMenuClosePrevented = true;\n }, []);\n return (\n
\n {\n metaItem !== null ?\n \n :\n null\n }\n {/* {\n props.stream !== null ?\n \n :\n null\n } */}\n {/* {\n props.addon !== null ?\n \n :\n null\n } */}\n
\n );\n};\n\nInfoMenu.propTypes = {\n className: PropTypes.string,\n metaItem: PropTypes.object,\n addon: PropTypes.object,\n stream: PropTypes.object\n};\n\nmodule.exports = InfoMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst InfoMenu = require('./InfoMenu');\n\nmodule.exports = InfoMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Image, Button, CONSTANTS } = require('stremio/common');\nconst styles = require('./styles');\n\nconst NextVideoPopup = ({ className, metaItem, nextVideo, onDismiss, onPlayNextVideoRequested }) => {\n const watchNowButtonRef = React.useRef(null);\n const [animationEnded, setAnimationEnded] = React.useState(false);\n const videoName = React.useMemo(() => {\n const title = nextVideo && nextVideo.title || metaItem && metaItem.title;\n return nextVideo !== null &&\n typeof nextVideo.season === 'number' &&\n typeof nextVideo.episode === 'number' ?\n `${title} (S${nextVideo.season}E${nextVideo.episode})`\n :\n title;\n }, [metaItem, nextVideo]);\n const onAnimationEnd = React.useCallback(() => {\n setAnimationEnded(true);\n }, []);\n const renderPosterFallback = React.useCallback(() => {\n return metaItem !== null && typeof metaItem.type === 'string' ?\n \n :\n null;\n }, [metaItem]);\n const onDismissButtonClick = React.useCallback(() => {\n if (typeof onDismiss === 'function') {\n onDismiss();\n }\n }, [onDismiss]);\n const onWatchNowButtonClick = React.useCallback(() => {\n if (typeof onPlayNextVideoRequested === 'function') {\n onPlayNextVideoRequested();\n }\n }, [onPlayNextVideoRequested]);\n React.useLayoutEffect(() => {\n if (animationEnded === true && watchNowButtonRef.current !== null) {\n watchNowButtonRef.current.focus();\n }\n }, [animationEnded]);\n return (\n
\n
\n \n
\n
\n
\n {\n typeof videoName === 'string' ?\n
\n { videoName }\n
\n :\n null\n }\n {\n nextVideo !== null && typeof nextVideo.overview === 'string' ?\n
\n { nextVideo.overview }\n
\n :\n null\n }\n
\n
\n \n \n
\n
\n
\n );\n};\n\nNextVideoPopup.propTypes = {\n className: PropTypes.string,\n metaItem: PropTypes.object,\n nextVideo: PropTypes.object,\n onDismiss: PropTypes.func,\n onPlayNextVideoRequested: PropTypes.func\n};\n\nmodule.exports = NextVideoPopup;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst NextVideoPopup = require('./NextVideoPopup');\n\nmodule.exports = NextVideoPopup;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button } = require('stremio/common');\nconst styles = require('./styles');\n\nconst Option = ({ icon, label, deviceId, disabled, onClick }) => {\n const onButtonClick = React.useCallback(() => {\n if (typeof onClick === 'function') {\n onClick(deviceId);\n }\n }, [onClick, deviceId]);\n return (\n \n );\n};\n\nOption.propTypes = {\n icon: PropTypes.string,\n label: PropTypes.string,\n deviceId: PropTypes.string,\n disabled: PropTypes.bool,\n onClick: PropTypes.func,\n};\n\nmodule.exports = Option;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Option = require('./Option');\n\nmodule.exports = Option;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useToast } = require('stremio/common');\nconst { useServices } = require('stremio/services');\nconst Option = require('./Option');\nconst styles = require('./styles');\n\nconst OptionsMenu = ({ className, stream, playbackDevices }) => {\n const { core } = useServices();\n const toast = useToast();\n const [streamingUrl, downloadUrl] = React.useMemo(() => {\n return stream !== null ?\n stream.deepLinks &&\n stream.deepLinks.externalPlayer &&\n [stream.deepLinks.externalPlayer.streaming, stream.deepLinks.externalPlayer.download]\n :\n [null, null];\n }, [stream]);\n const externalDevices = React.useMemo(() => {\n return playbackDevices.filter(({ type }) => type === 'external');\n }, [playbackDevices]);\n const onCopyStreamButtonClick = React.useCallback(() => {\n if (streamingUrl || downloadUrl) {\n navigator.clipboard.writeText(streamingUrl || downloadUrl)\n .then(() => {\n toast.show({\n type: 'success',\n title: 'Copied',\n message: 'Stream link was copied to your clipboard',\n timeout: 3000\n });\n })\n .catch((e) => {\n console.error(e);\n toast.show({\n type: 'error',\n title: 'Error',\n message: `Failed to copy stream link: ${streamingUrl || downloadUrl}`,\n timeout: 3000\n });\n });\n }\n }, [streamingUrl, downloadUrl]);\n const onDownloadVideoButtonClick = React.useCallback(() => {\n if (streamingUrl || downloadUrl) {\n window.open(streamingUrl || downloadUrl);\n }\n }, [streamingUrl, downloadUrl]);\n const onExternalDeviceRequested = React.useCallback((deviceId) => {\n if (streamingUrl) {\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'PlayOnDevice',\n args: {\n device: deviceId,\n source: streamingUrl,\n }\n }\n });\n }\n }, [streamingUrl]);\n const onMouseDown = React.useCallback((event) => {\n event.nativeEvent.optionsMenuClosePrevented = true;\n }, []);\n return (\n
\n {\n streamingUrl || downloadUrl ?\n \n :\n null\n }\n {\n streamingUrl || downloadUrl ?\n \n :\n null\n }\n {\n streamingUrl && externalDevices.map(({ id, name }) => (\n \n ))\n }\n
\n );\n};\n\nOptionsMenu.propTypes = {\n className: PropTypes.string,\n stream: PropTypes.object,\n playbackDevices: PropTypes.array\n};\n\nmodule.exports = OptionsMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst OptionsMenu = require('./OptionsMenu');\n\nmodule.exports = OptionsMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst debounce = require('lodash.debounce');\nconst langs = require('langs');\nconst { useRouteFocused } = require('stremio-router');\nconst { useServices } = require('stremio/services');\nconst { HorizontalNavBar, Button, useFullscreen, useBinaryState, useToast, useStreamingServer, withCoreSuspender } = require('stremio/common');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst BufferingLoader = require('./BufferingLoader');\nconst ControlBar = require('./ControlBar');\nconst NextVideoPopup = require('./NextVideoPopup');\nconst InfoMenu = require('./InfoMenu');\nconst OptionsMenu = require('./OptionsMenu');\nconst VideosMenu = require('./VideosMenu');\nconst SubtitlesMenu = require('./SubtitlesMenu');\nconst SpeedMenu = require('./SpeedMenu');\nconst Video = require('./Video');\nconst usePlayer = require('./usePlayer');\nconst useSettings = require('./useSettings');\nconst styles = require('./styles');\n\nconst Player = ({ urlParams, queryParams }) => {\n const { chromecast, shell, core } = useServices();\n const [forceTranscoding, maxAudioChannels] = React.useMemo(() => {\n return [\n queryParams.has('forceTranscoding'),\n queryParams.has('maxAudioChannels') ? parseInt(queryParams.get('maxAudioChannels'), 10) : null\n ];\n }, [queryParams]);\n const [videoState, setVideoState] = React.useReducer(\n (videoState, nextVideoState) => ({ ...videoState, ...nextVideoState }),\n {\n manifest: null,\n stream: null,\n paused: null,\n time: null,\n duration: null,\n buffering: null,\n volume: null,\n muted: null,\n playbackSpeed: null,\n videoParams: null,\n audioTracks: [],\n selectedAudioTrackId: null,\n subtitlesTracks: [],\n selectedSubtitlesTrackId: null,\n subtitlesOffset: null,\n subtitlesSize: null,\n subtitlesTextColor: null,\n subtitlesBackgroundColor: null,\n subtitlesOutlineColor: null,\n extraSubtitlesTracks: [],\n selectedExtraSubtitlesTrackId: null,\n extraSubtitlesSize: null,\n extraSubtitlesDelay: null,\n extraSubtitlesOffset: null,\n extraSubtitlesTextColor: null,\n extraSubtitlesBackgroundColor: null,\n extraSubtitlesOutlineColor: null\n }\n );\n const [player, timeChanged, pausedChanged, ended, pushToLibrary] = usePlayer(urlParams, videoState.videoParams);\n const [settings, updateSettings] = useSettings();\n const streamingServer = useStreamingServer();\n const routeFocused = useRouteFocused();\n const toast = useToast();\n const [, , , toggleFullscreen] = useFullscreen();\n const [casting, setCasting] = React.useState(() => {\n return chromecast.active && chromecast.transport.getCastState() === cast.framework.CastState.CONNECTED;\n });\n const [immersed, setImmersed] = React.useState(true);\n const setImmersedDebounced = React.useCallback(debounce(setImmersed, 3000), []);\n const [optionsMenuOpen, , closeOptionsMenu, toggleOptionsMenu] = useBinaryState(false);\n const [subtitlesMenuOpen, , closeSubtitlesMenu, toggleSubtitlesMenu] = useBinaryState(false);\n const [infoMenuOpen, , closeInfoMenu, toggleInfoMenu] = useBinaryState(false);\n const [speedMenuOpen, , closeSpeedMenu, toggleSpeedMenu] = useBinaryState(false);\n const [videosMenuOpen, , closeVideosMenu, toggleVideosMenu] = useBinaryState(false);\n const [nextVideoPopupOpen, openNextVideoPopup, closeNextVideoPopup] = useBinaryState(false);\n const nextVideoPopupDismissed = React.useRef(false);\n const defaultSubtitlesSelected = React.useRef(false);\n const defaultAudioTrackSelected = React.useRef(false);\n const [error, setError] = React.useState(null);\n const videoRef = React.useRef(null);\n const dispatch = React.useCallback((action, options) => {\n if (videoRef.current !== null) {\n videoRef.current.dispatch(action, options);\n }\n }, []);\n const onImplementationChanged = React.useCallback((manifest) => {\n setVideoState({ manifest });\n manifest.props.forEach((propName) => {\n dispatch({ type: 'observeProp', propName });\n });\n dispatch({ type: 'setProp', propName: 'subtitlesSize', propValue: settings.subtitlesSize });\n dispatch({ type: 'setProp', propName: 'subtitlesOffset', propValue: settings.subtitlesOffset });\n dispatch({ type: 'setProp', propName: 'subtitlesTextColor', propValue: settings.subtitlesTextColor });\n dispatch({ type: 'setProp', propName: 'subtitlesBackgroundColor', propValue: settings.subtitlesBackgroundColor });\n dispatch({ type: 'setProp', propName: 'subtitlesOutlineColor', propValue: settings.subtitlesOutlineColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesSize', propValue: settings.subtitlesSize });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesOffset', propValue: settings.subtitlesOffset });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesTextColor', propValue: settings.subtitlesTextColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesBackgroundColor', propValue: settings.subtitlesBackgroundColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesOutlineColor', propValue: settings.subtitlesOutlineColor });\n }, [settings.subtitlesSize, settings.subtitlesOffset, settings.subtitlesTextColor, settings.subtitlesBackgroundColor, settings.subtitlesOutlineColor]);\n const onPropChanged = React.useCallback((propName, propValue) => {\n setVideoState({ [propName]: propValue });\n }, []);\n const onEnded = React.useCallback(() => {\n ended();\n pushToLibrary();\n if (player.nextVideo !== null) {\n onPlayNextVideoRequested();\n } else {\n window.history.back();\n }\n }, [player.nextVideo, onPlayNextVideoRequested]);\n const onError = React.useCallback((error) => {\n console.error('Player', error);\n if (error.critical) {\n setError(error);\n } else {\n toast.show({\n type: 'error',\n title: 'Error',\n message: error.message,\n timeout: 3000\n });\n }\n }, []);\n const onSubtitlesTrackLoaded = React.useCallback(() => {\n toast.show({\n type: 'success',\n title: 'Subtitles loaded',\n message: 'Embedded subtitles loaded',\n timeout: 3000\n });\n }, []);\n const onExtraSubtitlesTrackLoaded = React.useCallback((track) => {\n toast.show({\n type: 'success',\n title: 'Subtitles loaded',\n message: track.exclusive ? 'Exclusice subtitles loaded' : `Subtitles from ${track.origin} loaded`,\n timeout: 3000\n });\n }, []);\n const onPlayRequested = React.useCallback(() => {\n dispatch({ type: 'setProp', propName: 'paused', propValue: false });\n }, []);\n const onPlayRequestedDebounced = React.useCallback(debounce(onPlayRequested, 200), []);\n const onPauseRequested = React.useCallback(() => {\n dispatch({ type: 'setProp', propName: 'paused', propValue: true });\n }, []);\n const onPauseRequestedDebounced = React.useCallback(debounce(onPauseRequested, 200), []);\n const onMuteRequested = React.useCallback(() => {\n dispatch({ type: 'setProp', propName: 'muted', propValue: true });\n }, []);\n const onUnmuteRequested = React.useCallback(() => {\n dispatch({ type: 'setProp', propName: 'muted', propValue: false });\n }, []);\n const onVolumeChangeRequested = React.useCallback((volume) => {\n dispatch({ type: 'setProp', propName: 'volume', propValue: volume });\n }, []);\n const onSeekRequested = React.useCallback((time) => {\n dispatch({ type: 'setProp', propName: 'time', propValue: time });\n }, []);\n const onPlaybackSpeedChanged = React.useCallback((rate) => {\n dispatch({ type: 'setProp', propName: 'playbackSpeed', propValue: rate });\n }, []);\n const onSubtitlesTrackSelected = React.useCallback((id) => {\n dispatch({ type: 'setProp', propName: 'selectedSubtitlesTrackId', propValue: id });\n dispatch({ type: 'setProp', propName: 'selectedExtraSubtitlesTrackId', propValue: null });\n }, []);\n const onExtraSubtitlesTrackSelected = React.useCallback((id) => {\n dispatch({ type: 'setProp', propName: 'selectedSubtitlesTrackId', propValue: null });\n dispatch({ type: 'setProp', propName: 'selectedExtraSubtitlesTrackId', propValue: id });\n }, []);\n const onAudioTrackSelected = React.useCallback((id) => {\n dispatch({ type: 'setProp', propName: 'selectedAudioTrackId', propValue: id });\n }, []);\n const onExtraSubtitlesDelayChanged = React.useCallback((delay) => {\n dispatch({ type: 'setProp', propName: 'extraSubtitlesDelay', propValue: delay });\n }, []);\n const onSubtitlesSizeChanged = React.useCallback((size) => {\n updateSettings({ subtitlesSize: size });\n }, [updateSettings]);\n const onSubtitlesOffsetChanged = React.useCallback((offset) => {\n updateSettings({ subtitlesOffset: offset });\n }, [updateSettings]);\n const onDismissNextVideoPopup = React.useCallback(() => {\n closeNextVideoPopup();\n nextVideoPopupDismissed.current = true;\n }, []);\n const onPlayNextVideoRequested = React.useCallback(() => {\n if (player.nextVideo !== null) {\n window.location.replace(\n typeof player.nextVideo.deepLinks.player === 'string' ?\n player.nextVideo.deepLinks.player\n :\n player.nextVideo.deepLinks.metaDetailsStreams\n );\n }\n }, [player.nextVideo]);\n const onVideoClick = React.useCallback(() => {\n if (videoState.paused !== null) {\n if (videoState.paused) {\n onPlayRequestedDebounced();\n } else {\n onPauseRequestedDebounced();\n }\n }\n }, [videoState.paused]);\n const onVideoDoubleClick = React.useCallback(() => {\n onPlayRequestedDebounced.cancel();\n onPauseRequestedDebounced.cancel();\n toggleFullscreen();\n }, [toggleFullscreen]);\n const onContainerMouseDown = React.useCallback((event) => {\n if (!event.nativeEvent.optionsMenuClosePrevented) {\n closeOptionsMenu();\n }\n if (!event.nativeEvent.subtitlesMenuClosePrevented) {\n closeSubtitlesMenu();\n }\n if (!event.nativeEvent.infoMenuClosePrevented) {\n closeInfoMenu();\n }\n if (!event.nativeEvent.speedMenuClosePrevented) {\n closeSpeedMenu();\n }\n if (!event.nativeEvent.videosMenuClosePrevented) {\n closeVideosMenu();\n }\n }, []);\n const onContainerMouseMove = React.useCallback((event) => {\n setImmersed(false);\n if (!event.nativeEvent.immersePrevented) {\n setImmersedDebounced(true);\n } else {\n setImmersedDebounced.cancel();\n }\n }, []);\n const onContainerMouseLeave = React.useCallback(() => {\n setImmersedDebounced.cancel();\n setImmersed(true);\n }, []);\n const onBarMouseMove = React.useCallback((event) => {\n event.nativeEvent.immersePrevented = true;\n }, []);\n React.useEffect(() => {\n setError(null);\n if (player.selected === null) {\n dispatch({ type: 'command', commandName: 'unload' });\n } else if (streamingServer.baseUrl !== null && streamingServer.baseUrl.type !== 'Loading' &&\n (player.selected.metaRequest === null || (player.metaItem !== null && player.metaItem.type !== 'Loading'))) {\n dispatch({\n type: 'command',\n commandName: 'load',\n commandArgs: {\n stream: {\n ...player.selected.stream,\n subtitles: Array.isArray(player.selected.stream.subtitles) ?\n player.selected.stream.subtitles.map((subtitles) => ({\n ...subtitles,\n label: subtitles.url\n }))\n :\n []\n },\n autoplay: true,\n time: player.libraryItem !== null &&\n player.selected.streamRequest !== null &&\n player.selected.streamRequest.path !== null &&\n player.libraryItem.state.video_id === player.selected.streamRequest.path.id ?\n player.libraryItem.state.timeOffset\n :\n 0,\n forceTranscoding: forceTranscoding || casting,\n maxAudioChannels: typeof maxAudioChannels === 'number' ?\n maxAudioChannels\n :\n window.chrome ?\n 2\n :\n null,\n streamingServerURL: streamingServer.baseUrl.type === 'Ready' ?\n casting ?\n streamingServer.baseUrl.content\n :\n streamingServer.selected.transportUrl\n :\n null,\n seriesInfo: player.seriesInfo\n }\n }, {\n chromecastTransport: chromecast.active ? chromecast.transport : null,\n shellTransport: shell.active ? shell.transport : null,\n });\n }\n }, [streamingServer.baseUrl, player.selected, player.metaItem, forceTranscoding, maxAudioChannels, casting]);\n React.useEffect(() => {\n if (videoState.stream !== null) {\n dispatch({\n type: 'command',\n commandName: 'addExtraSubtitlesTracks',\n commandArgs: {\n tracks: player.subtitles.map((subtitles) => ({\n ...subtitles,\n label: subtitles.url\n }))\n }\n });\n }\n }, [player.subtitles, videoState.stream]);\n React.useEffect(() => {\n dispatch({ type: 'setProp', propName: 'subtitlesSize', propValue: settings.subtitlesSize });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesSize', propValue: settings.subtitlesSize });\n }, [settings.subtitlesSize]);\n React.useEffect(() => {\n dispatch({ type: 'setProp', propName: 'subtitlesOffset', propValue: settings.subtitlesOffset });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesOffset', propValue: settings.subtitlesOffset });\n }, [settings.subtitlesOffset]);\n React.useEffect(() => {\n dispatch({ type: 'setProp', propName: 'subtitlesTextColor', propValue: settings.subtitlesTextColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesTextColor', propValue: settings.subtitlesTextColor });\n }, [settings.subtitlesTextColor]);\n React.useEffect(() => {\n dispatch({ type: 'setProp', propName: 'subtitlesBackgroundColor', propValue: settings.subtitlesBackgroundColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesBackgroundColor', propValue: settings.subtitlesBackgroundColor });\n }, [settings.subtitlesBackgroundColor]);\n React.useEffect(() => {\n dispatch({ type: 'setProp', propName: 'subtitlesOutlineColor', propValue: settings.subtitlesOutlineColor });\n dispatch({ type: 'setProp', propName: 'extraSubtitlesOutlineColor', propValue: settings.subtitlesOutlineColor });\n }, [settings.subtitlesOutlineColor]);\n React.useEffect(() => {\n if (videoState.time !== null && !isNaN(videoState.time) &&\n videoState.duration !== null && !isNaN(videoState.duration) &&\n videoState.manifest !== null && typeof videoState.manifest.name === 'string') {\n timeChanged(videoState.time, videoState.duration, videoState.manifest.name);\n }\n }, [videoState.time, videoState.duration, videoState.manifest]);\n React.useEffect(() => {\n if (videoState.paused !== null) {\n pausedChanged(videoState.paused);\n }\n }, [videoState.paused]);\n React.useEffect(() => {\n if (!!settings.bingeWatching && player.nextVideo !== null && !nextVideoPopupDismissed.current) {\n if (videoState.time !== null && videoState.duration !== null && videoState.time < videoState.duration && (videoState.duration - videoState.time) <= settings.nextVideoNotificationDuration) {\n openNextVideoPopup();\n } else {\n closeNextVideoPopup();\n }\n }\n }, [player.nextVideo, videoState.time, videoState.duration]);\n React.useEffect(() => {\n if (!defaultSubtitlesSelected.current) {\n const findTrackByLang = (tracks, lang) => tracks.find((track) => track.lang === lang || langs.where('1', track.lang)?.[2] === lang);\n\n const subtitlesTrack = findTrackByLang(videoState.subtitlesTracks, settings.subtitlesLanguage);\n const extraSubtitlesTrack = findTrackByLang(videoState.extraSubtitlesTracks, settings.subtitlesLanguage);\n\n if (subtitlesTrack && subtitlesTrack.id) {\n onSubtitlesTrackSelected(subtitlesTrack.id);\n defaultSubtitlesSelected.current = true;\n } else if (extraSubtitlesTrack && extraSubtitlesTrack.id) {\n onExtraSubtitlesTrackSelected(extraSubtitlesTrack.id);\n defaultSubtitlesSelected.current = true;\n }\n }\n }, [videoState.subtitlesTracks, videoState.extraSubtitlesTracks]);\n React.useEffect(() => {\n if (!defaultAudioTrackSelected.current) {\n const findTrackByLang = (tracks, lang) => tracks.find((track) => track.lang === lang || langs.where('1', track.lang)?.[2] === lang);\n const audioTrack = findTrackByLang(videoState.audioTracks, settings.audioLanguage);\n\n if (audioTrack && audioTrack.id) {\n onAudioTrackSelected(audioTrack.id);\n defaultAudioTrackSelected.current = true;\n }\n }\n }, [videoState.audioTracks]);\n React.useEffect(() => {\n defaultSubtitlesSelected.current = false;\n defaultAudioTrackSelected.current = false;\n nextVideoPopupDismissed.current = false;\n }, [videoState.stream]);\n React.useEffect(() => {\n if ((!Array.isArray(videoState.subtitlesTracks) || videoState.subtitlesTracks.length === 0) &&\n (!Array.isArray(videoState.extraSubtitlesTracks) || videoState.extraSubtitlesTracks.length === 0) &&\n (!Array.isArray(videoState.audioTracks) || videoState.audioTracks.length === 0)) {\n closeSubtitlesMenu();\n }\n }, [videoState.audioTracks, videoState.subtitlesTracks, videoState.extraSubtitlesTracks]);\n React.useEffect(() => {\n if (player.metaItem === null || player.metaItem.type !== 'Ready') {\n closeInfoMenu();\n closeVideosMenu();\n }\n }, [player.metaItem]);\n React.useEffect(() => {\n if (videoState.playbackSpeed === null) {\n closeSpeedMenu();\n }\n }, [videoState.playbackSpeed]);\n React.useEffect(() => {\n const intervalId = setInterval(() => {\n pushToLibrary();\n }, 30000);\n return () => {\n clearInterval(intervalId);\n };\n }, []);\n React.useEffect(() => {\n const toastFilter = (item) => item?.dataset?.type === 'CoreEvent';\n toast.addFilter(toastFilter);\n const onCastStateChange = () => {\n setCasting(chromecast.active && chromecast.transport.getCastState() === cast.framework.CastState.CONNECTED);\n };\n const onChromecastServiceStateChange = () => {\n onCastStateChange();\n if (chromecast.active) {\n chromecast.transport.on(\n cast.framework.CastContextEventType.CAST_STATE_CHANGED,\n onCastStateChange\n );\n }\n };\n const onCoreEvent = ({ event }) => {\n if (event === 'PlayingOnDevice') {\n onPauseRequested();\n }\n };\n chromecast.on('stateChanged', onChromecastServiceStateChange);\n core.transport.on('CoreEvent', onCoreEvent);\n onChromecastServiceStateChange();\n return () => {\n toast.removeFilter(toastFilter);\n chromecast.off('stateChanged', onChromecastServiceStateChange);\n core.transport.off('CoreEvent', onCoreEvent);\n if (chromecast.active) {\n chromecast.transport.off(\n cast.framework.CastContextEventType.CAST_STATE_CHANGED,\n onCastStateChange\n );\n }\n };\n }, []);\n React.useLayoutEffect(() => {\n const onKeyDown = (event) => {\n switch (event.code) {\n case 'Space': {\n if (!subtitlesMenuOpen && !infoMenuOpen && !videosMenuOpen && !speedMenuOpen && !optionsMenuOpen && videoState.paused !== null) {\n if (videoState.paused) {\n onPlayRequested();\n } else {\n onPauseRequested();\n }\n }\n\n break;\n }\n case 'ArrowRight': {\n if (!subtitlesMenuOpen && !infoMenuOpen && !videosMenuOpen && !speedMenuOpen && !optionsMenuOpen && videoState.time !== null) {\n const seekTimeMultiplier = event.shiftKey ? 3 : 1;\n onSeekRequested(videoState.time + (settings.seekTimeDuration * seekTimeMultiplier));\n }\n\n break;\n }\n case 'ArrowLeft': {\n if (!subtitlesMenuOpen && !infoMenuOpen && !videosMenuOpen && !speedMenuOpen && !optionsMenuOpen && videoState.time !== null) {\n const seekTimeMultiplier = event.shiftKey ? 3 : 1;\n onSeekRequested(videoState.time - (settings.seekTimeDuration * seekTimeMultiplier));\n }\n\n break;\n }\n case 'ArrowUp': {\n if (!subtitlesMenuOpen && !infoMenuOpen && !videosMenuOpen && !speedMenuOpen && !optionsMenuOpen && videoState.volume !== null) {\n onVolumeChangeRequested(videoState.volume + 5);\n }\n\n break;\n }\n case 'ArrowDown': {\n if (!subtitlesMenuOpen && !infoMenuOpen && !videosMenuOpen && !speedMenuOpen && !optionsMenuOpen && videoState.volume !== null) {\n onVolumeChangeRequested(videoState.volume - 5);\n }\n\n break;\n }\n case 'KeyS': {\n closeOptionsMenu();\n closeInfoMenu();\n closeSpeedMenu();\n closeVideosMenu();\n if ((Array.isArray(videoState.subtitlesTracks) && videoState.subtitlesTracks.length > 0) ||\n (Array.isArray(videoState.extraSubtitlesTracks) && videoState.extraSubtitlesTracks.length > 0) ||\n (Array.isArray(videoState.audioTracks) && videoState.audioTracks.length > 0)) {\n toggleSubtitlesMenu();\n }\n\n break;\n }\n case 'KeyI': {\n closeOptionsMenu();\n closeSubtitlesMenu();\n closeSpeedMenu();\n closeVideosMenu();\n if (player.metaItem !== null && player.metaItem.type === 'Ready') {\n toggleInfoMenu();\n }\n\n break;\n }\n case 'KeyR': {\n closeOptionsMenu();\n closeInfoMenu();\n closeSubtitlesMenu();\n closeVideosMenu();\n if (videoState.playbackSpeed !== null) {\n toggleSpeedMenu();\n }\n\n break;\n }\n case 'KeyV': {\n closeOptionsMenu();\n closeInfoMenu();\n closeSubtitlesMenu();\n closeSpeedMenu();\n if (player.metaItem !== null && player.metaItem.type === 'Ready') {\n toggleVideosMenu();\n }\n\n break;\n }\n case 'Escape': {\n closeOptionsMenu();\n closeSubtitlesMenu();\n closeInfoMenu();\n closeSpeedMenu();\n closeVideosMenu();\n onDismissNextVideoPopup();\n break;\n }\n }\n };\n if (routeFocused) {\n window.addEventListener('keydown', onKeyDown);\n }\n return () => {\n window.removeEventListener('keydown', onKeyDown);\n };\n }, [player.metaItem, settings.seekTimeDuration, routeFocused, subtitlesMenuOpen, infoMenuOpen, videosMenuOpen, speedMenuOpen, optionsMenuOpen, videoState.paused, videoState.time, videoState.volume, videoState.audioTracks, videoState.subtitlesTracks, videoState.extraSubtitlesTracks, videoState.playbackSpeed, toggleSubtitlesMenu, toggleInfoMenu, toggleVideosMenu]);\n React.useLayoutEffect(() => {\n return () => {\n setImmersedDebounced.cancel();\n onPlayRequestedDebounced.cancel();\n onPauseRequestedDebounced.cancel();\n };\n }, []);\n return (\n
\n \n {\n videoState.buffering ?\n \n :\n null\n }\n \n {\n error !== null ?\n
\n
{error.message}
\n {\n player.selected !== null ?\n \n :\n null\n }\n
\n :\n null\n }\n {\n subtitlesMenuOpen || infoMenuOpen || videosMenuOpen || speedMenuOpen || optionsMenuOpen ?\n
\n :\n null\n }\n \n \n {\n nextVideoPopupOpen ?\n \n :\n null\n }\n {\n subtitlesMenuOpen ?\n \n :\n null\n }\n {\n infoMenuOpen ?\n \n :\n null\n }\n {\n speedMenuOpen ?\n \n :\n null\n }\n {\n videosMenuOpen ?\n \n :\n null\n }\n {\n optionsMenuOpen ?\n \n :\n null\n }\n
\n );\n};\n\nPlayer.propTypes = {\n urlParams: PropTypes.shape({\n stream: PropTypes.string,\n streamTransportUrl: PropTypes.string,\n metaTransportUrl: PropTypes.string,\n type: PropTypes.string,\n id: PropTypes.string,\n videoId: PropTypes.string\n }),\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst PlayerFallback = () => (\n
\n);\n\nmodule.exports = withCoreSuspender(Player, PlayerFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { Button } = require('stremio/common');\nconst styles = require('./styles');\n\nconst OptionButton = ({ className, value, selected, onSelect }) => {\n const onClick = React.useCallback(() => {\n if (typeof onSelect === 'function') {\n onSelect(value);\n }\n }, [onSelect, value]);\n return (\n \n
{ value }x
\n
\n \n );\n};\n\nOptionButton.propTypes = {\n className: PropTypes.string,\n value: PropTypes.number,\n selected: PropTypes.bool,\n onSelect: PropTypes.func,\n};\n\nmodule.exports = OptionButton;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Option = require('./Option');\n\nmodule.exports = Option;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { useTranslation } = require('react-i18next');\nconst Option = require('./Option');\nconst styles = require('./styles');\n\nconst RATES = Array.from(Array(8).keys(), (n) => n * 0.25 + 0.25).reverse();\n\nconst SpeedMenu = ({ className, playbackSpeed, onPlaybackSpeedChanged }) => {\n const { t } = useTranslation();\n const onMouseDown = React.useCallback((event) => {\n event.nativeEvent.speedMenuClosePrevented = true;\n }, []);\n const onOptionSelect = React.useCallback((value) => {\n if (typeof onPlaybackSpeedChanged === 'function') {\n onPlaybackSpeedChanged(value);\n }\n }, [onPlaybackSpeedChanged]);\n return (\n
\n
\n { t('PLAYBACK_SPEED') }\n
\n
\n {\n RATES.map((rate) => (\n \n ))\n }\n
\n
\n );\n};\n\nSpeedMenu.propTypes = {\n className: PropTypes.string,\n playbackSpeed: PropTypes.number,\n onPlaybackSpeedChanged: PropTypes.func,\n};\n\nmodule.exports = SpeedMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SpeedMenu = require('./SpeedMenu');\n\nmodule.exports = SpeedMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Button } = require('stremio/common');\nconst styles = require('./styles');\n\nconst DiscreteSelectInput = ({ className, value, label, disabled, dataset, onChange }) => {\n const buttonOnClick = React.useCallback((event) => {\n if (typeof onChange === 'function') {\n onChange({\n type: 'change',\n value: event.currentTarget.dataset.type,\n dataset: dataset,\n reactEvent: event,\n nativeEvent: event.nativeEvent\n });\n }\n }, [dataset, onChange]);\n return (\n
\n
{label}
\n
\n \n
{value}
\n \n
\n
\n );\n};\n\nDiscreteSelectInput.propTypes = {\n className: PropTypes.string,\n value: PropTypes.string,\n label: PropTypes.string,\n disabled: PropTypes.bool,\n dataset: PropTypes.object,\n onChange: PropTypes.func\n};\n\nmodule.exports = DiscreteSelectInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst DiscreteSelectInput = require('./DiscreteSelectInput');\n\nmodule.exports = DiscreteSelectInput;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst { Button, CONSTANTS, comparatorWithPriorities, languageNames } = require('stremio/common');\nconst DiscreteSelectInput = require('./DiscreteSelectInput');\nconst styles = require('./styles');\nconst { t } = require('i18next');\n\nconst ORIGIN_PRIORITIES = {\n 'EMBEDDED': 2,\n 'EXCLUSIVE': 1\n};\nconst LANGUAGE_PRIORITIES = {\n 'eng': 1\n};\n\nconst SubtitlesMenu = React.memo((props) => {\n const subtitlesLanguages = React.useMemo(() => {\n return (Array.isArray(props.subtitlesTracks) ? props.subtitlesTracks : [])\n .concat(Array.isArray(props.extraSubtitlesTracks) ? props.extraSubtitlesTracks : [])\n .reduce((subtitlesLanguages, { lang }) => {\n if (!subtitlesLanguages.includes(lang)) {\n subtitlesLanguages.push(lang);\n }\n\n return subtitlesLanguages;\n }, [])\n .sort(comparatorWithPriorities(LANGUAGE_PRIORITIES));\n }, [props.subtitlesTracks, props.extraSubtitlesTracks]);\n const selectedSubtitlesLanguage = React.useMemo(() => {\n return typeof props.selectedSubtitlesTrackId === 'string' ?\n (Array.isArray(props.subtitlesTracks) ? props.subtitlesTracks : [])\n .reduce((selectedSubtitlesLanguage, { id, lang }) => {\n if (id === props.selectedSubtitlesTrackId) {\n return lang;\n }\n\n return selectedSubtitlesLanguage;\n }, null)\n :\n typeof props.selectedExtraSubtitlesTrackId === 'string' ?\n (Array.isArray(props.extraSubtitlesTracks) ? props.extraSubtitlesTracks : [])\n .reduce((selectedSubtitlesLanguage, { id, lang }) => {\n if (id === props.selectedExtraSubtitlesTrackId) {\n return lang;\n }\n\n return selectedSubtitlesLanguage;\n }, null)\n :\n null;\n }, [props.subtitlesTracks, props.extraSubtitlesTracks, props.selectedSubtitlesTrackId, props.selectedExtraSubtitlesTrackId]);\n const subtitlesTracksForLanguage = React.useMemo(() => {\n return (Array.isArray(props.subtitlesTracks) ? props.subtitlesTracks : [])\n .concat(Array.isArray(props.extraSubtitlesTracks) ? props.extraSubtitlesTracks : [])\n .filter(({ lang }) => lang === selectedSubtitlesLanguage)\n .sort((t1, t2) => comparatorWithPriorities(ORIGIN_PRIORITIES)(t1.origin, t2.origin));\n }, [props.subtitlesTracks, props.extraSubtitlesTracks, selectedSubtitlesLanguage]);\n const onMouseDown = React.useCallback((event) => {\n event.nativeEvent.subtitlesMenuClosePrevented = true;\n }, []);\n const subtitlesLanguageOnClick = React.useCallback((event) => {\n const track = (Array.isArray(props.subtitlesTracks) ? props.subtitlesTracks : [])\n .concat(Array.isArray(props.extraSubtitlesTracks) ? props.extraSubtitlesTracks : [])\n .filter(({ lang }) => lang === event.currentTarget.dataset.lang)\n .sort((t1, t2) => comparatorWithPriorities(ORIGIN_PRIORITIES)(t1.origin, t2.origin))\n .shift();\n if (!track) {\n if (typeof props.onSubtitlesTrackSelected === 'function') {\n props.onSubtitlesTrackSelected(null);\n }\n if (typeof props.onExtraSubtitlesTrackSelected === 'function') {\n props.onExtraSubtitlesTrackSelected(null);\n }\n } else if (track.embedded) {\n if (typeof props.onSubtitlesTrackSelected === 'function') {\n props.onSubtitlesTrackSelected(track.id);\n }\n } else {\n if (typeof props.onExtraSubtitlesTrackSelected === 'function') {\n props.onExtraSubtitlesTrackSelected(track.id);\n }\n }\n }, [props.subtitlesTracks, props.extraSubtitlesTracks, props.onSubtitlesTrackSelected, props.onExtraSubtitlesTrackSelected]);\n const subtitlesTrackOnClick = React.useCallback((event) => {\n if (event.currentTarget.dataset.embedded === 'true') {\n if (typeof props.onSubtitlesTrackSelected === 'function') {\n props.onSubtitlesTrackSelected(event.currentTarget.dataset.id);\n }\n } else {\n if (typeof props.onExtraSubtitlesTrackSelected === 'function') {\n props.onExtraSubtitlesTrackSelected(event.currentTarget.dataset.id);\n }\n }\n }, [props.onSubtitlesTrackSelected, props.onExtraSubtitlesTrackSelected]);\n const onSubtitlesDelayChanged = React.useCallback((event) => {\n const delta = event.value === 'increment' ? 250 : -250;\n if (typeof props.selectedExtraSubtitlesTrackId === 'string') {\n if (props.extraSubtitlesDelay !== null && !isNaN(props.extraSubtitlesDelay)) {\n const extraDelay = props.extraSubtitlesDelay + delta;\n if (typeof props.onExtraSubtitlesDelayChanged === 'function') {\n props.onExtraSubtitlesDelayChanged(extraDelay);\n }\n }\n }\n }, [props.selectedExtraSubtitlesTrackId, props.extraSubtitlesDelay, props.onExtraSubtitlesDelayChanged]);\n const onSubtitlesSizeChanged = React.useCallback((event) => {\n const delta = event.value === 'increment' ? 1 : -1;\n if (typeof props.selectedSubtitlesTrackId === 'string') {\n if (props.subtitlesSize !== null && !isNaN(props.subtitlesSize)) {\n const sizeIndex = CONSTANTS.SUBTITLES_SIZES.indexOf(props.subtitlesSize);\n const size = CONSTANTS.SUBTITLES_SIZES[Math.max(0, Math.min(CONSTANTS.SUBTITLES_SIZES.length - 1, sizeIndex + delta))];\n if (typeof props.onSubtitlesSizeChanged === 'function') {\n props.onSubtitlesSizeChanged(size);\n }\n }\n } else if (typeof props.selectedExtraSubtitlesTrackId === 'string') {\n if (props.extraSubtitlesSize !== null && !isNaN(props.extraSubtitlesSize)) {\n const extraSizeIndex = CONSTANTS.SUBTITLES_SIZES.indexOf(props.extraSubtitlesSize);\n const extraSize = CONSTANTS.SUBTITLES_SIZES[Math.max(0, Math.min(CONSTANTS.SUBTITLES_SIZES.length - 1, extraSizeIndex + delta))];\n if (typeof props.onExtraSubtitlesSizeChanged === 'function') {\n props.onExtraSubtitlesSizeChanged(extraSize);\n }\n }\n }\n }, [props.selectedSubtitlesTrackId, props.selectedExtraSubtitlesTrackId, props.subtitlesSize, props.extraSubtitlesSize, props.onSubtitlesSizeChanged, props.onExtraSubtitlesSizeChanged]);\n const onSubtitlesOffsetChanged = React.useCallback((event) => {\n const delta = event.value === 'increment' ? 1 : -1;\n if (typeof props.selectedSubtitlesTrackId === 'string') {\n if (props.extraSubtitlesOffset !== null && !isNaN(props.extraSubtitlesOffset)) {\n const offset = Math.max(0, Math.min(100, Math.floor(props.extraSubtitlesOffset + delta)));\n if (typeof props.onExtraSubtitlesOffsetChanged === 'function') {\n props.onExtraSubtitlesOffsetChanged(offset);\n }\n }\n } else if (typeof props.selectedExtraSubtitlesTrackId === 'string') {\n if (props.subtitlesOffset !== null && !isNaN(props.subtitlesOffset)) {\n const offset = Math.max(0, Math.min(100, Math.floor(props.subtitlesOffset + delta)));\n if (typeof props.onSubtitlesOffsetChanged === 'function') {\n props.onSubtitlesOffsetChanged(offset);\n }\n }\n }\n }, [props.selectedSubtitlesTrackId, props.selectedExtraSubtitlesTrackId, props.subtitlesOffset, props.extraSubtitlesOffset, props.onSubtitlesOffsetChanged, props.onExtraSubtitlesOffsetChanged]);\n const audioTrackOnClick = React.useCallback((event) => {\n if (typeof props.onAudioTrackSelected === 'function') {\n props.onAudioTrackSelected(event.currentTarget.dataset.id);\n }\n }, [props.onAudioTrackSelected]);\n return (\n
\n {\n Array.isArray(props.audioTracks) && props.audioTracks.length > 1 ?\n
\n
Audio Languages
\n
\n {props.audioTracks.map(({ id, label, lang }, index) => (\n \n ))}\n
\n
\n :\n null\n }\n
\n
{ t('PLAYER_SUBTITLES_LANGUAGES') }
\n
\n \n {subtitlesLanguages.map((lang, index) => (\n \n ))}\n
\n
\n
\n
{ t('PLAYER_SUBTITLES_VARIANTS') }
\n {\n subtitlesTracksForLanguage.length > 0 ?\n
\n {subtitlesTracksForLanguage.map((track, index) => (\n \n ))}\n
\n :\n
\n
\n { t('PLAYER_SUBTITLES_DISABLED') }\n
\n
\n }\n
\n
\n
Subtitles Settings
\n \n \n \n
\n \n
\n
\n );\n});\n\nSubtitlesMenu.displayName = 'MainNavBars';\n\nSubtitlesMenu.propTypes = {\n className: PropTypes.string,\n subtitlesTracks: PropTypes.arrayOf(PropTypes.shape({\n id: PropTypes.string.isRequired,\n lang: PropTypes.string.isRequired,\n origin: PropTypes.string.isRequired\n })),\n selectedSubtitlesTrackId: PropTypes.string,\n subtitlesOffset: PropTypes.number,\n subtitlesSize: PropTypes.number,\n extraSubtitlesTracks: PropTypes.arrayOf(PropTypes.shape({\n id: PropTypes.string.isRequired,\n lang: PropTypes.string.isRequired,\n origin: PropTypes.string.isRequired,\n label: PropTypes.string.isRequired\n })),\n selectedExtraSubtitlesTrackId: PropTypes.string,\n extraSubtitlesOffset: PropTypes.number,\n extraSubtitlesDelay: PropTypes.number,\n extraSubtitlesSize: PropTypes.number,\n audioTracks: PropTypes.arrayOf(PropTypes.shape({\n id: PropTypes.string.isRequired,\n lang: PropTypes.string.isRequired,\n origin: PropTypes.string.isRequired,\n label: PropTypes.string.isRequired\n })),\n selectedAudioTrackId: PropTypes.string,\n onSubtitlesTrackSelected: PropTypes.func,\n onExtraSubtitlesTrackSelected: PropTypes.func,\n onAudioTrackSelected: PropTypes.func,\n onSubtitlesOffsetChanged: PropTypes.func,\n onSubtitlesSizeChanged: PropTypes.func,\n onExtraSubtitlesOffsetChanged: PropTypes.func,\n onExtraSubtitlesDelayChanged: PropTypes.func,\n onExtraSubtitlesSizeChanged: PropTypes.func\n};\n\nmodule.exports = SubtitlesMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst SubtitlesMenu = require('./SubtitlesMenu');\n\nmodule.exports = SubtitlesMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst StremioVideo = require('@stremio/stremio-video');\nconst { useLiveRef } = require('stremio/common');\nconst styles = require('./styles');\n\nconst Video = React.forwardRef(({ className, ...props }, ref) => {\n const onEndedRef = useLiveRef(props.onEnded);\n const onErrorRef = useLiveRef(props.onError);\n const onPropValueRef = useLiveRef(props.onPropValue);\n const onPropChangedRef = useLiveRef(props.onPropChanged);\n const onSubtitlesTrackLoadedRef = useLiveRef(props.onSubtitlesTrackLoaded);\n const onExtraSubtitlesTrackLoadedRef = useLiveRef(props.onExtraSubtitlesTrackLoaded);\n const onImplementationChangedRef = useLiveRef(props.onImplementationChanged);\n const videoElementRef = React.useRef(null);\n const videoRef = React.useRef(null);\n const dispatch = React.useCallback((action, options = {}) => {\n if (videoRef.current !== null) {\n try {\n videoRef.current.dispatch(action, {\n ...options,\n containerElement: videoElementRef.current\n });\n } catch (error) {\n console.error('Video', error);\n }\n }\n }, []);\n React.useImperativeHandle(ref, () => ({ dispatch }), []);\n React.useEffect(() => {\n if (videoElementRef.current !== null) {\n videoRef.current = new StremioVideo();\n videoRef.current.on('ended', () => {\n if (typeof onEndedRef.current === 'function') {\n onEndedRef.current();\n }\n });\n videoRef.current.on('error', (args) => {\n if (typeof onErrorRef.current === 'function') {\n onErrorRef.current(args);\n }\n });\n videoRef.current.on('propValue', (propName, propValue) => {\n if (typeof onPropValueRef.current === 'function') {\n onPropValueRef.current(propName, propValue);\n }\n });\n videoRef.current.on('propChanged', (propName, propValue) => {\n if (typeof onPropChangedRef.current === 'function') {\n onPropChangedRef.current(propName, propValue);\n }\n });\n videoRef.current.on('subtitlesTrackLoaded', (track) => {\n if (typeof onSubtitlesTrackLoadedRef.current === 'function') {\n onSubtitlesTrackLoadedRef.current(track);\n }\n });\n videoRef.current.on('extraSubtitlesTrackLoaded', (track) => {\n if (typeof onExtraSubtitlesTrackLoadedRef.current === 'function') {\n onExtraSubtitlesTrackLoadedRef.current(track);\n }\n });\n videoRef.current.on('implementationChanged', (manifest) => {\n if (typeof onImplementationChangedRef.current === 'function') {\n onImplementationChangedRef.current(manifest);\n }\n });\n }\n return () => {\n videoRef.current.destroy();\n };\n }, []);\n return (\n
\n
\n
\n );\n});\n\nVideo.displayName = 'Video';\n\nVideo.propTypes = {\n className: PropTypes.string,\n onEnded: PropTypes.func,\n onError: PropTypes.func,\n onPropValue: PropTypes.func,\n onPropChanged: PropTypes.func,\n onSubtitlesTrackLoaded: PropTypes.func,\n onExtraSubtitlesTrackLoaded: PropTypes.func,\n onImplementationChanged: PropTypes.func\n};\n\nmodule.exports = Video;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Video = require('./Video');\n\nmodule.exports = Video;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst Video = require('../../MetaDetails/VideosList/Video');\nconst styles = require('./styles');\n\nconst VideosMenu = ({ className, metaItem, seriesInfo }) => {\n const onMouseDown = React.useCallback((event) => {\n event.nativeEvent.videosMenuClosePrevented = true;\n }, []);\n const videos = React.useMemo(() => {\n return seriesInfo && typeof seriesInfo.season === 'number' && Array.isArray(metaItem.videos) ?\n metaItem.videos.filter(({ season }) => season === seriesInfo.season)\n :\n metaItem.videos;\n }, [metaItem, seriesInfo]);\n return (\n
\n {\n videos.map((video, index) => (\n \n ))\n }\n
\n );\n};\n\nVideosMenu.propTypes = {\n className: PropTypes.string,\n metaItem: PropTypes.object,\n seriesInfo: PropTypes.shape({\n season: PropTypes.number,\n episode: PropTypes.number,\n }),\n};\n\nmodule.exports = VideosMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst VideosMenu = require('./VideosMenu');\n\nmodule.exports = VideosMenu;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Player = require('./Player');\n\nmodule.exports = Player;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst { useModelState, useCoreSuspender } = require('stremio/common');\n\nconst map = (player) => ({\n ...player,\n metaItem: player.metaItem !== null && player.metaItem.type === 'Ready' ?\n {\n ...player.metaItem,\n content: {\n ...player.metaItem.content,\n released: new Date(\n typeof player.metaItem.content.released === 'string' ?\n player.metaItem.content.released\n :\n NaN\n ),\n videos: player.metaItem.content.videos.map((video) => ({\n ...video,\n released: new Date(\n typeof video.released === 'string' ?\n video.released\n :\n NaN\n ),\n }))\n }\n }\n :\n player.metaItem,\n});\n\nconst usePlayer = (urlParams, videoParams) => {\n const { core } = useServices();\n const { decodeStream } = useCoreSuspender();\n const stream = decodeStream(urlParams.stream);\n const action = React.useMemo(() => {\n if (stream !== null) {\n return {\n action: 'Load',\n args: {\n model: 'Player',\n args: {\n stream,\n videoParams,\n streamRequest: typeof urlParams.streamTransportUrl === 'string' && typeof urlParams.type === 'string' && typeof urlParams.videoId === 'string' ?\n {\n base: urlParams.streamTransportUrl,\n path: {\n resource: 'stream',\n type: urlParams.type,\n id: urlParams.videoId,\n extra: []\n }\n }\n :\n null,\n metaRequest: typeof urlParams.metaTransportUrl === 'string' && typeof urlParams.type === 'string' && typeof urlParams.id === 'string' ?\n {\n base: urlParams.metaTransportUrl,\n path: {\n resource: 'meta',\n type: urlParams.type,\n id: urlParams.id,\n extra: []\n }\n }\n :\n null,\n subtitlesPath: typeof urlParams.type === 'string' && typeof urlParams.videoId === 'string' ?\n {\n resource: 'subtitles',\n type: urlParams.type,\n id: urlParams.videoId,\n extra: []\n }\n :\n null\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [urlParams, videoParams]);\n const timeChanged = React.useCallback((time, duration, device) => {\n core.transport.dispatch({\n action: 'Player',\n args: {\n action: 'TimeChanged',\n args: { time, duration, device }\n }\n }, 'player');\n }, []);\n const pushToLibrary = React.useCallback(() => {\n core.transport.dispatch({\n action: 'Player',\n args: {\n action: 'PushToLibrary'\n }\n }, 'player');\n }, []);\n const ended = React.useCallback(() => {\n core.transport.dispatch({\n action: 'Player',\n args: {\n action: 'Ended'\n }\n }, 'player');\n }, []);\n const pausedChanged = React.useCallback((paused) => {\n core.transport.dispatch({\n action: 'Player',\n args: {\n action: 'PausedChanged',\n args: { paused }\n }\n }, 'player');\n }, []);\n const player = useModelState({ model: 'player', action, map });\n return [player, timeChanged, pausedChanged, ended, pushToLibrary];\n};\n\nmodule.exports = usePlayer;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst { useProfile } = require('stremio/common');\n\nconst useSettings = () => {\n const { core } = useServices();\n const profile = useProfile();\n const updateSettings = React.useCallback((settings) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n ...settings\n }\n }\n });\n }, [profile]);\n return [profile.settings, updateSettings];\n};\n\nmodule.exports = useSettings;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst classnames = require('classnames');\nconst debounce = require('lodash.debounce');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { Image, MainNavBars, MetaRow, MetaItem, withCoreSuspender, getVisibleChildrenRange } = require('stremio/common');\nconst useSearch = require('./useSearch');\nconst styles = require('./styles');\n\nconst THRESHOLD = 100;\n\nconst Search = ({ queryParams }) => {\n const { t } = useTranslation();\n const [search, loadSearchRows] = useSearch(queryParams);\n const query = React.useMemo(() => {\n return search.selected !== null ?\n search.selected.extra.reduceRight((query, [name, value]) => {\n if (name === 'search') {\n return value;\n }\n\n return query;\n }, null)\n :\n null;\n }, [search.selected]);\n const scrollContainerRef = React.useRef();\n const onVisibleRangeChange = React.useCallback(() => {\n if (search.catalogs.length === 0) {\n return;\n }\n\n const range = getVisibleChildrenRange(scrollContainerRef.current, THRESHOLD);\n if (range === null) {\n return;\n }\n\n loadSearchRows(range);\n }, [search.catalogs]);\n const onScroll = React.useCallback(debounce(onVisibleRangeChange, 250), [onVisibleRangeChange]);\n React.useLayoutEffect(() => {\n onVisibleRangeChange();\n }, [search.catalogs, onVisibleRangeChange]);\n return (\n \n
\n {\n query === null ?\n
\n
\n \n
{ t('SEARCH_EXPLANATION_CONTENT') }
\n
\n
\n \n
{ t('SEARCH_EXPLANATION_PEOPLE') }
\n
\n
\n :\n search.catalogs.length === 0 ?\n
\n \n
{ t('STREMIO_TV_SEARCH_NO_ADDONS') }
\n
\n :\n search.catalogs.map((catalog, index) => {\n switch (catalog.content?.type) {\n case 'Ready': {\n return (\n \n );\n }\n case 'Err': {\n return (\n \n );\n }\n default: {\n return (\n \n );\n }\n }\n })\n }\n
\n
\n );\n};\n\nSearch.propTypes = {\n queryParams: PropTypes.instanceOf(URLSearchParams)\n};\n\nconst SearchFallback = ({ queryParams }) => (\n \n);\n\nSearchFallback.propTypes = Search.propTypes;\n\nmodule.exports = withCoreSuspender(Search, SearchFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Search = require('./Search');\n\nmodule.exports = Search;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useModelState } = require('stremio/common');\nconst { useServices } = require('stremio/services');\n\nconst useSearch = (queryParams) => {\n const { core } = useServices();\n // TODO: refactor this to be in stremio-core-web\n // React.useEffect(() => {\n // let timerId = setTimeout(emitSearchEvent, 500);\n // function emitSearchEvent() {\n // timerId = null;\n // const state = core.transport.getState('search');\n // if (state.selected !== null) {\n // const [, query] = state.selected.extra.find(([name]) => name === 'search');\n // const responses = state.catalogs.filter((catalog) => catalog.content?.type === 'Ready');\n // core.transport.analytics({\n // event: 'Search',\n // args: {\n // query,\n // responsesCount: responses.length\n // }\n // });\n // }\n // }\n // return () => {\n // if (timerId !== null) {\n // clearTimeout(timerId);\n // emitSearchEvent();\n // }\n // };\n // }, [queryParams.get('search')]);\n const action = React.useMemo(() => {\n if (queryParams.has('search') && queryParams.get('search').length > 0) {\n return {\n action: 'Load',\n args: {\n model: 'CatalogsWithExtra',\n args: {\n extra: [\n ['search', queryParams.get('search')]\n ]\n }\n }\n };\n } else {\n return {\n action: 'Unload'\n };\n }\n }, [queryParams]);\n const loadRange = React.useCallback((range) => {\n core.transport.dispatch({\n action: 'CatalogsWithExtra',\n args: {\n action: 'LoadRange',\n args: range\n }\n }, 'search');\n }, []);\n const search = useModelState({ model: 'search', action });\n return [search, loadRange];\n};\n\nmodule.exports = useSearch;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst classnames = require('classnames');\nconst throttle = require('lodash.throttle');\nconst { useTranslation } = require('react-i18next');\nconst Icon = require('@stremio/stremio-icons/dom');\nconst { useRouteFocused } = require('stremio-router');\nconst { useServices } = require('stremio/services');\nconst { Button, Checkbox, MainNavBars, Multiselect, ColorInput, TextInput, ModalDialog, useProfile, useStreamingServer, useBinaryState, withCoreSuspender, useToast } = require('stremio/common');\nconst useProfileSettingsInputs = require('./useProfileSettingsInputs');\nconst useStreamingServerSettingsInputs = require('./useStreamingServerSettingsInputs');\nconst useDataExport = require('./useDataExport');\nconst styles = require('./styles');\n\nconst GENERAL_SECTION = 'general';\nconst PLAYER_SECTION = 'player';\nconst STREAMING_SECTION = 'streaming';\nconst SHORTCUTS_SECTION = 'shortcuts';\n\nconst Settings = () => {\n const { t } = useTranslation();\n const { core } = useServices();\n const { routeFocused } = useRouteFocused();\n const profile = useProfile();\n const [dataExport, loadDataExport] = useDataExport();\n const streamingServer = useStreamingServer();\n const toast = useToast();\n const {\n interfaceLanguageSelect,\n subtitlesLanguageSelect,\n subtitlesSizeSelect,\n subtitlesTextColorInput,\n subtitlesBackgroundColorInput,\n subtitlesOutlineColorInput,\n audioLanguageSelect,\n seekTimeDurationSelect,\n nextVideoPopupDurationSelect,\n bingeWatchingCheckbox,\n playInBackgroundCheckbox,\n playInExternalPlayerCheckbox,\n hardwareDecodingCheckbox,\n streamingServerUrlInput\n } = useProfileSettingsInputs(profile);\n const {\n cacheSizeSelect,\n torrentProfileSelect\n } = useStreamingServerSettingsInputs(streamingServer);\n const [configureServerUrlModalOpen, openConfigureServerUrlModal, closeConfigureServerUrlModal] = useBinaryState(false);\n const configureServerUrlInputRef = React.useRef(null);\n const configureServerUrlOnSubmit = React.useCallback(() => {\n streamingServerUrlInput.onChange(configureServerUrlInputRef.current.value);\n closeConfigureServerUrlModal();\n }, [streamingServerUrlInput]);\n const [traktAuthStarted, setTraktAuthStarted] = React.useState(false);\n const isTraktAuthenticated = React.useMemo(() => {\n return profile.auth !== null && profile.auth.user !== null && profile.auth.user.trakt !== null &&\n (Date.now() / 1000) < (profile.auth.user.trakt.created_at + profile.auth.user.trakt.expires_in);\n }, [profile.auth]);\n const configureServerUrlModalButtons = React.useMemo(() => {\n return [\n {\n className: styles['cancel-button'],\n label: 'Cancel',\n props: {\n onClick: closeConfigureServerUrlModal\n }\n },\n {\n label: 'Submit',\n props: {\n onClick: configureServerUrlOnSubmit,\n }\n }\n ];\n }, [configureServerUrlOnSubmit]);\n const logoutButtonOnClick = React.useCallback(() => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'Logout'\n }\n });\n }, []);\n const toggleTraktOnClick = React.useCallback(() => {\n if (!isTraktAuthenticated && profile.auth !== null && profile.auth.user !== null && typeof profile.auth.user._id === 'string') {\n window.open(`https://www.strem.io/trakt/auth/${profile.auth.user._id}`);\n setTraktAuthStarted(true);\n } else {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'LogoutTrakt'\n }\n });\n }\n }, [isTraktAuthenticated, profile.auth]);\n const subscribeCalendarOnClick = React.useCallback(() => {\n const url = `webcal://www.strem.io/calendar/${profile.auth.user._id}.ics`;\n window.open(url);\n toast.show({\n type: 'success',\n title: 'Calendar has been added to your default caldendar app',\n timeout: 25000\n });\n //Stremio 4 emits not documented event subscribeCalendar\n }, []);\n const exportDataOnClick = React.useCallback(() => {\n loadDataExport();\n }, []);\n const reloadStreamingServer = React.useCallback(() => {\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'Reload'\n }\n });\n }, []);\n const sectionsContainerRef = React.useRef(null);\n const generalSectionRef = React.useRef(null);\n const playerSectionRef = React.useRef(null);\n const streamingServerSectionRef = React.useRef(null);\n const shortcutsSectionRef = React.useRef(null);\n const sections = React.useMemo(() => ([\n { ref: generalSectionRef, id: GENERAL_SECTION },\n { ref: playerSectionRef, id: PLAYER_SECTION },\n { ref: streamingServerSectionRef, id: STREAMING_SECTION },\n { ref: shortcutsSectionRef, id: SHORTCUTS_SECTION },\n ]), []);\n const [selectedSectionId, setSelectedSectionId] = React.useState(GENERAL_SECTION);\n const updateSelectedSectionId = React.useCallback(() => {\n if (sectionsContainerRef.current.scrollTop + sectionsContainerRef.current.clientHeight >= sectionsContainerRef.current.scrollHeight - 50) {\n setSelectedSectionId(sections[sections.length - 1].id);\n } else {\n for (let i = sections.length - 1; i >= 0; i--) {\n if (sections[i].ref.current.offsetTop - sectionsContainerRef.current.offsetTop <= sectionsContainerRef.current.scrollTop) {\n setSelectedSectionId(sections[i].id);\n break;\n }\n }\n }\n }, []);\n const sideMenuButtonOnClick = React.useCallback((event) => {\n const section = sections.find((section) => {\n return section.id === event.currentTarget.dataset.section;\n });\n sectionsContainerRef.current.scrollTo({\n top: section.ref.current.offsetTop - sectionsContainerRef.current.offsetTop,\n behavior: 'smooth'\n });\n }, []);\n const sectionsContainerOnScorll = React.useCallback(throttle(() => {\n updateSelectedSectionId();\n }, 50), []);\n React.useEffect(() => {\n if (isTraktAuthenticated && traktAuthStarted) {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'InstallTraktAddon'\n }\n });\n setTraktAuthStarted(false);\n }\n }, [isTraktAuthenticated, traktAuthStarted]);\n React.useEffect(() => {\n if (dataExport.exportUrl !== null && typeof dataExport.exportUrl === 'string') {\n window.open(dataExport.exportUrl);\n }\n }, [dataExport.exportUrl]);\n React.useLayoutEffect(() => {\n if (routeFocused) {\n updateSelectedSectionId();\n }\n closeConfigureServerUrlModal();\n }, [routeFocused]);\n return (\n \n
\n
\n \n \n \n \n
\n
App Version: {process.env.VERSION}
\n {\n streamingServer.settings !== null && streamingServer.settings.type === 'Ready' ?\n
Server Version: {streamingServer.settings.content.serverVersion}
\n :\n null\n }\n
\n
\n
\n
{ t('SETTINGS_NAV_GENERAL') }
\n
\n \n
\n
\n
\n {profile.auth === null ? 'Anonymous user' : profile.auth.user.email}\n
\n
\n {\n profile.auth !== null ?\n \n :\n null\n }\n
\n \n
\n {\n profile.auth === null ?\n
\n \n
\n :\n null\n }\n
\n
\n
{ t('SETTINGS_INTERFACE_LANGUAGE') }
\n
\n \n
\n
\n
\n
Trakt Scrobbling
\n
\n \n
\n
\n
\n
{ t('Calendar') }
\n
\n \n
\n
\n \n
\n
\n \n
\n
\n \n
\n
\n \n
\n
\n \n
\n
\n
\n
{ t('SETTINGS_NAV_PLAYER') }
\n
\n
\n
{ t('SETTINGS_SUBTITLES_LANGUAGE') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_SUBTITLES_SIZE') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_SUBTITLES_COLOR') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_SUBTITLES_COLOR_BACKGROUND') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_SUBTITLES_COLOR_OUTLINE') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_DEFAULT_AUDIO_TRACK') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_REWIND_FAST_FORWARD_DURATION') }
\n
\n \n
\n
\n
\n
{ t('AUTO_PLAY') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_NEXT_VIDEO_POPUP_DURATION') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_PLAY_IN_BACKGROUND') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_PLAY_IN_EXTERNAL_PLAYER') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_HWDEC') }
\n
\n \n
\n
\n
\n
{ t('SETTINGS_NAV_STREAMING') }
\n
\n \n
\n
\n
\n
{ t('STATUS') }
\n
\n
\n
\n {\n streamingServer.settings === null ?\n 'NotLoaded'\n :\n streamingServer.settings.type === 'Ready' ?\n t('SETTINGS_SERVER_STATUS_ONLINE')\n :\n streamingServer.settings.type === 'Error' ?\n `${t('SETTINGS_SERVER_STATUS_ERROR')}: (${streamingServer.settings.content})`\n :\n streamingServer.settings.type\n }\n
\n
\n
\n
\n
\n
Url
\n
\n
\n
{streamingServerUrlInput.value}
\n \n
\n
\n {\n cacheSizeSelect !== null ?\n
\n
\n
{ t('SETTINGS_SERVER_CACHE_SIZE') }
\n
\n \n
\n :\n null\n }\n {\n torrentProfileSelect !== null ?\n
\n
\n
{ t('SETTINGS_SERVER_TORRENT_PROFILE') }
\n
\n \n
\n :\n null\n }\n
\n
\n
{ t('SETTINGS_NAV_SHORTCUTS') }
\n
\n
\n
{ t('SETTINGS_SHORTCUT_PLAY_PAUSE') }
\n
\n
\n { t('SETTINGS_SHORTCUT_SPACE') }\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_SEEK_FORWARD') }
\n
\n
\n \n
{ t('SETTINGS_SHORTCUT_OR') }
\n ⇧ { t('SETTINGS_SHORTCUT_SHIFT') }\n
+
\n \n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_SEEK_BACKWARD') }
\n
\n
\n \n
{ t('SETTINGS_SHORTCUT_OR') }
\n ⇧ { t('SETTINGS_SHORTCUT_SHIFT') }\n
+
\n \n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_VOLUME_UP') }
\n
\n
\n \n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_VOLUME_DOWN') }
\n
\n
\n \n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_MENU_SUBTITLES') }
\n
\n
\n S\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_MENU_INFO') }
\n
\n
\n I\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_FULLSCREEN') }
\n
\n
\n F\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_NAVIGATE_MENUS') }
\n
\n
\n 1\n
{ t('SETTINGS_SHORTCUT_TO') }
\n 5\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_GO_TO_SEARCH') }
\n
\n
\n 0\n
\n
\n
\n
\n
{ t('SETTINGS_SHORTCUT_EXIT_BACK') }
\n
\n
\n { t('SETTINGS_SHORTCUT_ESC') }\n
\n
\n
\n
\n
\n {\n configureServerUrlModalOpen ?\n \n \n \n :\n null\n }\n \n );\n};\n\nconst SettingsFallback = () => (\n \n);\n\nmodule.exports = withCoreSuspender(Settings, SettingsFallback);\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Settings = require('./Settings');\n\nmodule.exports = Settings;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useServices } = require('stremio/services');\nconst { useModelState } = require('stremio/common');\n\nconst map = (dataExport) => ({\n ...dataExport,\n exportUrl: dataExport !== null && dataExport.exportUrl !== null && dataExport.exportUrl.type === 'Ready' ?\n dataExport.exportUrl.content\n :\n null\n});\n\nconst useDataExport = () => {\n const { core } = useServices();\n const loadDataExport = React.useCallback(() => {\n core.transport.dispatch({\n action: 'Load',\n args: {\n model: 'DataExport',\n }\n }, 'data_export');\n }, []);\n const dataExport = useModelState({ model: 'data_export', map });\n return [\n dataExport,\n loadDataExport\n ];\n};\n\nmodule.exports = useDataExport;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst { useTranslation } = require('react-i18next');\nconst { useServices } = require('stremio/services');\nconst { CONSTANTS, interfaceLanguages, languageNames } = require('stremio/common');\n\nconst useProfileSettingsInputs = (profile) => {\n const { t } = useTranslation();\n const { core } = useServices();\n // TODO combine those useMemo in one\n const interfaceLanguageSelect = React.useMemo(() => ({\n options: interfaceLanguages.map(({ name, codes }) => ({\n value: codes[0],\n label: name,\n })),\n selected: [\n interfaceLanguages.find(({ codes }) => codes[1] === profile.settings.interfaceLanguage)?.codes?.[0] || profile.settings.interfaceLanguage\n ],\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n interfaceLanguage: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const subtitlesLanguageSelect = React.useMemo(() => ({\n options: Object.keys(languageNames).map((code) => ({\n value: code,\n label: languageNames[code]\n })),\n selected: [profile.settings.subtitlesLanguage],\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n subtitlesLanguage: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const subtitlesSizeSelect = React.useMemo(() => ({\n options: CONSTANTS.SUBTITLES_SIZES.map((size) => ({\n value: `${size}`,\n label: `${size}%`\n })),\n selected: [`${profile.settings.subtitlesSize}`],\n renderLabelText: () => {\n return `${profile.settings.subtitlesSize}%`;\n },\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n subtitlesSize: parseInt(event.value, 10)\n }\n }\n });\n }\n }), [profile.settings]);\n const subtitlesTextColorInput = React.useMemo(() => ({\n value: profile.settings.subtitlesTextColor,\n onChange: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n subtitlesTextColor: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const subtitlesBackgroundColorInput = React.useMemo(() => ({\n value: profile.settings.subtitlesBackgroundColor,\n onChange: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n subtitlesBackgroundColor: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const subtitlesOutlineColorInput = React.useMemo(() => ({\n value: profile.settings.subtitlesOutlineColor,\n onChange: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n subtitlesOutlineColor: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const audioLanguageSelect = React.useMemo(() => ({\n options: Object.keys(languageNames).map((code) => ({\n value: code,\n label: languageNames[code]\n })),\n selected: [profile.settings.audioLanguage],\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n audioLanguage: event.value\n }\n }\n });\n }\n }), [profile.settings]);\n const seekTimeDurationSelect = React.useMemo(() => ({\n options: CONSTANTS.SEEK_TIME_DURATIONS.map((size) => ({\n value: `${size}`,\n label: `${size / 1000} ${t('SECONDS')}`\n })),\n selected: [`${profile.settings.seekTimeDuration}`],\n renderLabelText: () => {\n return `${profile.settings.seekTimeDuration / 1000} ${t('SECONDS')}`;\n },\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n seekTimeDuration: parseInt(event.value, 10)\n }\n }\n });\n }\n }), [profile.settings]);\n const nextVideoPopupDurationSelect = React.useMemo(() => ({\n options: CONSTANTS.NEXT_VIDEO_POPUP_DURATIONS.map((duration) => ({\n value: `${duration}`,\n label: duration === 0 ? 'Disabled' : `${duration / 1000} ${t('SECONDS')}`\n })),\n selected: [`${profile.settings.nextVideoNotificationDuration}`],\n renderLabelText: () => {\n return profile.settings.nextVideoNotificationDuration === 0 ?\n 'Disabled'\n :\n `${profile.settings.nextVideoNotificationDuration / 1000} ${t('SECONDS')}`;\n },\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n nextVideoNotificationDuration: parseInt(event.value, 10)\n }\n }\n });\n }\n }), [profile.settings]);\n const bingeWatchingCheckbox = React.useMemo(() => ({\n checked: profile.settings.bingeWatching,\n onClick: () => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n bingeWatching: !profile.settings.bingeWatching\n }\n }\n });\n }\n }), [profile.settings]);\n const playInBackgroundCheckbox = React.useMemo(() => ({\n checked: profile.settings.playInBackground,\n onClick: () => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n playInBackground: !profile.settings.playInBackground\n }\n }\n });\n }\n }), [profile.settings]);\n const playInExternalPlayerCheckbox = React.useMemo(() => ({\n checked: profile.settings.playInExternalPlayer,\n onClick: () => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n playInExternalPlayer: !profile.settings.playInExternalPlayer\n }\n }\n });\n }\n }), [profile.settings]);\n const hardwareDecodingCheckbox = React.useMemo(() => ({\n checked: profile.settings.hardwareDecoding,\n onClick: () => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n hardwareDecoding: !profile.settings.hardwareDecoding\n }\n }\n });\n }\n }), [profile.settings]);\n const streamingServerUrlInput = React.useMemo(() => ({\n value: profile.settings.streamingServerUrl,\n onChange: (value) => {\n core.transport.dispatch({\n action: 'Ctx',\n args: {\n action: 'UpdateSettings',\n args: {\n ...profile.settings,\n streamingServerUrl: value\n }\n }\n });\n }\n }), [profile.settings]);\n return {\n interfaceLanguageSelect,\n subtitlesLanguageSelect,\n subtitlesSizeSelect,\n subtitlesTextColorInput,\n subtitlesBackgroundColorInput,\n subtitlesOutlineColorInput,\n audioLanguageSelect,\n seekTimeDurationSelect,\n nextVideoPopupDurationSelect,\n bingeWatchingCheckbox,\n playInBackgroundCheckbox,\n playInExternalPlayerCheckbox,\n hardwareDecodingCheckbox,\n streamingServerUrlInput\n };\n};\n\nmodule.exports = useProfileSettingsInputs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst isEqual = require('lodash.isequal');\nconst { useServices } = require('stremio/services');\n\nconst CACHE_SIZES = [0, 2147483648, 5368709120, 10737418240, null];\n\nconst cacheSizeToString = (size) => {\n return size === null ?\n 'Infinite'\n :\n size === 0 ?\n 'No caching'\n :\n `${Math.ceil(((size / 1024 / 1024 / 1024) + Number.EPSILON) * 100) / 100}GiB`;\n};\n\nconst TORRENT_PROFILES = {\n default: {\n btDownloadSpeedHardLimit: 3670016,\n btDownloadSpeedSoftLimit: 2621440,\n btHandshakeTimeout: 20000,\n btMaxConnections: 55,\n btMinPeersForStable: 5,\n btRequestTimeout: 4000\n },\n soft: {\n btDownloadSpeedHardLimit: 1677721.6,\n btDownloadSpeedSoftLimit: 1677721.6,\n btHandshakeTimeout: 20000,\n btMaxConnections: 35,\n btMinPeersForStable: 5,\n btRequestTimeout: 4000\n },\n fast: {\n btDownloadSpeedHardLimit: 39321600,\n btDownloadSpeedSoftLimit: 4194304,\n btHandshakeTimeout: 20000,\n btMaxConnections: 200,\n btMinPeersForStable: 10,\n btRequestTimeout: 4000\n },\n 'ultra fast': {\n btDownloadSpeedHardLimit: 78643200,\n btDownloadSpeedSoftLimit: 8388608,\n btHandshakeTimeout: 25000,\n btMaxConnections: 400,\n btMinPeersForStable: 10,\n btRequestTimeout: 6000\n }\n};\n\nconst useStreamingServerSettingsInputs = (streamingServer) => {\n const { core } = useServices();\n // TODO combine those useMemo in one\n const cacheSizeSelect = React.useMemo(() => {\n if (streamingServer.settings === null || streamingServer.settings.type !== 'Ready') {\n return null;\n }\n\n return {\n options: CACHE_SIZES.map((size) => ({\n label: cacheSizeToString(size),\n value: JSON.stringify(size)\n })),\n selected: [JSON.stringify(streamingServer.settings.content.cacheSize)],\n renderLabelText: () => {\n return cacheSizeToString(streamingServer.settings.content.cacheSize);\n },\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'UpdateSettings',\n args: {\n ...streamingServer.settings.content,\n cacheSize: JSON.parse(event.value)\n }\n }\n });\n }\n };\n }, [streamingServer.settings]);\n const torrentProfileSelect = React.useMemo(() => {\n if (streamingServer.settings === null || streamingServer.settings.type !== 'Ready') {\n return null;\n }\n\n const selectedTorrentProfile = {\n btDownloadSpeedHardLimit: streamingServer.settings.content.btDownloadSpeedHardLimit,\n btDownloadSpeedSoftLimit: streamingServer.settings.content.btDownloadSpeedSoftLimit,\n btHandshakeTimeout: streamingServer.settings.content.btHandshakeTimeout,\n btMaxConnections: streamingServer.settings.content.btMaxConnections,\n btMinPeersForStable: streamingServer.settings.content.btMinPeersForStable,\n btRequestTimeout: streamingServer.settings.content.btRequestTimeout\n };\n const isCustomTorrentProfileSelected = Object.values(TORRENT_PROFILES).every((torrentProfile) => {\n return !isEqual(torrentProfile, selectedTorrentProfile);\n });\n return {\n options: Object.keys(TORRENT_PROFILES)\n .map((profileName) => ({\n label: profileName,\n value: JSON.stringify(TORRENT_PROFILES[profileName])\n }))\n .concat(\n isCustomTorrentProfileSelected ?\n [{\n label: 'custom',\n value: JSON.stringify(selectedTorrentProfile)\n }]\n :\n []\n ),\n selected: [JSON.stringify(selectedTorrentProfile)],\n onSelect: (event) => {\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'UpdateSettings',\n args: {\n ...streamingServer.settings.content,\n ...JSON.parse(event.value)\n }\n }\n });\n }\n };\n }, [streamingServer.settings]);\n return { cacheSizeSelect, torrentProfileSelect };\n};\n\nmodule.exports = useStreamingServerSettingsInputs;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Addons = require('./Addons');\nconst Board = require('./Board');\nconst Discover = require('./Discover');\nconst Library = require('./Library');\nconst MetaDetails = require('./MetaDetails');\nconst NotFound = require('./NotFound');\nconst Search = require('./Search');\nconst Settings = require('./Settings');\nconst Player = require('./Player');\nconst Intro = require('./Intro');\n\nmodule.exports = {\n Addons,\n Board,\n Discover,\n Library,\n MetaDetails,\n NotFound,\n Search,\n Settings,\n Player,\n Intro\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\nconst ChromecastTransport = require('./ChromecastTransport');\n\nfunction Chromecast() {\n let active = false;\n let error = null;\n let starting = false;\n let transport = null;\n\n const events = new EventEmitter();\n\n function onTransportInit() {\n active = true;\n error = null;\n starting = false;\n onStateChanged();\n }\n function onTransportInitError(args) {\n console.error(args);\n active = false;\n error = new Error('Google Cast API not available', { cause: args });\n starting = false;\n onStateChanged();\n transport = null;\n }\n function onStateChanged() {\n events.emit('stateChanged');\n }\n\n Object.defineProperties(this, {\n active: {\n configurable: false,\n enumerable: true,\n get: function() {\n return active;\n }\n },\n error: {\n configurable: false,\n enumerable: true,\n get: function() {\n return error;\n }\n },\n starting: {\n configurable: false,\n enumerable: true,\n get: function() {\n return starting;\n }\n },\n transport: {\n configurable: false,\n enumerable: true,\n get: function() {\n return transport;\n }\n }\n });\n\n this.start = function() {\n if (active || error instanceof Error || starting) {\n return;\n }\n\n starting = true;\n transport = new ChromecastTransport();\n transport.on('init', onTransportInit);\n transport.on('init-error', onTransportInitError);\n onStateChanged();\n };\n this.stop = function() {\n active = false;\n error = null;\n starting = false;\n onStateChanged();\n if (transport !== null) {\n transport.removeAllListeners();\n transport = null;\n }\n };\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n}\n\nmodule.exports = Chromecast;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\nconst hat = require('hat');\n\nconst MESSAGE_NAMESPACE = 'urn:x-cast:com.stremio';\nconst CHUNK_SIZE = 20000;\n\nlet castAPIAvailable = null;\nconst castAPIEvents = new EventEmitter();\nwindow['__onGCastApiAvailable'] = function(available) {\n delete window['__onGCastApiAvailable'];\n castAPIAvailable = !!available;\n castAPIEvents.emit('availabilityChanged');\n};\n\nconst initialize = () => {\n return new Promise((resolve, reject) => {\n function onCastAPIAvailabilityChanged() {\n castAPIEvents.off('availabilityChanged', onCastAPIAvailabilityChanged);\n if (castAPIAvailable) {\n resolve();\n } else {\n reject(new Error('window.cast api not available'));\n }\n }\n if (castAPIAvailable !== null) {\n onCastAPIAvailabilityChanged();\n } else {\n castAPIEvents.on('availabilityChanged', onCastAPIAvailabilityChanged);\n }\n });\n};\n\nfunction ChromecastTransport() {\n const events = new EventEmitter();\n const messages = {};\n\n initialize()\n .then(() => {\n cast.framework.CastContext.getInstance().addEventListener(\n cast.framework.CastContextEventType.CAST_STATE_CHANGED,\n onCastStateChanged\n );\n cast.framework.CastContext.getInstance().addEventListener(\n cast.framework.CastContextEventType.SESSION_STATE_CHANGED,\n onSesstionStateChanged\n );\n })\n .then(() => {\n try {\n events.emit('init');\n } catch (error) {\n console.error('ChromecastTransport', error);\n }\n })\n .catch((error) => {\n events.emit('init-error', error);\n });\n\n function onMessage(_, message) {\n try {\n const { id, chunk, index, length } = JSON.parse(message);\n messages[id] = messages[id] || [];\n messages[id][index] = chunk;\n if (Object.keys(messages[id]).length === length) {\n const parsedMessage = JSON.parse(messages[id].join(''));\n delete messages[id];\n events.emit('message', parsedMessage);\n }\n } catch (error) {\n events.emit('message-error', error);\n }\n }\n function onApplicationStatusChanged(event) {\n events.emit(cast.framework.CastSession.APPLICATION_STATUS_CHANGED, event);\n }\n function onApplicationMetadataChanged(event) {\n events.emit(cast.framework.CastSession.APPLICATION_METADATA_CHANGED, event);\n }\n function onActiveInputStateChanged(event) {\n events.emit(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED, event);\n }\n function onVolumeChanged(event) {\n events.emit(cast.framework.CastSession.VOLUME_CHANGED, event);\n }\n function onMediaSessionChanged(event) {\n events.emit(cast.framework.CastSession.MEDIA_SESSION, event);\n }\n function onCastStateChanged(event) {\n events.emit(cast.framework.CastContextEventType.CAST_STATE_CHANGED, event);\n }\n function onSesstionStateChanged(event) {\n events.emit(cast.framework.CastContextEventType.SESSION_STATE_CHANGED, event);\n switch (event.sessionState) {\n case cast.framework.SessionState.SESSION_STARTED: {\n event.session.addMessageListener(MESSAGE_NAMESPACE, onMessage);\n event.session.addEventListener(cast.framework.CastSession.APPLICATION_STATUS_CHANGED, onApplicationStatusChanged);\n event.session.addEventListener(cast.framework.CastSession.APPLICATION_METADATA_CHANGED, onApplicationMetadataChanged);\n event.session.addEventListener(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED, onActiveInputStateChanged);\n event.session.addEventListener(cast.framework.CastSession.VOLUME_CHANGED, onVolumeChanged);\n event.session.addEventListener(cast.framework.CastSession.MEDIA_SESSION, onMediaSessionChanged);\n break;\n }\n case cast.framework.SessionState.SESSION_ENDED: {\n event.session.removeMessageListener(MESSAGE_NAMESPACE, onMessage);\n event.session.removeEventListener(cast.framework.CastSession.APPLICATION_STATUS_CHANGED, onApplicationStatusChanged);\n event.session.removeEventListener(cast.framework.CastSession.APPLICATION_METADATA_CHANGED, onApplicationMetadataChanged);\n event.session.removeEventListener(cast.framework.CastSession.ACTIVE_INPUT_STATE_CHANGED, onActiveInputStateChanged);\n event.session.removeEventListener(cast.framework.CastSession.VOLUME_CHANGED, onVolumeChanged);\n event.session.removeEventListener(cast.framework.CastSession.MEDIA_SESSION, onMediaSessionChanged);\n break;\n }\n }\n }\n\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n this.removeAllListeners = function() {\n events.removeAllListeners();\n };\n this.getCastState = function() {\n return cast.framework.CastContext.getInstance().getCastState();\n };\n this.getSessionState = function() {\n return cast.framework.CastContext.getInstance().getSessionState();\n };\n this.getCastDevice = function() {\n const session = cast.framework.CastContext.getInstance().getCurrentSession();\n if (session !== null) {\n return session.getCastDevice();\n }\n\n return null;\n };\n this.setOptions = function(options) {\n cast.framework.CastContext.getInstance().setOptions(options);\n };\n this.requestSession = function() {\n return cast.framework.CastContext.getInstance().requestSession();\n };\n this.endCurrentSession = function(stopCasting) {\n cast.framework.CastContext.getInstance().endCurrentSession(stopCasting);\n };\n this.sendMessage = function(message) {\n const castSession = cast.framework.CastContext.getInstance().getCurrentSession();\n if (castSession !== null) {\n const serializedMessage = JSON.stringify(message);\n const chunksCount = Math.ceil(serializedMessage.length / CHUNK_SIZE);\n const chunks = [];\n for (let i = 0; i < chunksCount; i++) {\n const start = i * CHUNK_SIZE;\n const chunk = serializedMessage.slice(start, start + CHUNK_SIZE);\n chunks.push(chunk);\n }\n const id = hat();\n return Promise.all(chunks.map((chunk, index) => {\n return castSession.sendMessage(MESSAGE_NAMESPACE, {\n id,\n chunk,\n index,\n length: chunks.length\n });\n }));\n } else {\n return Promise.reject(new Error('Session not started'));\n }\n };\n}\n\nmodule.exports = ChromecastTransport;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Chromecast = require('./Chromecast');\n\nmodule.exports = Chromecast;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\nconst CoreTransport = require('./CoreTransport');\n\nfunction Core(args) {\n let active = false;\n let error = null;\n let starting = false;\n let transport = null;\n\n const events = new EventEmitter();\n\n function onTransportInit() {\n active = true;\n error = null;\n starting = false;\n onStateChanged();\n }\n function onTransportError(args) {\n console.error(args);\n active = false;\n error = new Error('Stremio Core Transport initialization failed', { cause: args });\n starting = false;\n onStateChanged();\n transport = null;\n }\n function onStateChanged() {\n events.emit('stateChanged');\n }\n\n Object.defineProperties(this, {\n active: {\n configurable: false,\n enumerable: true,\n get: function() {\n return active;\n }\n },\n error: {\n configurable: false,\n enumerable: true,\n get: function() {\n return error;\n }\n },\n starting: {\n configurable: false,\n enumerable: true,\n get: function() {\n return starting;\n }\n },\n transport: {\n configurable: false,\n enumerable: true,\n get: function() {\n return transport;\n }\n }\n });\n\n this.start = function() {\n if (active || error instanceof Error || starting) {\n return;\n }\n\n starting = true;\n transport = new CoreTransport(args);\n transport.on('init', onTransportInit);\n transport.on('error', onTransportError);\n onStateChanged();\n };\n this.stop = function() {\n active = false;\n error = null;\n starting = false;\n onStateChanged();\n if (transport !== null) {\n transport.removeAllListeners();\n transport = null;\n }\n };\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n}\n\nmodule.exports = Core;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\nconst Bridge = require('@stremio/stremio-core-web/bridge');\n\nfunction CoreTransport(args) {\n const events = new EventEmitter();\n const worker = new Worker(`${process.env.COMMIT_HASH}/scripts/worker.js`);\n const bridge = new Bridge(window, worker);\n\n window.onCoreEvent = ({ name, args }) => {\n try {\n events.emit(name, args);\n } catch (error) {\n console.error('CoreTransport', error);\n }\n };\n\n bridge.call(['init'], [args])\n .then(() => {\n try {\n events.emit('init');\n } catch (error) {\n console.error('CoreTransport', error);\n }\n })\n .catch((error) => {\n events.emit('error', error);\n });\n\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n this.removeAllListeners = function() {\n events.removeAllListeners();\n };\n this.getState = async function(field) {\n return bridge.call(['getState'], [field]);\n };\n this.getDebugState = async function() {\n return bridge.call(['getDebugState'], []);\n };\n this.dispatch = async function(action, field) {\n return bridge.call(['dispatch'], [action, field, location.hash]);\n };\n this.analytics = async function(event) {\n return bridge.call(['analytics'], [event, location.hash]);\n };\n this.decodeStream = async function(stream) {\n return bridge.call(['decodeStream'], [stream]);\n };\n}\n\nmodule.exports = CoreTransport;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Core = require('./Core');\n\nmodule.exports = Core;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\n\nfunction DragAndDrop({ core }) {\n let active = false;\n\n const events = new EventEmitter();\n\n function onDragOver(event) {\n event.preventDefault();\n }\n async function onDrop(event) {\n event.preventDefault();\n if (event.dataTransfer.files instanceof FileList && event.dataTransfer.files.length > 0) {\n const file = event.dataTransfer.files[0];\n switch (file.type) {\n case 'application/x-bittorrent': {\n try {\n const torrent = await file.arrayBuffer();\n core.transport.dispatch({\n action: 'StreamingServer',\n args: {\n action: 'CreateTorrent',\n args: Array.from(new Uint8Array(torrent))\n }\n });\n } catch (error) {\n events.emit('error', {\n message: 'Failed to process file',\n file: {\n name: file.name,\n type: file.type\n }\n });\n }\n break;\n }\n default: {\n events.emit('error', {\n message: 'Unsupported file',\n file: {\n name: file.name,\n type: file.type\n }\n });\n }\n }\n }\n }\n function onStateChanged() {\n events.emit('stateChanged');\n }\n\n Object.defineProperties(this, {\n active: {\n configurable: false,\n enumerable: true,\n get: function() {\n return active;\n }\n }\n });\n\n this.start = function() {\n if (active) {\n return;\n }\n\n window.addEventListener('dragover', onDragOver);\n window.addEventListener('drop', onDrop);\n active = true;\n onStateChanged();\n };\n this.stop = function() {\n window.removeEventListener('dragover', onDragOver);\n window.removeEventListener('drop', onDrop);\n active = false;\n onStateChanged();\n };\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n}\n\nmodule.exports = DragAndDrop;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst DragAndDrop = require('./DragAndDrop');\n\nmodule.exports = DragAndDrop;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\n\nfunction KeyboardShortcuts() {\n let active = false;\n\n const events = new EventEmitter();\n\n function onKeyDown(event) {\n if (event.keyboardShortcutPrevented || event.target.tagName === 'INPUT' || event.ctrlKey || event.altKey || event.shiftKey || event.metaKey) {\n return;\n }\n\n switch (event.code) {\n case 'Digit0': {\n event.preventDefault();\n window.location = '#/search';\n break;\n }\n case 'Digit1': {\n event.preventDefault();\n window.location = '#/';\n break;\n }\n case 'Digit2': {\n event.preventDefault();\n window.location = '#/discover';\n break;\n }\n case 'Digit3': {\n event.preventDefault();\n window.location = '#/library';\n break;\n }\n case 'Digit4': {\n event.preventDefault();\n window.location = '#/settings';\n break;\n }\n case 'Digit5': {\n event.preventDefault();\n window.location = '#/addons';\n break;\n }\n case 'Backspace': {\n event.preventDefault();\n if (event.ctrlKey) {\n window.history.forward();\n } else {\n window.history.back();\n }\n\n break;\n }\n case 'KeyF': {\n event.preventDefault();\n if (document.fullscreenElement === document.documentElement) {\n document.exitFullscreen();\n } else {\n document.documentElement.requestFullscreen();\n }\n\n break;\n }\n }\n }\n function onStateChanged() {\n events.emit('stateChanged');\n }\n\n Object.defineProperties(this, {\n active: {\n configurable: false,\n enumerable: true,\n get: function() {\n return active;\n }\n }\n });\n\n this.start = function() {\n if (active) {\n return;\n }\n\n window.addEventListener('keydown', onKeyDown);\n active = true;\n onStateChanged();\n };\n this.stop = function() {\n window.removeEventListener('keydown', onKeyDown);\n active = false;\n onStateChanged();\n };\n}\n\nmodule.exports = KeyboardShortcuts;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst KeyboardShortcuts = require('./KeyboardShortcuts');\n\nmodule.exports = KeyboardShortcuts;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\n\nconst ServicesContext = React.createContext({});\n\nServicesContext.displayName = 'ServicesContext';\n\nmodule.exports = ServicesContext;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst PropTypes = require('prop-types');\nconst ServicesContext = require('./ServicesContext');\n\nconst ServicesProvider = ({ services = {}, children }) => {\n return (\n \n {children}\n \n );\n};\n\nServicesProvider.propTypes = {\n services: PropTypes.object,\n children: PropTypes.oneOfType([\n PropTypes.arrayOf(PropTypes.node),\n PropTypes.node\n ])\n};\n\nmodule.exports = ServicesProvider;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst ServicesProvider = require('./ServicesProvider');\nconst useServices = require('./useServices');\n\nmodule.exports = {\n ServicesProvider,\n useServices\n};\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst React = require('react');\nconst ServicesContext = require('./ServicesContext');\n\nconst useServices = () => {\n return React.useContext(ServicesContext);\n};\n\nmodule.exports = useServices;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\nconst ShellTransport = require('./ShellTransport');\n\nfunction Shell() {\n let active = false;\n let error = null;\n let starting = false;\n let transport = null;\n\n const events = new EventEmitter();\n\n function onTransportInit() {\n active = true;\n error = null;\n starting = false;\n onStateChanged();\n }\n function onTransportInitError(err) {\n console.error(err);\n active = false;\n error = new Error(err);\n starting = false;\n onStateChanged();\n transport = null;\n }\n\n function onStateChanged() {\n events.emit('stateChanged');\n }\n\n Object.defineProperties(this, {\n active: {\n configurable: false,\n enumerable: true,\n get: function() {\n return active;\n }\n },\n error: {\n configurable: false,\n enumerable: true,\n get: function() {\n return error;\n }\n },\n starting: {\n configurable: false,\n enumerable: true,\n get: function() {\n return starting;\n }\n },\n transport: {\n configurable: false,\n enumerable: true,\n get: function() {\n return transport;\n }\n }\n });\n\n this.start = function() {\n if (active || error instanceof Error || starting) {\n return;\n }\n\n active = false;\n starting = true;\n transport = new ShellTransport();\n transport.on('init', onTransportInit);\n transport.on('init-error', onTransportInitError);\n onStateChanged();\n };\n this.stop = function() {\n active = false;\n error = null;\n starting = false;\n onStateChanged();\n };\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n}\n\nmodule.exports = Shell;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst EventEmitter = require('eventemitter3');\n\nlet shellAvailable = false;\nconst shellEvents = new EventEmitter();\n\nconst QtMsgTypes = {\n signal: 1,\n propertyUpdate: 2,\n init: 3,\n idle: 4,\n debug: 5,\n invokeMethod: 6,\n connectToSignal: 7,\n disconnectFromSignal: 8,\n setProperty: 9,\n response: 10,\n};\nconst QtObjId = 'transport'; // the ID of our transport object\n\nwindow.initShellComm = function () {\n delete window.initShellComm;\n shellEvents.emit('availabilityChanged');\n};\n\nconst initialize = () => {\n if(!window.qt) return Promise.reject('Qt API not found');\n return new Promise((resolve) => {\n function onShellAvailabilityChanged() {\n shellEvents.off('availabilityChanged', onShellAvailabilityChanged);\n shellAvailable = true;\n resolve();\n }\n if (shellAvailable) {\n onShellAvailabilityChanged();\n } else {\n shellEvents.on('availabilityChanged', onShellAvailabilityChanged);\n }\n });\n};\n\nfunction ShellTransport() {\n const events = new EventEmitter();\n\n this.props = {};\n\n const shell = this;\n initialize()\n .then(() => {\n const transport = window.qt && window.qt.webChannelTransport;\n if (!transport) throw 'no viable transport found (qt.webChannelTransport)';\n\n let id = 0;\n function send(msg) {\n msg.id = id++;\n transport.send(JSON.stringify(msg));\n }\n\n transport.onmessage = function (message) {\n const msg = JSON.parse(message.data);\n if (msg.id === 0) {\n const obj = msg.data[QtObjId];\n\n obj.properties.slice(1).forEach(function (prop) {\n shell.props[prop[1]] = prop[3];\n });\n if (typeof shell.props.shellVersion === 'string') {\n shell.shellVersionArr = (\n shell.props.shellVersion.match(/(\\d+)\\.(\\d+)\\.(\\d+)/) || []\n )\n .slice(1, 4)\n .map(Number);\n }\n events.emit('received-props', shell.props);\n\n obj.signals.forEach(function (sig) {\n send({\n type: QtMsgTypes.connectToSignal,\n object: QtObjId,\n signal: sig[1],\n });\n });\n\n const onEvent = obj.methods.filter(function (x) {\n return x[0] === 'onEvent';\n })[0];\n\n shell.send = function (ev, args) {\n send({\n type: QtMsgTypes.invokeMethod,\n object: QtObjId,\n method: onEvent[1],\n args: [ev, args || {}],\n });\n };\n\n shell.send('app-ready', {}); // signal that we're ready to take events\n }\n\n if (msg.object === QtObjId && msg.type === QtMsgTypes.signal)\n events.emit(msg.args[0], msg.args[1]);\n events.emit('init');\n };\n send({ type: QtMsgTypes.init });\n }) .catch((error) => {\n events.emit('init-error', error);\n });\n\n this.on = function(name, listener) {\n events.on(name, listener);\n };\n this.off = function(name, listener) {\n events.off(name, listener);\n };\n this.removeAllListeners = function() {\n events.removeAllListeners();\n };\n}\n\nmodule.exports = ShellTransport;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Shell = require('./Shell');\n\nmodule.exports = Shell;\n","// Copyright (C) 2017-2022 Smart code 203358507\n\nconst Chromecast = require('./Chromecast');\nconst Core = require('./Core');\nconst DragAndDrop = require('./DragAndDrop');\nconst KeyboardShortcuts = require('./KeyboardShortcuts');\nconst { ServicesProvider, useServices } = require('./ServicesContext');\nconst Shell = require('./Shell');\n\nmodule.exports = {\n Chromecast,\n Core,\n DragAndDrop,\n KeyboardShortcuts,\n ServicesProvider,\n useServices,\n Shell\n};\n","'use strict'\n\nexports.byteLength = byteLength\nexports.toByteArray = toByteArray\nexports.fromByteArray = fromByteArray\n\nvar lookup = []\nvar revLookup = []\nvar Arr = typeof Uint8Array !== 'undefined' ? Uint8Array : Array\n\nvar code = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'\nfor (var i = 0, len = code.length; i < len; ++i) {\n lookup[i] = code[i]\n revLookup[code.charCodeAt(i)] = i\n}\n\n// Support decoding URL-safe base64 strings, as Node.js does.\n// See: https://en.wikipedia.org/wiki/Base64#URL_applications\nrevLookup['-'.charCodeAt(0)] = 62\nrevLookup['_'.charCodeAt(0)] = 63\n\nfunction getLens (b64) {\n var len = b64.length\n\n if (len % 4 > 0) {\n throw new Error('Invalid string. Length must be a multiple of 4')\n }\n\n // Trim off extra bytes after placeholder bytes are found\n // See: https://github.com/beatgammit/base64-js/issues/42\n var validLen = b64.indexOf('=')\n if (validLen === -1) validLen = len\n\n var placeHoldersLen = validLen === len\n ? 0\n : 4 - (validLen % 4)\n\n return [validLen, placeHoldersLen]\n}\n\n// base64 is 4/3 + up to two characters of the original data\nfunction byteLength (b64) {\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction _byteLength (b64, validLen, placeHoldersLen) {\n return ((validLen + placeHoldersLen) * 3 / 4) - placeHoldersLen\n}\n\nfunction toByteArray (b64) {\n var tmp\n var lens = getLens(b64)\n var validLen = lens[0]\n var placeHoldersLen = lens[1]\n\n var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen))\n\n var curByte = 0\n\n // if there are placeholders, only get up to the last complete 4 chars\n var len = placeHoldersLen > 0\n ? validLen - 4\n : validLen\n\n var i\n for (i = 0; i < len; i += 4) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 18) |\n (revLookup[b64.charCodeAt(i + 1)] << 12) |\n (revLookup[b64.charCodeAt(i + 2)] << 6) |\n revLookup[b64.charCodeAt(i + 3)]\n arr[curByte++] = (tmp >> 16) & 0xFF\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 2) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 2) |\n (revLookup[b64.charCodeAt(i + 1)] >> 4)\n arr[curByte++] = tmp & 0xFF\n }\n\n if (placeHoldersLen === 1) {\n tmp =\n (revLookup[b64.charCodeAt(i)] << 10) |\n (revLookup[b64.charCodeAt(i + 1)] << 4) |\n (revLookup[b64.charCodeAt(i + 2)] >> 2)\n arr[curByte++] = (tmp >> 8) & 0xFF\n arr[curByte++] = tmp & 0xFF\n }\n\n return arr\n}\n\nfunction tripletToBase64 (num) {\n return lookup[num >> 18 & 0x3F] +\n lookup[num >> 12 & 0x3F] +\n lookup[num >> 6 & 0x3F] +\n lookup[num & 0x3F]\n}\n\nfunction encodeChunk (uint8, start, end) {\n var tmp\n var output = []\n for (var i = start; i < end; i += 3) {\n tmp =\n ((uint8[i] << 16) & 0xFF0000) +\n ((uint8[i + 1] << 8) & 0xFF00) +\n (uint8[i + 2] & 0xFF)\n output.push(tripletToBase64(tmp))\n }\n return output.join('')\n}\n\nfunction fromByteArray (uint8) {\n var tmp\n var len = uint8.length\n var extraBytes = len % 3 // if we have 1 byte left, pad 2 bytes\n var parts = []\n var maxChunkLength = 16383 // must be multiple of 3\n\n // go through the array every three bytes, we'll deal with trailing stuff later\n for (var i = 0, len2 = len - extraBytes; i < len2; i += maxChunkLength) {\n parts.push(encodeChunk(uint8, i, (i + maxChunkLength) > len2 ? len2 : (i + maxChunkLength)))\n }\n\n // pad the end with zeros, but make sure to not forget the extra bytes\n if (extraBytes === 1) {\n tmp = uint8[len - 1]\n parts.push(\n lookup[tmp >> 2] +\n lookup[(tmp << 4) & 0x3F] +\n '=='\n )\n } else if (extraBytes === 2) {\n tmp = (uint8[len - 2] << 8) + uint8[len - 1]\n parts.push(\n lookup[tmp >> 10] +\n lookup[(tmp >> 4) & 0x3F] +\n lookup[(tmp << 2) & 0x3F] +\n '='\n )\n }\n\n return parts.join('')\n}\n","module.exports = parseRange\nmodule.exports.parse = parseRange\nmodule.exports.compose = composeRange\n\nfunction composeRange (range) {\n return range\n .reduce((acc, cur, idx, arr) => {\n if (idx === 0 || cur !== arr[idx - 1] + 1) acc.push([])\n acc[acc.length - 1].push(cur)\n return acc\n }, [])\n .map((cur) => {\n return cur.length > 1 ? `${cur[0]}-${cur[cur.length - 1]}` : `${cur[0]}`\n })\n}\n\nfunction parseRange (range) {\n const generateRange = (start, end = start) => Array.from({ length: end - start + 1 }, (cur, idx) => idx + start)\n\n return range\n .reduce((acc, cur, idx, arr) => {\n const r = cur.split('-').map(cur => parseInt(cur))\n return acc.concat(generateRange(...r))\n }, [])\n}\n","!function(e,t){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=t():\"function\"==typeof define&&define.amd?define([],t):\"object\"==typeof exports?exports.bowser=t():e.bowser=t()}(this,(function(){return function(e){var t={};function r(n){if(t[n])return t[n].exports;var i=t[n]={i:n,l:!1,exports:{}};return e[n].call(i.exports,i,i.exports,r),i.l=!0,i.exports}return r.m=e,r.c=t,r.d=function(e,t,n){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},r.r=function(e){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(e,\"__esModule\",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&\"object\"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,\"default\",{enumerable:!0,value:e}),2&t&&\"string\"!=typeof e)for(var i in e)r.d(n,i,function(t){return e[t]}.bind(null,i));return n},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,\"a\",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p=\"\",r(r.s=90)}({17:function(e,t,r){\"use strict\";t.__esModule=!0,t.default=void 0;var n=r(18),i=function(){function e(){}return e.getFirstMatch=function(e,t){var r=t.match(e);return r&&r.length>0&&r[1]||\"\"},e.getSecondMatch=function(e,t){var r=t.match(e);return r&&r.length>1&&r[2]||\"\"},e.matchAndReturnConst=function(e,t,r){if(e.test(t))return r},e.getWindowsVersionName=function(e){switch(e){case\"NT\":return\"NT\";case\"XP\":return\"XP\";case\"NT 5.0\":return\"2000\";case\"NT 5.1\":return\"XP\";case\"NT 5.2\":return\"2003\";case\"NT 6.0\":return\"Vista\";case\"NT 6.1\":return\"7\";case\"NT 6.2\":return\"8\";case\"NT 6.3\":return\"8.1\";case\"NT 10.0\":return\"10\";default:return}},e.getMacOSVersionName=function(e){var t=e.split(\".\").splice(0,2).map((function(e){return parseInt(e,10)||0}));if(t.push(0),10===t[0])switch(t[1]){case 5:return\"Leopard\";case 6:return\"Snow Leopard\";case 7:return\"Lion\";case 8:return\"Mountain Lion\";case 9:return\"Mavericks\";case 10:return\"Yosemite\";case 11:return\"El Capitan\";case 12:return\"Sierra\";case 13:return\"High Sierra\";case 14:return\"Mojave\";case 15:return\"Catalina\";default:return}},e.getAndroidVersionName=function(e){var t=e.split(\".\").splice(0,2).map((function(e){return parseInt(e,10)||0}));if(t.push(0),!(1===t[0]&&t[1]<5))return 1===t[0]&&t[1]<6?\"Cupcake\":1===t[0]&&t[1]>=6?\"Donut\":2===t[0]&&t[1]<2?\"Eclair\":2===t[0]&&2===t[1]?\"Froyo\":2===t[0]&&t[1]>2?\"Gingerbread\":3===t[0]?\"Honeycomb\":4===t[0]&&t[1]<1?\"Ice Cream Sandwich\":4===t[0]&&t[1]<4?\"Jelly Bean\":4===t[0]&&t[1]>=4?\"KitKat\":5===t[0]?\"Lollipop\":6===t[0]?\"Marshmallow\":7===t[0]?\"Nougat\":8===t[0]?\"Oreo\":9===t[0]?\"Pie\":void 0},e.getVersionPrecision=function(e){return e.split(\".\").length},e.compareVersions=function(t,r,n){void 0===n&&(n=!1);var i=e.getVersionPrecision(t),s=e.getVersionPrecision(r),a=Math.max(i,s),o=0,u=e.map([t,r],(function(t){var r=a-e.getVersionPrecision(t),n=t+new Array(r+1).join(\".0\");return e.map(n.split(\".\"),(function(e){return new Array(20-e.length).join(\"0\")+e})).reverse()}));for(n&&(o=a-Math.min(i,s)),a-=1;a>=o;){if(u[0][a]>u[1][a])return 1;if(u[0][a]===u[1][a]){if(a===o)return 0;a-=1}else if(u[0][a]1?i-1:0),a=1;a0){var a=Object.keys(r),u=o.default.find(a,(function(e){return t.isOS(e)}));if(u){var d=this.satisfies(r[u]);if(void 0!==d)return d}var c=o.default.find(a,(function(e){return t.isPlatform(e)}));if(c){var f=this.satisfies(r[c]);if(void 0!==f)return f}}if(s>0){var l=Object.keys(i),h=o.default.find(l,(function(e){return t.isBrowser(e,!0)}));if(void 0!==h)return this.compareVersion(i[h])}},t.isBrowser=function(e,t){void 0===t&&(t=!1);var r=this.getBrowserName().toLowerCase(),n=e.toLowerCase(),i=o.default.getBrowserTypeByAlias(n);return t&&i&&(n=i.toLowerCase()),n===r},t.compareVersion=function(e){var t=[0],r=e,n=!1,i=this.getBrowserVersion();if(\"string\"==typeof i)return\">\"===e[0]||\"<\"===e[0]?(r=e.substr(1),\"=\"===e[1]?(n=!0,r=e.substr(2)):t=[],\">\"===e[0]?t.push(1):t.push(-1)):\"=\"===e[0]?r=e.substr(1):\"~\"===e[0]&&(n=!0,r=e.substr(1)),t.indexOf(o.default.compareVersions(i,r,n))>-1},t.isOS=function(e){return this.getOSName(!0)===String(e).toLowerCase()},t.isPlatform=function(e){return this.getPlatformType(!0)===String(e).toLowerCase()},t.isEngine=function(e){return this.getEngineName(!0)===String(e).toLowerCase()},t.is=function(e,t){return void 0===t&&(t=!1),this.isBrowser(e,t)||this.isOS(e)||this.isPlatform(e)},t.some=function(e){var t=this;return void 0===e&&(e=[]),e.some((function(e){return t.is(e)}))},e}();t.default=d,e.exports=t.default},92:function(e,t,r){\"use strict\";t.__esModule=!0,t.default=void 0;var n,i=(n=r(17))&&n.__esModule?n:{default:n};var s=/version\\/(\\d+(\\.?_?\\d+)+)/i,a=[{test:[/googlebot/i],describe:function(e){var t={name:\"Googlebot\"},r=i.default.getFirstMatch(/googlebot\\/(\\d+(\\.\\d+))/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/opera/i],describe:function(e){var t={name:\"Opera\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:opera)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/opr\\/|opios/i],describe:function(e){var t={name:\"Opera\"},r=i.default.getFirstMatch(/(?:opr|opios)[\\s/](\\S+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/SamsungBrowser/i],describe:function(e){var t={name:\"Samsung Internet for Android\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:SamsungBrowser)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/Whale/i],describe:function(e){var t={name:\"NAVER Whale Browser\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:whale)[\\s/](\\d+(?:\\.\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/MZBrowser/i],describe:function(e){var t={name:\"MZ Browser\"},r=i.default.getFirstMatch(/(?:MZBrowser)[\\s/](\\d+(?:\\.\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/focus/i],describe:function(e){var t={name:\"Focus\"},r=i.default.getFirstMatch(/(?:focus)[\\s/](\\d+(?:\\.\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/swing/i],describe:function(e){var t={name:\"Swing\"},r=i.default.getFirstMatch(/(?:swing)[\\s/](\\d+(?:\\.\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/coast/i],describe:function(e){var t={name:\"Opera Coast\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:coast)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/opt\\/\\d+(?:.?_?\\d+)+/i],describe:function(e){var t={name:\"Opera Touch\"},r=i.default.getFirstMatch(/(?:opt)[\\s/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/yabrowser/i],describe:function(e){var t={name:\"Yandex Browser\"},r=i.default.getFirstMatch(/(?:yabrowser)[\\s/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/ucbrowser/i],describe:function(e){var t={name:\"UC Browser\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:ucbrowser)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/Maxthon|mxios/i],describe:function(e){var t={name:\"Maxthon\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:Maxthon|mxios)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/epiphany/i],describe:function(e){var t={name:\"Epiphany\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:epiphany)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/puffin/i],describe:function(e){var t={name:\"Puffin\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:puffin)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/sleipnir/i],describe:function(e){var t={name:\"Sleipnir\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:sleipnir)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/k-meleon/i],describe:function(e){var t={name:\"K-Meleon\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/(?:k-meleon)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/micromessenger/i],describe:function(e){var t={name:\"WeChat\"},r=i.default.getFirstMatch(/(?:micromessenger)[\\s/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/qqbrowser/i],describe:function(e){var t={name:/qqbrowserlite/i.test(e)?\"QQ Browser Lite\":\"QQ Browser\"},r=i.default.getFirstMatch(/(?:qqbrowserlite|qqbrowser)[/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/msie|trident/i],describe:function(e){var t={name:\"Internet Explorer\"},r=i.default.getFirstMatch(/(?:msie |rv:)(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/\\sedg\\//i],describe:function(e){var t={name:\"Microsoft Edge\"},r=i.default.getFirstMatch(/\\sedg\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/edg([ea]|ios)/i],describe:function(e){var t={name:\"Microsoft Edge\"},r=i.default.getSecondMatch(/edg([ea]|ios)\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/vivaldi/i],describe:function(e){var t={name:\"Vivaldi\"},r=i.default.getFirstMatch(/vivaldi\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/seamonkey/i],describe:function(e){var t={name:\"SeaMonkey\"},r=i.default.getFirstMatch(/seamonkey\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/sailfish/i],describe:function(e){var t={name:\"Sailfish\"},r=i.default.getFirstMatch(/sailfish\\s?browser\\/(\\d+(\\.\\d+)?)/i,e);return r&&(t.version=r),t}},{test:[/silk/i],describe:function(e){var t={name:\"Amazon Silk\"},r=i.default.getFirstMatch(/silk\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/phantom/i],describe:function(e){var t={name:\"PhantomJS\"},r=i.default.getFirstMatch(/phantomjs\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/slimerjs/i],describe:function(e){var t={name:\"SlimerJS\"},r=i.default.getFirstMatch(/slimerjs\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/blackberry|\\bbb\\d+/i,/rim\\stablet/i],describe:function(e){var t={name:\"BlackBerry\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/blackberry[\\d]+\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/(web|hpw)[o0]s/i],describe:function(e){var t={name:\"WebOS Browser\"},r=i.default.getFirstMatch(s,e)||i.default.getFirstMatch(/w(?:eb)?[o0]sbrowser\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/bada/i],describe:function(e){var t={name:\"Bada\"},r=i.default.getFirstMatch(/dolfin\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/tizen/i],describe:function(e){var t={name:\"Tizen\"},r=i.default.getFirstMatch(/(?:tizen\\s?)?browser\\/(\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/qupzilla/i],describe:function(e){var t={name:\"QupZilla\"},r=i.default.getFirstMatch(/(?:qupzilla)[\\s/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/firefox|iceweasel|fxios/i],describe:function(e){var t={name:\"Firefox\"},r=i.default.getFirstMatch(/(?:firefox|iceweasel|fxios)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/electron/i],describe:function(e){var t={name:\"Electron\"},r=i.default.getFirstMatch(/(?:electron)\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/MiuiBrowser/i],describe:function(e){var t={name:\"Miui\"},r=i.default.getFirstMatch(/(?:MiuiBrowser)[\\s/](\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/chromium/i],describe:function(e){var t={name:\"Chromium\"},r=i.default.getFirstMatch(/(?:chromium)[\\s/](\\d+(\\.?_?\\d+)+)/i,e)||i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/chrome|crios|crmo/i],describe:function(e){var t={name:\"Chrome\"},r=i.default.getFirstMatch(/(?:chrome|crios|crmo)\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/GSA/i],describe:function(e){var t={name:\"Google Search\"},r=i.default.getFirstMatch(/(?:GSA)\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:function(e){var t=!e.test(/like android/i),r=e.test(/android/i);return t&&r},describe:function(e){var t={name:\"Android Browser\"},r=i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/playstation 4/i],describe:function(e){var t={name:\"PlayStation 4\"},r=i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/safari|applewebkit/i],describe:function(e){var t={name:\"Safari\"},r=i.default.getFirstMatch(s,e);return r&&(t.version=r),t}},{test:[/.*/i],describe:function(e){var t=-1!==e.search(\"\\\\(\")?/^(.*)\\/(.*)[ \\t]\\((.*)/:/^(.*)\\/(.*) /;return{name:i.default.getFirstMatch(t,e),version:i.default.getSecondMatch(t,e)}}}];t.default=a,e.exports=t.default},93:function(e,t,r){\"use strict\";t.__esModule=!0,t.default=void 0;var n,i=(n=r(17))&&n.__esModule?n:{default:n},s=r(18);var a=[{test:[/Roku\\/DVP/],describe:function(e){var t=i.default.getFirstMatch(/Roku\\/DVP-(\\d+\\.\\d+)/i,e);return{name:s.OS_MAP.Roku,version:t}}},{test:[/windows phone/i],describe:function(e){var t=i.default.getFirstMatch(/windows phone (?:os)?\\s?(\\d+(\\.\\d+)*)/i,e);return{name:s.OS_MAP.WindowsPhone,version:t}}},{test:[/windows /i],describe:function(e){var t=i.default.getFirstMatch(/Windows ((NT|XP)( \\d\\d?.\\d)?)/i,e),r=i.default.getWindowsVersionName(t);return{name:s.OS_MAP.Windows,version:t,versionName:r}}},{test:[/Macintosh(.*?) FxiOS(.*?)\\//],describe:function(e){var t={name:s.OS_MAP.iOS},r=i.default.getSecondMatch(/(Version\\/)(\\d[\\d.]+)/,e);return r&&(t.version=r),t}},{test:[/macintosh/i],describe:function(e){var t=i.default.getFirstMatch(/mac os x (\\d+(\\.?_?\\d+)+)/i,e).replace(/[_\\s]/g,\".\"),r=i.default.getMacOSVersionName(t),n={name:s.OS_MAP.MacOS,version:t};return r&&(n.versionName=r),n}},{test:[/(ipod|iphone|ipad)/i],describe:function(e){var t=i.default.getFirstMatch(/os (\\d+([_\\s]\\d+)*) like mac os x/i,e).replace(/[_\\s]/g,\".\");return{name:s.OS_MAP.iOS,version:t}}},{test:function(e){var t=!e.test(/like android/i),r=e.test(/android/i);return t&&r},describe:function(e){var t=i.default.getFirstMatch(/android[\\s/-](\\d+(\\.\\d+)*)/i,e),r=i.default.getAndroidVersionName(t),n={name:s.OS_MAP.Android,version:t};return r&&(n.versionName=r),n}},{test:[/(web|hpw)[o0]s/i],describe:function(e){var t=i.default.getFirstMatch(/(?:web|hpw)[o0]s\\/(\\d+(\\.\\d+)*)/i,e),r={name:s.OS_MAP.WebOS};return t&&t.length&&(r.version=t),r}},{test:[/blackberry|\\bbb\\d+/i,/rim\\stablet/i],describe:function(e){var t=i.default.getFirstMatch(/rim\\stablet\\sos\\s(\\d+(\\.\\d+)*)/i,e)||i.default.getFirstMatch(/blackberry\\d+\\/(\\d+([_\\s]\\d+)*)/i,e)||i.default.getFirstMatch(/\\bbb(\\d+)/i,e);return{name:s.OS_MAP.BlackBerry,version:t}}},{test:[/bada/i],describe:function(e){var t=i.default.getFirstMatch(/bada\\/(\\d+(\\.\\d+)*)/i,e);return{name:s.OS_MAP.Bada,version:t}}},{test:[/tizen/i],describe:function(e){var t=i.default.getFirstMatch(/tizen[/\\s](\\d+(\\.\\d+)*)/i,e);return{name:s.OS_MAP.Tizen,version:t}}},{test:[/linux/i],describe:function(){return{name:s.OS_MAP.Linux}}},{test:[/CrOS/],describe:function(){return{name:s.OS_MAP.ChromeOS}}},{test:[/PlayStation 4/],describe:function(e){var t=i.default.getFirstMatch(/PlayStation 4[/\\s](\\d+(\\.\\d+)*)/i,e);return{name:s.OS_MAP.PlayStation4,version:t}}}];t.default=a,e.exports=t.default},94:function(e,t,r){\"use strict\";t.__esModule=!0,t.default=void 0;var n,i=(n=r(17))&&n.__esModule?n:{default:n},s=r(18);var a=[{test:[/googlebot/i],describe:function(){return{type:\"bot\",vendor:\"Google\"}}},{test:[/huawei/i],describe:function(e){var t=i.default.getFirstMatch(/(can-l01)/i,e)&&\"Nova\",r={type:s.PLATFORMS_MAP.mobile,vendor:\"Huawei\"};return t&&(r.model=t),r}},{test:[/nexus\\s*(?:7|8|9|10).*/i],describe:function(){return{type:s.PLATFORMS_MAP.tablet,vendor:\"Nexus\"}}},{test:[/ipad/i],describe:function(){return{type:s.PLATFORMS_MAP.tablet,vendor:\"Apple\",model:\"iPad\"}}},{test:[/Macintosh(.*?) FxiOS(.*?)\\//],describe:function(){return{type:s.PLATFORMS_MAP.tablet,vendor:\"Apple\",model:\"iPad\"}}},{test:[/kftt build/i],describe:function(){return{type:s.PLATFORMS_MAP.tablet,vendor:\"Amazon\",model:\"Kindle Fire HD 7\"}}},{test:[/silk/i],describe:function(){return{type:s.PLATFORMS_MAP.tablet,vendor:\"Amazon\"}}},{test:[/tablet(?! pc)/i],describe:function(){return{type:s.PLATFORMS_MAP.tablet}}},{test:function(e){var t=e.test(/ipod|iphone/i),r=e.test(/like (ipod|iphone)/i);return t&&!r},describe:function(e){var t=i.default.getFirstMatch(/(ipod|iphone)/i,e);return{type:s.PLATFORMS_MAP.mobile,vendor:\"Apple\",model:t}}},{test:[/nexus\\s*[0-6].*/i,/galaxy nexus/i],describe:function(){return{type:s.PLATFORMS_MAP.mobile,vendor:\"Nexus\"}}},{test:[/[^-]mobi/i],describe:function(){return{type:s.PLATFORMS_MAP.mobile}}},{test:function(e){return\"blackberry\"===e.getBrowserName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.mobile,vendor:\"BlackBerry\"}}},{test:function(e){return\"bada\"===e.getBrowserName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.mobile}}},{test:function(e){return\"windows phone\"===e.getBrowserName()},describe:function(){return{type:s.PLATFORMS_MAP.mobile,vendor:\"Microsoft\"}}},{test:function(e){var t=Number(String(e.getOSVersion()).split(\".\")[0]);return\"android\"===e.getOSName(!0)&&t>=3},describe:function(){return{type:s.PLATFORMS_MAP.tablet}}},{test:function(e){return\"android\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.mobile}}},{test:function(e){return\"macos\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.desktop,vendor:\"Apple\"}}},{test:function(e){return\"windows\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.desktop}}},{test:function(e){return\"linux\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.desktop}}},{test:function(e){return\"playstation 4\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.tv}}},{test:function(e){return\"roku\"===e.getOSName(!0)},describe:function(){return{type:s.PLATFORMS_MAP.tv}}}];t.default=a,e.exports=t.default},95:function(e,t,r){\"use strict\";t.__esModule=!0,t.default=void 0;var n,i=(n=r(17))&&n.__esModule?n:{default:n},s=r(18);var a=[{test:function(e){return\"microsoft edge\"===e.getBrowserName(!0)},describe:function(e){if(/\\sedg\\//i.test(e))return{name:s.ENGINE_MAP.Blink};var t=i.default.getFirstMatch(/edge\\/(\\d+(\\.?_?\\d+)+)/i,e);return{name:s.ENGINE_MAP.EdgeHTML,version:t}}},{test:[/trident/i],describe:function(e){var t={name:s.ENGINE_MAP.Trident},r=i.default.getFirstMatch(/trident\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:function(e){return e.test(/presto/i)},describe:function(e){var t={name:s.ENGINE_MAP.Presto},r=i.default.getFirstMatch(/presto\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:function(e){var t=e.test(/gecko/i),r=e.test(/like gecko/i);return t&&!r},describe:function(e){var t={name:s.ENGINE_MAP.Gecko},r=i.default.getFirstMatch(/gecko\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}},{test:[/(apple)?webkit\\/537\\.36/i],describe:function(){return{name:s.ENGINE_MAP.Blink}}},{test:[/(apple)?webkit/i],describe:function(e){var t={name:s.ENGINE_MAP.WebKit},r=i.default.getFirstMatch(/webkit\\/(\\d+(\\.?_?\\d+)+)/i,e);return r&&(t.version=r),t}}];t.default=a,e.exports=t.default}})}));","/*!\n * The buffer module from node.js, for the browser.\n *\n * @author Feross Aboukhadijeh \n * @license MIT\n */\n/* eslint-disable no-proto */\n\n'use strict'\n\nconst base64 = require('base64-js')\nconst ieee754 = require('ieee754')\nconst customInspectSymbol =\n (typeof Symbol === 'function' && typeof Symbol['for'] === 'function') // eslint-disable-line dot-notation\n ? Symbol['for']('nodejs.util.inspect.custom') // eslint-disable-line dot-notation\n : null\n\nexports.Buffer = Buffer\nexports.SlowBuffer = SlowBuffer\nexports.INSPECT_MAX_BYTES = 50\n\nconst K_MAX_LENGTH = 0x7fffffff\nexports.kMaxLength = K_MAX_LENGTH\n\n/**\n * If `Buffer.TYPED_ARRAY_SUPPORT`:\n * === true Use Uint8Array implementation (fastest)\n * === false Print warning and recommend using `buffer` v4.x which has an Object\n * implementation (most compatible, even IE6)\n *\n * Browsers that support typed arrays are IE 10+, Firefox 4+, Chrome 7+, Safari 5.1+,\n * Opera 11.6+, iOS 4.2+.\n *\n * We report that the browser does not support typed arrays if the are not subclassable\n * using __proto__. Firefox 4-29 lacks support for adding new properties to `Uint8Array`\n * (See: https://bugzilla.mozilla.org/show_bug.cgi?id=695438). IE 10 lacks support\n * for __proto__ and has a buggy typed array implementation.\n */\nBuffer.TYPED_ARRAY_SUPPORT = typedArraySupport()\n\nif (!Buffer.TYPED_ARRAY_SUPPORT && typeof console !== 'undefined' &&\n typeof console.error === 'function') {\n console.error(\n 'This browser lacks typed array (Uint8Array) support which is required by ' +\n '`buffer` v5.x. Use `buffer` v4.x if you require old browser support.'\n )\n}\n\nfunction typedArraySupport () {\n // Can typed array instances can be augmented?\n try {\n const arr = new Uint8Array(1)\n const proto = { foo: function () { return 42 } }\n Object.setPrototypeOf(proto, Uint8Array.prototype)\n Object.setPrototypeOf(arr, proto)\n return arr.foo() === 42\n } catch (e) {\n return false\n }\n}\n\nObject.defineProperty(Buffer.prototype, 'parent', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.buffer\n }\n})\n\nObject.defineProperty(Buffer.prototype, 'offset', {\n enumerable: true,\n get: function () {\n if (!Buffer.isBuffer(this)) return undefined\n return this.byteOffset\n }\n})\n\nfunction createBuffer (length) {\n if (length > K_MAX_LENGTH) {\n throw new RangeError('The value \"' + length + '\" is invalid for option \"size\"')\n }\n // Return an augmented `Uint8Array` instance\n const buf = new Uint8Array(length)\n Object.setPrototypeOf(buf, Buffer.prototype)\n return buf\n}\n\n/**\n * The Buffer constructor returns instances of `Uint8Array` that have their\n * prototype changed to `Buffer.prototype`. Furthermore, `Buffer` is a subclass of\n * `Uint8Array`, so the returned instances will have all the node `Buffer` methods\n * and the `Uint8Array` methods. Square bracket notation works as expected -- it\n * returns a single octet.\n *\n * The `Uint8Array` prototype remains unmodified.\n */\n\nfunction Buffer (arg, encodingOrOffset, length) {\n // Common case.\n if (typeof arg === 'number') {\n if (typeof encodingOrOffset === 'string') {\n throw new TypeError(\n 'The \"string\" argument must be of type string. Received type number'\n )\n }\n return allocUnsafe(arg)\n }\n return from(arg, encodingOrOffset, length)\n}\n\nBuffer.poolSize = 8192 // not used by this implementation\n\nfunction from (value, encodingOrOffset, length) {\n if (typeof value === 'string') {\n return fromString(value, encodingOrOffset)\n }\n\n if (ArrayBuffer.isView(value)) {\n return fromArrayView(value)\n }\n\n if (value == null) {\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n }\n\n if (isInstance(value, ArrayBuffer) ||\n (value && isInstance(value.buffer, ArrayBuffer))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof SharedArrayBuffer !== 'undefined' &&\n (isInstance(value, SharedArrayBuffer) ||\n (value && isInstance(value.buffer, SharedArrayBuffer)))) {\n return fromArrayBuffer(value, encodingOrOffset, length)\n }\n\n if (typeof value === 'number') {\n throw new TypeError(\n 'The \"value\" argument must not be of type number. Received type number'\n )\n }\n\n const valueOf = value.valueOf && value.valueOf()\n if (valueOf != null && valueOf !== value) {\n return Buffer.from(valueOf, encodingOrOffset, length)\n }\n\n const b = fromObject(value)\n if (b) return b\n\n if (typeof Symbol !== 'undefined' && Symbol.toPrimitive != null &&\n typeof value[Symbol.toPrimitive] === 'function') {\n return Buffer.from(value[Symbol.toPrimitive]('string'), encodingOrOffset, length)\n }\n\n throw new TypeError(\n 'The first argument must be one of type string, Buffer, ArrayBuffer, Array, ' +\n 'or Array-like Object. Received type ' + (typeof value)\n )\n}\n\n/**\n * Functionally equivalent to Buffer(arg, encoding) but throws a TypeError\n * if value is a number.\n * Buffer.from(str[, encoding])\n * Buffer.from(array)\n * Buffer.from(buffer)\n * Buffer.from(arrayBuffer[, byteOffset[, length]])\n **/\nBuffer.from = function (value, encodingOrOffset, length) {\n return from(value, encodingOrOffset, length)\n}\n\n// Note: Change prototype *after* Buffer.from is defined to workaround Chrome bug:\n// https://github.com/feross/buffer/pull/148\nObject.setPrototypeOf(Buffer.prototype, Uint8Array.prototype)\nObject.setPrototypeOf(Buffer, Uint8Array)\n\nfunction assertSize (size) {\n if (typeof size !== 'number') {\n throw new TypeError('\"size\" argument must be of type number')\n } else if (size < 0) {\n throw new RangeError('The value \"' + size + '\" is invalid for option \"size\"')\n }\n}\n\nfunction alloc (size, fill, encoding) {\n assertSize(size)\n if (size <= 0) {\n return createBuffer(size)\n }\n if (fill !== undefined) {\n // Only pay attention to encoding if it's a string. This\n // prevents accidentally sending in a number that would\n // be interpreted as a start offset.\n return typeof encoding === 'string'\n ? createBuffer(size).fill(fill, encoding)\n : createBuffer(size).fill(fill)\n }\n return createBuffer(size)\n}\n\n/**\n * Creates a new filled Buffer instance.\n * alloc(size[, fill[, encoding]])\n **/\nBuffer.alloc = function (size, fill, encoding) {\n return alloc(size, fill, encoding)\n}\n\nfunction allocUnsafe (size) {\n assertSize(size)\n return createBuffer(size < 0 ? 0 : checked(size) | 0)\n}\n\n/**\n * Equivalent to Buffer(num), by default creates a non-zero-filled Buffer instance.\n * */\nBuffer.allocUnsafe = function (size) {\n return allocUnsafe(size)\n}\n/**\n * Equivalent to SlowBuffer(num), by default creates a non-zero-filled Buffer instance.\n */\nBuffer.allocUnsafeSlow = function (size) {\n return allocUnsafe(size)\n}\n\nfunction fromString (string, encoding) {\n if (typeof encoding !== 'string' || encoding === '') {\n encoding = 'utf8'\n }\n\n if (!Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n\n const length = byteLength(string, encoding) | 0\n let buf = createBuffer(length)\n\n const actual = buf.write(string, encoding)\n\n if (actual !== length) {\n // Writing a hex string, for example, that contains invalid characters will\n // cause everything after the first invalid character to be ignored. (e.g.\n // 'abxxcd' will be treated as 'ab')\n buf = buf.slice(0, actual)\n }\n\n return buf\n}\n\nfunction fromArrayLike (array) {\n const length = array.length < 0 ? 0 : checked(array.length) | 0\n const buf = createBuffer(length)\n for (let i = 0; i < length; i += 1) {\n buf[i] = array[i] & 255\n }\n return buf\n}\n\nfunction fromArrayView (arrayView) {\n if (isInstance(arrayView, Uint8Array)) {\n const copy = new Uint8Array(arrayView)\n return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength)\n }\n return fromArrayLike(arrayView)\n}\n\nfunction fromArrayBuffer (array, byteOffset, length) {\n if (byteOffset < 0 || array.byteLength < byteOffset) {\n throw new RangeError('\"offset\" is outside of buffer bounds')\n }\n\n if (array.byteLength < byteOffset + (length || 0)) {\n throw new RangeError('\"length\" is outside of buffer bounds')\n }\n\n let buf\n if (byteOffset === undefined && length === undefined) {\n buf = new Uint8Array(array)\n } else if (length === undefined) {\n buf = new Uint8Array(array, byteOffset)\n } else {\n buf = new Uint8Array(array, byteOffset, length)\n }\n\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(buf, Buffer.prototype)\n\n return buf\n}\n\nfunction fromObject (obj) {\n if (Buffer.isBuffer(obj)) {\n const len = checked(obj.length) | 0\n const buf = createBuffer(len)\n\n if (buf.length === 0) {\n return buf\n }\n\n obj.copy(buf, 0, 0, len)\n return buf\n }\n\n if (obj.length !== undefined) {\n if (typeof obj.length !== 'number' || numberIsNaN(obj.length)) {\n return createBuffer(0)\n }\n return fromArrayLike(obj)\n }\n\n if (obj.type === 'Buffer' && Array.isArray(obj.data)) {\n return fromArrayLike(obj.data)\n }\n}\n\nfunction checked (length) {\n // Note: cannot use `length < K_MAX_LENGTH` here because that fails when\n // length is NaN (which is otherwise coerced to zero.)\n if (length >= K_MAX_LENGTH) {\n throw new RangeError('Attempt to allocate Buffer larger than maximum ' +\n 'size: 0x' + K_MAX_LENGTH.toString(16) + ' bytes')\n }\n return length | 0\n}\n\nfunction SlowBuffer (length) {\n if (+length != length) { // eslint-disable-line eqeqeq\n length = 0\n }\n return Buffer.alloc(+length)\n}\n\nBuffer.isBuffer = function isBuffer (b) {\n return b != null && b._isBuffer === true &&\n b !== Buffer.prototype // so Buffer.isBuffer(Buffer.prototype) will be false\n}\n\nBuffer.compare = function compare (a, b) {\n if (isInstance(a, Uint8Array)) a = Buffer.from(a, a.offset, a.byteLength)\n if (isInstance(b, Uint8Array)) b = Buffer.from(b, b.offset, b.byteLength)\n if (!Buffer.isBuffer(a) || !Buffer.isBuffer(b)) {\n throw new TypeError(\n 'The \"buf1\", \"buf2\" arguments must be one of type Buffer or Uint8Array'\n )\n }\n\n if (a === b) return 0\n\n let x = a.length\n let y = b.length\n\n for (let i = 0, len = Math.min(x, y); i < len; ++i) {\n if (a[i] !== b[i]) {\n x = a[i]\n y = b[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\nBuffer.isEncoding = function isEncoding (encoding) {\n switch (String(encoding).toLowerCase()) {\n case 'hex':\n case 'utf8':\n case 'utf-8':\n case 'ascii':\n case 'latin1':\n case 'binary':\n case 'base64':\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return true\n default:\n return false\n }\n}\n\nBuffer.concat = function concat (list, length) {\n if (!Array.isArray(list)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n }\n\n if (list.length === 0) {\n return Buffer.alloc(0)\n }\n\n let i\n if (length === undefined) {\n length = 0\n for (i = 0; i < list.length; ++i) {\n length += list[i].length\n }\n }\n\n const buffer = Buffer.allocUnsafe(length)\n let pos = 0\n for (i = 0; i < list.length; ++i) {\n let buf = list[i]\n if (isInstance(buf, Uint8Array)) {\n if (pos + buf.length > buffer.length) {\n if (!Buffer.isBuffer(buf)) buf = Buffer.from(buf)\n buf.copy(buffer, pos)\n } else {\n Uint8Array.prototype.set.call(\n buffer,\n buf,\n pos\n )\n }\n } else if (!Buffer.isBuffer(buf)) {\n throw new TypeError('\"list\" argument must be an Array of Buffers')\n } else {\n buf.copy(buffer, pos)\n }\n pos += buf.length\n }\n return buffer\n}\n\nfunction byteLength (string, encoding) {\n if (Buffer.isBuffer(string)) {\n return string.length\n }\n if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {\n return string.byteLength\n }\n if (typeof string !== 'string') {\n throw new TypeError(\n 'The \"string\" argument must be one of type string, Buffer, or ArrayBuffer. ' +\n 'Received type ' + typeof string\n )\n }\n\n const len = string.length\n const mustMatch = (arguments.length > 2 && arguments[2] === true)\n if (!mustMatch && len === 0) return 0\n\n // Use a for loop to avoid recursion\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'ascii':\n case 'latin1':\n case 'binary':\n return len\n case 'utf8':\n case 'utf-8':\n return utf8ToBytes(string).length\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return len * 2\n case 'hex':\n return len >>> 1\n case 'base64':\n return base64ToBytes(string).length\n default:\n if (loweredCase) {\n return mustMatch ? -1 : utf8ToBytes(string).length // assume utf8\n }\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\nBuffer.byteLength = byteLength\n\nfunction slowToString (encoding, start, end) {\n let loweredCase = false\n\n // No need to verify that \"this.length <= MAX_UINT32\" since it's a read-only\n // property of a typed array.\n\n // This behaves neither like String nor Uint8Array in that we set start/end\n // to their upper/lower bounds if the value passed is out of range.\n // undefined is handled specially as per ECMA-262 6th Edition,\n // Section 13.3.3.7 Runtime Semantics: KeyedBindingInitialization.\n if (start === undefined || start < 0) {\n start = 0\n }\n // Return early if start > this.length. Done here to prevent potential uint32\n // coercion fail below.\n if (start > this.length) {\n return ''\n }\n\n if (end === undefined || end > this.length) {\n end = this.length\n }\n\n if (end <= 0) {\n return ''\n }\n\n // Force coercion to uint32. This will also coerce falsey/NaN values to 0.\n end >>>= 0\n start >>>= 0\n\n if (end <= start) {\n return ''\n }\n\n if (!encoding) encoding = 'utf8'\n\n while (true) {\n switch (encoding) {\n case 'hex':\n return hexSlice(this, start, end)\n\n case 'utf8':\n case 'utf-8':\n return utf8Slice(this, start, end)\n\n case 'ascii':\n return asciiSlice(this, start, end)\n\n case 'latin1':\n case 'binary':\n return latin1Slice(this, start, end)\n\n case 'base64':\n return base64Slice(this, start, end)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return utf16leSlice(this, start, end)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = (encoding + '').toLowerCase()\n loweredCase = true\n }\n }\n}\n\n// This property is used by `Buffer.isBuffer` (and the `is-buffer` npm package)\n// to detect a Buffer instance. It's not possible to use `instanceof Buffer`\n// reliably in a browserify context because there could be multiple different\n// copies of the 'buffer' package in use. This method works even for Buffer\n// instances that were created from another copy of the `buffer` package.\n// See: https://github.com/feross/buffer/issues/154\nBuffer.prototype._isBuffer = true\n\nfunction swap (b, n, m) {\n const i = b[n]\n b[n] = b[m]\n b[m] = i\n}\n\nBuffer.prototype.swap16 = function swap16 () {\n const len = this.length\n if (len % 2 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 16-bits')\n }\n for (let i = 0; i < len; i += 2) {\n swap(this, i, i + 1)\n }\n return this\n}\n\nBuffer.prototype.swap32 = function swap32 () {\n const len = this.length\n if (len % 4 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 32-bits')\n }\n for (let i = 0; i < len; i += 4) {\n swap(this, i, i + 3)\n swap(this, i + 1, i + 2)\n }\n return this\n}\n\nBuffer.prototype.swap64 = function swap64 () {\n const len = this.length\n if (len % 8 !== 0) {\n throw new RangeError('Buffer size must be a multiple of 64-bits')\n }\n for (let i = 0; i < len; i += 8) {\n swap(this, i, i + 7)\n swap(this, i + 1, i + 6)\n swap(this, i + 2, i + 5)\n swap(this, i + 3, i + 4)\n }\n return this\n}\n\nBuffer.prototype.toString = function toString () {\n const length = this.length\n if (length === 0) return ''\n if (arguments.length === 0) return utf8Slice(this, 0, length)\n return slowToString.apply(this, arguments)\n}\n\nBuffer.prototype.toLocaleString = Buffer.prototype.toString\n\nBuffer.prototype.equals = function equals (b) {\n if (!Buffer.isBuffer(b)) throw new TypeError('Argument must be a Buffer')\n if (this === b) return true\n return Buffer.compare(this, b) === 0\n}\n\nBuffer.prototype.inspect = function inspect () {\n let str = ''\n const max = exports.INSPECT_MAX_BYTES\n str = this.toString('hex', 0, max).replace(/(.{2})/g, '$1 ').trim()\n if (this.length > max) str += ' ... '\n return ''\n}\nif (customInspectSymbol) {\n Buffer.prototype[customInspectSymbol] = Buffer.prototype.inspect\n}\n\nBuffer.prototype.compare = function compare (target, start, end, thisStart, thisEnd) {\n if (isInstance(target, Uint8Array)) {\n target = Buffer.from(target, target.offset, target.byteLength)\n }\n if (!Buffer.isBuffer(target)) {\n throw new TypeError(\n 'The \"target\" argument must be one of type Buffer or Uint8Array. ' +\n 'Received type ' + (typeof target)\n )\n }\n\n if (start === undefined) {\n start = 0\n }\n if (end === undefined) {\n end = target ? target.length : 0\n }\n if (thisStart === undefined) {\n thisStart = 0\n }\n if (thisEnd === undefined) {\n thisEnd = this.length\n }\n\n if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {\n throw new RangeError('out of range index')\n }\n\n if (thisStart >= thisEnd && start >= end) {\n return 0\n }\n if (thisStart >= thisEnd) {\n return -1\n }\n if (start >= end) {\n return 1\n }\n\n start >>>= 0\n end >>>= 0\n thisStart >>>= 0\n thisEnd >>>= 0\n\n if (this === target) return 0\n\n let x = thisEnd - thisStart\n let y = end - start\n const len = Math.min(x, y)\n\n const thisCopy = this.slice(thisStart, thisEnd)\n const targetCopy = target.slice(start, end)\n\n for (let i = 0; i < len; ++i) {\n if (thisCopy[i] !== targetCopy[i]) {\n x = thisCopy[i]\n y = targetCopy[i]\n break\n }\n }\n\n if (x < y) return -1\n if (y < x) return 1\n return 0\n}\n\n// Finds either the first index of `val` in `buffer` at offset >= `byteOffset`,\n// OR the last index of `val` in `buffer` at offset <= `byteOffset`.\n//\n// Arguments:\n// - buffer - a Buffer to search\n// - val - a string, Buffer, or number\n// - byteOffset - an index into `buffer`; will be clamped to an int32\n// - encoding - an optional encoding, relevant is val is a string\n// - dir - true for indexOf, false for lastIndexOf\nfunction bidirectionalIndexOf (buffer, val, byteOffset, encoding, dir) {\n // Empty buffer means no match\n if (buffer.length === 0) return -1\n\n // Normalize byteOffset\n if (typeof byteOffset === 'string') {\n encoding = byteOffset\n byteOffset = 0\n } else if (byteOffset > 0x7fffffff) {\n byteOffset = 0x7fffffff\n } else if (byteOffset < -0x80000000) {\n byteOffset = -0x80000000\n }\n byteOffset = +byteOffset // Coerce to Number.\n if (numberIsNaN(byteOffset)) {\n // byteOffset: it it's undefined, null, NaN, \"foo\", etc, search whole buffer\n byteOffset = dir ? 0 : (buffer.length - 1)\n }\n\n // Normalize byteOffset: negative offsets start from the end of the buffer\n if (byteOffset < 0) byteOffset = buffer.length + byteOffset\n if (byteOffset >= buffer.length) {\n if (dir) return -1\n else byteOffset = buffer.length - 1\n } else if (byteOffset < 0) {\n if (dir) byteOffset = 0\n else return -1\n }\n\n // Normalize val\n if (typeof val === 'string') {\n val = Buffer.from(val, encoding)\n }\n\n // Finally, search either indexOf (if dir is true) or lastIndexOf\n if (Buffer.isBuffer(val)) {\n // Special case: looking for empty string/buffer always fails\n if (val.length === 0) {\n return -1\n }\n return arrayIndexOf(buffer, val, byteOffset, encoding, dir)\n } else if (typeof val === 'number') {\n val = val & 0xFF // Search for a byte value [0-255]\n if (typeof Uint8Array.prototype.indexOf === 'function') {\n if (dir) {\n return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset)\n } else {\n return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset)\n }\n }\n return arrayIndexOf(buffer, [val], byteOffset, encoding, dir)\n }\n\n throw new TypeError('val must be string, number or Buffer')\n}\n\nfunction arrayIndexOf (arr, val, byteOffset, encoding, dir) {\n let indexSize = 1\n let arrLength = arr.length\n let valLength = val.length\n\n if (encoding !== undefined) {\n encoding = String(encoding).toLowerCase()\n if (encoding === 'ucs2' || encoding === 'ucs-2' ||\n encoding === 'utf16le' || encoding === 'utf-16le') {\n if (arr.length < 2 || val.length < 2) {\n return -1\n }\n indexSize = 2\n arrLength /= 2\n valLength /= 2\n byteOffset /= 2\n }\n }\n\n function read (buf, i) {\n if (indexSize === 1) {\n return buf[i]\n } else {\n return buf.readUInt16BE(i * indexSize)\n }\n }\n\n let i\n if (dir) {\n let foundIndex = -1\n for (i = byteOffset; i < arrLength; i++) {\n if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) {\n if (foundIndex === -1) foundIndex = i\n if (i - foundIndex + 1 === valLength) return foundIndex * indexSize\n } else {\n if (foundIndex !== -1) i -= i - foundIndex\n foundIndex = -1\n }\n }\n } else {\n if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength\n for (i = byteOffset; i >= 0; i--) {\n let found = true\n for (let j = 0; j < valLength; j++) {\n if (read(arr, i + j) !== read(val, j)) {\n found = false\n break\n }\n }\n if (found) return i\n }\n }\n\n return -1\n}\n\nBuffer.prototype.includes = function includes (val, byteOffset, encoding) {\n return this.indexOf(val, byteOffset, encoding) !== -1\n}\n\nBuffer.prototype.indexOf = function indexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, true)\n}\n\nBuffer.prototype.lastIndexOf = function lastIndexOf (val, byteOffset, encoding) {\n return bidirectionalIndexOf(this, val, byteOffset, encoding, false)\n}\n\nfunction hexWrite (buf, string, offset, length) {\n offset = Number(offset) || 0\n const remaining = buf.length - offset\n if (!length) {\n length = remaining\n } else {\n length = Number(length)\n if (length > remaining) {\n length = remaining\n }\n }\n\n const strLen = string.length\n\n if (length > strLen / 2) {\n length = strLen / 2\n }\n let i\n for (i = 0; i < length; ++i) {\n const parsed = parseInt(string.substr(i * 2, 2), 16)\n if (numberIsNaN(parsed)) return i\n buf[offset + i] = parsed\n }\n return i\n}\n\nfunction utf8Write (buf, string, offset, length) {\n return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nfunction asciiWrite (buf, string, offset, length) {\n return blitBuffer(asciiToBytes(string), buf, offset, length)\n}\n\nfunction base64Write (buf, string, offset, length) {\n return blitBuffer(base64ToBytes(string), buf, offset, length)\n}\n\nfunction ucs2Write (buf, string, offset, length) {\n return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length)\n}\n\nBuffer.prototype.write = function write (string, offset, length, encoding) {\n // Buffer#write(string)\n if (offset === undefined) {\n encoding = 'utf8'\n length = this.length\n offset = 0\n // Buffer#write(string, encoding)\n } else if (length === undefined && typeof offset === 'string') {\n encoding = offset\n length = this.length\n offset = 0\n // Buffer#write(string, offset[, length][, encoding])\n } else if (isFinite(offset)) {\n offset = offset >>> 0\n if (isFinite(length)) {\n length = length >>> 0\n if (encoding === undefined) encoding = 'utf8'\n } else {\n encoding = length\n length = undefined\n }\n } else {\n throw new Error(\n 'Buffer.write(string, encoding, offset[, length]) is no longer supported'\n )\n }\n\n const remaining = this.length - offset\n if (length === undefined || length > remaining) length = remaining\n\n if ((string.length > 0 && (length < 0 || offset < 0)) || offset > this.length) {\n throw new RangeError('Attempt to write outside buffer bounds')\n }\n\n if (!encoding) encoding = 'utf8'\n\n let loweredCase = false\n for (;;) {\n switch (encoding) {\n case 'hex':\n return hexWrite(this, string, offset, length)\n\n case 'utf8':\n case 'utf-8':\n return utf8Write(this, string, offset, length)\n\n case 'ascii':\n case 'latin1':\n case 'binary':\n return asciiWrite(this, string, offset, length)\n\n case 'base64':\n // Warning: maxLength not taken into account in base64Write\n return base64Write(this, string, offset, length)\n\n case 'ucs2':\n case 'ucs-2':\n case 'utf16le':\n case 'utf-16le':\n return ucs2Write(this, string, offset, length)\n\n default:\n if (loweredCase) throw new TypeError('Unknown encoding: ' + encoding)\n encoding = ('' + encoding).toLowerCase()\n loweredCase = true\n }\n }\n}\n\nBuffer.prototype.toJSON = function toJSON () {\n return {\n type: 'Buffer',\n data: Array.prototype.slice.call(this._arr || this, 0)\n }\n}\n\nfunction base64Slice (buf, start, end) {\n if (start === 0 && end === buf.length) {\n return base64.fromByteArray(buf)\n } else {\n return base64.fromByteArray(buf.slice(start, end))\n }\n}\n\nfunction utf8Slice (buf, start, end) {\n end = Math.min(buf.length, end)\n const res = []\n\n let i = start\n while (i < end) {\n const firstByte = buf[i]\n let codePoint = null\n let bytesPerSequence = (firstByte > 0xEF)\n ? 4\n : (firstByte > 0xDF)\n ? 3\n : (firstByte > 0xBF)\n ? 2\n : 1\n\n if (i + bytesPerSequence <= end) {\n let secondByte, thirdByte, fourthByte, tempCodePoint\n\n switch (bytesPerSequence) {\n case 1:\n if (firstByte < 0x80) {\n codePoint = firstByte\n }\n break\n case 2:\n secondByte = buf[i + 1]\n if ((secondByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0x1F) << 0x6 | (secondByte & 0x3F)\n if (tempCodePoint > 0x7F) {\n codePoint = tempCodePoint\n }\n }\n break\n case 3:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0xC | (secondByte & 0x3F) << 0x6 | (thirdByte & 0x3F)\n if (tempCodePoint > 0x7FF && (tempCodePoint < 0xD800 || tempCodePoint > 0xDFFF)) {\n codePoint = tempCodePoint\n }\n }\n break\n case 4:\n secondByte = buf[i + 1]\n thirdByte = buf[i + 2]\n fourthByte = buf[i + 3]\n if ((secondByte & 0xC0) === 0x80 && (thirdByte & 0xC0) === 0x80 && (fourthByte & 0xC0) === 0x80) {\n tempCodePoint = (firstByte & 0xF) << 0x12 | (secondByte & 0x3F) << 0xC | (thirdByte & 0x3F) << 0x6 | (fourthByte & 0x3F)\n if (tempCodePoint > 0xFFFF && tempCodePoint < 0x110000) {\n codePoint = tempCodePoint\n }\n }\n }\n }\n\n if (codePoint === null) {\n // we did not generate a valid codePoint so insert a\n // replacement char (U+FFFD) and advance only 1 byte\n codePoint = 0xFFFD\n bytesPerSequence = 1\n } else if (codePoint > 0xFFFF) {\n // encode to utf16 (surrogate pair dance)\n codePoint -= 0x10000\n res.push(codePoint >>> 10 & 0x3FF | 0xD800)\n codePoint = 0xDC00 | codePoint & 0x3FF\n }\n\n res.push(codePoint)\n i += bytesPerSequence\n }\n\n return decodeCodePointsArray(res)\n}\n\n// Based on http://stackoverflow.com/a/22747272/680742, the browser with\n// the lowest limit is Chrome, with 0x10000 args.\n// We go 1 magnitude less, for safety\nconst MAX_ARGUMENTS_LENGTH = 0x1000\n\nfunction decodeCodePointsArray (codePoints) {\n const len = codePoints.length\n if (len <= MAX_ARGUMENTS_LENGTH) {\n return String.fromCharCode.apply(String, codePoints) // avoid extra slice()\n }\n\n // Decode in chunks to avoid \"call stack size exceeded\".\n let res = ''\n let i = 0\n while (i < len) {\n res += String.fromCharCode.apply(\n String,\n codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH)\n )\n }\n return res\n}\n\nfunction asciiSlice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i] & 0x7F)\n }\n return ret\n}\n\nfunction latin1Slice (buf, start, end) {\n let ret = ''\n end = Math.min(buf.length, end)\n\n for (let i = start; i < end; ++i) {\n ret += String.fromCharCode(buf[i])\n }\n return ret\n}\n\nfunction hexSlice (buf, start, end) {\n const len = buf.length\n\n if (!start || start < 0) start = 0\n if (!end || end < 0 || end > len) end = len\n\n let out = ''\n for (let i = start; i < end; ++i) {\n out += hexSliceLookupTable[buf[i]]\n }\n return out\n}\n\nfunction utf16leSlice (buf, start, end) {\n const bytes = buf.slice(start, end)\n let res = ''\n // If bytes.length is odd, the last 8 bits must be ignored (same as node.js)\n for (let i = 0; i < bytes.length - 1; i += 2) {\n res += String.fromCharCode(bytes[i] + (bytes[i + 1] * 256))\n }\n return res\n}\n\nBuffer.prototype.slice = function slice (start, end) {\n const len = this.length\n start = ~~start\n end = end === undefined ? len : ~~end\n\n if (start < 0) {\n start += len\n if (start < 0) start = 0\n } else if (start > len) {\n start = len\n }\n\n if (end < 0) {\n end += len\n if (end < 0) end = 0\n } else if (end > len) {\n end = len\n }\n\n if (end < start) end = start\n\n const newBuf = this.subarray(start, end)\n // Return an augmented `Uint8Array` instance\n Object.setPrototypeOf(newBuf, Buffer.prototype)\n\n return newBuf\n}\n\n/*\n * Need to make sure that buffer isn't trying to write out of bounds.\n */\nfunction checkOffset (offset, ext, length) {\n if ((offset % 1) !== 0 || offset < 0) throw new RangeError('offset is not uint')\n if (offset + ext > length) throw new RangeError('Trying to access beyond buffer length')\n}\n\nBuffer.prototype.readUintLE =\nBuffer.prototype.readUIntLE = function readUIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUintBE =\nBuffer.prototype.readUIntBE = function readUIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n checkOffset(offset, byteLength, this.length)\n }\n\n let val = this[offset + --byteLength]\n let mul = 1\n while (byteLength > 0 && (mul *= 0x100)) {\n val += this[offset + --byteLength] * mul\n }\n\n return val\n}\n\nBuffer.prototype.readUint8 =\nBuffer.prototype.readUInt8 = function readUInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n return this[offset]\n}\n\nBuffer.prototype.readUint16LE =\nBuffer.prototype.readUInt16LE = function readUInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return this[offset] | (this[offset + 1] << 8)\n}\n\nBuffer.prototype.readUint16BE =\nBuffer.prototype.readUInt16BE = function readUInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n return (this[offset] << 8) | this[offset + 1]\n}\n\nBuffer.prototype.readUint32LE =\nBuffer.prototype.readUInt32LE = function readUInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return ((this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16)) +\n (this[offset + 3] * 0x1000000)\n}\n\nBuffer.prototype.readUint32BE =\nBuffer.prototype.readUInt32BE = function readUInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] * 0x1000000) +\n ((this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n this[offset + 3])\n}\n\nBuffer.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const lo = first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24\n\n const hi = this[++offset] +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n last * 2 ** 24\n\n return BigInt(lo) + (BigInt(hi) << BigInt(32))\n})\n\nBuffer.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const hi = first * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n const lo = this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last\n\n return (BigInt(hi) << BigInt(32)) + BigInt(lo)\n})\n\nBuffer.prototype.readIntLE = function readIntLE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let val = this[offset]\n let mul = 1\n let i = 0\n while (++i < byteLength && (mul *= 0x100)) {\n val += this[offset + i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readIntBE = function readIntBE (offset, byteLength, noAssert) {\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) checkOffset(offset, byteLength, this.length)\n\n let i = byteLength\n let mul = 1\n let val = this[offset + --i]\n while (i > 0 && (mul *= 0x100)) {\n val += this[offset + --i] * mul\n }\n mul *= 0x80\n\n if (val >= mul) val -= Math.pow(2, 8 * byteLength)\n\n return val\n}\n\nBuffer.prototype.readInt8 = function readInt8 (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 1, this.length)\n if (!(this[offset] & 0x80)) return (this[offset])\n return ((0xff - this[offset] + 1) * -1)\n}\n\nBuffer.prototype.readInt16LE = function readInt16LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset] | (this[offset + 1] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt16BE = function readInt16BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 2, this.length)\n const val = this[offset + 1] | (this[offset] << 8)\n return (val & 0x8000) ? val | 0xFFFF0000 : val\n}\n\nBuffer.prototype.readInt32LE = function readInt32LE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset]) |\n (this[offset + 1] << 8) |\n (this[offset + 2] << 16) |\n (this[offset + 3] << 24)\n}\n\nBuffer.prototype.readInt32BE = function readInt32BE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n\n return (this[offset] << 24) |\n (this[offset + 1] << 16) |\n (this[offset + 2] << 8) |\n (this[offset + 3])\n}\n\nBuffer.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = this[offset + 4] +\n this[offset + 5] * 2 ** 8 +\n this[offset + 6] * 2 ** 16 +\n (last << 24) // Overflow\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(first +\n this[++offset] * 2 ** 8 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 24)\n})\n\nBuffer.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE (offset) {\n offset = offset >>> 0\n validateNumber(offset, 'offset')\n const first = this[offset]\n const last = this[offset + 7]\n if (first === undefined || last === undefined) {\n boundsError(offset, this.length - 8)\n }\n\n const val = (first << 24) + // Overflow\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n this[++offset]\n\n return (BigInt(val) << BigInt(32)) +\n BigInt(this[++offset] * 2 ** 24 +\n this[++offset] * 2 ** 16 +\n this[++offset] * 2 ** 8 +\n last)\n})\n\nBuffer.prototype.readFloatLE = function readFloatLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, true, 23, 4)\n}\n\nBuffer.prototype.readFloatBE = function readFloatBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 4, this.length)\n return ieee754.read(this, offset, false, 23, 4)\n}\n\nBuffer.prototype.readDoubleLE = function readDoubleLE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, true, 52, 8)\n}\n\nBuffer.prototype.readDoubleBE = function readDoubleBE (offset, noAssert) {\n offset = offset >>> 0\n if (!noAssert) checkOffset(offset, 8, this.length)\n return ieee754.read(this, offset, false, 52, 8)\n}\n\nfunction checkInt (buf, value, offset, ext, max, min) {\n if (!Buffer.isBuffer(buf)) throw new TypeError('\"buffer\" argument must be a Buffer instance')\n if (value > max || value < min) throw new RangeError('\"value\" argument is out of bounds')\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n}\n\nBuffer.prototype.writeUintLE =\nBuffer.prototype.writeUIntLE = function writeUIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let mul = 1\n let i = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUintBE =\nBuffer.prototype.writeUIntBE = function writeUIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n byteLength = byteLength >>> 0\n if (!noAssert) {\n const maxBytes = Math.pow(2, 8 * byteLength) - 1\n checkInt(this, value, offset, byteLength, maxBytes, 0)\n }\n\n let i = byteLength - 1\n let mul = 1\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n this[offset + i] = (value / mul) & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeUint8 =\nBuffer.prototype.writeUInt8 = function writeUInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0xff, 0)\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeUint16LE =\nBuffer.prototype.writeUInt16LE = function writeUInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeUint16BE =\nBuffer.prototype.writeUInt16BE = function writeUInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0xffff, 0)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeUint32LE =\nBuffer.prototype.writeUInt32LE = function writeUInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset + 3] = (value >>> 24)\n this[offset + 2] = (value >>> 16)\n this[offset + 1] = (value >>> 8)\n this[offset] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeUint32BE =\nBuffer.prototype.writeUInt32BE = function writeUInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0xffffffff, 0)\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nfunction wrtBigUInt64LE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n lo = lo >> 8\n buf[offset++] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n hi = hi >> 8\n buf[offset++] = hi\n return offset\n}\n\nfunction wrtBigUInt64BE (buf, value, offset, min, max) {\n checkIntBI(value, min, max, buf, offset, 7)\n\n let lo = Number(value & BigInt(0xffffffff))\n buf[offset + 7] = lo\n lo = lo >> 8\n buf[offset + 6] = lo\n lo = lo >> 8\n buf[offset + 5] = lo\n lo = lo >> 8\n buf[offset + 4] = lo\n let hi = Number(value >> BigInt(32) & BigInt(0xffffffff))\n buf[offset + 3] = hi\n hi = hi >> 8\n buf[offset + 2] = hi\n hi = hi >> 8\n buf[offset + 1] = hi\n hi = hi >> 8\n buf[offset] = hi\n return offset + 8\n}\n\nBuffer.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt('0xffffffffffffffff'))\n})\n\nBuffer.prototype.writeIntLE = function writeIntLE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = 0\n let mul = 1\n let sub = 0\n this[offset] = value & 0xFF\n while (++i < byteLength && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeIntBE = function writeIntBE (value, offset, byteLength, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n const limit = Math.pow(2, (8 * byteLength) - 1)\n\n checkInt(this, value, offset, byteLength, limit - 1, -limit)\n }\n\n let i = byteLength - 1\n let mul = 1\n let sub = 0\n this[offset + i] = value & 0xFF\n while (--i >= 0 && (mul *= 0x100)) {\n if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) {\n sub = 1\n }\n this[offset + i] = ((value / mul) >> 0) - sub & 0xFF\n }\n\n return offset + byteLength\n}\n\nBuffer.prototype.writeInt8 = function writeInt8 (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 1, 0x7f, -0x80)\n if (value < 0) value = 0xff + value + 1\n this[offset] = (value & 0xff)\n return offset + 1\n}\n\nBuffer.prototype.writeInt16LE = function writeInt16LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n return offset + 2\n}\n\nBuffer.prototype.writeInt16BE = function writeInt16BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 2, 0x7fff, -0x8000)\n this[offset] = (value >>> 8)\n this[offset + 1] = (value & 0xff)\n return offset + 2\n}\n\nBuffer.prototype.writeInt32LE = function writeInt32LE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n this[offset] = (value & 0xff)\n this[offset + 1] = (value >>> 8)\n this[offset + 2] = (value >>> 16)\n this[offset + 3] = (value >>> 24)\n return offset + 4\n}\n\nBuffer.prototype.writeInt32BE = function writeInt32BE (value, offset, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) checkInt(this, value, offset, 4, 0x7fffffff, -0x80000000)\n if (value < 0) value = 0xffffffff + value + 1\n this[offset] = (value >>> 24)\n this[offset + 1] = (value >>> 16)\n this[offset + 2] = (value >>> 8)\n this[offset + 3] = (value & 0xff)\n return offset + 4\n}\n\nBuffer.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE (value, offset = 0) {\n return wrtBigUInt64LE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nBuffer.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE (value, offset = 0) {\n return wrtBigUInt64BE(this, value, offset, -BigInt('0x8000000000000000'), BigInt('0x7fffffffffffffff'))\n})\n\nfunction checkIEEE754 (buf, value, offset, ext, max, min) {\n if (offset + ext > buf.length) throw new RangeError('Index out of range')\n if (offset < 0) throw new RangeError('Index out of range')\n}\n\nfunction writeFloat (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 4, 3.4028234663852886e+38, -3.4028234663852886e+38)\n }\n ieee754.write(buf, value, offset, littleEndian, 23, 4)\n return offset + 4\n}\n\nBuffer.prototype.writeFloatLE = function writeFloatLE (value, offset, noAssert) {\n return writeFloat(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeFloatBE = function writeFloatBE (value, offset, noAssert) {\n return writeFloat(this, value, offset, false, noAssert)\n}\n\nfunction writeDouble (buf, value, offset, littleEndian, noAssert) {\n value = +value\n offset = offset >>> 0\n if (!noAssert) {\n checkIEEE754(buf, value, offset, 8, 1.7976931348623157E+308, -1.7976931348623157E+308)\n }\n ieee754.write(buf, value, offset, littleEndian, 52, 8)\n return offset + 8\n}\n\nBuffer.prototype.writeDoubleLE = function writeDoubleLE (value, offset, noAssert) {\n return writeDouble(this, value, offset, true, noAssert)\n}\n\nBuffer.prototype.writeDoubleBE = function writeDoubleBE (value, offset, noAssert) {\n return writeDouble(this, value, offset, false, noAssert)\n}\n\n// copy(targetBuffer, targetStart=0, sourceStart=0, sourceEnd=buffer.length)\nBuffer.prototype.copy = function copy (target, targetStart, start, end) {\n if (!Buffer.isBuffer(target)) throw new TypeError('argument should be a Buffer')\n if (!start) start = 0\n if (!end && end !== 0) end = this.length\n if (targetStart >= target.length) targetStart = target.length\n if (!targetStart) targetStart = 0\n if (end > 0 && end < start) end = start\n\n // Copy 0 bytes; we're done\n if (end === start) return 0\n if (target.length === 0 || this.length === 0) return 0\n\n // Fatal error conditions\n if (targetStart < 0) {\n throw new RangeError('targetStart out of bounds')\n }\n if (start < 0 || start >= this.length) throw new RangeError('Index out of range')\n if (end < 0) throw new RangeError('sourceEnd out of bounds')\n\n // Are we oob?\n if (end > this.length) end = this.length\n if (target.length - targetStart < end - start) {\n end = target.length - targetStart + start\n }\n\n const len = end - start\n\n if (this === target && typeof Uint8Array.prototype.copyWithin === 'function') {\n // Use built-in when available, missing from IE11\n this.copyWithin(targetStart, start, end)\n } else {\n Uint8Array.prototype.set.call(\n target,\n this.subarray(start, end),\n targetStart\n )\n }\n\n return len\n}\n\n// Usage:\n// buffer.fill(number[, offset[, end]])\n// buffer.fill(buffer[, offset[, end]])\n// buffer.fill(string[, offset[, end]][, encoding])\nBuffer.prototype.fill = function fill (val, start, end, encoding) {\n // Handle string cases:\n if (typeof val === 'string') {\n if (typeof start === 'string') {\n encoding = start\n start = 0\n end = this.length\n } else if (typeof end === 'string') {\n encoding = end\n end = this.length\n }\n if (encoding !== undefined && typeof encoding !== 'string') {\n throw new TypeError('encoding must be a string')\n }\n if (typeof encoding === 'string' && !Buffer.isEncoding(encoding)) {\n throw new TypeError('Unknown encoding: ' + encoding)\n }\n if (val.length === 1) {\n const code = val.charCodeAt(0)\n if ((encoding === 'utf8' && code < 128) ||\n encoding === 'latin1') {\n // Fast path: If `val` fits into a single byte, use that numeric value.\n val = code\n }\n }\n } else if (typeof val === 'number') {\n val = val & 255\n } else if (typeof val === 'boolean') {\n val = Number(val)\n }\n\n // Invalid ranges are not set to a default, so can range check early.\n if (start < 0 || this.length < start || this.length < end) {\n throw new RangeError('Out of range index')\n }\n\n if (end <= start) {\n return this\n }\n\n start = start >>> 0\n end = end === undefined ? this.length : end >>> 0\n\n if (!val) val = 0\n\n let i\n if (typeof val === 'number') {\n for (i = start; i < end; ++i) {\n this[i] = val\n }\n } else {\n const bytes = Buffer.isBuffer(val)\n ? val\n : Buffer.from(val, encoding)\n const len = bytes.length\n if (len === 0) {\n throw new TypeError('The value \"' + val +\n '\" is invalid for argument \"value\"')\n }\n for (i = 0; i < end - start; ++i) {\n this[i + start] = bytes[i % len]\n }\n }\n\n return this\n}\n\n// CUSTOM ERRORS\n// =============\n\n// Simplified versions from Node, changed for Buffer-only usage\nconst errors = {}\nfunction E (sym, getMessage, Base) {\n errors[sym] = class NodeError extends Base {\n constructor () {\n super()\n\n Object.defineProperty(this, 'message', {\n value: getMessage.apply(this, arguments),\n writable: true,\n configurable: true\n })\n\n // Add the error code to the name to include it in the stack trace.\n this.name = `${this.name} [${sym}]`\n // Access the stack to generate the error message including the error code\n // from the name.\n this.stack // eslint-disable-line no-unused-expressions\n // Reset the name to the actual name.\n delete this.name\n }\n\n get code () {\n return sym\n }\n\n set code (value) {\n Object.defineProperty(this, 'code', {\n configurable: true,\n enumerable: true,\n value,\n writable: true\n })\n }\n\n toString () {\n return `${this.name} [${sym}]: ${this.message}`\n }\n }\n}\n\nE('ERR_BUFFER_OUT_OF_BOUNDS',\n function (name) {\n if (name) {\n return `${name} is outside of buffer bounds`\n }\n\n return 'Attempt to access memory outside buffer bounds'\n }, RangeError)\nE('ERR_INVALID_ARG_TYPE',\n function (name, actual) {\n return `The \"${name}\" argument must be of type number. Received type ${typeof actual}`\n }, TypeError)\nE('ERR_OUT_OF_RANGE',\n function (str, range, input) {\n let msg = `The value of \"${str}\" is out of range.`\n let received = input\n if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) {\n received = addNumericalSeparator(String(input))\n } else if (typeof input === 'bigint') {\n received = String(input)\n if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) {\n received = addNumericalSeparator(received)\n }\n received += 'n'\n }\n msg += ` It must be ${range}. Received ${received}`\n return msg\n }, RangeError)\n\nfunction addNumericalSeparator (val) {\n let res = ''\n let i = val.length\n const start = val[0] === '-' ? 1 : 0\n for (; i >= start + 4; i -= 3) {\n res = `_${val.slice(i - 3, i)}${res}`\n }\n return `${val.slice(0, i)}${res}`\n}\n\n// CHECK FUNCTIONS\n// ===============\n\nfunction checkBounds (buf, offset, byteLength) {\n validateNumber(offset, 'offset')\n if (buf[offset] === undefined || buf[offset + byteLength] === undefined) {\n boundsError(offset, buf.length - (byteLength + 1))\n }\n}\n\nfunction checkIntBI (value, min, max, buf, offset, byteLength) {\n if (value > max || value < min) {\n const n = typeof min === 'bigint' ? 'n' : ''\n let range\n if (byteLength > 3) {\n if (min === 0 || min === BigInt(0)) {\n range = `>= 0${n} and < 2${n} ** ${(byteLength + 1) * 8}${n}`\n } else {\n range = `>= -(2${n} ** ${(byteLength + 1) * 8 - 1}${n}) and < 2 ** ` +\n `${(byteLength + 1) * 8 - 1}${n}`\n }\n } else {\n range = `>= ${min}${n} and <= ${max}${n}`\n }\n throw new errors.ERR_OUT_OF_RANGE('value', range, value)\n }\n checkBounds(buf, offset, byteLength)\n}\n\nfunction validateNumber (value, name) {\n if (typeof value !== 'number') {\n throw new errors.ERR_INVALID_ARG_TYPE(name, 'number', value)\n }\n}\n\nfunction boundsError (value, length, type) {\n if (Math.floor(value) !== value) {\n validateNumber(value, type)\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset', 'an integer', value)\n }\n\n if (length < 0) {\n throw new errors.ERR_BUFFER_OUT_OF_BOUNDS()\n }\n\n throw new errors.ERR_OUT_OF_RANGE(type || 'offset',\n `>= ${type ? 1 : 0} and <= ${length}`,\n value)\n}\n\n// HELPER FUNCTIONS\n// ================\n\nconst INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g\n\nfunction base64clean (str) {\n // Node takes equal signs as end of the Base64 encoding\n str = str.split('=')[0]\n // Node strips out invalid characters like \\n and \\t from the string, base64-js does not\n str = str.trim().replace(INVALID_BASE64_RE, '')\n // Node converts strings with length < 2 to ''\n if (str.length < 2) return ''\n // Node allows for non-padded base64 strings (missing trailing ===), base64-js does not\n while (str.length % 4 !== 0) {\n str = str + '='\n }\n return str\n}\n\nfunction utf8ToBytes (string, units) {\n units = units || Infinity\n let codePoint\n const length = string.length\n let leadSurrogate = null\n const bytes = []\n\n for (let i = 0; i < length; ++i) {\n codePoint = string.charCodeAt(i)\n\n // is surrogate component\n if (codePoint > 0xD7FF && codePoint < 0xE000) {\n // last char was a lead\n if (!leadSurrogate) {\n // no lead yet\n if (codePoint > 0xDBFF) {\n // unexpected trail\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n } else if (i + 1 === length) {\n // unpaired lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n continue\n }\n\n // valid lead\n leadSurrogate = codePoint\n\n continue\n }\n\n // 2 leads in a row\n if (codePoint < 0xDC00) {\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n leadSurrogate = codePoint\n continue\n }\n\n // valid surrogate pair\n codePoint = (leadSurrogate - 0xD800 << 10 | codePoint - 0xDC00) + 0x10000\n } else if (leadSurrogate) {\n // valid bmp char, but last char was a lead\n if ((units -= 3) > -1) bytes.push(0xEF, 0xBF, 0xBD)\n }\n\n leadSurrogate = null\n\n // encode utf8\n if (codePoint < 0x80) {\n if ((units -= 1) < 0) break\n bytes.push(codePoint)\n } else if (codePoint < 0x800) {\n if ((units -= 2) < 0) break\n bytes.push(\n codePoint >> 0x6 | 0xC0,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x10000) {\n if ((units -= 3) < 0) break\n bytes.push(\n codePoint >> 0xC | 0xE0,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else if (codePoint < 0x110000) {\n if ((units -= 4) < 0) break\n bytes.push(\n codePoint >> 0x12 | 0xF0,\n codePoint >> 0xC & 0x3F | 0x80,\n codePoint >> 0x6 & 0x3F | 0x80,\n codePoint & 0x3F | 0x80\n )\n } else {\n throw new Error('Invalid code point')\n }\n }\n\n return bytes\n}\n\nfunction asciiToBytes (str) {\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n // Node's code seems to be doing this and not & 0x7F..\n byteArray.push(str.charCodeAt(i) & 0xFF)\n }\n return byteArray\n}\n\nfunction utf16leToBytes (str, units) {\n let c, hi, lo\n const byteArray = []\n for (let i = 0; i < str.length; ++i) {\n if ((units -= 2) < 0) break\n\n c = str.charCodeAt(i)\n hi = c >> 8\n lo = c % 256\n byteArray.push(lo)\n byteArray.push(hi)\n }\n\n return byteArray\n}\n\nfunction base64ToBytes (str) {\n return base64.toByteArray(base64clean(str))\n}\n\nfunction blitBuffer (src, dst, offset, length) {\n let i\n for (i = 0; i < length; ++i) {\n if ((i + offset >= dst.length) || (i >= src.length)) break\n dst[i + offset] = src[i]\n }\n return i\n}\n\n// ArrayBuffer or Uint8Array objects from other contexts (i.e. iframes) do not pass\n// the `instanceof` check but they should be treated as of that type.\n// See: https://github.com/feross/buffer/issues/166\nfunction isInstance (obj, type) {\n return obj instanceof type ||\n (obj != null && obj.constructor != null && obj.constructor.name != null &&\n obj.constructor.name === type.name)\n}\nfunction numberIsNaN (obj) {\n // For IE11 support\n return obj !== obj // eslint-disable-line no-self-compare\n}\n\n// Create lookup table for `toString('hex')`\n// See: https://github.com/feross/buffer/issues/219\nconst hexSliceLookupTable = (function () {\n const alphabet = '0123456789abcdef'\n const table = new Array(256)\n for (let i = 0; i < 16; ++i) {\n const i16 = i * 16\n for (let j = 0; j < 16; ++j) {\n table[i16 + j] = alphabet[i] + alphabet[j]\n }\n }\n return table\n})()\n\n// Return not function with Error if BigInt not supported\nfunction defineBigIntMethod (fn) {\n return typeof BigInt === 'undefined' ? BufferBigIntNotDefined : fn\n}\n\nfunction BufferBigIntNotDefined () {\n throw new Error('BigInt not supported')\n}\n","/*!\n Copyright (c) 2018 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames() {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tif (arg.length) {\n\t\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\t\tif (inner) {\n\t\t\t\t\t\tclasses.push(inner);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tif (arg.toString === Object.prototype.toString) {\n\t\t\t\t\tfor (var key in arg) {\n\t\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tclasses.push(arg.toString());\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","/* MIT license */\nvar colorNames = require('color-name');\nvar swizzle = require('simple-swizzle');\nvar hasOwnProperty = Object.hasOwnProperty;\n\nvar reverseNames = Object.create(null);\n\n// create a list of reverse color names\nfor (var name in colorNames) {\n\tif (hasOwnProperty.call(colorNames, name)) {\n\t\treverseNames[colorNames[name]] = name;\n\t}\n}\n\nvar cs = module.exports = {\n\tto: {},\n\tget: {}\n};\n\ncs.get = function (string) {\n\tvar prefix = string.substring(0, 3).toLowerCase();\n\tvar val;\n\tvar model;\n\tswitch (prefix) {\n\t\tcase 'hsl':\n\t\t\tval = cs.get.hsl(string);\n\t\t\tmodel = 'hsl';\n\t\t\tbreak;\n\t\tcase 'hwb':\n\t\t\tval = cs.get.hwb(string);\n\t\t\tmodel = 'hwb';\n\t\t\tbreak;\n\t\tdefault:\n\t\t\tval = cs.get.rgb(string);\n\t\t\tmodel = 'rgb';\n\t\t\tbreak;\n\t}\n\n\tif (!val) {\n\t\treturn null;\n\t}\n\n\treturn {model: model, value: val};\n};\n\ncs.get.rgb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar abbr = /^#([a-f0-9]{3,4})$/i;\n\tvar hex = /^#([a-f0-9]{6})([a-f0-9]{2})?$/i;\n\tvar rgba = /^rgba?\\(\\s*([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)(?=[\\s,])\\s*(?:,\\s*)?([+-]?\\d+)\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/;\n\tvar per = /^rgba?\\(\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*,?\\s*([+-]?[\\d\\.]+)\\%\\s*(?:[,|\\/]\\s*([+-]?[\\d\\.]+)(%?)\\s*)?\\)$/;\n\tvar keyword = /^(\\w+)$/;\n\n\tvar rgb = [0, 0, 0, 1];\n\tvar match;\n\tvar i;\n\tvar hexAlpha;\n\n\tif (match = string.match(hex)) {\n\t\thexAlpha = match[2];\n\t\tmatch = match[1];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\t// https://jsperf.com/slice-vs-substr-vs-substring-methods-long-string/19\n\t\t\tvar i2 = i * 2;\n\t\t\trgb[i] = parseInt(match.slice(i2, i2 + 2), 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(abbr)) {\n\t\tmatch = match[1];\n\t\thexAlpha = match[3];\n\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i] + match[i], 16);\n\t\t}\n\n\t\tif (hexAlpha) {\n\t\t\trgb[3] = parseInt(hexAlpha + hexAlpha, 16) / 255;\n\t\t}\n\t} else if (match = string.match(rgba)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = parseInt(match[i + 1], 0);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\tif (match[5]) {\n\t\t\t\trgb[3] = parseFloat(match[4]) * 0.01;\n\t\t\t} else {\n\t\t\t\trgb[3] = parseFloat(match[4]);\n\t\t\t}\n\t\t}\n\t} else if (match = string.match(per)) {\n\t\tfor (i = 0; i < 3; i++) {\n\t\t\trgb[i] = Math.round(parseFloat(match[i + 1]) * 2.55);\n\t\t}\n\n\t\tif (match[4]) {\n\t\t\tif (match[5]) {\n\t\t\t\trgb[3] = parseFloat(match[4]) * 0.01;\n\t\t\t} else {\n\t\t\t\trgb[3] = parseFloat(match[4]);\n\t\t\t}\n\t\t}\n\t} else if (match = string.match(keyword)) {\n\t\tif (match[1] === 'transparent') {\n\t\t\treturn [0, 0, 0, 0];\n\t\t}\n\n\t\tif (!hasOwnProperty.call(colorNames, match[1])) {\n\t\t\treturn null;\n\t\t}\n\n\t\trgb = colorNames[match[1]];\n\t\trgb[3] = 1;\n\n\t\treturn rgb;\n\t} else {\n\t\treturn null;\n\t}\n\n\tfor (i = 0; i < 3; i++) {\n\t\trgb[i] = clamp(rgb[i], 0, 255);\n\t}\n\trgb[3] = clamp(rgb[3], 0, 1);\n\n\treturn rgb;\n};\n\ncs.get.hsl = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hsl = /^hsla?\\(\\s*([+-]?(?:\\d{0,3}\\.)?\\d+)(?:deg)?\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*,?\\s*([+-]?[\\d\\.]+)%\\s*(?:[,|\\/]\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/;\n\tvar match = string.match(hsl);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = ((parseFloat(match[1]) % 360) + 360) % 360;\n\t\tvar s = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar l = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\n\t\treturn [h, s, l, a];\n\t}\n\n\treturn null;\n};\n\ncs.get.hwb = function (string) {\n\tif (!string) {\n\t\treturn null;\n\t}\n\n\tvar hwb = /^hwb\\(\\s*([+-]?\\d{0,3}(?:\\.\\d+)?)(?:deg)?\\s*,\\s*([+-]?[\\d\\.]+)%\\s*,\\s*([+-]?[\\d\\.]+)%\\s*(?:,\\s*([+-]?(?=\\.\\d|\\d)(?:0|[1-9]\\d*)?(?:\\.\\d*)?(?:[eE][+-]?\\d+)?)\\s*)?\\)$/;\n\tvar match = string.match(hwb);\n\n\tif (match) {\n\t\tvar alpha = parseFloat(match[4]);\n\t\tvar h = ((parseFloat(match[1]) % 360) + 360) % 360;\n\t\tvar w = clamp(parseFloat(match[2]), 0, 100);\n\t\tvar b = clamp(parseFloat(match[3]), 0, 100);\n\t\tvar a = clamp(isNaN(alpha) ? 1 : alpha, 0, 1);\n\t\treturn [h, w, b, a];\n\t}\n\n\treturn null;\n};\n\ncs.to.hex = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn (\n\t\t'#' +\n\t\thexDouble(rgba[0]) +\n\t\thexDouble(rgba[1]) +\n\t\thexDouble(rgba[2]) +\n\t\t(rgba[3] < 1\n\t\t\t? (hexDouble(Math.round(rgba[3] * 255)))\n\t\t\t: '')\n\t);\n};\n\ncs.to.rgb = function () {\n\tvar rgba = swizzle(arguments);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ')'\n\t\t: 'rgba(' + Math.round(rgba[0]) + ', ' + Math.round(rgba[1]) + ', ' + Math.round(rgba[2]) + ', ' + rgba[3] + ')';\n};\n\ncs.to.rgb.percent = function () {\n\tvar rgba = swizzle(arguments);\n\n\tvar r = Math.round(rgba[0] / 255 * 100);\n\tvar g = Math.round(rgba[1] / 255 * 100);\n\tvar b = Math.round(rgba[2] / 255 * 100);\n\n\treturn rgba.length < 4 || rgba[3] === 1\n\t\t? 'rgb(' + r + '%, ' + g + '%, ' + b + '%)'\n\t\t: 'rgba(' + r + '%, ' + g + '%, ' + b + '%, ' + rgba[3] + ')';\n};\n\ncs.to.hsl = function () {\n\tvar hsla = swizzle(arguments);\n\treturn hsla.length < 4 || hsla[3] === 1\n\t\t? 'hsl(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%)'\n\t\t: 'hsla(' + hsla[0] + ', ' + hsla[1] + '%, ' + hsla[2] + '%, ' + hsla[3] + ')';\n};\n\n// hwb is a bit different than rgb(a) & hsl(a) since there is no alpha specific syntax\n// (hwb have alpha optional & 1 is default value)\ncs.to.hwb = function () {\n\tvar hwba = swizzle(arguments);\n\n\tvar a = '';\n\tif (hwba.length >= 4 && hwba[3] !== 1) {\n\t\ta = ', ' + hwba[3];\n\t}\n\n\treturn 'hwb(' + hwba[0] + ', ' + hwba[1] + '%, ' + hwba[2] + '%' + a + ')';\n};\n\ncs.to.keyword = function (rgb) {\n\treturn reverseNames[rgb.slice(0, 3)];\n};\n\n// helpers\nfunction clamp(num, min, max) {\n\treturn Math.min(Math.max(min, num), max);\n}\n\nfunction hexDouble(num) {\n\tvar str = Math.round(num).toString(16).toUpperCase();\n\treturn (str.length < 2) ? '0' + str : str;\n}\n","const colorString = require('color-string');\nconst convert = require('color-convert');\n\nconst skippedModels = [\n\t// To be honest, I don't really feel like keyword belongs in color convert, but eh.\n\t'keyword',\n\n\t// Gray conflicts with some method names, and has its own method defined.\n\t'gray',\n\n\t// Shouldn't really be in color-convert either...\n\t'hex',\n];\n\nconst hashedModelKeys = {};\nfor (const model of Object.keys(convert)) {\n\thashedModelKeys[[...convert[model].labels].sort().join('')] = model;\n}\n\nconst limiters = {};\n\nfunction Color(object, model) {\n\tif (!(this instanceof Color)) {\n\t\treturn new Color(object, model);\n\t}\n\n\tif (model && model in skippedModels) {\n\t\tmodel = null;\n\t}\n\n\tif (model && !(model in convert)) {\n\t\tthrow new Error('Unknown model: ' + model);\n\t}\n\n\tlet i;\n\tlet channels;\n\n\tif (object == null) { // eslint-disable-line no-eq-null,eqeqeq\n\t\tthis.model = 'rgb';\n\t\tthis.color = [0, 0, 0];\n\t\tthis.valpha = 1;\n\t} else if (object instanceof Color) {\n\t\tthis.model = object.model;\n\t\tthis.color = [...object.color];\n\t\tthis.valpha = object.valpha;\n\t} else if (typeof object === 'string') {\n\t\tconst result = colorString.get(object);\n\t\tif (result === null) {\n\t\t\tthrow new Error('Unable to parse color from string: ' + object);\n\t\t}\n\n\t\tthis.model = result.model;\n\t\tchannels = convert[this.model].channels;\n\t\tthis.color = result.value.slice(0, channels);\n\t\tthis.valpha = typeof result.value[channels] === 'number' ? result.value[channels] : 1;\n\t} else if (object.length > 0) {\n\t\tthis.model = model || 'rgb';\n\t\tchannels = convert[this.model].channels;\n\t\tconst newArray = Array.prototype.slice.call(object, 0, channels);\n\t\tthis.color = zeroArray(newArray, channels);\n\t\tthis.valpha = typeof object[channels] === 'number' ? object[channels] : 1;\n\t} else if (typeof object === 'number') {\n\t\t// This is always RGB - can be converted later on.\n\t\tthis.model = 'rgb';\n\t\tthis.color = [\n\t\t\t(object >> 16) & 0xFF,\n\t\t\t(object >> 8) & 0xFF,\n\t\t\tobject & 0xFF,\n\t\t];\n\t\tthis.valpha = 1;\n\t} else {\n\t\tthis.valpha = 1;\n\n\t\tconst keys = Object.keys(object);\n\t\tif ('alpha' in object) {\n\t\t\tkeys.splice(keys.indexOf('alpha'), 1);\n\t\t\tthis.valpha = typeof object.alpha === 'number' ? object.alpha : 0;\n\t\t}\n\n\t\tconst hashedKeys = keys.sort().join('');\n\t\tif (!(hashedKeys in hashedModelKeys)) {\n\t\t\tthrow new Error('Unable to parse color from object: ' + JSON.stringify(object));\n\t\t}\n\n\t\tthis.model = hashedModelKeys[hashedKeys];\n\n\t\tconst {labels} = convert[this.model];\n\t\tconst color = [];\n\t\tfor (i = 0; i < labels.length; i++) {\n\t\t\tcolor.push(object[labels[i]]);\n\t\t}\n\n\t\tthis.color = zeroArray(color);\n\t}\n\n\t// Perform limitations (clamping, etc.)\n\tif (limiters[this.model]) {\n\t\tchannels = convert[this.model].channels;\n\t\tfor (i = 0; i < channels; i++) {\n\t\t\tconst limit = limiters[this.model][i];\n\t\t\tif (limit) {\n\t\t\t\tthis.color[i] = limit(this.color[i]);\n\t\t\t}\n\t\t}\n\t}\n\n\tthis.valpha = Math.max(0, Math.min(1, this.valpha));\n\n\tif (Object.freeze) {\n\t\tObject.freeze(this);\n\t}\n}\n\nColor.prototype = {\n\ttoString() {\n\t\treturn this.string();\n\t},\n\n\ttoJSON() {\n\t\treturn this[this.model]();\n\t},\n\n\tstring(places) {\n\t\tlet self = this.model in colorString.to ? this : this.rgb();\n\t\tself = self.round(typeof places === 'number' ? places : 1);\n\t\tconst args = self.valpha === 1 ? self.color : [...self.color, this.valpha];\n\t\treturn colorString.to[self.model](args);\n\t},\n\n\tpercentString(places) {\n\t\tconst self = this.rgb().round(typeof places === 'number' ? places : 1);\n\t\tconst args = self.valpha === 1 ? self.color : [...self.color, this.valpha];\n\t\treturn colorString.to.rgb.percent(args);\n\t},\n\n\tarray() {\n\t\treturn this.valpha === 1 ? [...this.color] : [...this.color, this.valpha];\n\t},\n\n\tobject() {\n\t\tconst result = {};\n\t\tconst {channels} = convert[this.model];\n\t\tconst {labels} = convert[this.model];\n\n\t\tfor (let i = 0; i < channels; i++) {\n\t\t\tresult[labels[i]] = this.color[i];\n\t\t}\n\n\t\tif (this.valpha !== 1) {\n\t\t\tresult.alpha = this.valpha;\n\t\t}\n\n\t\treturn result;\n\t},\n\n\tunitArray() {\n\t\tconst rgb = this.rgb().color;\n\t\trgb[0] /= 255;\n\t\trgb[1] /= 255;\n\t\trgb[2] /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.push(this.valpha);\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tunitObject() {\n\t\tconst rgb = this.rgb().object();\n\t\trgb.r /= 255;\n\t\trgb.g /= 255;\n\t\trgb.b /= 255;\n\n\t\tif (this.valpha !== 1) {\n\t\t\trgb.alpha = this.valpha;\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tround(places) {\n\t\tplaces = Math.max(places || 0, 0);\n\t\treturn new Color([...this.color.map(roundToPlace(places)), this.valpha], this.model);\n\t},\n\n\talpha(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color([...this.color, Math.max(0, Math.min(1, value))], this.model);\n\t\t}\n\n\t\treturn this.valpha;\n\t},\n\n\t// Rgb\n\tred: getset('rgb', 0, maxfn(255)),\n\tgreen: getset('rgb', 1, maxfn(255)),\n\tblue: getset('rgb', 2, maxfn(255)),\n\n\thue: getset(['hsl', 'hsv', 'hsl', 'hwb', 'hcg'], 0, value => ((value % 360) + 360) % 360),\n\n\tsaturationl: getset('hsl', 1, maxfn(100)),\n\tlightness: getset('hsl', 2, maxfn(100)),\n\n\tsaturationv: getset('hsv', 1, maxfn(100)),\n\tvalue: getset('hsv', 2, maxfn(100)),\n\n\tchroma: getset('hcg', 1, maxfn(100)),\n\tgray: getset('hcg', 2, maxfn(100)),\n\n\twhite: getset('hwb', 1, maxfn(100)),\n\twblack: getset('hwb', 2, maxfn(100)),\n\n\tcyan: getset('cmyk', 0, maxfn(100)),\n\tmagenta: getset('cmyk', 1, maxfn(100)),\n\tyellow: getset('cmyk', 2, maxfn(100)),\n\tblack: getset('cmyk', 3, maxfn(100)),\n\n\tx: getset('xyz', 0, maxfn(95.047)),\n\ty: getset('xyz', 1, maxfn(100)),\n\tz: getset('xyz', 2, maxfn(108.833)),\n\n\tl: getset('lab', 0, maxfn(100)),\n\ta: getset('lab', 1),\n\tb: getset('lab', 2),\n\n\tkeyword(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\treturn convert[this.model].keyword(this.color);\n\t},\n\n\thex(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\treturn colorString.to.hex(this.rgb().round().color);\n\t},\n\n\thexa(value) {\n\t\tif (value !== undefined) {\n\t\t\treturn new Color(value);\n\t\t}\n\n\t\tconst rgbArray = this.rgb().round().color;\n\n\t\tlet alphaHex = Math.round(this.valpha * 255).toString(16).toUpperCase();\n\t\tif (alphaHex.length === 1) {\n\t\t\talphaHex = '0' + alphaHex;\n\t\t}\n\n\t\treturn colorString.to.hex(rgbArray) + alphaHex;\n\t},\n\n\trgbNumber() {\n\t\tconst rgb = this.rgb().color;\n\t\treturn ((rgb[0] & 0xFF) << 16) | ((rgb[1] & 0xFF) << 8) | (rgb[2] & 0xFF);\n\t},\n\n\tluminosity() {\n\t\t// http://www.w3.org/TR/WCAG20/#relativeluminancedef\n\t\tconst rgb = this.rgb().color;\n\n\t\tconst lum = [];\n\t\tfor (const [i, element] of rgb.entries()) {\n\t\t\tconst chan = element / 255;\n\t\t\tlum[i] = (chan <= 0.04045) ? chan / 12.92 : ((chan + 0.055) / 1.055) ** 2.4;\n\t\t}\n\n\t\treturn 0.2126 * lum[0] + 0.7152 * lum[1] + 0.0722 * lum[2];\n\t},\n\n\tcontrast(color2) {\n\t\t// http://www.w3.org/TR/WCAG20/#contrast-ratiodef\n\t\tconst lum1 = this.luminosity();\n\t\tconst lum2 = color2.luminosity();\n\n\t\tif (lum1 > lum2) {\n\t\t\treturn (lum1 + 0.05) / (lum2 + 0.05);\n\t\t}\n\n\t\treturn (lum2 + 0.05) / (lum1 + 0.05);\n\t},\n\n\tlevel(color2) {\n\t\t// https://www.w3.org/TR/WCAG/#contrast-enhanced\n\t\tconst contrastRatio = this.contrast(color2);\n\t\tif (contrastRatio >= 7) {\n\t\t\treturn 'AAA';\n\t\t}\n\n\t\treturn (contrastRatio >= 4.5) ? 'AA' : '';\n\t},\n\n\tisDark() {\n\t\t// YIQ equation from http://24ways.org/2010/calculating-color-contrast\n\t\tconst rgb = this.rgb().color;\n\t\tconst yiq = (rgb[0] * 2126 + rgb[1] * 7152 + rgb[2] * 722) / 10000;\n\t\treturn yiq < 128;\n\t},\n\n\tisLight() {\n\t\treturn !this.isDark();\n\t},\n\n\tnegate() {\n\t\tconst rgb = this.rgb();\n\t\tfor (let i = 0; i < 3; i++) {\n\t\t\trgb.color[i] = 255 - rgb.color[i];\n\t\t}\n\n\t\treturn rgb;\n\t},\n\n\tlighten(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[2] += hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdarken(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[2] -= hsl.color[2] * ratio;\n\t\treturn hsl;\n\t},\n\n\tsaturate(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[1] += hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\tdesaturate(ratio) {\n\t\tconst hsl = this.hsl();\n\t\thsl.color[1] -= hsl.color[1] * ratio;\n\t\treturn hsl;\n\t},\n\n\twhiten(ratio) {\n\t\tconst hwb = this.hwb();\n\t\thwb.color[1] += hwb.color[1] * ratio;\n\t\treturn hwb;\n\t},\n\n\tblacken(ratio) {\n\t\tconst hwb = this.hwb();\n\t\thwb.color[2] += hwb.color[2] * ratio;\n\t\treturn hwb;\n\t},\n\n\tgrayscale() {\n\t\t// http://en.wikipedia.org/wiki/Grayscale#Converting_color_to_grayscale\n\t\tconst rgb = this.rgb().color;\n\t\tconst value = rgb[0] * 0.3 + rgb[1] * 0.59 + rgb[2] * 0.11;\n\t\treturn Color.rgb(value, value, value);\n\t},\n\n\tfade(ratio) {\n\t\treturn this.alpha(this.valpha - (this.valpha * ratio));\n\t},\n\n\topaquer(ratio) {\n\t\treturn this.alpha(this.valpha + (this.valpha * ratio));\n\t},\n\n\trotate(degrees) {\n\t\tconst hsl = this.hsl();\n\t\tlet hue = hsl.color[0];\n\t\thue = (hue + degrees) % 360;\n\t\thue = hue < 0 ? 360 + hue : hue;\n\t\thsl.color[0] = hue;\n\t\treturn hsl;\n\t},\n\n\tmix(mixinColor, weight) {\n\t\t// Ported from sass implementation in C\n\t\t// https://github.com/sass/libsass/blob/0e6b4a2850092356aa3ece07c6b249f0221caced/functions.cpp#L209\n\t\tif (!mixinColor || !mixinColor.rgb) {\n\t\t\tthrow new Error('Argument to \"mix\" was not a Color instance, but rather an instance of ' + typeof mixinColor);\n\t\t}\n\n\t\tconst color1 = mixinColor.rgb();\n\t\tconst color2 = this.rgb();\n\t\tconst p = weight === undefined ? 0.5 : weight;\n\n\t\tconst w = 2 * p - 1;\n\t\tconst a = color1.alpha() - color2.alpha();\n\n\t\tconst w1 = (((w * a === -1) ? w : (w + a) / (1 + w * a)) + 1) / 2;\n\t\tconst w2 = 1 - w1;\n\n\t\treturn Color.rgb(\n\t\t\tw1 * color1.red() + w2 * color2.red(),\n\t\t\tw1 * color1.green() + w2 * color2.green(),\n\t\t\tw1 * color1.blue() + w2 * color2.blue(),\n\t\t\tcolor1.alpha() * p + color2.alpha() * (1 - p));\n\t},\n};\n\n// Model conversion methods and static constructors\nfor (const model of Object.keys(convert)) {\n\tif (skippedModels.includes(model)) {\n\t\tcontinue;\n\t}\n\n\tconst {channels} = convert[model];\n\n\t// Conversion methods\n\tColor.prototype[model] = function (...args) {\n\t\tif (this.model === model) {\n\t\t\treturn new Color(this);\n\t\t}\n\n\t\tif (args.length > 0) {\n\t\t\treturn new Color(args, model);\n\t\t}\n\n\t\treturn new Color([...assertArray(convert[this.model][model].raw(this.color)), this.valpha], model);\n\t};\n\n\t// 'static' construction methods\n\tColor[model] = function (...args) {\n\t\tlet color = args[0];\n\t\tif (typeof color === 'number') {\n\t\t\tcolor = zeroArray(args, channels);\n\t\t}\n\n\t\treturn new Color(color, model);\n\t};\n}\n\nfunction roundTo(number, places) {\n\treturn Number(number.toFixed(places));\n}\n\nfunction roundToPlace(places) {\n\treturn function (number) {\n\t\treturn roundTo(number, places);\n\t};\n}\n\nfunction getset(model, channel, modifier) {\n\tmodel = Array.isArray(model) ? model : [model];\n\n\tfor (const m of model) {\n\t\t(limiters[m] || (limiters[m] = []))[channel] = modifier;\n\t}\n\n\tmodel = model[0];\n\n\treturn function (value) {\n\t\tlet result;\n\n\t\tif (value !== undefined) {\n\t\t\tif (modifier) {\n\t\t\t\tvalue = modifier(value);\n\t\t\t}\n\n\t\t\tresult = this[model]();\n\t\t\tresult.color[channel] = value;\n\t\t\treturn result;\n\t\t}\n\n\t\tresult = this[model]().color[channel];\n\t\tif (modifier) {\n\t\t\tresult = modifier(result);\n\t\t}\n\n\t\treturn result;\n\t};\n}\n\nfunction maxfn(max) {\n\treturn function (v) {\n\t\treturn Math.max(0, Math.min(max, v));\n\t};\n}\n\nfunction assertArray(value) {\n\treturn Array.isArray(value) ? value : [value];\n}\n\nfunction zeroArray(array, length) {\n\tfor (let i = 0; i < length; i++) {\n\t\tif (typeof array[i] !== 'number') {\n\t\t\tarray[i] = 0;\n\t\t}\n\t}\n\n\treturn array;\n}\n\nmodule.exports = Color;\n","/* MIT license */\n/* eslint-disable no-mixed-operators */\nconst cssKeywords = require('color-name');\n\n// NOTE: conversions should only return primitive values (i.e. arrays, or\n// values that give correct `typeof` results).\n// do not use box values types (i.e. Number(), String(), etc.)\n\nconst reverseKeywords = {};\nfor (const key of Object.keys(cssKeywords)) {\n\treverseKeywords[cssKeywords[key]] = key;\n}\n\nconst convert = {\n\trgb: {channels: 3, labels: 'rgb'},\n\thsl: {channels: 3, labels: 'hsl'},\n\thsv: {channels: 3, labels: 'hsv'},\n\thwb: {channels: 3, labels: 'hwb'},\n\tcmyk: {channels: 4, labels: 'cmyk'},\n\txyz: {channels: 3, labels: 'xyz'},\n\tlab: {channels: 3, labels: 'lab'},\n\tlch: {channels: 3, labels: 'lch'},\n\thex: {channels: 1, labels: ['hex']},\n\tkeyword: {channels: 1, labels: ['keyword']},\n\tansi16: {channels: 1, labels: ['ansi16']},\n\tansi256: {channels: 1, labels: ['ansi256']},\n\thcg: {channels: 3, labels: ['h', 'c', 'g']},\n\tapple: {channels: 3, labels: ['r16', 'g16', 'b16']},\n\tgray: {channels: 1, labels: ['gray']}\n};\n\nmodule.exports = convert;\n\n// Hide .channels and .labels properties\nfor (const model of Object.keys(convert)) {\n\tif (!('channels' in convert[model])) {\n\t\tthrow new Error('missing channels property: ' + model);\n\t}\n\n\tif (!('labels' in convert[model])) {\n\t\tthrow new Error('missing channel labels property: ' + model);\n\t}\n\n\tif (convert[model].labels.length !== convert[model].channels) {\n\t\tthrow new Error('channel and label counts mismatch: ' + model);\n\t}\n\n\tconst {channels, labels} = convert[model];\n\tdelete convert[model].channels;\n\tdelete convert[model].labels;\n\tObject.defineProperty(convert[model], 'channels', {value: channels});\n\tObject.defineProperty(convert[model], 'labels', {value: labels});\n}\n\nconvert.rgb.hsl = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst min = Math.min(r, g, b);\n\tconst max = Math.max(r, g, b);\n\tconst delta = max - min;\n\tlet h;\n\tlet s;\n\n\tif (max === min) {\n\t\th = 0;\n\t} else if (r === max) {\n\t\th = (g - b) / delta;\n\t} else if (g === max) {\n\t\th = 2 + (b - r) / delta;\n\t} else if (b === max) {\n\t\th = 4 + (r - g) / delta;\n\t}\n\n\th = Math.min(h * 60, 360);\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tconst l = (min + max) / 2;\n\n\tif (max === min) {\n\t\ts = 0;\n\t} else if (l <= 0.5) {\n\t\ts = delta / (max + min);\n\t} else {\n\t\ts = delta / (2 - max - min);\n\t}\n\n\treturn [h, s * 100, l * 100];\n};\n\nconvert.rgb.hsv = function (rgb) {\n\tlet rdif;\n\tlet gdif;\n\tlet bdif;\n\tlet h;\n\tlet s;\n\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst v = Math.max(r, g, b);\n\tconst diff = v - Math.min(r, g, b);\n\tconst diffc = function (c) {\n\t\treturn (v - c) / 6 / diff + 1 / 2;\n\t};\n\n\tif (diff === 0) {\n\t\th = 0;\n\t\ts = 0;\n\t} else {\n\t\ts = diff / v;\n\t\trdif = diffc(r);\n\t\tgdif = diffc(g);\n\t\tbdif = diffc(b);\n\n\t\tif (r === v) {\n\t\t\th = bdif - gdif;\n\t\t} else if (g === v) {\n\t\t\th = (1 / 3) + rdif - bdif;\n\t\t} else if (b === v) {\n\t\t\th = (2 / 3) + gdif - rdif;\n\t\t}\n\n\t\tif (h < 0) {\n\t\t\th += 1;\n\t\t} else if (h > 1) {\n\t\t\th -= 1;\n\t\t}\n\t}\n\n\treturn [\n\t\th * 360,\n\t\ts * 100,\n\t\tv * 100\n\t];\n};\n\nconvert.rgb.hwb = function (rgb) {\n\tconst r = rgb[0];\n\tconst g = rgb[1];\n\tlet b = rgb[2];\n\tconst h = convert.rgb.hsl(rgb)[0];\n\tconst w = 1 / 255 * Math.min(r, Math.min(g, b));\n\n\tb = 1 - 1 / 255 * Math.max(r, Math.max(g, b));\n\n\treturn [h, w * 100, b * 100];\n};\n\nconvert.rgb.cmyk = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\n\tconst k = Math.min(1 - r, 1 - g, 1 - b);\n\tconst c = (1 - r - k) / (1 - k) || 0;\n\tconst m = (1 - g - k) / (1 - k) || 0;\n\tconst y = (1 - b - k) / (1 - k) || 0;\n\n\treturn [c * 100, m * 100, y * 100, k * 100];\n};\n\nfunction comparativeDistance(x, y) {\n\t/*\n\t\tSee https://en.m.wikipedia.org/wiki/Euclidean_distance#Squared_Euclidean_distance\n\t*/\n\treturn (\n\t\t((x[0] - y[0]) ** 2) +\n\t\t((x[1] - y[1]) ** 2) +\n\t\t((x[2] - y[2]) ** 2)\n\t);\n}\n\nconvert.rgb.keyword = function (rgb) {\n\tconst reversed = reverseKeywords[rgb];\n\tif (reversed) {\n\t\treturn reversed;\n\t}\n\n\tlet currentClosestDistance = Infinity;\n\tlet currentClosestKeyword;\n\n\tfor (const keyword of Object.keys(cssKeywords)) {\n\t\tconst value = cssKeywords[keyword];\n\n\t\t// Compute comparative distance\n\t\tconst distance = comparativeDistance(rgb, value);\n\n\t\t// Check if its less, if so set as closest\n\t\tif (distance < currentClosestDistance) {\n\t\t\tcurrentClosestDistance = distance;\n\t\t\tcurrentClosestKeyword = keyword;\n\t\t}\n\t}\n\n\treturn currentClosestKeyword;\n};\n\nconvert.keyword.rgb = function (keyword) {\n\treturn cssKeywords[keyword];\n};\n\nconvert.rgb.xyz = function (rgb) {\n\tlet r = rgb[0] / 255;\n\tlet g = rgb[1] / 255;\n\tlet b = rgb[2] / 255;\n\n\t// Assume sRGB\n\tr = r > 0.04045 ? (((r + 0.055) / 1.055) ** 2.4) : (r / 12.92);\n\tg = g > 0.04045 ? (((g + 0.055) / 1.055) ** 2.4) : (g / 12.92);\n\tb = b > 0.04045 ? (((b + 0.055) / 1.055) ** 2.4) : (b / 12.92);\n\n\tconst x = (r * 0.4124) + (g * 0.3576) + (b * 0.1805);\n\tconst y = (r * 0.2126) + (g * 0.7152) + (b * 0.0722);\n\tconst z = (r * 0.0193) + (g * 0.1192) + (b * 0.9505);\n\n\treturn [x * 100, y * 100, z * 100];\n};\n\nconvert.rgb.lab = function (rgb) {\n\tconst xyz = convert.rgb.xyz(rgb);\n\tlet x = xyz[0];\n\tlet y = xyz[1];\n\tlet z = xyz[2];\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);\n\n\tconst l = (116 * y) - 16;\n\tconst a = 500 * (x - y);\n\tconst b = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.hsl.rgb = function (hsl) {\n\tconst h = hsl[0] / 360;\n\tconst s = hsl[1] / 100;\n\tconst l = hsl[2] / 100;\n\tlet t2;\n\tlet t3;\n\tlet val;\n\n\tif (s === 0) {\n\t\tval = l * 255;\n\t\treturn [val, val, val];\n\t}\n\n\tif (l < 0.5) {\n\t\tt2 = l * (1 + s);\n\t} else {\n\t\tt2 = l + s - l * s;\n\t}\n\n\tconst t1 = 2 * l - t2;\n\n\tconst rgb = [0, 0, 0];\n\tfor (let i = 0; i < 3; i++) {\n\t\tt3 = h + 1 / 3 * -(i - 1);\n\t\tif (t3 < 0) {\n\t\t\tt3++;\n\t\t}\n\n\t\tif (t3 > 1) {\n\t\t\tt3--;\n\t\t}\n\n\t\tif (6 * t3 < 1) {\n\t\t\tval = t1 + (t2 - t1) * 6 * t3;\n\t\t} else if (2 * t3 < 1) {\n\t\t\tval = t2;\n\t\t} else if (3 * t3 < 2) {\n\t\t\tval = t1 + (t2 - t1) * (2 / 3 - t3) * 6;\n\t\t} else {\n\t\t\tval = t1;\n\t\t}\n\n\t\trgb[i] = val * 255;\n\t}\n\n\treturn rgb;\n};\n\nconvert.hsl.hsv = function (hsl) {\n\tconst h = hsl[0];\n\tlet s = hsl[1] / 100;\n\tlet l = hsl[2] / 100;\n\tlet smin = s;\n\tconst lmin = Math.max(l, 0.01);\n\n\tl *= 2;\n\ts *= (l <= 1) ? l : 2 - l;\n\tsmin *= lmin <= 1 ? lmin : 2 - lmin;\n\tconst v = (l + s) / 2;\n\tconst sv = l === 0 ? (2 * smin) / (lmin + smin) : (2 * s) / (l + s);\n\n\treturn [h, sv * 100, v * 100];\n};\n\nconvert.hsv.rgb = function (hsv) {\n\tconst h = hsv[0] / 60;\n\tconst s = hsv[1] / 100;\n\tlet v = hsv[2] / 100;\n\tconst hi = Math.floor(h) % 6;\n\n\tconst f = h - Math.floor(h);\n\tconst p = 255 * v * (1 - s);\n\tconst q = 255 * v * (1 - (s * f));\n\tconst t = 255 * v * (1 - (s * (1 - f)));\n\tv *= 255;\n\n\tswitch (hi) {\n\t\tcase 0:\n\t\t\treturn [v, t, p];\n\t\tcase 1:\n\t\t\treturn [q, v, p];\n\t\tcase 2:\n\t\t\treturn [p, v, t];\n\t\tcase 3:\n\t\t\treturn [p, q, v];\n\t\tcase 4:\n\t\t\treturn [t, p, v];\n\t\tcase 5:\n\t\t\treturn [v, p, q];\n\t}\n};\n\nconvert.hsv.hsl = function (hsv) {\n\tconst h = hsv[0];\n\tconst s = hsv[1] / 100;\n\tconst v = hsv[2] / 100;\n\tconst vmin = Math.max(v, 0.01);\n\tlet sl;\n\tlet l;\n\n\tl = (2 - s) * v;\n\tconst lmin = (2 - s) * vmin;\n\tsl = s * vmin;\n\tsl /= (lmin <= 1) ? lmin : 2 - lmin;\n\tsl = sl || 0;\n\tl /= 2;\n\n\treturn [h, sl * 100, l * 100];\n};\n\n// http://dev.w3.org/csswg/css-color/#hwb-to-rgb\nconvert.hwb.rgb = function (hwb) {\n\tconst h = hwb[0] / 360;\n\tlet wh = hwb[1] / 100;\n\tlet bl = hwb[2] / 100;\n\tconst ratio = wh + bl;\n\tlet f;\n\n\t// Wh + bl cant be > 1\n\tif (ratio > 1) {\n\t\twh /= ratio;\n\t\tbl /= ratio;\n\t}\n\n\tconst i = Math.floor(6 * h);\n\tconst v = 1 - bl;\n\tf = 6 * h - i;\n\n\tif ((i & 0x01) !== 0) {\n\t\tf = 1 - f;\n\t}\n\n\tconst n = wh + f * (v - wh); // Linear interpolation\n\n\tlet r;\n\tlet g;\n\tlet b;\n\t/* eslint-disable max-statements-per-line,no-multi-spaces */\n\tswitch (i) {\n\t\tdefault:\n\t\tcase 6:\n\t\tcase 0: r = v; g = n; b = wh; break;\n\t\tcase 1: r = n; g = v; b = wh; break;\n\t\tcase 2: r = wh; g = v; b = n; break;\n\t\tcase 3: r = wh; g = n; b = v; break;\n\t\tcase 4: r = n; g = wh; b = v; break;\n\t\tcase 5: r = v; g = wh; b = n; break;\n\t}\n\t/* eslint-enable max-statements-per-line,no-multi-spaces */\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.cmyk.rgb = function (cmyk) {\n\tconst c = cmyk[0] / 100;\n\tconst m = cmyk[1] / 100;\n\tconst y = cmyk[2] / 100;\n\tconst k = cmyk[3] / 100;\n\n\tconst r = 1 - Math.min(1, c * (1 - k) + k);\n\tconst g = 1 - Math.min(1, m * (1 - k) + k);\n\tconst b = 1 - Math.min(1, y * (1 - k) + k);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.rgb = function (xyz) {\n\tconst x = xyz[0] / 100;\n\tconst y = xyz[1] / 100;\n\tconst z = xyz[2] / 100;\n\tlet r;\n\tlet g;\n\tlet b;\n\n\tr = (x * 3.2406) + (y * -1.5372) + (z * -0.4986);\n\tg = (x * -0.9689) + (y * 1.8758) + (z * 0.0415);\n\tb = (x * 0.0557) + (y * -0.2040) + (z * 1.0570);\n\n\t// Assume sRGB\n\tr = r > 0.0031308\n\t\t? ((1.055 * (r ** (1.0 / 2.4))) - 0.055)\n\t\t: r * 12.92;\n\n\tg = g > 0.0031308\n\t\t? ((1.055 * (g ** (1.0 / 2.4))) - 0.055)\n\t\t: g * 12.92;\n\n\tb = b > 0.0031308\n\t\t? ((1.055 * (b ** (1.0 / 2.4))) - 0.055)\n\t\t: b * 12.92;\n\n\tr = Math.min(Math.max(0, r), 1);\n\tg = Math.min(Math.max(0, g), 1);\n\tb = Math.min(Math.max(0, b), 1);\n\n\treturn [r * 255, g * 255, b * 255];\n};\n\nconvert.xyz.lab = function (xyz) {\n\tlet x = xyz[0];\n\tlet y = xyz[1];\n\tlet z = xyz[2];\n\n\tx /= 95.047;\n\ty /= 100;\n\tz /= 108.883;\n\n\tx = x > 0.008856 ? (x ** (1 / 3)) : (7.787 * x) + (16 / 116);\n\ty = y > 0.008856 ? (y ** (1 / 3)) : (7.787 * y) + (16 / 116);\n\tz = z > 0.008856 ? (z ** (1 / 3)) : (7.787 * z) + (16 / 116);\n\n\tconst l = (116 * y) - 16;\n\tconst a = 500 * (x - y);\n\tconst b = 200 * (y - z);\n\n\treturn [l, a, b];\n};\n\nconvert.lab.xyz = function (lab) {\n\tconst l = lab[0];\n\tconst a = lab[1];\n\tconst b = lab[2];\n\tlet x;\n\tlet y;\n\tlet z;\n\n\ty = (l + 16) / 116;\n\tx = a / 500 + y;\n\tz = y - b / 200;\n\n\tconst y2 = y ** 3;\n\tconst x2 = x ** 3;\n\tconst z2 = z ** 3;\n\ty = y2 > 0.008856 ? y2 : (y - 16 / 116) / 7.787;\n\tx = x2 > 0.008856 ? x2 : (x - 16 / 116) / 7.787;\n\tz = z2 > 0.008856 ? z2 : (z - 16 / 116) / 7.787;\n\n\tx *= 95.047;\n\ty *= 100;\n\tz *= 108.883;\n\n\treturn [x, y, z];\n};\n\nconvert.lab.lch = function (lab) {\n\tconst l = lab[0];\n\tconst a = lab[1];\n\tconst b = lab[2];\n\tlet h;\n\n\tconst hr = Math.atan2(b, a);\n\th = hr * 360 / 2 / Math.PI;\n\n\tif (h < 0) {\n\t\th += 360;\n\t}\n\n\tconst c = Math.sqrt(a * a + b * b);\n\n\treturn [l, c, h];\n};\n\nconvert.lch.lab = function (lch) {\n\tconst l = lch[0];\n\tconst c = lch[1];\n\tconst h = lch[2];\n\n\tconst hr = h / 360 * 2 * Math.PI;\n\tconst a = c * Math.cos(hr);\n\tconst b = c * Math.sin(hr);\n\n\treturn [l, a, b];\n};\n\nconvert.rgb.ansi16 = function (args, saturation = null) {\n\tconst [r, g, b] = args;\n\tlet value = saturation === null ? convert.rgb.hsv(args)[2] : saturation; // Hsv -> ansi16 optimization\n\n\tvalue = Math.round(value / 50);\n\n\tif (value === 0) {\n\t\treturn 30;\n\t}\n\n\tlet ansi = 30\n\t\t+ ((Math.round(b / 255) << 2)\n\t\t| (Math.round(g / 255) << 1)\n\t\t| Math.round(r / 255));\n\n\tif (value === 2) {\n\t\tansi += 60;\n\t}\n\n\treturn ansi;\n};\n\nconvert.hsv.ansi16 = function (args) {\n\t// Optimization here; we already know the value and don't need to get\n\t// it converted for us.\n\treturn convert.rgb.ansi16(convert.hsv.rgb(args), args[2]);\n};\n\nconvert.rgb.ansi256 = function (args) {\n\tconst r = args[0];\n\tconst g = args[1];\n\tconst b = args[2];\n\n\t// We use the extended greyscale palette here, with the exception of\n\t// black and white. normal palette only has 4 greyscale shades.\n\tif (r === g && g === b) {\n\t\tif (r < 8) {\n\t\t\treturn 16;\n\t\t}\n\n\t\tif (r > 248) {\n\t\t\treturn 231;\n\t\t}\n\n\t\treturn Math.round(((r - 8) / 247) * 24) + 232;\n\t}\n\n\tconst ansi = 16\n\t\t+ (36 * Math.round(r / 255 * 5))\n\t\t+ (6 * Math.round(g / 255 * 5))\n\t\t+ Math.round(b / 255 * 5);\n\n\treturn ansi;\n};\n\nconvert.ansi16.rgb = function (args) {\n\tlet color = args % 10;\n\n\t// Handle greyscale\n\tif (color === 0 || color === 7) {\n\t\tif (args > 50) {\n\t\t\tcolor += 3.5;\n\t\t}\n\n\t\tcolor = color / 10.5 * 255;\n\n\t\treturn [color, color, color];\n\t}\n\n\tconst mult = (~~(args > 50) + 1) * 0.5;\n\tconst r = ((color & 1) * mult) * 255;\n\tconst g = (((color >> 1) & 1) * mult) * 255;\n\tconst b = (((color >> 2) & 1) * mult) * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.ansi256.rgb = function (args) {\n\t// Handle greyscale\n\tif (args >= 232) {\n\t\tconst c = (args - 232) * 10 + 8;\n\t\treturn [c, c, c];\n\t}\n\n\targs -= 16;\n\n\tlet rem;\n\tconst r = Math.floor(args / 36) / 5 * 255;\n\tconst g = Math.floor((rem = args % 36) / 6) / 5 * 255;\n\tconst b = (rem % 6) / 5 * 255;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hex = function (args) {\n\tconst integer = ((Math.round(args[0]) & 0xFF) << 16)\n\t\t+ ((Math.round(args[1]) & 0xFF) << 8)\n\t\t+ (Math.round(args[2]) & 0xFF);\n\n\tconst string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.hex.rgb = function (args) {\n\tconst match = args.toString(16).match(/[a-f0-9]{6}|[a-f0-9]{3}/i);\n\tif (!match) {\n\t\treturn [0, 0, 0];\n\t}\n\n\tlet colorString = match[0];\n\n\tif (match[0].length === 3) {\n\t\tcolorString = colorString.split('').map(char => {\n\t\t\treturn char + char;\n\t\t}).join('');\n\t}\n\n\tconst integer = parseInt(colorString, 16);\n\tconst r = (integer >> 16) & 0xFF;\n\tconst g = (integer >> 8) & 0xFF;\n\tconst b = integer & 0xFF;\n\n\treturn [r, g, b];\n};\n\nconvert.rgb.hcg = function (rgb) {\n\tconst r = rgb[0] / 255;\n\tconst g = rgb[1] / 255;\n\tconst b = rgb[2] / 255;\n\tconst max = Math.max(Math.max(r, g), b);\n\tconst min = Math.min(Math.min(r, g), b);\n\tconst chroma = (max - min);\n\tlet grayscale;\n\tlet hue;\n\n\tif (chroma < 1) {\n\t\tgrayscale = min / (1 - chroma);\n\t} else {\n\t\tgrayscale = 0;\n\t}\n\n\tif (chroma <= 0) {\n\t\thue = 0;\n\t} else\n\tif (max === r) {\n\t\thue = ((g - b) / chroma) % 6;\n\t} else\n\tif (max === g) {\n\t\thue = 2 + (b - r) / chroma;\n\t} else {\n\t\thue = 4 + (r - g) / chroma;\n\t}\n\n\thue /= 6;\n\thue %= 1;\n\n\treturn [hue * 360, chroma * 100, grayscale * 100];\n};\n\nconvert.hsl.hcg = function (hsl) {\n\tconst s = hsl[1] / 100;\n\tconst l = hsl[2] / 100;\n\n\tconst c = l < 0.5 ? (2.0 * s * l) : (2.0 * s * (1.0 - l));\n\n\tlet f = 0;\n\tif (c < 1.0) {\n\t\tf = (l - 0.5 * c) / (1.0 - c);\n\t}\n\n\treturn [hsl[0], c * 100, f * 100];\n};\n\nconvert.hsv.hcg = function (hsv) {\n\tconst s = hsv[1] / 100;\n\tconst v = hsv[2] / 100;\n\n\tconst c = s * v;\n\tlet f = 0;\n\n\tif (c < 1.0) {\n\t\tf = (v - c) / (1 - c);\n\t}\n\n\treturn [hsv[0], c * 100, f * 100];\n};\n\nconvert.hcg.rgb = function (hcg) {\n\tconst h = hcg[0] / 360;\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tif (c === 0.0) {\n\t\treturn [g * 255, g * 255, g * 255];\n\t}\n\n\tconst pure = [0, 0, 0];\n\tconst hi = (h % 1) * 6;\n\tconst v = hi % 1;\n\tconst w = 1 - v;\n\tlet mg = 0;\n\n\t/* eslint-disable max-statements-per-line */\n\tswitch (Math.floor(hi)) {\n\t\tcase 0:\n\t\t\tpure[0] = 1; pure[1] = v; pure[2] = 0; break;\n\t\tcase 1:\n\t\t\tpure[0] = w; pure[1] = 1; pure[2] = 0; break;\n\t\tcase 2:\n\t\t\tpure[0] = 0; pure[1] = 1; pure[2] = v; break;\n\t\tcase 3:\n\t\t\tpure[0] = 0; pure[1] = w; pure[2] = 1; break;\n\t\tcase 4:\n\t\t\tpure[0] = v; pure[1] = 0; pure[2] = 1; break;\n\t\tdefault:\n\t\t\tpure[0] = 1; pure[1] = 0; pure[2] = w;\n\t}\n\t/* eslint-enable max-statements-per-line */\n\n\tmg = (1.0 - c) * g;\n\n\treturn [\n\t\t(c * pure[0] + mg) * 255,\n\t\t(c * pure[1] + mg) * 255,\n\t\t(c * pure[2] + mg) * 255\n\t];\n};\n\nconvert.hcg.hsv = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tconst v = c + g * (1.0 - c);\n\tlet f = 0;\n\n\tif (v > 0.0) {\n\t\tf = c / v;\n\t}\n\n\treturn [hcg[0], f * 100, v * 100];\n};\n\nconvert.hcg.hsl = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\n\tconst l = g * (1.0 - c) + 0.5 * c;\n\tlet s = 0;\n\n\tif (l > 0.0 && l < 0.5) {\n\t\ts = c / (2 * l);\n\t} else\n\tif (l >= 0.5 && l < 1.0) {\n\t\ts = c / (2 * (1 - l));\n\t}\n\n\treturn [hcg[0], s * 100, l * 100];\n};\n\nconvert.hcg.hwb = function (hcg) {\n\tconst c = hcg[1] / 100;\n\tconst g = hcg[2] / 100;\n\tconst v = c + g * (1.0 - c);\n\treturn [hcg[0], (v - c) * 100, (1 - v) * 100];\n};\n\nconvert.hwb.hcg = function (hwb) {\n\tconst w = hwb[1] / 100;\n\tconst b = hwb[2] / 100;\n\tconst v = 1 - b;\n\tconst c = v - w;\n\tlet g = 0;\n\n\tif (c < 1) {\n\t\tg = (v - c) / (1 - c);\n\t}\n\n\treturn [hwb[0], c * 100, g * 100];\n};\n\nconvert.apple.rgb = function (apple) {\n\treturn [(apple[0] / 65535) * 255, (apple[1] / 65535) * 255, (apple[2] / 65535) * 255];\n};\n\nconvert.rgb.apple = function (rgb) {\n\treturn [(rgb[0] / 255) * 65535, (rgb[1] / 255) * 65535, (rgb[2] / 255) * 65535];\n};\n\nconvert.gray.rgb = function (args) {\n\treturn [args[0] / 100 * 255, args[0] / 100 * 255, args[0] / 100 * 255];\n};\n\nconvert.gray.hsl = function (args) {\n\treturn [0, 0, args[0]];\n};\n\nconvert.gray.hsv = convert.gray.hsl;\n\nconvert.gray.hwb = function (gray) {\n\treturn [0, 100, gray[0]];\n};\n\nconvert.gray.cmyk = function (gray) {\n\treturn [0, 0, 0, gray[0]];\n};\n\nconvert.gray.lab = function (gray) {\n\treturn [gray[0], 0, 0];\n};\n\nconvert.gray.hex = function (gray) {\n\tconst val = Math.round(gray[0] / 100 * 255) & 0xFF;\n\tconst integer = (val << 16) + (val << 8) + val;\n\n\tconst string = integer.toString(16).toUpperCase();\n\treturn '000000'.substring(string.length) + string;\n};\n\nconvert.rgb.gray = function (rgb) {\n\tconst val = (rgb[0] + rgb[1] + rgb[2]) / 3;\n\treturn [val / 255 * 100];\n};\n","const conversions = require('./conversions');\nconst route = require('./route');\n\nconst convert = {};\n\nconst models = Object.keys(conversions);\n\nfunction wrapRaw(fn) {\n\tconst wrappedFn = function (...args) {\n\t\tconst arg0 = args[0];\n\t\tif (arg0 === undefined || arg0 === null) {\n\t\t\treturn arg0;\n\t\t}\n\n\t\tif (arg0.length > 1) {\n\t\t\targs = arg0;\n\t\t}\n\n\t\treturn fn(args);\n\t};\n\n\t// Preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nfunction wrapRounded(fn) {\n\tconst wrappedFn = function (...args) {\n\t\tconst arg0 = args[0];\n\n\t\tif (arg0 === undefined || arg0 === null) {\n\t\t\treturn arg0;\n\t\t}\n\n\t\tif (arg0.length > 1) {\n\t\t\targs = arg0;\n\t\t}\n\n\t\tconst result = fn(args);\n\n\t\t// We're assuming the result is an array here.\n\t\t// see notice in conversions.js; don't use box types\n\t\t// in conversion functions.\n\t\tif (typeof result === 'object') {\n\t\t\tfor (let len = result.length, i = 0; i < len; i++) {\n\t\t\t\tresult[i] = Math.round(result[i]);\n\t\t\t}\n\t\t}\n\n\t\treturn result;\n\t};\n\n\t// Preserve .conversion property if there is one\n\tif ('conversion' in fn) {\n\t\twrappedFn.conversion = fn.conversion;\n\t}\n\n\treturn wrappedFn;\n}\n\nmodels.forEach(fromModel => {\n\tconvert[fromModel] = {};\n\n\tObject.defineProperty(convert[fromModel], 'channels', {value: conversions[fromModel].channels});\n\tObject.defineProperty(convert[fromModel], 'labels', {value: conversions[fromModel].labels});\n\n\tconst routes = route(fromModel);\n\tconst routeModels = Object.keys(routes);\n\n\trouteModels.forEach(toModel => {\n\t\tconst fn = routes[toModel];\n\n\t\tconvert[fromModel][toModel] = wrapRounded(fn);\n\t\tconvert[fromModel][toModel].raw = wrapRaw(fn);\n\t});\n});\n\nmodule.exports = convert;\n","const conversions = require('./conversions');\n\n/*\n\tThis function routes a model to all other models.\n\n\tall functions that are routed have a property `.conversion` attached\n\tto the returned synthetic function. This property is an array\n\tof strings, each with the steps in between the 'from' and 'to'\n\tcolor models (inclusive).\n\n\tconversions that are not possible simply are not included.\n*/\n\nfunction buildGraph() {\n\tconst graph = {};\n\t// https://jsperf.com/object-keys-vs-for-in-with-closure/3\n\tconst models = Object.keys(conversions);\n\n\tfor (let len = models.length, i = 0; i < len; i++) {\n\t\tgraph[models[i]] = {\n\t\t\t// http://jsperf.com/1-vs-infinity\n\t\t\t// micro-opt, but this is simple.\n\t\t\tdistance: -1,\n\t\t\tparent: null\n\t\t};\n\t}\n\n\treturn graph;\n}\n\n// https://en.wikipedia.org/wiki/Breadth-first_search\nfunction deriveBFS(fromModel) {\n\tconst graph = buildGraph();\n\tconst queue = [fromModel]; // Unshift -> queue -> pop\n\n\tgraph[fromModel].distance = 0;\n\n\twhile (queue.length) {\n\t\tconst current = queue.pop();\n\t\tconst adjacents = Object.keys(conversions[current]);\n\n\t\tfor (let len = adjacents.length, i = 0; i < len; i++) {\n\t\t\tconst adjacent = adjacents[i];\n\t\t\tconst node = graph[adjacent];\n\n\t\t\tif (node.distance === -1) {\n\t\t\t\tnode.distance = graph[current].distance + 1;\n\t\t\t\tnode.parent = current;\n\t\t\t\tqueue.unshift(adjacent);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn graph;\n}\n\nfunction link(from, to) {\n\treturn function (args) {\n\t\treturn to(from(args));\n\t};\n}\n\nfunction wrapConversion(toModel, graph) {\n\tconst path = [graph[toModel].parent, toModel];\n\tlet fn = conversions[graph[toModel].parent][toModel];\n\n\tlet cur = graph[toModel].parent;\n\twhile (graph[cur].parent) {\n\t\tpath.unshift(graph[cur].parent);\n\t\tfn = link(conversions[graph[cur].parent][cur], fn);\n\t\tcur = graph[cur].parent;\n\t}\n\n\tfn.conversion = path;\n\treturn fn;\n}\n\nmodule.exports = function (fromModel) {\n\tconst graph = deriveBFS(fromModel);\n\tconst conversion = {};\n\n\tconst models = Object.keys(graph);\n\tfor (let len = models.length, i = 0; i < len; i++) {\n\t\tconst toModel = models[i];\n\t\tconst node = graph[toModel];\n\n\t\tif (node.parent === null) {\n\t\t\t// No possible conversion, or this node is the source model.\n\t\t\tcontinue;\n\t\t}\n\n\t\tconversion[toModel] = wrapConversion(toModel, graph);\n\t}\n\n\treturn conversion;\n};\n\n","'use strict'\r\n\r\nmodule.exports = {\r\n\t\"aliceblue\": [240, 248, 255],\r\n\t\"antiquewhite\": [250, 235, 215],\r\n\t\"aqua\": [0, 255, 255],\r\n\t\"aquamarine\": [127, 255, 212],\r\n\t\"azure\": [240, 255, 255],\r\n\t\"beige\": [245, 245, 220],\r\n\t\"bisque\": [255, 228, 196],\r\n\t\"black\": [0, 0, 0],\r\n\t\"blanchedalmond\": [255, 235, 205],\r\n\t\"blue\": [0, 0, 255],\r\n\t\"blueviolet\": [138, 43, 226],\r\n\t\"brown\": [165, 42, 42],\r\n\t\"burlywood\": [222, 184, 135],\r\n\t\"cadetblue\": [95, 158, 160],\r\n\t\"chartreuse\": [127, 255, 0],\r\n\t\"chocolate\": [210, 105, 30],\r\n\t\"coral\": [255, 127, 80],\r\n\t\"cornflowerblue\": [100, 149, 237],\r\n\t\"cornsilk\": [255, 248, 220],\r\n\t\"crimson\": [220, 20, 60],\r\n\t\"cyan\": [0, 255, 255],\r\n\t\"darkblue\": [0, 0, 139],\r\n\t\"darkcyan\": [0, 139, 139],\r\n\t\"darkgoldenrod\": [184, 134, 11],\r\n\t\"darkgray\": [169, 169, 169],\r\n\t\"darkgreen\": [0, 100, 0],\r\n\t\"darkgrey\": [169, 169, 169],\r\n\t\"darkkhaki\": [189, 183, 107],\r\n\t\"darkmagenta\": [139, 0, 139],\r\n\t\"darkolivegreen\": [85, 107, 47],\r\n\t\"darkorange\": [255, 140, 0],\r\n\t\"darkorchid\": [153, 50, 204],\r\n\t\"darkred\": [139, 0, 0],\r\n\t\"darksalmon\": [233, 150, 122],\r\n\t\"darkseagreen\": [143, 188, 143],\r\n\t\"darkslateblue\": [72, 61, 139],\r\n\t\"darkslategray\": [47, 79, 79],\r\n\t\"darkslategrey\": [47, 79, 79],\r\n\t\"darkturquoise\": [0, 206, 209],\r\n\t\"darkviolet\": [148, 0, 211],\r\n\t\"deeppink\": [255, 20, 147],\r\n\t\"deepskyblue\": [0, 191, 255],\r\n\t\"dimgray\": [105, 105, 105],\r\n\t\"dimgrey\": [105, 105, 105],\r\n\t\"dodgerblue\": [30, 144, 255],\r\n\t\"firebrick\": [178, 34, 34],\r\n\t\"floralwhite\": [255, 250, 240],\r\n\t\"forestgreen\": [34, 139, 34],\r\n\t\"fuchsia\": [255, 0, 255],\r\n\t\"gainsboro\": [220, 220, 220],\r\n\t\"ghostwhite\": [248, 248, 255],\r\n\t\"gold\": [255, 215, 0],\r\n\t\"goldenrod\": [218, 165, 32],\r\n\t\"gray\": [128, 128, 128],\r\n\t\"green\": [0, 128, 0],\r\n\t\"greenyellow\": [173, 255, 47],\r\n\t\"grey\": [128, 128, 128],\r\n\t\"honeydew\": [240, 255, 240],\r\n\t\"hotpink\": [255, 105, 180],\r\n\t\"indianred\": [205, 92, 92],\r\n\t\"indigo\": [75, 0, 130],\r\n\t\"ivory\": [255, 255, 240],\r\n\t\"khaki\": [240, 230, 140],\r\n\t\"lavender\": [230, 230, 250],\r\n\t\"lavenderblush\": [255, 240, 245],\r\n\t\"lawngreen\": [124, 252, 0],\r\n\t\"lemonchiffon\": [255, 250, 205],\r\n\t\"lightblue\": [173, 216, 230],\r\n\t\"lightcoral\": [240, 128, 128],\r\n\t\"lightcyan\": [224, 255, 255],\r\n\t\"lightgoldenrodyellow\": [250, 250, 210],\r\n\t\"lightgray\": [211, 211, 211],\r\n\t\"lightgreen\": [144, 238, 144],\r\n\t\"lightgrey\": [211, 211, 211],\r\n\t\"lightpink\": [255, 182, 193],\r\n\t\"lightsalmon\": [255, 160, 122],\r\n\t\"lightseagreen\": [32, 178, 170],\r\n\t\"lightskyblue\": [135, 206, 250],\r\n\t\"lightslategray\": [119, 136, 153],\r\n\t\"lightslategrey\": [119, 136, 153],\r\n\t\"lightsteelblue\": [176, 196, 222],\r\n\t\"lightyellow\": [255, 255, 224],\r\n\t\"lime\": [0, 255, 0],\r\n\t\"limegreen\": [50, 205, 50],\r\n\t\"linen\": [250, 240, 230],\r\n\t\"magenta\": [255, 0, 255],\r\n\t\"maroon\": [128, 0, 0],\r\n\t\"mediumaquamarine\": [102, 205, 170],\r\n\t\"mediumblue\": [0, 0, 205],\r\n\t\"mediumorchid\": [186, 85, 211],\r\n\t\"mediumpurple\": [147, 112, 219],\r\n\t\"mediumseagreen\": [60, 179, 113],\r\n\t\"mediumslateblue\": [123, 104, 238],\r\n\t\"mediumspringgreen\": [0, 250, 154],\r\n\t\"mediumturquoise\": [72, 209, 204],\r\n\t\"mediumvioletred\": [199, 21, 133],\r\n\t\"midnightblue\": [25, 25, 112],\r\n\t\"mintcream\": [245, 255, 250],\r\n\t\"mistyrose\": [255, 228, 225],\r\n\t\"moccasin\": [255, 228, 181],\r\n\t\"navajowhite\": [255, 222, 173],\r\n\t\"navy\": [0, 0, 128],\r\n\t\"oldlace\": [253, 245, 230],\r\n\t\"olive\": [128, 128, 0],\r\n\t\"olivedrab\": [107, 142, 35],\r\n\t\"orange\": [255, 165, 0],\r\n\t\"orangered\": [255, 69, 0],\r\n\t\"orchid\": [218, 112, 214],\r\n\t\"palegoldenrod\": [238, 232, 170],\r\n\t\"palegreen\": [152, 251, 152],\r\n\t\"paleturquoise\": [175, 238, 238],\r\n\t\"palevioletred\": [219, 112, 147],\r\n\t\"papayawhip\": [255, 239, 213],\r\n\t\"peachpuff\": [255, 218, 185],\r\n\t\"peru\": [205, 133, 63],\r\n\t\"pink\": [255, 192, 203],\r\n\t\"plum\": [221, 160, 221],\r\n\t\"powderblue\": [176, 224, 230],\r\n\t\"purple\": [128, 0, 128],\r\n\t\"rebeccapurple\": [102, 51, 153],\r\n\t\"red\": [255, 0, 0],\r\n\t\"rosybrown\": [188, 143, 143],\r\n\t\"royalblue\": [65, 105, 225],\r\n\t\"saddlebrown\": [139, 69, 19],\r\n\t\"salmon\": [250, 128, 114],\r\n\t\"sandybrown\": [244, 164, 96],\r\n\t\"seagreen\": [46, 139, 87],\r\n\t\"seashell\": [255, 245, 238],\r\n\t\"sienna\": [160, 82, 45],\r\n\t\"silver\": [192, 192, 192],\r\n\t\"skyblue\": [135, 206, 235],\r\n\t\"slateblue\": [106, 90, 205],\r\n\t\"slategray\": [112, 128, 144],\r\n\t\"slategrey\": [112, 128, 144],\r\n\t\"snow\": [255, 250, 250],\r\n\t\"springgreen\": [0, 255, 127],\r\n\t\"steelblue\": [70, 130, 180],\r\n\t\"tan\": [210, 180, 140],\r\n\t\"teal\": [0, 128, 128],\r\n\t\"thistle\": [216, 191, 216],\r\n\t\"tomato\": [255, 99, 71],\r\n\t\"turquoise\": [64, 224, 208],\r\n\t\"violet\": [238, 130, 238],\r\n\t\"wheat\": [245, 222, 179],\r\n\t\"white\": [255, 255, 255],\r\n\t\"whitesmoke\": [245, 245, 245],\r\n\t\"yellow\": [255, 255, 0],\r\n\t\"yellowgreen\": [154, 205, 50]\r\n};\r\n","module.exports = function deepFreeze (o) {\n Object.freeze(o);\n\n Object.getOwnPropertyNames(o).forEach(function (prop) {\n if (o.hasOwnProperty(prop)\n && o[prop] !== null\n && (typeof o[prop] === \"object\" || typeof o[prop] === \"function\")\n && !Object.isFrozen(o[prop])) {\n deepFreeze(o[prop]);\n }\n });\n \n return o;\n};\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n\tvalue: true\n});\nexports.default = filterInvalidDOMProps;\n\nvar _htmlAttributes = require(\"html-attributes\");\n\nvar _htmlAttributes2 = _interopRequireDefault(_htmlAttributes);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar eventProps = {\n\tonCopy: true,\n\tonCut: true,\n\tonPaste: true,\n\tonLoad: true,\n\tonError: true,\n\tonWheel: true,\n\tonScroll: true,\n\tonCompositionEnd: true,\n\tonCompositionStart: true,\n\tonCompositionUpdate: true,\n\tonKeyDown: true,\n\tonKeyPress: true,\n\tonKeyUp: true,\n\tonFocus: true,\n\tonBlur: true,\n\tonChange: true,\n\tonInput: true,\n\tonSubmit: true,\n\tonClick: true,\n\tonContextMenu: true,\n\tonDoubleClick: true,\n\tonDrag: true,\n\tonDragEnd: true,\n\tonDragEnter: true,\n\tonDragExit: true,\n\tonDragLeave: true,\n\tonDragOver: true,\n\tonDragStart: true,\n\tonDrop: true,\n\tonMouseDown: true,\n\tonMouseEnter: true,\n\tonMouseLeave: true,\n\tonMouseMove: true,\n\tonMouseOut: true,\n\tonMouseOver: true,\n\tonMouseUp: true,\n\tonSelect: true,\n\tonTouchCancel: true,\n\tonTouchEnd: true,\n\tonTouchMove: true,\n\tonTouchStart: true,\n\tonAnimationStart: true,\n\tonAnimationEnd: true,\n\tonAnimationIteration: true,\n\tonTransitionEnd: true\n};\n\nfunction isValidDOMProp(prop) {\n\treturn eventProps[prop] || _htmlAttributes2.default[prop] || /^(data|aria)-/.test(prop);\n}\n\nfunction filterInvalidDOMProps(props) {\n\tvar domProps = {};\n\tfor (var prop in props) {\n\t\tif (props.hasOwnProperty(prop) && isValidDOMProp(prop)) {\n\t\t\tdomProps[prop] = props[prop];\n\t\t}\n\t}\n\treturn domProps;\n}","var hat = module.exports = function (bits, base) {\n if (!base) base = 16;\n if (bits === undefined) bits = 128;\n if (bits <= 0) return '0';\n \n var digits = Math.log(Math.pow(2, bits)) / Math.log(base);\n for (var i = 2; digits === Infinity; i *= 2) {\n digits = Math.log(Math.pow(2, bits / i)) / Math.log(base) * i;\n }\n \n var rem = digits - Math.floor(digits);\n \n var res = '';\n \n for (var i = 0; i < Math.floor(digits); i++) {\n var x = Math.floor(Math.random() * base).toString(base);\n res = x + res;\n }\n \n if (rem) {\n var b = Math.pow(base, rem);\n var x = Math.floor(Math.random() * b).toString(base);\n res = x + res;\n }\n \n var parsed = parseInt(res, base);\n if (parsed !== Infinity && parsed >= Math.pow(2, bits)) {\n return hat(bits, base)\n }\n else return res;\n};\n\nhat.rack = function (bits, base, expandBy) {\n var fn = function (data) {\n var iters = 0;\n do {\n if (iters ++ > 10) {\n if (expandBy) bits += expandBy;\n else throw new Error('too many ID collisions, use more bits')\n }\n \n var id = hat(bits, base);\n } while (Object.hasOwnProperty.call(hats, id));\n \n hats[id] = data;\n return id;\n };\n var hats = fn.hats = {};\n \n fn.get = function (id) {\n return fn.hats[id];\n };\n \n fn.set = function (id, value) {\n fn.hats[id] = value;\n return fn;\n };\n \n fn.bits = bits || 128;\n fn.base = base || 16;\n return fn;\n};\n","typeof window !== \"undefined\" &&\n(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"Hls\"] = factory();\n\telse\n\t\troot[\"Hls\"] = factory();\n})(this, function() {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"/dist/\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = \"./src/hls.ts\");\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./node_modules/eventemitter3/index.js\":\n/*!*********************************************!*\\\n !*** ./node_modules/eventemitter3/index.js ***!\n \\*********************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\n\"use strict\";\n\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif (true) {\n module.exports = EventEmitter;\n}\n\n\n/***/ }),\n\n/***/ \"./node_modules/url-toolkit/src/url-toolkit.js\":\n/*!*****************************************************!*\\\n !*** ./node_modules/url-toolkit/src/url-toolkit.js ***!\n \\*****************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\n// see https://tools.ietf.org/html/rfc1808\n\n(function (root) {\n var URL_REGEX =\n /^(?=((?:[a-zA-Z0-9+\\-.]+:)?))\\1(?=((?:\\/\\/[^\\/?#]*)?))\\2(?=((?:(?:[^?#\\/]*\\/)*[^;?#\\/]*)?))\\3((?:;[^?#]*)?)(\\?[^#]*)?(#[^]*)?$/;\n var FIRST_SEGMENT_REGEX = /^(?=([^\\/?#]*))\\1([^]*)$/;\n var SLASH_DOT_REGEX = /(?:\\/|^)\\.(?=\\/)/g;\n var SLASH_DOT_DOT_REGEX = /(?:\\/|^)\\.\\.\\/(?!\\.\\.\\/)[^\\/]*(?=\\/)/g;\n\n var URLToolkit = {\n // If opts.alwaysNormalize is true then the path will always be normalized even when it starts with / or //\n // E.g\n // With opts.alwaysNormalize = false (default, spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/f/../g\n // With opts.alwaysNormalize = true (not spec compliant)\n // http://a.com/b/cd + /e/f/../g => http://a.com/e/g\n buildAbsoluteURL: function (baseURL, relativeURL, opts) {\n opts = opts || {};\n // remove any remaining space and CRLF\n baseURL = baseURL.trim();\n relativeURL = relativeURL.trim();\n if (!relativeURL) {\n // 2a) If the embedded URL is entirely empty, it inherits the\n // entire base URL (i.e., is set equal to the base URL)\n // and we are done.\n if (!opts.alwaysNormalize) {\n return baseURL;\n }\n var basePartsForNormalise = URLToolkit.parseURL(baseURL);\n if (!basePartsForNormalise) {\n throw new Error('Error trying to parse base URL.');\n }\n basePartsForNormalise.path = URLToolkit.normalizePath(\n basePartsForNormalise.path\n );\n return URLToolkit.buildURLFromParts(basePartsForNormalise);\n }\n var relativeParts = URLToolkit.parseURL(relativeURL);\n if (!relativeParts) {\n throw new Error('Error trying to parse relative URL.');\n }\n if (relativeParts.scheme) {\n // 2b) If the embedded URL starts with a scheme name, it is\n // interpreted as an absolute URL and we are done.\n if (!opts.alwaysNormalize) {\n return relativeURL;\n }\n relativeParts.path = URLToolkit.normalizePath(relativeParts.path);\n return URLToolkit.buildURLFromParts(relativeParts);\n }\n var baseParts = URLToolkit.parseURL(baseURL);\n if (!baseParts) {\n throw new Error('Error trying to parse base URL.');\n }\n if (!baseParts.netLoc && baseParts.path && baseParts.path[0] !== '/') {\n // If netLoc missing and path doesn't start with '/', assume everthing before the first '/' is the netLoc\n // This causes 'example.com/a' to be handled as '//example.com/a' instead of '/example.com/a'\n var pathParts = FIRST_SEGMENT_REGEX.exec(baseParts.path);\n baseParts.netLoc = pathParts[1];\n baseParts.path = pathParts[2];\n }\n if (baseParts.netLoc && !baseParts.path) {\n baseParts.path = '/';\n }\n var builtParts = {\n // 2c) Otherwise, the embedded URL inherits the scheme of\n // the base URL.\n scheme: baseParts.scheme,\n netLoc: relativeParts.netLoc,\n path: null,\n params: relativeParts.params,\n query: relativeParts.query,\n fragment: relativeParts.fragment,\n };\n if (!relativeParts.netLoc) {\n // 3) If the embedded URL's is non-empty, we skip to\n // Step 7. Otherwise, the embedded URL inherits the \n // (if any) of the base URL.\n builtParts.netLoc = baseParts.netLoc;\n // 4) If the embedded URL path is preceded by a slash \"/\", the\n // path is not relative and we skip to Step 7.\n if (relativeParts.path[0] !== '/') {\n if (!relativeParts.path) {\n // 5) If the embedded URL path is empty (and not preceded by a\n // slash), then the embedded URL inherits the base URL path\n builtParts.path = baseParts.path;\n // 5a) if the embedded URL's is non-empty, we skip to\n // step 7; otherwise, it inherits the of the base\n // URL (if any) and\n if (!relativeParts.params) {\n builtParts.params = baseParts.params;\n // 5b) if the embedded URL's is non-empty, we skip to\n // step 7; otherwise, it inherits the of the base\n // URL (if any) and we skip to step 7.\n if (!relativeParts.query) {\n builtParts.query = baseParts.query;\n }\n }\n } else {\n // 6) The last segment of the base URL's path (anything\n // following the rightmost slash \"/\", or the entire path if no\n // slash is present) is removed and the embedded URL's path is\n // appended in its place.\n var baseURLPath = baseParts.path;\n var newPath =\n baseURLPath.substring(0, baseURLPath.lastIndexOf('/') + 1) +\n relativeParts.path;\n builtParts.path = URLToolkit.normalizePath(newPath);\n }\n }\n }\n if (builtParts.path === null) {\n builtParts.path = opts.alwaysNormalize\n ? URLToolkit.normalizePath(relativeParts.path)\n : relativeParts.path;\n }\n return URLToolkit.buildURLFromParts(builtParts);\n },\n parseURL: function (url) {\n var parts = URL_REGEX.exec(url);\n if (!parts) {\n return null;\n }\n return {\n scheme: parts[1] || '',\n netLoc: parts[2] || '',\n path: parts[3] || '',\n params: parts[4] || '',\n query: parts[5] || '',\n fragment: parts[6] || '',\n };\n },\n normalizePath: function (path) {\n // The following operations are\n // then applied, in order, to the new path:\n // 6a) All occurrences of \"./\", where \".\" is a complete path\n // segment, are removed.\n // 6b) If the path ends with \".\" as a complete path segment,\n // that \".\" is removed.\n path = path.split('').reverse().join('').replace(SLASH_DOT_REGEX, '');\n // 6c) All occurrences of \"/../\", where is a\n // complete path segment not equal to \"..\", are removed.\n // Removal of these path segments is performed iteratively,\n // removing the leftmost matching pattern on each iteration,\n // until no matching pattern remains.\n // 6d) If the path ends with \"/..\", where is a\n // complete path segment not equal to \"..\", that\n // \"/..\" is removed.\n while (\n path.length !== (path = path.replace(SLASH_DOT_DOT_REGEX, '')).length\n ) {}\n return path.split('').reverse().join('');\n },\n buildURLFromParts: function (parts) {\n return (\n parts.scheme +\n parts.netLoc +\n parts.path +\n parts.params +\n parts.query +\n parts.fragment\n );\n },\n };\n\n if (true)\n module.exports = URLToolkit;\n else {}\n})(this);\n\n\n/***/ }),\n\n/***/ \"./node_modules/webworkify-webpack/index.js\":\n/*!**************************************************!*\\\n !*** ./node_modules/webworkify-webpack/index.js ***!\n \\**************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nfunction webpackBootstrapFunc (modules) {\n/******/ // The module cache\n/******/ var installedModules = {};\n\n/******/ // The require function\n/******/ function __webpack_require__(moduleId) {\n\n/******/ // Check if module is in cache\n/******/ if(installedModules[moduleId])\n/******/ return installedModules[moduleId].exports;\n\n/******/ // Create a new module (and put it into the cache)\n/******/ var module = installedModules[moduleId] = {\n/******/ i: moduleId,\n/******/ l: false,\n/******/ exports: {}\n/******/ };\n\n/******/ // Execute the module function\n/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n/******/ // Flag the module as loaded\n/******/ module.l = true;\n\n/******/ // Return the exports of the module\n/******/ return module.exports;\n/******/ }\n\n/******/ // expose the modules object (__webpack_modules__)\n/******/ __webpack_require__.m = modules;\n\n/******/ // expose the module cache\n/******/ __webpack_require__.c = installedModules;\n\n/******/ // identity function for calling harmony imports with the correct context\n/******/ __webpack_require__.i = function(value) { return value; };\n\n/******/ // define getter function for harmony exports\n/******/ __webpack_require__.d = function(exports, name, getter) {\n/******/ if(!__webpack_require__.o(exports, name)) {\n/******/ Object.defineProperty(exports, name, {\n/******/ configurable: false,\n/******/ enumerable: true,\n/******/ get: getter\n/******/ });\n/******/ }\n/******/ };\n\n/******/ // define __esModule on exports\n/******/ __webpack_require__.r = function(exports) {\n/******/ Object.defineProperty(exports, '__esModule', { value: true });\n/******/ };\n\n/******/ // getDefaultExport function for compatibility with non-harmony modules\n/******/ __webpack_require__.n = function(module) {\n/******/ var getter = module && module.__esModule ?\n/******/ function getDefault() { return module['default']; } :\n/******/ function getModuleExports() { return module; };\n/******/ __webpack_require__.d(getter, 'a', getter);\n/******/ return getter;\n/******/ };\n\n/******/ // Object.prototype.hasOwnProperty.call\n/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n/******/ // __webpack_public_path__\n/******/ __webpack_require__.p = \"/\";\n\n/******/ // on error function for async loading\n/******/ __webpack_require__.oe = function(err) { console.error(err); throw err; };\n\n var f = __webpack_require__(__webpack_require__.s = ENTRY_MODULE)\n return f.default || f // try to call default if defined to also support babel esmodule exports\n}\n\nvar moduleNameReqExp = '[\\\\.|\\\\-|\\\\+|\\\\w|\\/|@]+'\nvar dependencyRegExp = '\\\\(\\\\s*(\\/\\\\*.*?\\\\*\\/)?\\\\s*.*?(' + moduleNameReqExp + ').*?\\\\)' // additional chars when output.pathinfo is true\n\n// http://stackoverflow.com/a/2593661/130442\nfunction quoteRegExp (str) {\n return (str + '').replace(/[.?*+^$[\\]\\\\(){}|-]/g, '\\\\$&')\n}\n\nfunction isNumeric(n) {\n return !isNaN(1 * n); // 1 * n converts integers, integers as string (\"123\"), 1e3 and \"1e3\" to integers and strings to NaN\n}\n\nfunction getModuleDependencies (sources, module, queueName) {\n var retval = {}\n retval[queueName] = []\n\n var fnString = module.toString()\n var wrapperSignature = fnString.match(/^function\\s?\\w*\\(\\w+,\\s*\\w+,\\s*(\\w+)\\)/)\n if (!wrapperSignature) return retval\n var webpackRequireName = wrapperSignature[1]\n\n // main bundle deps\n var re = new RegExp('(\\\\\\\\n|\\\\W)' + quoteRegExp(webpackRequireName) + dependencyRegExp, 'g')\n var match\n while ((match = re.exec(fnString))) {\n if (match[3] === 'dll-reference') continue\n retval[queueName].push(match[3])\n }\n\n // dll deps\n re = new RegExp('\\\\(' + quoteRegExp(webpackRequireName) + '\\\\(\"(dll-reference\\\\s(' + moduleNameReqExp + '))\"\\\\)\\\\)' + dependencyRegExp, 'g')\n while ((match = re.exec(fnString))) {\n if (!sources[match[2]]) {\n retval[queueName].push(match[1])\n sources[match[2]] = __webpack_require__(match[1]).m\n }\n retval[match[2]] = retval[match[2]] || []\n retval[match[2]].push(match[4])\n }\n\n // convert 1e3 back to 1000 - this can be important after uglify-js converted 1000 to 1e3\n var keys = Object.keys(retval);\n for (var i = 0; i < keys.length; i++) {\n for (var j = 0; j < retval[keys[i]].length; j++) {\n if (isNumeric(retval[keys[i]][j])) {\n retval[keys[i]][j] = 1 * retval[keys[i]][j];\n }\n }\n }\n\n return retval\n}\n\nfunction hasValuesInQueues (queues) {\n var keys = Object.keys(queues)\n return keys.reduce(function (hasValues, key) {\n return hasValues || queues[key].length > 0\n }, false)\n}\n\nfunction getRequiredModules (sources, moduleId) {\n var modulesQueue = {\n main: [moduleId]\n }\n var requiredModules = {\n main: []\n }\n var seenModules = {\n main: {}\n }\n\n while (hasValuesInQueues(modulesQueue)) {\n var queues = Object.keys(modulesQueue)\n for (var i = 0; i < queues.length; i++) {\n var queueName = queues[i]\n var queue = modulesQueue[queueName]\n var moduleToCheck = queue.pop()\n seenModules[queueName] = seenModules[queueName] || {}\n if (seenModules[queueName][moduleToCheck] || !sources[queueName][moduleToCheck]) continue\n seenModules[queueName][moduleToCheck] = true\n requiredModules[queueName] = requiredModules[queueName] || []\n requiredModules[queueName].push(moduleToCheck)\n var newModules = getModuleDependencies(sources, sources[queueName][moduleToCheck], queueName)\n var newModulesKeys = Object.keys(newModules)\n for (var j = 0; j < newModulesKeys.length; j++) {\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]] || []\n modulesQueue[newModulesKeys[j]] = modulesQueue[newModulesKeys[j]].concat(newModules[newModulesKeys[j]])\n }\n }\n }\n\n return requiredModules\n}\n\nmodule.exports = function (moduleId, options) {\n options = options || {}\n var sources = {\n main: __webpack_require__.m\n }\n\n var requiredModules = options.all ? { main: Object.keys(sources.main) } : getRequiredModules(sources, moduleId)\n\n var src = ''\n\n Object.keys(requiredModules).filter(function (m) { return m !== 'main' }).forEach(function (module) {\n var entryModule = 0\n while (requiredModules[module][entryModule]) {\n entryModule++\n }\n requiredModules[module].push(entryModule)\n sources[module][entryModule] = '(function(module, exports, __webpack_require__) { module.exports = __webpack_require__; })'\n src = src + 'var ' + module + ' = (' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(entryModule)) + ')({' + requiredModules[module].map(function (id) { return '' + JSON.stringify(id) + ': ' + sources[module][id].toString() }).join(',') + '});\\n'\n })\n\n src = src + 'new ((' + webpackBootstrapFunc.toString().replace('ENTRY_MODULE', JSON.stringify(moduleId)) + ')({' + requiredModules.main.map(function (id) { return '' + JSON.stringify(id) + ': ' + sources.main[id].toString() }).join(',') + '}))(self);'\n\n var blob = new window.Blob([src], { type: 'text/javascript' })\n if (options.bare) { return blob }\n\n var URL = window.URL || window.webkitURL || window.mozURL || window.msURL\n\n var workerUrl = URL.createObjectURL(blob)\n var worker = new window.Worker(workerUrl)\n worker.objectURL = workerUrl\n\n return worker\n}\n\n\n/***/ }),\n\n/***/ \"./src/config.ts\":\n/*!***********************!*\\\n !*** ./src/config.ts ***!\n \\***********************/\n/*! exports provided: hlsDefaultConfig, mergeConfig, enableStreamingMode */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"hlsDefaultConfig\", function() { return hlsDefaultConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"mergeConfig\", function() { return mergeConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"enableStreamingMode\", function() { return enableStreamingMode; });\n/* harmony import */ var _controller_abr_controller__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./controller/abr-controller */ \"./src/controller/abr-controller.ts\");\n/* harmony import */ var _controller_audio_stream_controller__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./controller/audio-stream-controller */ \"./src/controller/audio-stream-controller.ts\");\n/* harmony import */ var _controller_audio_track_controller__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./controller/audio-track-controller */ \"./src/controller/audio-track-controller.ts\");\n/* harmony import */ var _controller_subtitle_stream_controller__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./controller/subtitle-stream-controller */ \"./src/controller/subtitle-stream-controller.ts\");\n/* harmony import */ var _controller_subtitle_track_controller__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./controller/subtitle-track-controller */ \"./src/controller/subtitle-track-controller.ts\");\n/* harmony import */ var _controller_buffer_controller__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./controller/buffer-controller */ \"./src/controller/buffer-controller.ts\");\n/* harmony import */ var _controller_timeline_controller__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./controller/timeline-controller */ \"./src/controller/timeline-controller.ts\");\n/* harmony import */ var _controller_cap_level_controller__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./controller/cap-level-controller */ \"./src/controller/cap-level-controller.ts\");\n/* harmony import */ var _controller_fps_controller__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./controller/fps-controller */ \"./src/controller/fps-controller.ts\");\n/* harmony import */ var _controller_eme_controller__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./controller/eme-controller */ \"./src/controller/eme-controller.ts\");\n/* harmony import */ var _controller_cmcd_controller__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./controller/cmcd-controller */ \"./src/controller/cmcd-controller.ts\");\n/* harmony import */ var _utils_xhr_loader__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./utils/xhr-loader */ \"./src/utils/xhr-loader.ts\");\n/* harmony import */ var _utils_fetch_loader__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./utils/fetch-loader */ \"./src/utils/fetch-loader.ts\");\n/* harmony import */ var _utils_cues__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./utils/cues */ \"./src/utils/cues.ts\");\n/* harmony import */ var _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./utils/mediakeys-helper */ \"./src/utils/mediakeys-helper.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./utils/logger */ \"./src/utils/logger.ts\");\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n// If possible, keep hlsDefaultConfig shallow\n// It is cloned whenever a new Hls instance is created, by keeping the config\n// shallow the properties are cloned, and we don't end up manipulating the default\nvar hlsDefaultConfig = _objectSpread(_objectSpread({\n autoStartLoad: true,\n // used by stream-controller\n startPosition: -1,\n // used by stream-controller\n defaultAudioCodec: undefined,\n // used by stream-controller\n debug: false,\n // used by logger\n capLevelOnFPSDrop: false,\n // used by fps-controller\n capLevelToPlayerSize: false,\n // used by cap-level-controller\n ignoreDevicePixelRatio: false,\n // used by cap-level-controller\n initialLiveManifestSize: 1,\n // used by stream-controller\n maxBufferLength: 30,\n // used by stream-controller\n backBufferLength: Infinity,\n // used by buffer-controller\n maxBufferSize: 60 * 1000 * 1000,\n // used by stream-controller\n maxBufferHole: 0.1,\n // used by stream-controller\n highBufferWatchdogPeriod: 2,\n // used by stream-controller\n nudgeOffset: 0.1,\n // used by stream-controller\n nudgeMaxRetry: 3,\n // used by stream-controller\n maxFragLookUpTolerance: 0.25,\n // used by stream-controller\n liveSyncDurationCount: 3,\n // used by latency-controller\n liveMaxLatencyDurationCount: Infinity,\n // used by latency-controller\n liveSyncDuration: undefined,\n // used by latency-controller\n liveMaxLatencyDuration: undefined,\n // used by latency-controller\n maxLiveSyncPlaybackRate: 1,\n // used by latency-controller\n liveDurationInfinity: false,\n // used by buffer-controller\n liveBackBufferLength: null,\n // used by buffer-controller\n maxMaxBufferLength: 600,\n // used by stream-controller\n enableWorker: true,\n // used by demuxer\n enableSoftwareAES: true,\n // used by decrypter\n manifestLoadingTimeOut: 10000,\n // used by playlist-loader\n manifestLoadingMaxRetry: 1,\n // used by playlist-loader\n manifestLoadingRetryDelay: 1000,\n // used by playlist-loader\n manifestLoadingMaxRetryTimeout: 64000,\n // used by playlist-loader\n startLevel: undefined,\n // used by level-controller\n levelLoadingTimeOut: 10000,\n // used by playlist-loader\n levelLoadingMaxRetry: 4,\n // used by playlist-loader\n levelLoadingRetryDelay: 1000,\n // used by playlist-loader\n levelLoadingMaxRetryTimeout: 64000,\n // used by playlist-loader\n fragLoadingTimeOut: 20000,\n // used by fragment-loader\n fragLoadingMaxRetry: 6,\n // used by fragment-loader\n fragLoadingRetryDelay: 1000,\n // used by fragment-loader\n fragLoadingMaxRetryTimeout: 64000,\n // used by fragment-loader\n startFragPrefetch: false,\n // used by stream-controller\n fpsDroppedMonitoringPeriod: 5000,\n // used by fps-controller\n fpsDroppedMonitoringThreshold: 0.2,\n // used by fps-controller\n appendErrorMaxRetry: 3,\n // used by buffer-controller\n loader: _utils_xhr_loader__WEBPACK_IMPORTED_MODULE_11__[\"default\"],\n // loader: FetchLoader,\n fLoader: undefined,\n // used by fragment-loader\n pLoader: undefined,\n // used by playlist-loader\n xhrSetup: undefined,\n // used by xhr-loader\n licenseXhrSetup: undefined,\n // used by eme-controller\n licenseResponseCallback: undefined,\n // used by eme-controller\n abrController: _controller_abr_controller__WEBPACK_IMPORTED_MODULE_0__[\"default\"],\n bufferController: _controller_buffer_controller__WEBPACK_IMPORTED_MODULE_5__[\"default\"],\n capLevelController: _controller_cap_level_controller__WEBPACK_IMPORTED_MODULE_7__[\"default\"],\n fpsController: _controller_fps_controller__WEBPACK_IMPORTED_MODULE_8__[\"default\"],\n stretchShortVideoTrack: false,\n // used by mp4-remuxer\n maxAudioFramesDrift: 1,\n // used by mp4-remuxer\n forceKeyFrameOnDiscontinuity: true,\n // used by ts-demuxer\n abrEwmaFastLive: 3,\n // used by abr-controller\n abrEwmaSlowLive: 9,\n // used by abr-controller\n abrEwmaFastVoD: 3,\n // used by abr-controller\n abrEwmaSlowVoD: 9,\n // used by abr-controller\n abrEwmaDefaultEstimate: 5e5,\n // 500 kbps // used by abr-controller\n abrBandWidthFactor: 0.95,\n // used by abr-controller\n abrBandWidthUpFactor: 0.7,\n // used by abr-controller\n abrMaxWithRealBitrate: false,\n // used by abr-controller\n maxStarvationDelay: 4,\n // used by abr-controller\n maxLoadingDelay: 4,\n // used by abr-controller\n minAutoBitrate: 0,\n // used by hls\n emeEnabled: false,\n // used by eme-controller\n widevineLicenseUrl: undefined,\n // used by eme-controller\n drmSystemOptions: {},\n // used by eme-controller\n requestMediaKeySystemAccessFunc: _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_14__[\"requestMediaKeySystemAccess\"],\n // used by eme-controller\n testBandwidth: true,\n progressive: false,\n lowLatencyMode: true,\n cmcd: undefined,\n enableDateRangeMetadataCues: true,\n enableEmsgMetadataCues: true,\n enableID3MetadataCues: true\n}, timelineConfig()), {}, {\n subtitleStreamController: true ? _controller_subtitle_stream_controller__WEBPACK_IMPORTED_MODULE_3__[\"SubtitleStreamController\"] : undefined,\n subtitleTrackController: true ? _controller_subtitle_track_controller__WEBPACK_IMPORTED_MODULE_4__[\"default\"] : undefined,\n timelineController: true ? _controller_timeline_controller__WEBPACK_IMPORTED_MODULE_6__[\"TimelineController\"] : undefined,\n audioStreamController: true ? _controller_audio_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"default\"] : undefined,\n audioTrackController: true ? _controller_audio_track_controller__WEBPACK_IMPORTED_MODULE_2__[\"default\"] : undefined,\n emeController: true ? _controller_eme_controller__WEBPACK_IMPORTED_MODULE_9__[\"default\"] : undefined,\n cmcdController: true ? _controller_cmcd_controller__WEBPACK_IMPORTED_MODULE_10__[\"default\"] : undefined\n});\n\nfunction timelineConfig() {\n return {\n cueHandler: _utils_cues__WEBPACK_IMPORTED_MODULE_13__[\"default\"],\n // used by timeline-controller\n enableWebVTT: true,\n // used by timeline-controller\n enableIMSC1: true,\n // used by timeline-controller\n enableCEA708Captions: true,\n // used by timeline-controller\n captionsTextTrack1Label: 'English',\n // used by timeline-controller\n captionsTextTrack1LanguageCode: 'en',\n // used by timeline-controller\n captionsTextTrack2Label: 'Spanish',\n // used by timeline-controller\n captionsTextTrack2LanguageCode: 'es',\n // used by timeline-controller\n captionsTextTrack3Label: 'Unknown CC',\n // used by timeline-controller\n captionsTextTrack3LanguageCode: '',\n // used by timeline-controller\n captionsTextTrack4Label: 'Unknown CC',\n // used by timeline-controller\n captionsTextTrack4LanguageCode: '',\n // used by timeline-controller\n renderTextTracksNatively: true\n };\n}\n\nfunction mergeConfig(defaultConfig, userConfig) {\n if ((userConfig.liveSyncDurationCount || userConfig.liveMaxLatencyDurationCount) && (userConfig.liveSyncDuration || userConfig.liveMaxLatencyDuration)) {\n throw new Error(\"Illegal hls.js config: don't mix up liveSyncDurationCount/liveMaxLatencyDurationCount and liveSyncDuration/liveMaxLatencyDuration\");\n }\n\n if (userConfig.liveMaxLatencyDurationCount !== undefined && (userConfig.liveSyncDurationCount === undefined || userConfig.liveMaxLatencyDurationCount <= userConfig.liveSyncDurationCount)) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDurationCount\" must be greater than \"liveSyncDurationCount\"');\n }\n\n if (userConfig.liveMaxLatencyDuration !== undefined && (userConfig.liveSyncDuration === undefined || userConfig.liveMaxLatencyDuration <= userConfig.liveSyncDuration)) {\n throw new Error('Illegal hls.js config: \"liveMaxLatencyDuration\" must be greater than \"liveSyncDuration\"');\n }\n\n return _extends({}, defaultConfig, userConfig);\n}\nfunction enableStreamingMode(config) {\n var currentLoader = config.loader;\n\n if (currentLoader !== _utils_fetch_loader__WEBPACK_IMPORTED_MODULE_12__[\"default\"] && currentLoader !== _utils_xhr_loader__WEBPACK_IMPORTED_MODULE_11__[\"default\"]) {\n // If a developer has configured their own loader, respect that choice\n _utils_logger__WEBPACK_IMPORTED_MODULE_15__[\"logger\"].log('[config]: Custom loader detected, cannot enable progressive streaming');\n config.progressive = false;\n } else {\n var canStreamProgressively = Object(_utils_fetch_loader__WEBPACK_IMPORTED_MODULE_12__[\"fetchSupported\"])();\n\n if (canStreamProgressively) {\n config.loader = _utils_fetch_loader__WEBPACK_IMPORTED_MODULE_12__[\"default\"];\n config.progressive = true;\n config.enableSoftwareAES = true;\n _utils_logger__WEBPACK_IMPORTED_MODULE_15__[\"logger\"].log('[config]: Progressive streaming enabled, using FetchLoader');\n }\n }\n}\n\n/***/ }),\n\n/***/ \"./src/controller/abr-controller.ts\":\n/*!******************************************!*\\\n !*** ./src/controller/abr-controller.ts ***!\n \\******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _utils_ewma_bandwidth_estimator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/ewma-bandwidth-estimator */ \"./src/utils/ewma-bandwidth-estimator.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\n\n\n\n\n\nvar AbrController = /*#__PURE__*/function () {\n function AbrController(hls) {\n this.hls = void 0;\n this.lastLoadedFragLevel = 0;\n this._nextAutoLevel = -1;\n this.timer = void 0;\n this.onCheck = this._abandonRulesCheck.bind(this);\n this.fragCurrent = null;\n this.partCurrent = null;\n this.bitrateTestDelay = 0;\n this.bwEstimator = void 0;\n this.hls = hls;\n var config = hls.config;\n this.bwEstimator = new _utils_ewma_bandwidth_estimator__WEBPACK_IMPORTED_MODULE_1__[\"default\"](config.abrEwmaSlowVoD, config.abrEwmaFastVoD, config.abrEwmaDefaultEstimate);\n this.registerListeners();\n }\n\n var _proto = AbrController.prototype;\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_LOADING, this.onFragLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_LOADING, this.onFragLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.clearTimer(); // @ts-ignore\n\n this.hls = this.onCheck = null;\n this.fragCurrent = this.partCurrent = null;\n };\n\n _proto.onFragLoading = function onFragLoading(event, data) {\n var frag = data.frag;\n\n if (frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_5__[\"PlaylistLevelType\"].MAIN) {\n if (!this.timer) {\n var _data$part;\n\n this.fragCurrent = frag;\n this.partCurrent = (_data$part = data.part) != null ? _data$part : null;\n this.timer = self.setInterval(this.onCheck, 100);\n }\n }\n };\n\n _proto.onLevelLoaded = function onLevelLoaded(event, data) {\n var config = this.hls.config;\n\n if (data.details.live) {\n this.bwEstimator.update(config.abrEwmaSlowLive, config.abrEwmaFastLive);\n } else {\n this.bwEstimator.update(config.abrEwmaSlowVoD, config.abrEwmaFastVoD);\n }\n }\n /*\n This method monitors the download rate of the current fragment, and will downswitch if that fragment will not load\n quickly enough to prevent underbuffering\n */\n ;\n\n _proto._abandonRulesCheck = function _abandonRulesCheck() {\n var frag = this.fragCurrent,\n part = this.partCurrent,\n hls = this.hls;\n var autoLevelEnabled = hls.autoLevelEnabled,\n config = hls.config,\n media = hls.media;\n\n if (!frag || !media) {\n return;\n }\n\n var stats = part ? part.stats : frag.stats;\n var duration = part ? part.duration : frag.duration; // If loading has been aborted and not in lowLatencyMode, stop timer and return\n\n if (stats.aborted) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn('frag loader destroy or aborted, disarm abandonRules');\n this.clearTimer(); // reset forced auto level value so that next level will be selected\n\n this._nextAutoLevel = -1;\n return;\n } // This check only runs if we're in ABR mode and actually playing\n\n\n if (!autoLevelEnabled || media.paused || !media.playbackRate || !media.readyState) {\n return;\n }\n\n var requestDelay = performance.now() - stats.loading.start;\n var playbackRate = Math.abs(media.playbackRate); // In order to work with a stable bandwidth, only begin monitoring bandwidth after half of the fragment has been loaded\n\n if (requestDelay <= 500 * duration / playbackRate) {\n return;\n }\n\n var levels = hls.levels,\n minAutoLevel = hls.minAutoLevel;\n var level = levels[frag.level];\n var expectedLen = stats.total || Math.max(stats.loaded, Math.round(duration * level.maxBitrate / 8));\n var loadRate = Math.max(1, stats.bwEstimate ? stats.bwEstimate / 8 : stats.loaded * 1000 / requestDelay); // fragLoadDelay is an estimate of the time (in seconds) it will take to buffer the entire fragment\n\n var fragLoadedDelay = (expectedLen - stats.loaded) / loadRate;\n var pos = media.currentTime; // bufferStarvationDelay is an estimate of the amount time (in seconds) it will take to exhaust the buffer\n\n var bufferStarvationDelay = (_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(media, pos, config.maxBufferHole).end - pos) / playbackRate; // Attempt an emergency downswitch only if less than 2 fragment lengths are buffered, and the time to finish loading\n // the current fragment is greater than the amount of buffer we have left\n\n if (bufferStarvationDelay >= 2 * duration / playbackRate || fragLoadedDelay <= bufferStarvationDelay) {\n return;\n }\n\n var fragLevelNextLoadedDelay = Number.POSITIVE_INFINITY;\n var nextLoadLevel; // Iterate through lower level and try to find the largest one that avoids rebuffering\n\n for (nextLoadLevel = frag.level - 1; nextLoadLevel > minAutoLevel; nextLoadLevel--) {\n // compute time to load next fragment at lower level\n // 0.8 : consider only 80% of current bw to be conservative\n // 8 = bits per byte (bps/Bps)\n var levelNextBitrate = levels[nextLoadLevel].maxBitrate;\n fragLevelNextLoadedDelay = duration * levelNextBitrate / (8 * 0.8 * loadRate);\n\n if (fragLevelNextLoadedDelay < bufferStarvationDelay) {\n break;\n }\n } // Only emergency switch down if it takes less time to load a new fragment at lowest level instead of continuing\n // to load the current one\n\n\n if (fragLevelNextLoadedDelay >= fragLoadedDelay) {\n return;\n }\n\n var bwEstimate = this.bwEstimator.getEstimate();\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn(\"Fragment \" + frag.sn + (part ? ' part ' + part.index : '') + \" of level \" + frag.level + \" is loading too slowly and will cause an underbuffer; aborting and switching to level \" + nextLoadLevel + \"\\n Current BW estimate: \" + (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(bwEstimate) ? (bwEstimate / 1024).toFixed(3) : 'Unknown') + \" Kb/s\\n Estimated load time for current fragment: \" + fragLoadedDelay.toFixed(3) + \" s\\n Estimated load time for the next fragment: \" + fragLevelNextLoadedDelay.toFixed(3) + \" s\\n Time to underbuffer: \" + bufferStarvationDelay.toFixed(3) + \" s\");\n hls.nextLoadLevel = nextLoadLevel;\n this.bwEstimator.sample(requestDelay, stats.loaded);\n this.clearTimer();\n\n if (frag.loader) {\n this.fragCurrent = this.partCurrent = null;\n frag.loader.abort();\n }\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_LOAD_EMERGENCY_ABORTED, {\n frag: frag,\n part: part,\n stats: stats\n });\n };\n\n _proto.onFragLoaded = function onFragLoaded(event, _ref) {\n var frag = _ref.frag,\n part = _ref.part;\n\n if (frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_5__[\"PlaylistLevelType\"].MAIN && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.sn)) {\n var stats = part ? part.stats : frag.stats;\n var duration = part ? part.duration : frag.duration; // stop monitoring bw once frag loaded\n\n this.clearTimer(); // store level id after successful fragment load\n\n this.lastLoadedFragLevel = frag.level; // reset forced auto level value so that next level will be selected\n\n this._nextAutoLevel = -1; // compute level average bitrate\n\n if (this.hls.config.abrMaxWithRealBitrate) {\n var level = this.hls.levels[frag.level];\n var loadedBytes = (level.loaded ? level.loaded.bytes : 0) + stats.loaded;\n var loadedDuration = (level.loaded ? level.loaded.duration : 0) + duration;\n level.loaded = {\n bytes: loadedBytes,\n duration: loadedDuration\n };\n level.realBitrate = Math.round(8 * loadedBytes / loadedDuration);\n }\n\n if (frag.bitrateTest) {\n var fragBufferedData = {\n stats: stats,\n frag: frag,\n part: part,\n id: frag.type\n };\n this.onFragBuffered(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_BUFFERED, fragBufferedData);\n }\n }\n };\n\n _proto.onFragBuffered = function onFragBuffered(event, data) {\n var frag = data.frag,\n part = data.part;\n var stats = part ? part.stats : frag.stats;\n\n if (stats.aborted) {\n return;\n } // Only count non-alt-audio frags which were actually buffered in our BW calculations\n\n\n if (frag.type !== _types_loader__WEBPACK_IMPORTED_MODULE_5__[\"PlaylistLevelType\"].MAIN || frag.sn === 'initSegment') {\n return;\n } // Use the difference between parsing and request instead of buffering and request to compute fragLoadingProcessing;\n // rationale is that buffer appending only happens once media is attached. This can happen when config.startFragPrefetch\n // is used. If we used buffering in that case, our BW estimate sample will be very large.\n\n\n var processingMs = stats.parsing.end - stats.loading.start;\n this.bwEstimator.sample(processingMs, stats.loaded);\n stats.bwEstimate = this.bwEstimator.getEstimate();\n\n if (frag.bitrateTest) {\n this.bitrateTestDelay = processingMs / 1000;\n } else {\n this.bitrateTestDelay = 0;\n }\n };\n\n _proto.onError = function onError(event, data) {\n // stop timer in case of frag loading error\n switch (data.details) {\n case _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorDetails\"].FRAG_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT:\n this.clearTimer();\n break;\n\n default:\n break;\n }\n };\n\n _proto.clearTimer = function clearTimer() {\n self.clearInterval(this.timer);\n this.timer = undefined;\n } // return next auto level\n ;\n\n _proto.getNextABRAutoLevel = function getNextABRAutoLevel() {\n var fragCurrent = this.fragCurrent,\n partCurrent = this.partCurrent,\n hls = this.hls;\n var maxAutoLevel = hls.maxAutoLevel,\n config = hls.config,\n minAutoLevel = hls.minAutoLevel,\n media = hls.media;\n var currentFragDuration = partCurrent ? partCurrent.duration : fragCurrent ? fragCurrent.duration : 0;\n var pos = media ? media.currentTime : 0; // playbackRate is the absolute value of the playback rate; if media.playbackRate is 0, we use 1 to load as\n // if we're playing back at the normal rate.\n\n var playbackRate = media && media.playbackRate !== 0 ? Math.abs(media.playbackRate) : 1.0;\n var avgbw = this.bwEstimator ? this.bwEstimator.getEstimate() : config.abrEwmaDefaultEstimate; // bufferStarvationDelay is the wall-clock time left until the playback buffer is exhausted.\n\n var bufferStarvationDelay = (_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(media, pos, config.maxBufferHole).end - pos) / playbackRate; // First, look to see if we can find a level matching with our avg bandwidth AND that could also guarantee no rebuffering at all\n\n var bestLevel = this.findBestLevel(avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay, config.abrBandWidthFactor, config.abrBandWidthUpFactor);\n\n if (bestLevel >= 0) {\n return bestLevel;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].trace((bufferStarvationDelay ? 'rebuffering expected' : 'buffer is empty') + \", finding optimal quality level\"); // not possible to get rid of rebuffering ... let's try to find level that will guarantee less than maxStarvationDelay of rebuffering\n // if no matching level found, logic will return 0\n\n var maxStarvationDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxStarvationDelay) : config.maxStarvationDelay;\n var bwFactor = config.abrBandWidthFactor;\n var bwUpFactor = config.abrBandWidthUpFactor;\n\n if (!bufferStarvationDelay) {\n // in case buffer is empty, let's check if previous fragment was loaded to perform a bitrate test\n var bitrateTestDelay = this.bitrateTestDelay;\n\n if (bitrateTestDelay) {\n // if it is the case, then we need to adjust our max starvation delay using maxLoadingDelay config value\n // max video loading delay used in automatic start level selection :\n // in that mode ABR controller will ensure that video loading time (ie the time to fetch the first fragment at lowest quality level +\n // the time to fetch the fragment at the appropriate quality level is less than ```maxLoadingDelay``` )\n // cap maxLoadingDelay and ensure it is not bigger 'than bitrate test' frag duration\n var maxLoadingDelay = currentFragDuration ? Math.min(currentFragDuration, config.maxLoadingDelay) : config.maxLoadingDelay;\n maxStarvationDelay = maxLoadingDelay - bitrateTestDelay;\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].trace(\"bitrate test took \" + Math.round(1000 * bitrateTestDelay) + \"ms, set first fragment max fetchDuration to \" + Math.round(1000 * maxStarvationDelay) + \" ms\"); // don't use conservative factor on bitrate test\n\n bwFactor = bwUpFactor = 1;\n }\n }\n\n bestLevel = this.findBestLevel(avgbw, minAutoLevel, maxAutoLevel, bufferStarvationDelay + maxStarvationDelay, bwFactor, bwUpFactor);\n return Math.max(bestLevel, 0);\n };\n\n _proto.findBestLevel = function findBestLevel(currentBw, minAutoLevel, maxAutoLevel, maxFetchDuration, bwFactor, bwUpFactor) {\n var _level$details;\n\n var fragCurrent = this.fragCurrent,\n partCurrent = this.partCurrent,\n currentLevel = this.lastLoadedFragLevel;\n var levels = this.hls.levels;\n var level = levels[currentLevel];\n var live = !!(level !== null && level !== void 0 && (_level$details = level.details) !== null && _level$details !== void 0 && _level$details.live);\n var currentCodecSet = level === null || level === void 0 ? void 0 : level.codecSet;\n var currentFragDuration = partCurrent ? partCurrent.duration : fragCurrent ? fragCurrent.duration : 0;\n\n for (var i = maxAutoLevel; i >= minAutoLevel; i--) {\n var levelInfo = levels[i];\n\n if (!levelInfo || currentCodecSet && levelInfo.codecSet !== currentCodecSet) {\n continue;\n }\n\n var levelDetails = levelInfo.details;\n var avgDuration = (partCurrent ? levelDetails === null || levelDetails === void 0 ? void 0 : levelDetails.partTarget : levelDetails === null || levelDetails === void 0 ? void 0 : levelDetails.averagetargetduration) || currentFragDuration;\n var adjustedbw = void 0; // follow algorithm captured from stagefright :\n // https://android.googlesource.com/platform/frameworks/av/+/master/media/libstagefright/httplive/LiveSession.cpp\n // Pick the highest bandwidth stream below or equal to estimated bandwidth.\n // consider only 80% of the available bandwidth, but if we are switching up,\n // be even more conservative (70%) to avoid overestimating and immediately\n // switching back.\n\n if (i <= currentLevel) {\n adjustedbw = bwFactor * currentBw;\n } else {\n adjustedbw = bwUpFactor * currentBw;\n }\n\n var bitrate = levels[i].maxBitrate;\n var fetchDuration = bitrate * avgDuration / adjustedbw;\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].trace(\"level/adjustedbw/bitrate/avgDuration/maxFetchDuration/fetchDuration: \" + i + \"/\" + Math.round(adjustedbw) + \"/\" + bitrate + \"/\" + avgDuration + \"/\" + maxFetchDuration + \"/\" + fetchDuration); // if adjusted bw is greater than level bitrate AND\n\n if (adjustedbw > bitrate && ( // fragment fetchDuration unknown OR live stream OR fragment fetchDuration less than max allowed fetch duration, then this level matches\n // we don't account for max Fetch Duration for live streams, this is to avoid switching down when near the edge of live sliding window ...\n // special case to support startLevel = -1 (bitrateTest) on live streams : in that case we should not exit loop so that findBestLevel will return -1\n !fetchDuration || live && !this.bitrateTestDelay || fetchDuration < maxFetchDuration)) {\n // as we are looping from highest to lowest, this will return the best achievable quality level\n return i;\n }\n } // not enough time budget even with quality level 0 ... rebuffering might happen\n\n\n return -1;\n };\n\n _createClass(AbrController, [{\n key: \"nextAutoLevel\",\n get: function get() {\n var forcedAutoLevel = this._nextAutoLevel;\n var bwEstimator = this.bwEstimator; // in case next auto level has been forced, and bw not available or not reliable, return forced value\n\n if (forcedAutoLevel !== -1 && !bwEstimator.canEstimate()) {\n return forcedAutoLevel;\n } // compute next level using ABR logic\n\n\n var nextABRAutoLevel = this.getNextABRAutoLevel(); // use forced auto level when ABR selected level has errored\n\n if (forcedAutoLevel !== -1 && this.hls.levels[nextABRAutoLevel].loadError) {\n return forcedAutoLevel;\n } // if forced auto level has been defined, use it to cap ABR computed quality level\n\n\n if (forcedAutoLevel !== -1) {\n nextABRAutoLevel = Math.min(forcedAutoLevel, nextABRAutoLevel);\n }\n\n return nextABRAutoLevel;\n },\n set: function set(nextLevel) {\n this._nextAutoLevel = nextLevel;\n }\n }]);\n\n return AbrController;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (AbrController);\n\n/***/ }),\n\n/***/ \"./src/controller/audio-stream-controller.ts\":\n/*!***************************************************!*\\\n !*** ./src/controller/audio-stream-controller.ts ***!\n \\***************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./base-stream-controller */ \"./src/controller/base-stream-controller.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _fragment_tracker__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./fragment-tracker */ \"./src/controller/fragment-tracker.ts\");\n/* harmony import */ var _types_level__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../types/level */ \"./src/types/level.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _loader_fragment__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../loader/fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _demux_chunk_cache__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../demux/chunk-cache */ \"./src/demux/chunk-cache.ts\");\n/* harmony import */ var _demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../demux/transmuxer-interface */ \"./src/demux/transmuxer-interface.ts\");\n/* harmony import */ var _types_transmuxer__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../types/transmuxer */ \"./src/types/transmuxer.ts\");\n/* harmony import */ var _fragment_finders__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./fragment-finders */ \"./src/controller/fragment-finders.ts\");\n/* harmony import */ var _utils_discontinuities__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../utils/discontinuities */ \"./src/utils/discontinuities.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar TICK_INTERVAL = 100; // how often to tick in ms\n\nvar AudioStreamController = /*#__PURE__*/function (_BaseStreamController) {\n _inheritsLoose(AudioStreamController, _BaseStreamController);\n\n function AudioStreamController(hls, fragmentTracker) {\n var _this;\n\n _this = _BaseStreamController.call(this, hls, fragmentTracker, '[audio-stream-controller]') || this;\n _this.videoBuffer = null;\n _this.videoTrackCC = -1;\n _this.waitingVideoCC = -1;\n _this.audioSwitch = false;\n _this.trackId = -1;\n _this.waitingData = null;\n _this.mainDetails = null;\n _this.bufferFlushed = false;\n _this.cachedTrackLoadedData = null;\n\n _this._registerListeners();\n\n return _this;\n }\n\n var _proto = AudioStreamController.prototype;\n\n _proto.onHandlerDestroying = function onHandlerDestroying() {\n this._unregisterListeners();\n\n this.mainDetails = null;\n };\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACKS_UPDATED, this.onAudioTracksUpdated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_SWITCHING, this.onAudioTrackSwitching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_LOADED, this.onAudioTrackLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, this.onError, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_RESET, this.onBufferReset, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_FLUSHED, this.onBufferFlushed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].INIT_PTS_FOUND, this.onInitPtsFound, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACKS_UPDATED, this.onAudioTracksUpdated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_SWITCHING, this.onAudioTrackSwitching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_LOADED, this.onAudioTrackLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, this.onError, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_RESET, this.onBufferReset, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_FLUSHED, this.onBufferFlushed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].INIT_PTS_FOUND, this.onInitPtsFound, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n } // INIT_PTS_FOUND is triggered when the video track parsed in the stream-controller has a new PTS value\n ;\n\n _proto.onInitPtsFound = function onInitPtsFound(event, _ref) {\n var frag = _ref.frag,\n id = _ref.id,\n initPTS = _ref.initPTS;\n\n // Always update the new INIT PTS\n // Can change due level switch\n if (id === 'main') {\n var cc = frag.cc;\n this.initPTS[frag.cc] = initPTS;\n this.log(\"InitPTS for cc: \" + cc + \" found from main: \" + initPTS);\n this.videoTrackCC = cc; // If we are waiting, tick immediately to unblock audio fragment transmuxing\n\n if (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_INIT_PTS) {\n this.tick();\n }\n }\n };\n\n _proto.startLoad = function startLoad(startPosition) {\n if (!this.levels) {\n this.startPosition = startPosition;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].STOPPED;\n return;\n }\n\n var lastCurrentTime = this.lastCurrentTime;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.fragLoadError = 0;\n\n if (lastCurrentTime > 0 && startPosition === -1) {\n this.log(\"Override startPosition with lastCurrentTime @\" + lastCurrentTime.toFixed(3));\n startPosition = lastCurrentTime;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n } else {\n this.loadedmetadata = false;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_TRACK;\n }\n\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime = startPosition;\n this.tick();\n };\n\n _proto.doTick = function doTick() {\n switch (this.state) {\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE:\n this.doTickIdle();\n break;\n\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_TRACK:\n {\n var _levels$trackId;\n\n var levels = this.levels,\n trackId = this.trackId;\n var details = levels === null || levels === void 0 ? void 0 : (_levels$trackId = levels[trackId]) === null || _levels$trackId === void 0 ? void 0 : _levels$trackId.details;\n\n if (details) {\n if (this.waitForCdnTuneIn(details)) {\n break;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_INIT_PTS;\n }\n\n break;\n }\n\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING_WAITING_RETRY:\n {\n var _this$media;\n\n var now = performance.now();\n var retryDate = this.retryDate; // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n\n if (!retryDate || now >= retryDate || (_this$media = this.media) !== null && _this$media !== void 0 && _this$media.seeking) {\n this.log('RetryDate reached, switch back to IDLE state');\n this.resetStartWhenNotLoaded(this.trackId);\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n\n break;\n }\n\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_INIT_PTS:\n {\n // Ensure we don't get stuck in the WAITING_INIT_PTS state if the waiting frag CC doesn't match any initPTS\n var waitingData = this.waitingData;\n\n if (waitingData) {\n var frag = waitingData.frag,\n part = waitingData.part,\n cache = waitingData.cache,\n complete = waitingData.complete;\n\n if (this.initPTS[frag.cc] !== undefined) {\n this.waitingData = null;\n this.waitingVideoCC = -1;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING;\n var payload = cache.flush();\n var data = {\n frag: frag,\n part: part,\n payload: payload,\n networkDetails: null\n };\n\n this._handleFragmentLoadProgress(data);\n\n if (complete) {\n _BaseStreamController.prototype._handleFragmentLoadComplete.call(this, data);\n }\n } else if (this.videoTrackCC !== this.waitingVideoCC) {\n // Drop waiting fragment if videoTrackCC has changed since waitingFragment was set and initPTS was not found\n this.log(\"Waiting fragment cc (\" + frag.cc + \") cancelled because video is at cc \" + this.videoTrackCC);\n this.clearWaitingFragment();\n } else {\n // Drop waiting fragment if an earlier fragment is needed\n var pos = this.getLoadPosition();\n var bufferInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(this.mediaBuffer, pos, this.config.maxBufferHole);\n var waitingFragmentAtPosition = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_11__[\"fragmentWithinToleranceTest\"])(bufferInfo.end, this.config.maxFragLookUpTolerance, frag);\n\n if (waitingFragmentAtPosition < 0) {\n this.log(\"Waiting fragment cc (\" + frag.cc + \") @ \" + frag.start + \" cancelled because another fragment at \" + bufferInfo.end + \" is needed\");\n this.clearWaitingFragment();\n }\n }\n } else {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n }\n }\n\n this.onTickEnd();\n };\n\n _proto.clearWaitingFragment = function clearWaitingFragment() {\n var waitingData = this.waitingData;\n\n if (waitingData) {\n this.fragmentTracker.removeFragment(waitingData.frag);\n this.waitingData = null;\n this.waitingVideoCC = -1;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n };\n\n _proto.resetLoadingState = function resetLoadingState() {\n this.clearWaitingFragment();\n\n _BaseStreamController.prototype.resetLoadingState.call(this);\n };\n\n _proto.onTickEnd = function onTickEnd() {\n var media = this.media;\n\n if (!media || !media.readyState) {\n // Exit early if we don't have media or if the media hasn't buffered anything yet (readyState 0)\n return;\n }\n\n var mediaBuffer = this.mediaBuffer ? this.mediaBuffer : media;\n var buffered = mediaBuffer.buffered;\n\n if (!this.loadedmetadata && buffered.length) {\n this.loadedmetadata = true;\n }\n\n this.lastCurrentTime = media.currentTime;\n };\n\n _proto.doTickIdle = function doTickIdle() {\n var _frag$decryptdata, _frag$decryptdata2;\n\n var hls = this.hls,\n levels = this.levels,\n media = this.media,\n trackId = this.trackId;\n var config = hls.config;\n\n if (!levels || !levels[trackId]) {\n return;\n } // if video not attached AND\n // start fragment already requested OR start frag prefetch not enabled\n // exit loop\n // => if media not attached but start frag prefetch is enabled and start frag not requested yet, we will not exit loop\n\n\n if (!media && (this.startFragRequested || !config.startFragPrefetch)) {\n return;\n }\n\n var levelInfo = levels[trackId];\n var trackDetails = levelInfo.details;\n\n if (!trackDetails || trackDetails.live && this.levelLastLoaded !== trackId || this.waitForCdnTuneIn(trackDetails)) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_TRACK;\n return;\n }\n\n var bufferable = this.mediaBuffer ? this.mediaBuffer : this.media;\n\n if (this.bufferFlushed && bufferable) {\n this.bufferFlushed = false;\n this.afterBufferFlushed(bufferable, _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO);\n }\n\n var bufferInfo = this.getFwdBufferInfo(bufferable, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO);\n\n if (bufferInfo === null) {\n return;\n }\n\n var mainBufferInfo = this.getFwdBufferInfo(this.videoBuffer ? this.videoBuffer : this.media, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n var bufferLen = bufferInfo.len;\n var maxBufLen = this.getMaxBufferLength(mainBufferInfo === null || mainBufferInfo === void 0 ? void 0 : mainBufferInfo.len);\n var audioSwitch = this.audioSwitch; // if buffer length is less than maxBufLen try to load a new fragment\n\n if (bufferLen >= maxBufLen && !audioSwitch) {\n return;\n }\n\n if (!audioSwitch && this._streamEnded(bufferInfo, trackDetails)) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_EOS, {\n type: 'audio'\n });\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ENDED;\n return;\n }\n\n var fragments = trackDetails.fragments;\n var start = fragments[0].start;\n var targetBufferTime = bufferInfo.end;\n\n if (audioSwitch && media) {\n var pos = this.getLoadPosition();\n targetBufferTime = pos; // if currentTime (pos) is less than alt audio playlist start time, it means that alt audio is ahead of currentTime\n\n if (trackDetails.PTSKnown && pos < start) {\n // if everything is buffered from pos to start or if audio buffer upfront, let's seek to start\n if (bufferInfo.end > start || bufferInfo.nextStart) {\n this.log('Alt audio track ahead of main track, seek to start of alt audio track');\n media.currentTime = start + 0.05;\n }\n }\n } // buffer audio up to one target duration ahead of main buffer\n\n\n if (mainBufferInfo && targetBufferTime > mainBufferInfo.end + trackDetails.targetduration) {\n return;\n } // wait for main buffer after buffing some audio\n\n\n if ((!mainBufferInfo || !mainBufferInfo.len) && bufferInfo.len) {\n return;\n }\n\n var frag = this.getNextFragment(targetBufferTime, trackDetails);\n\n if (!frag) {\n this.bufferFlushed = true;\n return;\n }\n\n if (((_frag$decryptdata = frag.decryptdata) === null || _frag$decryptdata === void 0 ? void 0 : _frag$decryptdata.keyFormat) === 'identity' && !((_frag$decryptdata2 = frag.decryptdata) !== null && _frag$decryptdata2 !== void 0 && _frag$decryptdata2.key)) {\n this.loadKey(frag, trackDetails);\n } else {\n this.loadFragment(frag, trackDetails, targetBufferTime);\n }\n };\n\n _proto.getMaxBufferLength = function getMaxBufferLength(mainBufferLength) {\n var maxConfigBuffer = _BaseStreamController.prototype.getMaxBufferLength.call(this);\n\n if (!mainBufferLength) {\n return maxConfigBuffer;\n }\n\n return Math.max(maxConfigBuffer, mainBufferLength);\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n this.videoBuffer = null;\n\n _BaseStreamController.prototype.onMediaDetaching.call(this);\n };\n\n _proto.onAudioTracksUpdated = function onAudioTracksUpdated(event, _ref2) {\n var audioTracks = _ref2.audioTracks;\n this.resetTransmuxer();\n this.levels = audioTracks.map(function (mediaPlaylist) {\n return new _types_level__WEBPACK_IMPORTED_MODULE_5__[\"Level\"](mediaPlaylist);\n });\n };\n\n _proto.onAudioTrackSwitching = function onAudioTrackSwitching(event, data) {\n // if any URL found on new audio track, it is an alternate audio track\n var altAudio = !!data.url;\n this.trackId = data.id;\n var fragCurrent = this.fragCurrent;\n\n if (fragCurrent !== null && fragCurrent !== void 0 && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n this.fragCurrent = null;\n this.clearWaitingFragment(); // destroy useless transmuxer when switching audio to main\n\n if (!altAudio) {\n this.resetTransmuxer();\n } else {\n // switching to audio track, start timer if not already started\n this.setInterval(TICK_INTERVAL);\n } // should we switch tracks ?\n\n\n if (altAudio) {\n this.audioSwitch = true; // main audio track are handled by stream-controller, just do something if switching to alt audio track\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n } else {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].STOPPED;\n }\n\n this.tick();\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.mainDetails = null;\n this.fragmentTracker.removeAllFragments();\n this.startPosition = this.lastCurrentTime = 0;\n this.bufferFlushed = false;\n };\n\n _proto.onLevelLoaded = function onLevelLoaded(event, data) {\n this.mainDetails = data.details;\n\n if (this.cachedTrackLoadedData !== null) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_LOADED, this.cachedTrackLoadedData);\n this.cachedTrackLoadedData = null;\n }\n };\n\n _proto.onAudioTrackLoaded = function onAudioTrackLoaded(event, data) {\n var _track$details;\n\n if (this.mainDetails == null) {\n this.cachedTrackLoadedData = data;\n return;\n }\n\n var levels = this.levels;\n var newDetails = data.details,\n trackId = data.id;\n\n if (!levels) {\n this.warn(\"Audio tracks were reset while loading level \" + trackId);\n return;\n }\n\n this.log(\"Track \" + trackId + \" loaded [\" + newDetails.startSN + \",\" + newDetails.endSN + \"],duration:\" + newDetails.totalduration);\n var track = levels[trackId];\n var sliding = 0;\n\n if (newDetails.live || (_track$details = track.details) !== null && _track$details !== void 0 && _track$details.live) {\n var mainDetails = this.mainDetails;\n\n if (!newDetails.fragments[0]) {\n newDetails.deltaUpdateFailed = true;\n }\n\n if (newDetails.deltaUpdateFailed || !mainDetails) {\n return;\n }\n\n if (!track.details && newDetails.hasProgramDateTime && mainDetails.hasProgramDateTime) {\n // Make sure our audio rendition is aligned with the \"main\" rendition, using\n // pdt as our reference times.\n Object(_utils_discontinuities__WEBPACK_IMPORTED_MODULE_12__[\"alignMediaPlaylistByPDT\"])(newDetails, mainDetails);\n sliding = newDetails.fragments[0].start;\n } else {\n sliding = this.alignPlaylists(newDetails, track.details);\n }\n }\n\n track.details = newDetails;\n this.levelLastLoaded = trackId; // compute start position if we are aligned with the main playlist\n\n if (!this.startFragRequested && (this.mainDetails || !newDetails.live)) {\n this.setStartPosition(track.details, sliding);\n } // only switch back to IDLE state if we were waiting for track to start downloading a new fragment\n\n\n if (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_TRACK && !this.waitForCdnTuneIn(newDetails)) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n } // trigger handler right now\n\n\n this.tick();\n };\n\n _proto._handleFragmentLoadProgress = function _handleFragmentLoadProgress(data) {\n var _frag$initSegment;\n\n var frag = data.frag,\n part = data.part,\n payload = data.payload;\n var config = this.config,\n trackId = this.trackId,\n levels = this.levels;\n\n if (!levels) {\n this.warn(\"Audio tracks were reset while fragment load was in progress. Fragment \" + frag.sn + \" of level \" + frag.level + \" will not be buffered\");\n return;\n }\n\n var track = levels[trackId];\n console.assert(track, 'Audio track is defined on fragment load progress');\n var details = track.details;\n console.assert(details, 'Audio track details are defined on fragment load progress');\n var audioCodec = config.defaultAudioCodec || track.audioCodec || 'mp4a.40.2';\n var transmuxer = this.transmuxer;\n\n if (!transmuxer) {\n transmuxer = this.transmuxer = new _demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_9__[\"default\"](this.hls, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO, this._handleTransmuxComplete.bind(this), this._handleTransmuxerFlush.bind(this));\n } // Check if we have video initPTS\n // If not we need to wait for it\n\n\n var initPTS = this.initPTS[frag.cc];\n var initSegmentData = (_frag$initSegment = frag.initSegment) === null || _frag$initSegment === void 0 ? void 0 : _frag$initSegment.data;\n\n if (initPTS !== undefined) {\n // this.log(`Transmuxing ${sn} of [${details.startSN} ,${details.endSN}],track ${trackId}`);\n // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live)\n var accurateTimeOffset = false; // details.PTSKnown || !details.live;\n\n var partIndex = part ? part.index : -1;\n var partial = partIndex !== -1;\n var chunkMeta = new _types_transmuxer__WEBPACK_IMPORTED_MODULE_10__[\"ChunkMetadata\"](frag.level, frag.sn, frag.stats.chunkCount, payload.byteLength, partIndex, partial);\n transmuxer.push(payload, initSegmentData, audioCodec, '', frag, part, details.totalduration, accurateTimeOffset, chunkMeta, initPTS);\n } else {\n this.log(\"Unknown video PTS for cc \" + frag.cc + \", waiting for video PTS before demuxing audio frag \" + frag.sn + \" of [\" + details.startSN + \" ,\" + details.endSN + \"],track \" + trackId);\n\n var _this$waitingData = this.waitingData = this.waitingData || {\n frag: frag,\n part: part,\n cache: new _demux_chunk_cache__WEBPACK_IMPORTED_MODULE_8__[\"default\"](),\n complete: false\n },\n cache = _this$waitingData.cache;\n\n cache.push(new Uint8Array(payload));\n this.waitingVideoCC = this.videoTrackCC;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_INIT_PTS;\n }\n };\n\n _proto._handleFragmentLoadComplete = function _handleFragmentLoadComplete(fragLoadedData) {\n if (this.waitingData) {\n this.waitingData.complete = true;\n return;\n }\n\n _BaseStreamController.prototype._handleFragmentLoadComplete.call(this, fragLoadedData);\n };\n\n _proto.onBufferReset = function\n /* event: Events.BUFFER_RESET */\n onBufferReset() {\n // reset reference to sourcebuffers\n this.mediaBuffer = this.videoBuffer = null;\n this.loadedmetadata = false;\n };\n\n _proto.onBufferCreated = function onBufferCreated(event, data) {\n var audioTrack = data.tracks.audio;\n\n if (audioTrack) {\n this.mediaBuffer = audioTrack.buffer || null;\n }\n\n if (data.tracks.video) {\n this.videoBuffer = data.tracks.video.buffer || null;\n }\n };\n\n _proto.onFragBuffered = function onFragBuffered(event, data) {\n var frag = data.frag,\n part = data.part;\n\n if (frag.type !== _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO) {\n return;\n }\n\n if (this.fragContextChanged(frag)) {\n // If a level switch was requested while a fragment was buffering, it will emit the FRAG_BUFFERED event upon completion\n // Avoid setting state back to IDLE or concluding the audio switch; otherwise, the switched-to track will not buffer\n this.warn(\"Fragment \" + frag.sn + (part ? ' p: ' + part.index : '') + \" of level \" + frag.level + \" finished buffering, but was aborted. state: \" + this.state + \", audioSwitch: \" + this.audioSwitch);\n return;\n }\n\n if (frag.sn !== 'initSegment') {\n this.fragPrevious = frag;\n\n if (this.audioSwitch) {\n this.audioSwitch = false;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_SWITCHED, {\n id: this.trackId\n });\n }\n }\n\n this.fragBufferedComplete(frag, part);\n };\n\n _proto.onError = function onError(event, data) {\n switch (data.details) {\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].FRAG_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT:\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].KEY_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].KEY_LOAD_TIMEOUT:\n // TODO: Skip fragments that do not belong to this.fragCurrent audio-group id\n this.onFragmentOrKeyLoadError(_types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO, data);\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].AUDIO_TRACK_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].AUDIO_TRACK_LOAD_TIMEOUT:\n // when in ERROR state, don't switch back to IDLE state in case a non-fatal error is received\n if (this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ERROR && this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].STOPPED) {\n // if fatal error, stop processing, otherwise move to IDLE to retry loading\n this.state = data.fatal ? _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ERROR : _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n this.warn(data.details + \" while loading frag, switching to \" + this.state + \" state\");\n }\n\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'audio' && (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING || this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSED)) {\n var flushBuffer = true;\n var bufferedInfo = this.getFwdBufferInfo(this.mediaBuffer, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO); // 0.5 : tolerance needed as some browsers stalls playback before reaching buffered end\n // reduce max buf len if current position is buffered\n\n if (bufferedInfo && bufferedInfo.len > 0.5) {\n flushBuffer = !this.reduceMaxBufferLength(bufferedInfo.len);\n }\n\n if (flushBuffer) {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole audio buffer to recover\n this.warn('Buffer full error also media.currentTime is not buffered, flush audio buffer');\n this.fragCurrent = null;\n\n _BaseStreamController.prototype.flushMainBuffer.call(this, 0, Number.POSITIVE_INFINITY, 'audio');\n }\n\n this.resetLoadingState();\n }\n\n break;\n\n default:\n break;\n }\n };\n\n _proto.onBufferFlushed = function onBufferFlushed(event, _ref3) {\n var type = _ref3.type;\n\n if (type === _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO) {\n this.bufferFlushed = true;\n }\n };\n\n _proto._handleTransmuxComplete = function _handleTransmuxComplete(transmuxResult) {\n var _id3$samples;\n\n var id = 'audio';\n var hls = this.hls;\n var remuxResult = transmuxResult.remuxResult,\n chunkMeta = transmuxResult.chunkMeta;\n var context = this.getCurrentContext(chunkMeta);\n\n if (!context) {\n this.warn(\"The loading context changed while buffering fragment \" + chunkMeta.sn + \" of level \" + chunkMeta.level + \". This chunk will not be buffered.\");\n this.resetStartWhenNotLoaded(chunkMeta.level);\n return;\n }\n\n var frag = context.frag,\n part = context.part,\n details = context.level.details;\n var audio = remuxResult.audio,\n text = remuxResult.text,\n id3 = remuxResult.id3,\n initSegment = remuxResult.initSegment; // Check if the current fragment has been aborted. We check this by first seeing if we're still playing the current level.\n // If we are, subsequently check if the currently loading fragment (fragCurrent) has changed.\n\n if (this.fragContextChanged(frag) || !details) {\n return;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING;\n\n if (this.audioSwitch && audio) {\n this.completeAudioSwitch();\n }\n\n if (initSegment !== null && initSegment !== void 0 && initSegment.tracks) {\n this._bufferInitSegment(initSegment.tracks, frag, chunkMeta);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_PARSING_INIT_SEGMENT, {\n frag: frag,\n id: id,\n tracks: initSegment.tracks\n }); // Only flush audio from old audio tracks when PTS is known on new audio track\n }\n\n if (audio) {\n var startPTS = audio.startPTS,\n endPTS = audio.endPTS,\n startDTS = audio.startDTS,\n endDTS = audio.endDTS;\n\n if (part) {\n part.elementaryStreams[_loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO] = {\n startPTS: startPTS,\n endPTS: endPTS,\n startDTS: startDTS,\n endDTS: endDTS\n };\n }\n\n frag.setElementaryStreamInfo(_loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO, startPTS, endPTS, startDTS, endDTS);\n this.bufferFragmentData(audio, frag, part, chunkMeta);\n }\n\n if (id3 !== null && id3 !== void 0 && (_id3$samples = id3.samples) !== null && _id3$samples !== void 0 && _id3$samples.length) {\n var emittedID3 = _extends({\n id: id,\n frag: frag,\n details: details\n }, id3);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_PARSING_METADATA, emittedID3);\n }\n\n if (text) {\n var emittedText = _extends({\n id: id,\n frag: frag,\n details: details\n }, text);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].FRAG_PARSING_USERDATA, emittedText);\n }\n };\n\n _proto._bufferInitSegment = function _bufferInitSegment(tracks, frag, chunkMeta) {\n if (this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING) {\n return;\n } // delete any video track found on audio transmuxer\n\n\n if (tracks.video) {\n delete tracks.video;\n } // include levelCodec in audio and video tracks\n\n\n var track = tracks.audio;\n\n if (!track) {\n return;\n }\n\n track.levelCodec = track.codec;\n track.id = 'audio';\n this.log(\"Init audio buffer, container:\" + track.container + \", codecs[parsed]=[\" + track.codec + \"]\");\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_CODECS, tracks);\n var initSegment = track.initSegment;\n\n if (initSegment !== null && initSegment !== void 0 && initSegment.byteLength) {\n var segment = {\n type: 'audio',\n frag: frag,\n part: null,\n chunkMeta: chunkMeta,\n parent: frag.type,\n data: initSegment\n };\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].BUFFER_APPENDING, segment);\n } // trigger handler right now\n\n\n this.tick();\n };\n\n _proto.loadFragment = function loadFragment(frag, trackDetails, targetBufferTime) {\n // only load if fragment is not loaded or if in audio switch\n var fragState = this.fragmentTracker.getState(frag);\n this.fragCurrent = frag; // we force a frag loading in audio switch as fragment tracker might not have evicted previous frags in case of quick audio switch\n\n if (this.audioSwitch || fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_4__[\"FragmentState\"].NOT_LOADED || fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_4__[\"FragmentState\"].PARTIAL) {\n if (frag.sn === 'initSegment') {\n this._loadInitSegment(frag);\n } else if (trackDetails.live && !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.initPTS[frag.cc])) {\n this.log(\"Waiting for video PTS in continuity counter \" + frag.cc + \" of live stream before loading audio fragment \" + frag.sn + \" of level \" + this.trackId);\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_INIT_PTS;\n } else {\n this.startFragRequested = true;\n\n _BaseStreamController.prototype.loadFragment.call(this, frag, trackDetails, targetBufferTime);\n }\n }\n };\n\n _proto.completeAudioSwitch = function completeAudioSwitch() {\n var hls = this.hls,\n media = this.media,\n trackId = this.trackId;\n\n if (media) {\n this.log('Switching audio track : flushing all audio');\n\n _BaseStreamController.prototype.flushMainBuffer.call(this, 0, Number.POSITIVE_INFINITY, 'audio');\n }\n\n this.audioSwitch = false;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].AUDIO_TRACK_SWITCHED, {\n id: trackId\n });\n };\n\n return AudioStreamController;\n}(_base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"default\"]);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (AudioStreamController);\n\n/***/ }),\n\n/***/ \"./src/controller/audio-track-controller.ts\":\n/*!**************************************************!*\\\n !*** ./src/controller/audio-track-controller.ts ***!\n \\**************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _base_playlist_controller__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./base-playlist-controller */ \"./src/controller/base-playlist-controller.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\nvar AudioTrackController = /*#__PURE__*/function (_BasePlaylistControll) {\n _inheritsLoose(AudioTrackController, _BasePlaylistControll);\n\n function AudioTrackController(hls) {\n var _this;\n\n _this = _BasePlaylistControll.call(this, hls, '[audio-track-controller]') || this;\n _this.tracks = [];\n _this.groupId = null;\n _this.tracksInGroup = [];\n _this.trackId = -1;\n _this.trackName = '';\n _this.selectDefaultTrack = true;\n\n _this.registerListeners();\n\n return _this;\n }\n\n var _proto = AudioTrackController.prototype;\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_SWITCHING, this.onLevelSwitching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].AUDIO_TRACK_LOADED, this.onAudioTrackLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_SWITCHING, this.onLevelSwitching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].AUDIO_TRACK_LOADED, this.onAudioTrackLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.tracks.length = 0;\n this.tracksInGroup.length = 0;\n\n _BasePlaylistControll.prototype.destroy.call(this);\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.tracks = [];\n this.groupId = null;\n this.tracksInGroup = [];\n this.trackId = -1;\n this.trackName = '';\n this.selectDefaultTrack = true;\n };\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n this.tracks = data.audioTracks || [];\n };\n\n _proto.onAudioTrackLoaded = function onAudioTrackLoaded(event, data) {\n var id = data.id,\n details = data.details;\n var currentTrack = this.tracksInGroup[id];\n\n if (!currentTrack) {\n this.warn(\"Invalid audio track id \" + id);\n return;\n }\n\n var curDetails = currentTrack.details;\n currentTrack.details = data.details;\n this.log(\"audioTrack \" + id + \" loaded [\" + details.startSN + \"-\" + details.endSN + \"]\");\n\n if (id === this.trackId) {\n this.retryCount = 0;\n this.playlistLoaded(id, data, curDetails);\n }\n };\n\n _proto.onLevelLoading = function onLevelLoading(event, data) {\n this.switchLevel(data.level);\n };\n\n _proto.onLevelSwitching = function onLevelSwitching(event, data) {\n this.switchLevel(data.level);\n };\n\n _proto.switchLevel = function switchLevel(levelIndex) {\n var levelInfo = this.hls.levels[levelIndex];\n\n if (!(levelInfo !== null && levelInfo !== void 0 && levelInfo.audioGroupIds)) {\n return;\n }\n\n var audioGroupId = levelInfo.audioGroupIds[levelInfo.urlId];\n\n if (this.groupId !== audioGroupId) {\n this.groupId = audioGroupId;\n var audioTracks = this.tracks.filter(function (track) {\n return !audioGroupId || track.groupId === audioGroupId;\n }); // Disable selectDefaultTrack if there are no default tracks\n\n if (this.selectDefaultTrack && !audioTracks.some(function (track) {\n return track.default;\n })) {\n this.selectDefaultTrack = false;\n }\n\n this.tracksInGroup = audioTracks;\n var audioTracksUpdated = {\n audioTracks: audioTracks\n };\n this.log(\"Updating audio tracks, \" + audioTracks.length + \" track(s) found in \\\"\" + audioGroupId + \"\\\" group-id\");\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].AUDIO_TRACKS_UPDATED, audioTracksUpdated);\n this.selectInitialTrack();\n }\n };\n\n _proto.onError = function onError(event, data) {\n _BasePlaylistControll.prototype.onError.call(this, event, data);\n\n if (data.fatal || !data.context) {\n return;\n }\n\n if (data.context.type === _types_loader__WEBPACK_IMPORTED_MODULE_3__[\"PlaylistContextType\"].AUDIO_TRACK && data.context.id === this.trackId && data.context.groupId === this.groupId) {\n this.retryLoadingOrFail(data);\n }\n };\n\n _proto.setAudioTrack = function setAudioTrack(newId) {\n var tracks = this.tracksInGroup; // check if level idx is valid\n\n if (newId < 0 || newId >= tracks.length) {\n this.warn('Invalid id passed to audio-track controller');\n return;\n } // stopping live reloading timer if any\n\n\n this.clearTimer();\n var lastTrack = tracks[this.trackId];\n this.log(\"Now switching to audio-track index \" + newId);\n var track = tracks[newId];\n var id = track.id,\n _track$groupId = track.groupId,\n groupId = _track$groupId === void 0 ? '' : _track$groupId,\n name = track.name,\n type = track.type,\n url = track.url;\n this.trackId = newId;\n this.trackName = name;\n this.selectDefaultTrack = false;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].AUDIO_TRACK_SWITCHING, {\n id: id,\n groupId: groupId,\n name: name,\n type: type,\n url: url\n }); // Do not reload track unless live\n\n if (track.details && !track.details.live) {\n return;\n }\n\n var hlsUrlParameters = this.switchParams(track.url, lastTrack === null || lastTrack === void 0 ? void 0 : lastTrack.details);\n this.loadPlaylist(hlsUrlParameters);\n };\n\n _proto.selectInitialTrack = function selectInitialTrack() {\n var audioTracks = this.tracksInGroup;\n console.assert(audioTracks.length, 'Initial audio track should be selected when tracks are known');\n var currentAudioTrackName = this.trackName;\n var trackId = this.findTrackId(currentAudioTrackName) || this.findTrackId();\n\n if (trackId !== -1) {\n this.setAudioTrack(trackId);\n } else {\n this.warn(\"No track found for running audio group-ID: \" + this.groupId);\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].AUDIO_TRACK_LOAD_ERROR,\n fatal: true\n });\n }\n };\n\n _proto.findTrackId = function findTrackId(name) {\n var audioTracks = this.tracksInGroup;\n\n for (var i = 0; i < audioTracks.length; i++) {\n var track = audioTracks[i];\n\n if (!this.selectDefaultTrack || track.default) {\n if (!name || name === track.name) {\n return track.id;\n }\n }\n }\n\n return -1;\n };\n\n _proto.loadPlaylist = function loadPlaylist(hlsUrlParameters) {\n var audioTrack = this.tracksInGroup[this.trackId];\n\n if (this.shouldLoadTrack(audioTrack)) {\n var id = audioTrack.id;\n var groupId = audioTrack.groupId;\n var url = audioTrack.url;\n\n if (hlsUrlParameters) {\n try {\n url = hlsUrlParameters.addDirectives(url);\n } catch (error) {\n this.warn(\"Could not construct new URL with HLS Delivery Directives: \" + error);\n }\n } // track not retrieved yet, or live playlist we need to (re)load it\n\n\n this.log(\"loading audio-track playlist for id: \" + id);\n this.clearTimer();\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].AUDIO_TRACK_LOADING, {\n url: url,\n id: id,\n groupId: groupId,\n deliveryDirectives: hlsUrlParameters || null\n });\n }\n };\n\n _createClass(AudioTrackController, [{\n key: \"audioTracks\",\n get: function get() {\n return this.tracksInGroup;\n }\n }, {\n key: \"audioTrack\",\n get: function get() {\n return this.trackId;\n },\n set: function set(newId) {\n // If audio track is selected from API then don't choose from the manifest default track\n this.selectDefaultTrack = false;\n this.setAudioTrack(newId);\n }\n }]);\n\n return AudioTrackController;\n}(_base_playlist_controller__WEBPACK_IMPORTED_MODULE_2__[\"default\"]);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (AudioTrackController);\n\n/***/ }),\n\n/***/ \"./src/controller/base-playlist-controller.ts\":\n/*!****************************************************!*\\\n !*** ./src/controller/base-playlist-controller.ts ***!\n \\****************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BasePlaylistController; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _types_level__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../types/level */ \"./src/types/level.ts\");\n/* harmony import */ var _level_helper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./level-helper */ \"./src/controller/level-helper.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n\n\n\n\n\n\n\nvar BasePlaylistController = /*#__PURE__*/function () {\n function BasePlaylistController(hls, logPrefix) {\n this.hls = void 0;\n this.timer = -1;\n this.canLoad = false;\n this.retryCount = 0;\n this.log = void 0;\n this.warn = void 0;\n this.log = _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log.bind(_utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"], logPrefix + \":\");\n this.warn = _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn.bind(_utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"], logPrefix + \":\");\n this.hls = hls;\n }\n\n var _proto = BasePlaylistController.prototype;\n\n _proto.destroy = function destroy() {\n this.clearTimer(); // @ts-ignore\n\n this.hls = this.log = this.warn = null;\n };\n\n _proto.onError = function onError(event, data) {\n if (data.fatal && data.type === _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorTypes\"].NETWORK_ERROR) {\n this.clearTimer();\n }\n };\n\n _proto.clearTimer = function clearTimer() {\n clearTimeout(this.timer);\n this.timer = -1;\n };\n\n _proto.startLoad = function startLoad() {\n this.canLoad = true;\n this.retryCount = 0;\n this.loadPlaylist();\n };\n\n _proto.stopLoad = function stopLoad() {\n this.canLoad = false;\n this.clearTimer();\n };\n\n _proto.switchParams = function switchParams(playlistUri, previous) {\n var renditionReports = previous === null || previous === void 0 ? void 0 : previous.renditionReports;\n\n if (renditionReports) {\n for (var i = 0; i < renditionReports.length; i++) {\n var attr = renditionReports[i];\n var uri = '' + attr.URI;\n\n if (uri === playlistUri.slice(-uri.length)) {\n var msn = parseInt(attr['LAST-MSN']);\n var part = parseInt(attr['LAST-PART']);\n\n if (previous && this.hls.config.lowLatencyMode) {\n var currentGoal = Math.min(previous.age - previous.partTarget, previous.targetduration);\n\n if (part !== undefined && currentGoal > previous.partTarget) {\n part += 1;\n }\n }\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(msn)) {\n return new _types_level__WEBPACK_IMPORTED_MODULE_1__[\"HlsUrlParameters\"](msn, Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(part) ? part : undefined, _types_level__WEBPACK_IMPORTED_MODULE_1__[\"HlsSkip\"].No);\n }\n }\n }\n }\n };\n\n _proto.loadPlaylist = function loadPlaylist(hlsUrlParameters) {};\n\n _proto.shouldLoadTrack = function shouldLoadTrack(track) {\n return this.canLoad && track && !!track.url && (!track.details || track.details.live);\n };\n\n _proto.playlistLoaded = function playlistLoaded(index, data, previousDetails) {\n var _this = this;\n\n var details = data.details,\n stats = data.stats; // Set last updated date-time\n\n var elapsed = stats.loading.end ? Math.max(0, self.performance.now() - stats.loading.end) : 0;\n details.advancedDateTime = Date.now() - elapsed; // if current playlist is a live playlist, arm a timer to reload it\n\n if (details.live || previousDetails !== null && previousDetails !== void 0 && previousDetails.live) {\n details.reloaded(previousDetails);\n\n if (previousDetails) {\n this.log(\"live playlist \" + index + \" \" + (details.advanced ? 'REFRESHED ' + details.lastPartSn + '-' + details.lastPartIndex : 'MISSED'));\n } // Merge live playlists to adjust fragment starts and fill in delta playlist skipped segments\n\n\n if (previousDetails && details.fragments.length > 0) {\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_2__[\"mergeDetails\"])(previousDetails, details);\n }\n\n if (!this.canLoad || !details.live) {\n return;\n }\n\n var deliveryDirectives;\n var msn = undefined;\n var part = undefined;\n\n if (details.canBlockReload && details.endSN && details.advanced) {\n // Load level with LL-HLS delivery directives\n var lowLatencyMode = this.hls.config.lowLatencyMode;\n var lastPartSn = details.lastPartSn;\n var endSn = details.endSN;\n var lastPartIndex = details.lastPartIndex;\n var hasParts = lastPartIndex !== -1;\n var lastPart = lastPartSn === endSn; // When low latency mode is disabled, we'll skip part requests once the last part index is found\n\n var nextSnStartIndex = lowLatencyMode ? 0 : lastPartIndex;\n\n if (hasParts) {\n msn = lastPart ? endSn + 1 : lastPartSn;\n part = lastPart ? nextSnStartIndex : lastPartIndex + 1;\n } else {\n msn = endSn + 1;\n } // Low-Latency CDN Tune-in: \"age\" header and time since load indicates we're behind by more than one part\n // Update directives to obtain the Playlist that has the estimated additional duration of media\n\n\n var lastAdvanced = details.age;\n var cdnAge = lastAdvanced + details.ageHeader;\n var currentGoal = Math.min(cdnAge - details.partTarget, details.targetduration * 1.5);\n\n if (currentGoal > 0) {\n if (previousDetails && currentGoal > previousDetails.tuneInGoal) {\n // If we attempted to get the next or latest playlist update, but currentGoal increased,\n // then we either can't catchup, or the \"age\" header cannot be trusted.\n this.warn(\"CDN Tune-in goal increased from: \" + previousDetails.tuneInGoal + \" to: \" + currentGoal + \" with playlist age: \" + details.age);\n currentGoal = 0;\n } else {\n var segments = Math.floor(currentGoal / details.targetduration);\n msn += segments;\n\n if (part !== undefined) {\n var parts = Math.round(currentGoal % details.targetduration / details.partTarget);\n part += parts;\n }\n\n this.log(\"CDN Tune-in age: \" + details.ageHeader + \"s last advanced \" + lastAdvanced.toFixed(2) + \"s goal: \" + currentGoal + \" skip sn \" + segments + \" to part \" + part);\n }\n\n details.tuneInGoal = currentGoal;\n }\n\n deliveryDirectives = this.getDeliveryDirectives(details, data.deliveryDirectives, msn, part);\n\n if (lowLatencyMode || !lastPart) {\n this.loadPlaylist(deliveryDirectives);\n return;\n }\n } else {\n deliveryDirectives = this.getDeliveryDirectives(details, data.deliveryDirectives, msn, part);\n }\n\n var reloadInterval = Object(_level_helper__WEBPACK_IMPORTED_MODULE_2__[\"computeReloadInterval\"])(details, stats);\n\n if (msn !== undefined && details.canBlockReload) {\n reloadInterval -= details.partTarget || 1;\n }\n\n this.log(\"reload live playlist \" + index + \" in \" + Math.round(reloadInterval) + \" ms\");\n this.timer = self.setTimeout(function () {\n return _this.loadPlaylist(deliveryDirectives);\n }, reloadInterval);\n } else {\n this.clearTimer();\n }\n };\n\n _proto.getDeliveryDirectives = function getDeliveryDirectives(details, previousDeliveryDirectives, msn, part) {\n var skip = Object(_types_level__WEBPACK_IMPORTED_MODULE_1__[\"getSkipValue\"])(details, msn);\n\n if (previousDeliveryDirectives !== null && previousDeliveryDirectives !== void 0 && previousDeliveryDirectives.skip && details.deltaUpdateFailed) {\n msn = previousDeliveryDirectives.msn;\n part = previousDeliveryDirectives.part;\n skip = _types_level__WEBPACK_IMPORTED_MODULE_1__[\"HlsSkip\"].No;\n }\n\n return new _types_level__WEBPACK_IMPORTED_MODULE_1__[\"HlsUrlParameters\"](msn, part, skip);\n };\n\n _proto.retryLoadingOrFail = function retryLoadingOrFail(errorEvent) {\n var _this2 = this;\n\n var config = this.hls.config;\n var retry = this.retryCount < config.levelLoadingMaxRetry;\n\n if (retry) {\n var _errorEvent$context;\n\n this.retryCount++;\n\n if (errorEvent.details.indexOf('LoadTimeOut') > -1 && (_errorEvent$context = errorEvent.context) !== null && _errorEvent$context !== void 0 && _errorEvent$context.deliveryDirectives) {\n // The LL-HLS request already timed out so retry immediately\n this.warn(\"retry playlist loading #\" + this.retryCount + \" after \\\"\" + errorEvent.details + \"\\\"\");\n this.loadPlaylist();\n } else {\n // exponential backoff capped to max retry timeout\n var delay = Math.min(Math.pow(2, this.retryCount) * config.levelLoadingRetryDelay, config.levelLoadingMaxRetryTimeout); // Schedule level/track reload\n\n this.timer = self.setTimeout(function () {\n return _this2.loadPlaylist();\n }, delay);\n this.warn(\"retry playlist loading #\" + this.retryCount + \" in \" + delay + \" ms after \\\"\" + errorEvent.details + \"\\\"\");\n }\n } else {\n this.warn(\"cannot recover from error \\\"\" + errorEvent.details + \"\\\"\"); // stopping live reloading timer if any\n\n this.clearTimer(); // switch error to fatal\n\n errorEvent.fatal = true;\n }\n\n return retry;\n };\n\n return BasePlaylistController;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/base-stream-controller.ts\":\n/*!**************************************************!*\\\n !*** ./src/controller/base-stream-controller.ts ***!\n \\**************************************************/\n/*! exports provided: State, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"State\", function() { return State; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BaseStreamController; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _task_loop__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../task-loop */ \"./src/task-loop.ts\");\n/* harmony import */ var _fragment_tracker__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./fragment-tracker */ \"./src/controller/fragment-tracker.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _types_transmuxer__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../types/transmuxer */ \"./src/types/transmuxer.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _utils_discontinuities__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../utils/discontinuities */ \"./src/utils/discontinuities.ts\");\n/* harmony import */ var _fragment_finders__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./fragment-finders */ \"./src/controller/fragment-finders.ts\");\n/* harmony import */ var _level_helper__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./level-helper */ \"./src/controller/level-helper.ts\");\n/* harmony import */ var _loader_fragment_loader__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../loader/fragment-loader */ \"./src/loader/fragment-loader.ts\");\n/* harmony import */ var _crypt_decrypter__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../crypt/decrypter */ \"./src/crypt/decrypter.ts\");\n/* harmony import */ var _utils_time_ranges__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../utils/time-ranges */ \"./src/utils/time-ranges.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n\n\n\n\n\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nvar State = {\n STOPPED: 'STOPPED',\n IDLE: 'IDLE',\n KEY_LOADING: 'KEY_LOADING',\n FRAG_LOADING: 'FRAG_LOADING',\n FRAG_LOADING_WAITING_RETRY: 'FRAG_LOADING_WAITING_RETRY',\n WAITING_TRACK: 'WAITING_TRACK',\n PARSING: 'PARSING',\n PARSED: 'PARSED',\n ENDED: 'ENDED',\n ERROR: 'ERROR',\n WAITING_INIT_PTS: 'WAITING_INIT_PTS',\n WAITING_LEVEL: 'WAITING_LEVEL'\n};\n\nvar BaseStreamController = /*#__PURE__*/function (_TaskLoop) {\n _inheritsLoose(BaseStreamController, _TaskLoop);\n\n function BaseStreamController(hls, fragmentTracker, logPrefix) {\n var _this;\n\n _this = _TaskLoop.call(this) || this;\n _this.hls = void 0;\n _this.fragPrevious = null;\n _this.fragCurrent = null;\n _this.fragmentTracker = void 0;\n _this.transmuxer = null;\n _this._state = State.STOPPED;\n _this.media = null;\n _this.mediaBuffer = null;\n _this.config = void 0;\n _this.bitrateTest = false;\n _this.lastCurrentTime = 0;\n _this.nextLoadPosition = 0;\n _this.startPosition = 0;\n _this.loadedmetadata = false;\n _this.fragLoadError = 0;\n _this.retryDate = 0;\n _this.levels = null;\n _this.fragmentLoader = void 0;\n _this.levelLastLoaded = null;\n _this.startFragRequested = false;\n _this.decrypter = void 0;\n _this.initPTS = [];\n _this.onvseeking = null;\n _this.onvended = null;\n _this.logPrefix = '';\n _this.log = void 0;\n _this.warn = void 0;\n _this.logPrefix = logPrefix;\n _this.log = _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].log.bind(_utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"], logPrefix + \":\");\n _this.warn = _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].warn.bind(_utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"], logPrefix + \":\");\n _this.hls = hls;\n _this.fragmentLoader = new _loader_fragment_loader__WEBPACK_IMPORTED_MODULE_12__[\"default\"](hls.config);\n _this.fragmentTracker = fragmentTracker;\n _this.config = hls.config;\n _this.decrypter = new _crypt_decrypter__WEBPACK_IMPORTED_MODULE_13__[\"default\"](hls, hls.config);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].KEY_LOADED, _this.onKeyLoaded, _assertThisInitialized(_this));\n hls.on(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].LEVEL_SWITCHING, _this.onLevelSwitching, _assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = BaseStreamController.prototype;\n\n _proto.doTick = function doTick() {\n this.onTickEnd();\n };\n\n _proto.onTickEnd = function onTickEnd() {} // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ;\n\n _proto.startLoad = function startLoad(startPosition) {};\n\n _proto.stopLoad = function stopLoad() {\n this.fragmentLoader.abort();\n var frag = this.fragCurrent;\n\n if (frag) {\n this.fragmentTracker.removeFragment(frag);\n }\n\n this.resetTransmuxer();\n this.fragCurrent = null;\n this.fragPrevious = null;\n this.clearInterval();\n this.clearNextTick();\n this.state = State.STOPPED;\n };\n\n _proto._streamEnded = function _streamEnded(bufferInfo, levelDetails) {\n var fragCurrent = this.fragCurrent,\n fragmentTracker = this.fragmentTracker; // we just got done loading the final fragment and there is no other buffered range after ...\n // rationale is that in case there are any buffered ranges after, it means that there are unbuffered portion in between\n // so we should not switch to ENDED in that case, to be able to buffer them\n\n if (!levelDetails.live && fragCurrent && this.media && // NOTE: Because of the way parts are currently parsed/represented in the playlist, we can end up\n // in situations where the current fragment is actually greater than levelDetails.endSN. While\n // this feels like the \"wrong place\" to account for that, this is a narrower/safer change than\n // updating e.g. M3U8Parser::parseLevelPlaylist().\n fragCurrent.sn >= levelDetails.endSN && !bufferInfo.nextStart) {\n var partList = levelDetails.partList; // Since the last part isn't guaranteed to correspond to fragCurrent for ll-hls, check instead if the last part is buffered.\n\n if (partList !== null && partList !== void 0 && partList.length) {\n var lastPart = partList[partList.length - 1]; // Checking the midpoint of the part for potential margin of error and related issues.\n // NOTE: Technically I believe parts could yield content that is < the computed duration (including potential a duration of 0)\n // and still be spec-compliant, so there may still be edge cases here. Likewise, there could be issues in end of stream\n // part mismatches for independent audio and video playlists/segments.\n\n var lastPartBuffered = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].isBuffered(this.media, lastPart.start + lastPart.duration / 2);\n return lastPartBuffered;\n }\n\n var fragState = fragmentTracker.getState(fragCurrent);\n return fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_2__[\"FragmentState\"].PARTIAL || fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_2__[\"FragmentState\"].OK;\n }\n\n return false;\n };\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n var media = this.media = this.mediaBuffer = data.media;\n this.onvseeking = this.onMediaSeeking.bind(this);\n this.onvended = this.onMediaEnded.bind(this);\n media.addEventListener('seeking', this.onvseeking);\n media.addEventListener('ended', this.onvended);\n var config = this.config;\n\n if (this.levels && config.autoStartLoad && this.state === State.STOPPED) {\n this.startLoad(config.startPosition);\n }\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n var media = this.media;\n\n if (media !== null && media !== void 0 && media.ended) {\n this.log('MSE detaching and video ended, reset startPosition');\n this.startPosition = this.lastCurrentTime = 0;\n } // remove video listeners\n\n\n if (media && this.onvseeking && this.onvended) {\n media.removeEventListener('seeking', this.onvseeking);\n media.removeEventListener('ended', this.onvended);\n this.onvseeking = this.onvended = null;\n }\n\n this.media = this.mediaBuffer = null;\n this.loadedmetadata = false;\n this.fragmentTracker.removeAllFragments();\n this.stopLoad();\n };\n\n _proto.onMediaSeeking = function onMediaSeeking() {\n var config = this.config,\n fragCurrent = this.fragCurrent,\n media = this.media,\n mediaBuffer = this.mediaBuffer,\n state = this.state;\n var currentTime = media ? media.currentTime : 0;\n var bufferInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(mediaBuffer ? mediaBuffer : media, currentTime, config.maxBufferHole);\n this.log(\"media seeking to \" + (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(currentTime) ? currentTime.toFixed(3) : currentTime) + \", state: \" + state);\n\n if (state === State.ENDED) {\n this.resetLoadingState();\n } else if (fragCurrent && !bufferInfo.len) {\n // check if we are seeking to a unbuffered area AND if frag loading is in progress\n var tolerance = config.maxFragLookUpTolerance;\n var fragStartOffset = fragCurrent.start - tolerance;\n var fragEndOffset = fragCurrent.start + fragCurrent.duration + tolerance;\n var pastFragment = currentTime > fragEndOffset; // check if the seek position is past current fragment, and if so abort loading\n\n if (currentTime < fragStartOffset || pastFragment) {\n if (pastFragment && fragCurrent.loader) {\n this.log('seeking outside of buffer while fragment load in progress, cancel fragment load');\n fragCurrent.loader.abort();\n }\n\n this.resetLoadingState();\n }\n }\n\n if (media) {\n this.lastCurrentTime = currentTime;\n } // in case seeking occurs although no media buffered, adjust startPosition and nextLoadPosition to seek target\n\n\n if (!this.loadedmetadata && !bufferInfo.len) {\n this.nextLoadPosition = this.startPosition = currentTime;\n } // Async tick to speed up processing\n\n\n this.tickImmediate();\n };\n\n _proto.onMediaEnded = function onMediaEnded() {\n // reset startPosition and lastCurrentTime to restart playback @ stream beginning\n this.startPosition = this.lastCurrentTime = 0;\n };\n\n _proto.onKeyLoaded = function onKeyLoaded(event, data) {\n if (this.state !== State.KEY_LOADING || data.frag !== this.fragCurrent || !this.levels) {\n return;\n }\n\n this.state = State.IDLE;\n var levelDetails = this.levels[data.frag.level].details;\n\n if (levelDetails) {\n this.loadFragment(data.frag, levelDetails, data.frag.start);\n }\n };\n\n _proto.onLevelSwitching = function onLevelSwitching(event, data) {\n this.fragLoadError = 0;\n };\n\n _proto.onHandlerDestroying = function onHandlerDestroying() {\n this.stopLoad();\n\n _TaskLoop.prototype.onHandlerDestroying.call(this);\n };\n\n _proto.onHandlerDestroyed = function onHandlerDestroyed() {\n this.state = State.STOPPED;\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].KEY_LOADED, this.onKeyLoaded, this);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].LEVEL_SWITCHING, this.onLevelSwitching, this);\n\n if (this.fragmentLoader) {\n this.fragmentLoader.destroy();\n }\n\n if (this.decrypter) {\n this.decrypter.destroy();\n }\n\n this.hls = this.log = this.warn = this.decrypter = this.fragmentLoader = this.fragmentTracker = null;\n\n _TaskLoop.prototype.onHandlerDestroyed.call(this);\n };\n\n _proto.loadKey = function loadKey(frag, details) {\n this.log(\"Loading key for \" + frag.sn + \" of [\" + details.startSN + \"-\" + details.endSN + \"], \" + (this.logPrefix === '[stream-controller]' ? 'level' : 'track') + \" \" + frag.level);\n this.state = State.KEY_LOADING;\n this.fragCurrent = frag;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].KEY_LOADING, {\n frag: frag\n });\n };\n\n _proto.loadFragment = function loadFragment(frag, levelDetails, targetBufferTime) {\n this._loadFragForPlayback(frag, levelDetails, targetBufferTime);\n };\n\n _proto._loadFragForPlayback = function _loadFragForPlayback(frag, levelDetails, targetBufferTime) {\n var _this2 = this;\n\n var progressCallback = function progressCallback(data) {\n if (_this2.fragContextChanged(frag)) {\n _this2.warn(\"Fragment \" + frag.sn + (data.part ? ' p: ' + data.part.index : '') + \" of level \" + frag.level + \" was dropped during download.\");\n\n _this2.fragmentTracker.removeFragment(frag);\n\n return;\n }\n\n frag.stats.chunkCount++;\n\n _this2._handleFragmentLoadProgress(data);\n };\n\n this._doFragLoad(frag, levelDetails, targetBufferTime, progressCallback).then(function (data) {\n if (!data) {\n // if we're here we probably needed to backtrack or are waiting for more parts\n return;\n }\n\n _this2.fragLoadError = 0;\n var state = _this2.state;\n\n if (_this2.fragContextChanged(frag)) {\n if (state === State.FRAG_LOADING || !_this2.fragCurrent && state === State.PARSING) {\n _this2.fragmentTracker.removeFragment(frag);\n\n _this2.state = State.IDLE;\n }\n\n return;\n }\n\n if ('payload' in data) {\n _this2.log(\"Loaded fragment \" + frag.sn + \" of level \" + frag.level);\n\n _this2.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_LOADED, data);\n } // Pass through the whole payload; controllers not implementing progressive loading receive data from this callback\n\n\n _this2._handleFragmentLoadComplete(data);\n }).catch(function (reason) {\n if (_this2.state === State.STOPPED || _this2.state === State.ERROR) {\n return;\n }\n\n _this2.warn(reason);\n\n _this2.resetFragmentLoading(frag);\n });\n };\n\n _proto.flushMainBuffer = function flushMainBuffer(startOffset, endOffset, type) {\n if (type === void 0) {\n type = null;\n }\n\n if (!(startOffset - endOffset)) {\n return;\n } // When alternate audio is playing, the audio-stream-controller is responsible for the audio buffer. Otherwise,\n // passing a null type flushes both buffers\n\n\n var flushScope = {\n startOffset: startOffset,\n endOffset: endOffset,\n type: type\n }; // Reset load errors on flush\n\n this.fragLoadError = 0;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].BUFFER_FLUSHING, flushScope);\n };\n\n _proto._loadInitSegment = function _loadInitSegment(frag) {\n var _this3 = this;\n\n this._doFragLoad(frag).then(function (data) {\n if (!data || _this3.fragContextChanged(frag) || !_this3.levels) {\n throw new Error('init load aborted');\n }\n\n return data;\n }).then(function (data) {\n var hls = _this3.hls;\n var payload = data.payload;\n var decryptData = frag.decryptdata; // check to see if the payload needs to be decrypted\n\n if (payload && payload.byteLength > 0 && decryptData && decryptData.key && decryptData.iv && decryptData.method === 'AES-128') {\n var startTime = self.performance.now(); // decrypt the subtitles\n\n return _this3.decrypter.webCryptoDecrypt(new Uint8Array(payload), decryptData.key.buffer, decryptData.iv.buffer).then(function (decryptedData) {\n var endTime = self.performance.now();\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_DECRYPTED, {\n frag: frag,\n payload: decryptedData,\n stats: {\n tstart: startTime,\n tdecrypt: endTime\n }\n });\n data.payload = decryptedData;\n return data;\n });\n }\n\n return data;\n }).then(function (data) {\n var fragCurrent = _this3.fragCurrent,\n hls = _this3.hls,\n levels = _this3.levels;\n\n if (!levels) {\n throw new Error('init load aborted, missing levels');\n }\n\n var details = levels[frag.level].details;\n console.assert(details, 'Level details are defined when init segment is loaded');\n var stats = frag.stats;\n _this3.state = State.IDLE;\n _this3.fragLoadError = 0;\n frag.data = new Uint8Array(data.payload);\n stats.parsing.start = stats.buffering.start = self.performance.now();\n stats.parsing.end = stats.buffering.end = self.performance.now(); // Silence FRAG_BUFFERED event if fragCurrent is null\n\n if (data.frag === fragCurrent) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_BUFFERED, {\n stats: stats,\n frag: fragCurrent,\n part: null,\n id: frag.type\n });\n }\n\n _this3.tick();\n }).catch(function (reason) {\n if (_this3.state === State.STOPPED || _this3.state === State.ERROR) {\n return;\n }\n\n _this3.warn(reason);\n\n _this3.resetFragmentLoading(frag);\n });\n };\n\n _proto.fragContextChanged = function fragContextChanged(frag) {\n var fragCurrent = this.fragCurrent;\n return !frag || !fragCurrent || frag.level !== fragCurrent.level || frag.sn !== fragCurrent.sn || frag.urlId !== fragCurrent.urlId;\n };\n\n _proto.fragBufferedComplete = function fragBufferedComplete(frag, part) {\n var media = this.mediaBuffer ? this.mediaBuffer : this.media;\n this.log(\"Buffered \" + frag.type + \" sn: \" + frag.sn + (part ? ' part: ' + part.index : '') + \" of \" + (this.logPrefix === '[stream-controller]' ? 'level' : 'track') + \" \" + frag.level + \" \" + (media ? _utils_time_ranges__WEBPACK_IMPORTED_MODULE_14__[\"default\"].toString(_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].getBuffered(media)) : '(detached)'));\n this.state = State.IDLE;\n\n if (!media) {\n return;\n }\n\n if (!this.loadedmetadata && media.buffered.length && this.fragCurrent === this.fragPrevious) {\n this.loadedmetadata = true;\n this.seekToStartPos();\n }\n\n this.tick();\n };\n\n _proto.seekToStartPos = function seekToStartPos() {};\n\n _proto._handleFragmentLoadComplete = function _handleFragmentLoadComplete(fragLoadedEndData) {\n var transmuxer = this.transmuxer;\n\n if (!transmuxer) {\n return;\n }\n\n var frag = fragLoadedEndData.frag,\n part = fragLoadedEndData.part,\n partsLoaded = fragLoadedEndData.partsLoaded; // If we did not load parts, or loaded all parts, we have complete (not partial) fragment data\n\n var complete = !partsLoaded || partsLoaded.length === 0 || partsLoaded.some(function (fragLoaded) {\n return !fragLoaded;\n });\n var chunkMeta = new _types_transmuxer__WEBPACK_IMPORTED_MODULE_7__[\"ChunkMetadata\"](frag.level, frag.sn, frag.stats.chunkCount + 1, 0, part ? part.index : -1, !complete);\n transmuxer.flush(chunkMeta);\n } // eslint-disable-next-line @typescript-eslint/no-unused-vars\n ;\n\n _proto._handleFragmentLoadProgress = function _handleFragmentLoadProgress(frag) {};\n\n _proto._doFragLoad = function _doFragLoad(frag, details, targetBufferTime, progressCallback) {\n var _this4 = this;\n\n if (targetBufferTime === void 0) {\n targetBufferTime = null;\n }\n\n if (!this.levels) {\n throw new Error('frag load aborted, missing levels');\n }\n\n targetBufferTime = Math.max(frag.start, targetBufferTime || 0);\n\n if (this.config.lowLatencyMode && details) {\n var partList = details.partList;\n\n if (partList && progressCallback) {\n if (targetBufferTime > frag.end && details.fragmentHint) {\n frag = details.fragmentHint;\n }\n\n var partIndex = this.getNextPart(partList, frag, targetBufferTime);\n\n if (partIndex > -1) {\n var part = partList[partIndex];\n this.log(\"Loading part sn: \" + frag.sn + \" p: \" + part.index + \" cc: \" + frag.cc + \" of playlist [\" + details.startSN + \"-\" + details.endSN + \"] parts [0-\" + partIndex + \"-\" + (partList.length - 1) + \"] \" + (this.logPrefix === '[stream-controller]' ? 'level' : 'track') + \": \" + frag.level + \", target: \" + parseFloat(targetBufferTime.toFixed(3)));\n this.nextLoadPosition = part.start + part.duration;\n this.state = State.FRAG_LOADING;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_LOADING, {\n frag: frag,\n part: partList[partIndex],\n targetBufferTime: targetBufferTime\n });\n return this.doFragPartsLoad(frag, partList, partIndex, progressCallback).catch(function (error) {\n return _this4.handleFragLoadError(error);\n });\n } else if (!frag.url || this.loadedEndOfParts(partList, targetBufferTime)) {\n // Fragment hint has no parts\n return Promise.resolve(null);\n }\n }\n }\n\n this.log(\"Loading fragment \" + frag.sn + \" cc: \" + frag.cc + \" \" + (details ? 'of [' + details.startSN + '-' + details.endSN + '] ' : '') + (this.logPrefix === '[stream-controller]' ? 'level' : 'track') + \": \" + frag.level + \", target: \" + parseFloat(targetBufferTime.toFixed(3))); // Don't update nextLoadPosition for fragments which are not buffered\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.sn) && !this.bitrateTest) {\n this.nextLoadPosition = frag.start + frag.duration;\n }\n\n this.state = State.FRAG_LOADING;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_LOADING, {\n frag: frag,\n targetBufferTime: targetBufferTime\n });\n return this.fragmentLoader.load(frag, progressCallback).catch(function (error) {\n return _this4.handleFragLoadError(error);\n });\n };\n\n _proto.doFragPartsLoad = function doFragPartsLoad(frag, partList, partIndex, progressCallback) {\n var _this5 = this;\n\n return new Promise(function (resolve, reject) {\n var partsLoaded = [];\n\n var loadPartIndex = function loadPartIndex(index) {\n var part = partList[index];\n\n _this5.fragmentLoader.loadPart(frag, part, progressCallback).then(function (partLoadedData) {\n partsLoaded[part.index] = partLoadedData;\n var loadedPart = partLoadedData.part;\n\n _this5.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_LOADED, partLoadedData);\n\n var nextPart = partList[index + 1];\n\n if (nextPart && nextPart.fragment === frag) {\n loadPartIndex(index + 1);\n } else {\n return resolve({\n frag: frag,\n part: loadedPart,\n partsLoaded: partsLoaded\n });\n }\n }).catch(reject);\n };\n\n loadPartIndex(partIndex);\n });\n };\n\n _proto.handleFragLoadError = function handleFragLoadError(_ref) {\n var data = _ref.data;\n\n if (data && data.details === _errors__WEBPACK_IMPORTED_MODULE_6__[\"ErrorDetails\"].INTERNAL_ABORTED) {\n this.handleFragLoadAborted(data.frag, data.part);\n } else {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].ERROR, data);\n }\n\n return null;\n };\n\n _proto._handleTransmuxerFlush = function _handleTransmuxerFlush(chunkMeta) {\n var context = this.getCurrentContext(chunkMeta);\n\n if (!context || this.state !== State.PARSING) {\n if (!this.fragCurrent) {\n this.state = State.IDLE;\n }\n\n return;\n }\n\n var frag = context.frag,\n part = context.part,\n level = context.level;\n var now = self.performance.now();\n frag.stats.parsing.end = now;\n\n if (part) {\n part.stats.parsing.end = now;\n }\n\n this.updateLevelTiming(frag, part, level, chunkMeta.partial);\n };\n\n _proto.getCurrentContext = function getCurrentContext(chunkMeta) {\n var levels = this.levels;\n var levelIndex = chunkMeta.level,\n sn = chunkMeta.sn,\n partIndex = chunkMeta.part;\n\n if (!levels || !levels[levelIndex]) {\n this.warn(\"Levels object was unset while buffering fragment \" + sn + \" of level \" + levelIndex + \". The current chunk will not be buffered.\");\n return null;\n }\n\n var level = levels[levelIndex];\n var part = partIndex > -1 ? Object(_level_helper__WEBPACK_IMPORTED_MODULE_11__[\"getPartWith\"])(level, sn, partIndex) : null;\n var frag = part ? part.fragment : Object(_level_helper__WEBPACK_IMPORTED_MODULE_11__[\"getFragmentWithSN\"])(level, sn, this.fragCurrent);\n\n if (!frag) {\n return null;\n }\n\n return {\n frag: frag,\n part: part,\n level: level\n };\n };\n\n _proto.bufferFragmentData = function bufferFragmentData(data, frag, part, chunkMeta) {\n if (!data || this.state !== State.PARSING) {\n return;\n }\n\n var data1 = data.data1,\n data2 = data.data2;\n var buffer = data1;\n\n if (data1 && data2) {\n // Combine the moof + mdat so that we buffer with a single append\n buffer = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_8__[\"appendUint8Array\"])(data1, data2);\n }\n\n if (!buffer || !buffer.length) {\n return;\n }\n\n var segment = {\n type: data.type,\n frag: frag,\n part: part,\n chunkMeta: chunkMeta,\n parent: frag.type,\n data: buffer\n };\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].BUFFER_APPENDING, segment);\n\n if (data.dropped && data.independent && !part) {\n // Clear buffer so that we reload previous segments sequentially if required\n this.flushBufferGap(frag);\n }\n };\n\n _proto.flushBufferGap = function flushBufferGap(frag) {\n var media = this.media;\n\n if (!media) {\n return;\n } // If currentTime is not buffered, clear the back buffer so that we can backtrack as much as needed\n\n\n if (!_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].isBuffered(media, media.currentTime)) {\n this.flushMainBuffer(0, frag.start);\n return;\n } // Remove back-buffer without interrupting playback to allow back tracking\n\n\n var currentTime = media.currentTime;\n var bufferInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(media, currentTime, 0);\n var fragDuration = frag.duration;\n var segmentFraction = Math.min(this.config.maxFragLookUpTolerance * 2, fragDuration * 0.25);\n var start = Math.max(Math.min(frag.start - segmentFraction, bufferInfo.end - segmentFraction), currentTime + segmentFraction);\n\n if (frag.start - start > segmentFraction) {\n this.flushMainBuffer(start, frag.start);\n }\n };\n\n _proto.getFwdBufferInfo = function getFwdBufferInfo(bufferable, type) {\n var config = this.config;\n var pos = this.getLoadPosition();\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(pos)) {\n return null;\n }\n\n var bufferInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(bufferable, pos, config.maxBufferHole); // Workaround flaw in getting forward buffer when maxBufferHole is smaller than gap at current pos\n\n if (bufferInfo.len === 0 && bufferInfo.nextStart !== undefined) {\n var bufferedFragAtPos = this.fragmentTracker.getBufferedFrag(pos, type);\n\n if (bufferedFragAtPos && bufferInfo.nextStart < bufferedFragAtPos.end) {\n return _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].bufferInfo(bufferable, pos, Math.max(bufferInfo.nextStart, config.maxBufferHole));\n }\n }\n\n return bufferInfo;\n };\n\n _proto.getMaxBufferLength = function getMaxBufferLength(levelBitrate) {\n var config = this.config;\n var maxBufLen;\n\n if (levelBitrate) {\n maxBufLen = Math.max(8 * config.maxBufferSize / levelBitrate, config.maxBufferLength);\n } else {\n maxBufLen = config.maxBufferLength;\n }\n\n return Math.min(maxBufLen, config.maxMaxBufferLength);\n };\n\n _proto.reduceMaxBufferLength = function reduceMaxBufferLength(threshold) {\n var config = this.config;\n var minLength = threshold || config.maxBufferLength;\n\n if (config.maxMaxBufferLength >= minLength) {\n // reduce max buffer length as it might be too high. we do this to avoid loop flushing ...\n config.maxMaxBufferLength /= 2;\n this.warn(\"Reduce max buffer length to \" + config.maxMaxBufferLength + \"s\");\n return true;\n }\n\n return false;\n };\n\n _proto.getNextFragment = function getNextFragment(pos, levelDetails) {\n var fragments = levelDetails.fragments;\n var fragLen = fragments.length;\n\n if (!fragLen) {\n return null;\n } // find fragment index, contiguous with end of buffer position\n\n\n var config = this.config;\n var start = fragments[0].start;\n var frag;\n\n if (levelDetails.live) {\n var initialLiveManifestSize = config.initialLiveManifestSize;\n\n if (fragLen < initialLiveManifestSize) {\n this.warn(\"Not enough fragments to start playback (have: \" + fragLen + \", need: \" + initialLiveManifestSize + \")\");\n return null;\n } // The real fragment start times for a live stream are only known after the PTS range for that level is known.\n // In order to discover the range, we load the best matching fragment for that level and demux it.\n // Do not load using live logic if the starting frag is requested - we want to use getFragmentAtPosition() so that\n // we get the fragment matching that start time\n\n\n if (!levelDetails.PTSKnown && !this.startFragRequested && this.startPosition === -1) {\n frag = this.getInitialLiveFragment(levelDetails, fragments);\n this.startPosition = frag ? this.hls.liveSyncPosition || frag.start : pos;\n }\n } else if (pos <= start) {\n // VoD playlist: if loadPosition before start of playlist, load first fragment\n frag = fragments[0];\n } // If we haven't run into any special cases already, just load the fragment most closely matching the requested position\n\n\n if (!frag) {\n var end = config.lowLatencyMode ? levelDetails.partEnd : levelDetails.fragmentEnd;\n frag = this.getFragmentAtPosition(pos, end, levelDetails);\n }\n\n return this.mapToInitFragWhenRequired(frag);\n };\n\n _proto.mapToInitFragWhenRequired = function mapToInitFragWhenRequired(frag) {\n // If an initSegment is present, it must be buffered first\n if (frag !== null && frag !== void 0 && frag.initSegment && !(frag !== null && frag !== void 0 && frag.initSegment.data) && !this.bitrateTest) {\n return frag.initSegment;\n }\n\n return frag;\n };\n\n _proto.getNextPart = function getNextPart(partList, frag, targetBufferTime) {\n var nextPart = -1;\n var contiguous = false;\n var independentAttrOmitted = true;\n\n for (var i = 0, len = partList.length; i < len; i++) {\n var part = partList[i];\n independentAttrOmitted = independentAttrOmitted && !part.independent;\n\n if (nextPart > -1 && targetBufferTime < part.start) {\n break;\n }\n\n var loaded = part.loaded;\n\n if (!loaded && (contiguous || part.independent || independentAttrOmitted) && part.fragment === frag) {\n nextPart = i;\n }\n\n contiguous = loaded;\n }\n\n return nextPart;\n };\n\n _proto.loadedEndOfParts = function loadedEndOfParts(partList, targetBufferTime) {\n var lastPart = partList[partList.length - 1];\n return lastPart && targetBufferTime > lastPart.start && lastPart.loaded;\n }\n /*\n This method is used find the best matching first fragment for a live playlist. This fragment is used to calculate the\n \"sliding\" of the playlist, which is its offset from the start of playback. After sliding we can compute the real\n start and end times for each fragment in the playlist (after which this method will not need to be called).\n */\n ;\n\n _proto.getInitialLiveFragment = function getInitialLiveFragment(levelDetails, fragments) {\n var fragPrevious = this.fragPrevious;\n var frag = null;\n\n if (fragPrevious) {\n if (levelDetails.hasProgramDateTime) {\n // Prefer using PDT, because it can be accurate enough to choose the correct fragment without knowing the level sliding\n this.log(\"Live playlist, switching playlist, load frag with same PDT: \" + fragPrevious.programDateTime);\n frag = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_10__[\"findFragmentByPDT\"])(fragments, fragPrevious.endProgramDateTime, this.config.maxFragLookUpTolerance);\n }\n\n if (!frag) {\n // SN does not need to be accurate between renditions, but depending on the packaging it may be so.\n var targetSN = fragPrevious.sn + 1;\n\n if (targetSN >= levelDetails.startSN && targetSN <= levelDetails.endSN) {\n var fragNext = fragments[targetSN - levelDetails.startSN]; // Ensure that we're staying within the continuity range, since PTS resets upon a new range\n\n if (fragPrevious.cc === fragNext.cc) {\n frag = fragNext;\n this.log(\"Live playlist, switching playlist, load frag with next SN: \" + frag.sn);\n }\n } // It's important to stay within the continuity range if available; otherwise the fragments in the playlist\n // will have the wrong start times\n\n\n if (!frag) {\n frag = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_10__[\"findFragWithCC\"])(fragments, fragPrevious.cc);\n\n if (frag) {\n this.log(\"Live playlist, switching playlist, load frag with same CC: \" + frag.sn);\n }\n }\n }\n } else {\n // Find a new start fragment when fragPrevious is null\n var liveStart = this.hls.liveSyncPosition;\n\n if (liveStart !== null) {\n frag = this.getFragmentAtPosition(liveStart, this.bitrateTest ? levelDetails.fragmentEnd : levelDetails.edge, levelDetails);\n }\n }\n\n return frag;\n }\n /*\n This method finds the best matching fragment given the provided position.\n */\n ;\n\n _proto.getFragmentAtPosition = function getFragmentAtPosition(bufferEnd, end, levelDetails) {\n var config = this.config,\n fragPrevious = this.fragPrevious;\n var fragments = levelDetails.fragments,\n endSN = levelDetails.endSN;\n var fragmentHint = levelDetails.fragmentHint;\n var tolerance = config.maxFragLookUpTolerance;\n var loadingParts = !!(config.lowLatencyMode && levelDetails.partList && fragmentHint);\n\n if (loadingParts && fragmentHint && !this.bitrateTest) {\n // Include incomplete fragment with parts at end\n fragments = fragments.concat(fragmentHint);\n endSN = fragmentHint.sn;\n }\n\n var frag;\n\n if (bufferEnd < end) {\n var lookupTolerance = bufferEnd > end - tolerance ? 0 : tolerance; // Remove the tolerance if it would put the bufferEnd past the actual end of stream\n // Uses buffer and sequence number to calculate switch segment (required if using EXT-X-DISCONTINUITY-SEQUENCE)\n\n frag = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_10__[\"findFragmentByPTS\"])(fragPrevious, fragments, bufferEnd, lookupTolerance);\n } else {\n // reach end of playlist\n frag = fragments[fragments.length - 1];\n }\n\n if (frag) {\n var curSNIdx = frag.sn - levelDetails.startSN;\n\n if (fragPrevious && frag.sn === fragPrevious.sn && !loadingParts) {\n // Force the next fragment to load if the previous one was already selected. This can occasionally happen with\n // non-uniform fragment durations\n var sameLevel = fragPrevious && frag.level === fragPrevious.level;\n\n if (sameLevel) {\n var nextFrag = fragments[curSNIdx + 1];\n\n if (frag.sn < endSN && this.fragmentTracker.getState(nextFrag) !== _fragment_tracker__WEBPACK_IMPORTED_MODULE_2__[\"FragmentState\"].OK) {\n this.log(\"SN \" + frag.sn + \" just loaded, load next one: \" + nextFrag.sn);\n frag = nextFrag;\n } else {\n frag = null;\n }\n }\n }\n }\n\n return frag;\n };\n\n _proto.synchronizeToLiveEdge = function synchronizeToLiveEdge(levelDetails) {\n var config = this.config,\n media = this.media;\n\n if (!media) {\n return;\n }\n\n var liveSyncPosition = this.hls.liveSyncPosition;\n var currentTime = media.currentTime;\n var start = levelDetails.fragments[0].start;\n var end = levelDetails.edge;\n var withinSlidingWindow = currentTime >= start - config.maxFragLookUpTolerance && currentTime <= end; // Continue if we can seek forward to sync position or if current time is outside of sliding window\n\n if (liveSyncPosition !== null && media.duration > liveSyncPosition && (currentTime < liveSyncPosition || !withinSlidingWindow)) {\n // Continue if buffer is starving or if current time is behind max latency\n var maxLatency = config.liveMaxLatencyDuration !== undefined ? config.liveMaxLatencyDuration : config.liveMaxLatencyDurationCount * levelDetails.targetduration;\n\n if (!withinSlidingWindow && media.readyState < 4 || currentTime < end - maxLatency) {\n if (!this.loadedmetadata) {\n this.nextLoadPosition = liveSyncPosition;\n } // Only seek if ready and there is not a significant forward buffer available for playback\n\n\n if (media.readyState) {\n this.warn(\"Playback: \" + currentTime.toFixed(3) + \" is located too far from the end of live sliding playlist: \" + end + \", reset currentTime to : \" + liveSyncPosition.toFixed(3));\n media.currentTime = liveSyncPosition;\n }\n }\n }\n };\n\n _proto.alignPlaylists = function alignPlaylists(details, previousDetails) {\n var levels = this.levels,\n levelLastLoaded = this.levelLastLoaded,\n fragPrevious = this.fragPrevious;\n var lastLevel = levelLastLoaded !== null ? levels[levelLastLoaded] : null; // FIXME: If not for `shouldAlignOnDiscontinuities` requiring fragPrevious.cc,\n // this could all go in level-helper mergeDetails()\n\n var length = details.fragments.length;\n\n if (!length) {\n this.warn(\"No fragments in live playlist\");\n return 0;\n }\n\n var slidingStart = details.fragments[0].start;\n var firstLevelLoad = !previousDetails;\n\n var aligned = details.alignedSliding && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(slidingStart);\n\n if (firstLevelLoad || !aligned && !slidingStart) {\n Object(_utils_discontinuities__WEBPACK_IMPORTED_MODULE_9__[\"alignStream\"])(fragPrevious, lastLevel, details);\n var alignedSlidingStart = details.fragments[0].start;\n this.log(\"Live playlist sliding: \" + alignedSlidingStart.toFixed(2) + \" start-sn: \" + (previousDetails ? previousDetails.startSN : 'na') + \"->\" + details.startSN + \" prev-sn: \" + (fragPrevious ? fragPrevious.sn : 'na') + \" fragments: \" + length);\n return alignedSlidingStart;\n }\n\n return slidingStart;\n };\n\n _proto.waitForCdnTuneIn = function waitForCdnTuneIn(details) {\n // Wait for Low-Latency CDN Tune-in to get an updated playlist\n var advancePartLimit = 3;\n return details.live && details.canBlockReload && details.partTarget && details.tuneInGoal > Math.max(details.partHoldBack, details.partTarget * advancePartLimit);\n };\n\n _proto.setStartPosition = function setStartPosition(details, sliding) {\n // compute start position if set to -1. use it straight away if value is defined\n var startPosition = this.startPosition;\n\n if (startPosition < sliding) {\n startPosition = -1;\n }\n\n if (startPosition === -1 || this.lastCurrentTime === -1) {\n // first, check if start time offset has been set in playlist, if yes, use this value\n var startTimeOffset = details.startTimeOffset;\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(startTimeOffset)) {\n startPosition = sliding + startTimeOffset;\n\n if (startTimeOffset < 0) {\n startPosition += details.totalduration;\n }\n\n startPosition = Math.min(Math.max(sliding, startPosition), sliding + details.totalduration);\n this.log(\"Start time offset \" + startTimeOffset + \" found in playlist, adjust startPosition to \" + startPosition);\n this.startPosition = startPosition;\n } else if (details.live) {\n // Leave this.startPosition at -1, so that we can use `getInitialLiveFragment` logic when startPosition has\n // not been specified via the config or an as an argument to startLoad (#3736).\n startPosition = this.hls.liveSyncPosition || sliding;\n } else {\n this.startPosition = startPosition = 0;\n }\n\n this.lastCurrentTime = startPosition;\n }\n\n this.nextLoadPosition = startPosition;\n };\n\n _proto.getLoadPosition = function getLoadPosition() {\n var media = this.media; // if we have not yet loaded any fragment, start loading from start position\n\n var pos = 0;\n\n if (this.loadedmetadata && media) {\n pos = media.currentTime;\n } else if (this.nextLoadPosition) {\n pos = this.nextLoadPosition;\n }\n\n return pos;\n };\n\n _proto.handleFragLoadAborted = function handleFragLoadAborted(frag, part) {\n if (this.transmuxer && frag.sn !== 'initSegment' && frag.stats.aborted) {\n this.warn(\"Fragment \" + frag.sn + (part ? ' part' + part.index : '') + \" of level \" + frag.level + \" was aborted\");\n this.resetFragmentLoading(frag);\n }\n };\n\n _proto.resetFragmentLoading = function resetFragmentLoading(frag) {\n if (!this.fragCurrent || !this.fragContextChanged(frag) && this.state !== State.FRAG_LOADING_WAITING_RETRY) {\n this.state = State.IDLE;\n }\n };\n\n _proto.onFragmentOrKeyLoadError = function onFragmentOrKeyLoadError(filterType, data) {\n if (data.fatal) {\n return;\n }\n\n var frag = data.frag; // Handle frag error related to caller's filterType\n\n if (!frag || frag.type !== filterType) {\n return;\n }\n\n var fragCurrent = this.fragCurrent;\n console.assert(fragCurrent && frag.sn === fragCurrent.sn && frag.level === fragCurrent.level && frag.urlId === fragCurrent.urlId, 'Frag load error must match current frag to retry');\n var config = this.config; // keep retrying until the limit will be reached\n\n if (this.fragLoadError + 1 <= config.fragLoadingMaxRetry) {\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n } // exponential backoff capped to config.fragLoadingMaxRetryTimeout\n\n\n var delay = Math.min(Math.pow(2, this.fragLoadError) * config.fragLoadingRetryDelay, config.fragLoadingMaxRetryTimeout);\n this.warn(\"Fragment \" + frag.sn + \" of \" + filterType + \" \" + frag.level + \" failed to load, retrying in \" + delay + \"ms\");\n this.retryDate = self.performance.now() + delay;\n this.fragLoadError++;\n this.state = State.FRAG_LOADING_WAITING_RETRY;\n } else if (data.levelRetry) {\n if (filterType === _types_loader__WEBPACK_IMPORTED_MODULE_15__[\"PlaylistLevelType\"].AUDIO) {\n // Reset current fragment since audio track audio is essential and may not have a fail-over track\n this.fragCurrent = null;\n } // Fragment errors that result in a level switch or redundant fail-over\n // should reset the stream controller state to idle\n\n\n this.fragLoadError = 0;\n this.state = State.IDLE;\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].error(data.details + \" reaches max retry, redispatch as fatal ...\"); // switch error to fatal\n\n data.fatal = true;\n this.hls.stopLoad();\n this.state = State.ERROR;\n }\n };\n\n _proto.afterBufferFlushed = function afterBufferFlushed(media, bufferType, playlistType) {\n if (!media) {\n return;\n } // After successful buffer flushing, filter flushed fragments from bufferedFrags use mediaBuffered instead of media\n // (so that we will check against video.buffered ranges in case of alt audio track)\n\n\n var bufferedTimeRanges = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__[\"BufferHelper\"].getBuffered(media);\n this.fragmentTracker.detectEvictedFragments(bufferType, bufferedTimeRanges, playlistType);\n\n if (this.state === State.ENDED) {\n this.resetLoadingState();\n }\n };\n\n _proto.resetLoadingState = function resetLoadingState() {\n this.fragCurrent = null;\n this.fragPrevious = null;\n this.state = State.IDLE;\n };\n\n _proto.resetStartWhenNotLoaded = function resetStartWhenNotLoaded(level) {\n // if loadedmetadata is not set, it means that first frag request failed\n // in that case, reset startFragRequested flag\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n var details = this.levels ? this.levels[level].details : null;\n\n if (details !== null && details !== void 0 && details.live) {\n // Update the start position and return to IDLE to recover live start\n this.startPosition = -1;\n this.setStartPosition(details, 0);\n this.resetLoadingState();\n } else {\n this.nextLoadPosition = this.startPosition;\n }\n }\n };\n\n _proto.updateLevelTiming = function updateLevelTiming(frag, part, level, partial) {\n var _this6 = this;\n\n var details = level.details;\n console.assert(!!details, 'level.details must be defined');\n var parsed = Object.keys(frag.elementaryStreams).reduce(function (result, type) {\n var info = frag.elementaryStreams[type];\n\n if (info) {\n var parsedDuration = info.endPTS - info.startPTS;\n\n if (parsedDuration <= 0) {\n // Destroy the transmuxer after it's next time offset failed to advance because duration was <= 0.\n // The new transmuxer will be configured with a time offset matching the next fragment start,\n // preventing the timeline from shifting.\n _this6.warn(\"Could not parse fragment \" + frag.sn + \" \" + type + \" duration reliably (\" + parsedDuration + \")\");\n\n return result || false;\n }\n\n var drift = partial ? 0 : Object(_level_helper__WEBPACK_IMPORTED_MODULE_11__[\"updateFragPTSDTS\"])(details, frag, info.startPTS, info.endPTS, info.startDTS, info.endDTS);\n\n _this6.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].LEVEL_PTS_UPDATED, {\n details: details,\n level: level,\n drift: drift,\n type: type,\n frag: frag,\n start: info.startPTS,\n end: info.endPTS\n });\n\n return true;\n }\n\n return result;\n }, false);\n\n if (!parsed) {\n this.warn(\"Found no media in fragment \" + frag.sn + \" of level \" + level.id + \" resetting transmuxer to fallback to playlist timing\");\n this.resetTransmuxer();\n }\n\n this.state = State.PARSED;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_5__[\"Events\"].FRAG_PARSED, {\n frag: frag,\n part: part\n });\n };\n\n _proto.resetTransmuxer = function resetTransmuxer() {\n if (this.transmuxer) {\n this.transmuxer.destroy();\n this.transmuxer = null;\n }\n };\n\n _createClass(BaseStreamController, [{\n key: \"state\",\n get: function get() {\n return this._state;\n },\n set: function set(nextState) {\n var previousState = this._state;\n\n if (previousState !== nextState) {\n this._state = nextState;\n this.log(previousState + \"->\" + nextState);\n }\n }\n }]);\n\n return BaseStreamController;\n}(_task_loop__WEBPACK_IMPORTED_MODULE_1__[\"default\"]);\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/buffer-controller.ts\":\n/*!*********************************************!*\\\n !*** ./src/controller/buffer-controller.ts ***!\n \\*********************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BufferController; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/mediasource-helper */ \"./src/utils/mediasource-helper.ts\");\n/* harmony import */ var _loader_fragment__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../loader/fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _buffer_operation_queue__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./buffer-operation-queue */ \"./src/controller/buffer-operation-queue.ts\");\n\n\n\n\n\n\n\n\n\n\n\n\nvar MediaSource = Object(_utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_5__[\"getMediaSource\"])();\nvar VIDEO_CODEC_PROFILE_REPACE = /([ha]vc.)(?:\\.[^.,]+)+/;\n\nvar BufferController = /*#__PURE__*/function () {\n // The level details used to determine duration, target-duration and live\n // cache the self generated object url to detect hijack of video tag\n // A queue of buffer operations which require the SourceBuffer to not be updating upon execution\n // References to event listeners for each SourceBuffer, so that they can be referenced for event removal\n // The number of BUFFER_CODEC events received before any sourceBuffers are created\n // The total number of BUFFER_CODEC events received\n // A reference to the attached media element\n // A reference to the active media source\n // counters\n function BufferController(_hls) {\n var _this = this;\n\n this.details = null;\n this._objectUrl = null;\n this.operationQueue = void 0;\n this.listeners = void 0;\n this.hls = void 0;\n this.bufferCodecEventsExpected = 0;\n this._bufferCodecEventsTotal = 0;\n this.media = null;\n this.mediaSource = null;\n this.appendError = 0;\n this.tracks = {};\n this.pendingTracks = {};\n this.sourceBuffer = void 0;\n\n this._onMediaSourceOpen = function () {\n var hls = _this.hls,\n media = _this.media,\n mediaSource = _this.mediaSource;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: Media source opened');\n\n if (media) {\n _this.updateMediaElementDuration();\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHED, {\n media: media\n });\n }\n\n if (mediaSource) {\n // once received, don't listen anymore to sourceopen event\n mediaSource.removeEventListener('sourceopen', _this._onMediaSourceOpen);\n }\n\n _this.checkPendingTracks();\n };\n\n this._onMediaSourceClose = function () {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: Media source closed');\n };\n\n this._onMediaSourceEnded = function () {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: Media source ended');\n };\n\n this.hls = _hls;\n\n this._initSourceBuffer();\n\n this.registerListeners();\n }\n\n var _proto = BufferController.prototype;\n\n _proto.hasSourceTypes = function hasSourceTypes() {\n return this.getSourceBufferTypes().length > 0 || Object.keys(this.pendingTracks).length > 0;\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.details = null;\n };\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_RESET, this.onBufferReset, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_APPENDING, this.onBufferAppending, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_CODECS, this.onBufferCodecs, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_EOS, this.onBufferEos, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSED, this.onFragParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_CHANGED, this.onFragChanged, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_RESET, this.onBufferReset, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_APPENDING, this.onBufferAppending, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_CODECS, this.onBufferCodecs, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_EOS, this.onBufferEos, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSED, this.onFragParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_CHANGED, this.onFragChanged, this);\n };\n\n _proto._initSourceBuffer = function _initSourceBuffer() {\n this.sourceBuffer = {};\n this.operationQueue = new _buffer_operation_queue__WEBPACK_IMPORTED_MODULE_7__[\"default\"](this.sourceBuffer);\n this.listeners = {\n audio: [],\n video: [],\n audiovideo: []\n };\n };\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n // in case of alt audio 2 BUFFER_CODECS events will be triggered, one per stream controller\n // sourcebuffers will be created all at once when the expected nb of tracks will be reached\n // in case alt audio is not used, only one BUFFER_CODEC event will be fired from main stream controller\n // it will contain the expected nb of source buffers, no need to compute it\n var codecEvents = 2;\n\n if (data.audio && !data.video || !data.altAudio) {\n codecEvents = 1;\n }\n\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal = codecEvents;\n this.details = null;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(this.bufferCodecEventsExpected + \" bufferCodec event(s) expected\");\n };\n\n _proto.onMediaAttaching = function onMediaAttaching(event, data) {\n var media = this.media = data.media;\n\n if (media && MediaSource) {\n var ms = this.mediaSource = new MediaSource(); // MediaSource listeners are arrow functions with a lexical scope, and do not need to be bound\n\n ms.addEventListener('sourceopen', this._onMediaSourceOpen);\n ms.addEventListener('sourceended', this._onMediaSourceEnded);\n ms.addEventListener('sourceclose', this._onMediaSourceClose); // link video and media Source\n\n media.src = self.URL.createObjectURL(ms); // cache the locally generated object url\n\n this._objectUrl = media.src;\n }\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n var media = this.media,\n mediaSource = this.mediaSource,\n _objectUrl = this._objectUrl;\n\n if (mediaSource) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: media source detaching');\n\n if (mediaSource.readyState === 'open') {\n try {\n // endOfStream could trigger exception if any sourcebuffer is in updating state\n // we don't really care about checking sourcebuffer state here,\n // as we are anyway detaching the MediaSource\n // let's just avoid this exception to propagate\n mediaSource.endOfStream();\n } catch (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: onMediaDetaching: \" + err.message + \" while calling endOfStream\");\n }\n } // Clean up the SourceBuffers by invoking onBufferReset\n\n\n this.onBufferReset();\n mediaSource.removeEventListener('sourceopen', this._onMediaSourceOpen);\n mediaSource.removeEventListener('sourceended', this._onMediaSourceEnded);\n mediaSource.removeEventListener('sourceclose', this._onMediaSourceClose); // Detach properly the MediaSource from the HTMLMediaElement as\n // suggested in https://github.com/w3c/media-source/issues/53.\n\n if (media) {\n if (_objectUrl) {\n self.URL.revokeObjectURL(_objectUrl);\n } // clean up video tag src only if it's our own url. some external libraries might\n // hijack the video tag and change its 'src' without destroying the Hls instance first\n\n\n if (media.src === _objectUrl) {\n media.removeAttribute('src');\n media.load();\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('[buffer-controller]: media.src was changed by a third party - skip cleanup');\n }\n }\n\n this.mediaSource = null;\n this.media = null;\n this._objectUrl = null;\n this.bufferCodecEventsExpected = this._bufferCodecEventsTotal;\n this.pendingTracks = {};\n this.tracks = {};\n }\n\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHED, undefined);\n };\n\n _proto.onBufferReset = function onBufferReset() {\n var _this2 = this;\n\n this.getSourceBufferTypes().forEach(function (type) {\n var sb = _this2.sourceBuffer[type];\n\n try {\n if (sb) {\n _this2.removeBufferListeners(type);\n\n if (_this2.mediaSource) {\n _this2.mediaSource.removeSourceBuffer(sb);\n } // Synchronously remove the SB from the map before the next call in order to prevent an async function from\n // accessing it\n\n\n _this2.sourceBuffer[type] = undefined;\n }\n } catch (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: Failed to reset the \" + type + \" buffer\", err);\n }\n });\n\n this._initSourceBuffer();\n };\n\n _proto.onBufferCodecs = function onBufferCodecs(event, data) {\n var _this3 = this;\n\n var sourceBufferCount = this.getSourceBufferTypes().length;\n Object.keys(data).forEach(function (trackName) {\n if (sourceBufferCount) {\n // check if SourceBuffer codec needs to change\n var track = _this3.tracks[trackName];\n\n if (track && typeof track.buffer.changeType === 'function') {\n var _data$trackName = data[trackName],\n id = _data$trackName.id,\n codec = _data$trackName.codec,\n levelCodec = _data$trackName.levelCodec,\n container = _data$trackName.container,\n metadata = _data$trackName.metadata;\n var currentCodec = (track.levelCodec || track.codec).replace(VIDEO_CODEC_PROFILE_REPACE, '$1');\n var nextCodec = (levelCodec || codec).replace(VIDEO_CODEC_PROFILE_REPACE, '$1');\n\n if (currentCodec !== nextCodec) {\n var mimeType = container + \";codecs=\" + (levelCodec || codec);\n\n _this3.appendChangeType(trackName, mimeType);\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: switching codec \" + currentCodec + \" to \" + nextCodec);\n _this3.tracks[trackName] = {\n buffer: track.buffer,\n codec: codec,\n container: container,\n levelCodec: levelCodec,\n metadata: metadata,\n id: id\n };\n }\n }\n } else {\n // if source buffer(s) not created yet, appended buffer tracks in this.pendingTracks\n _this3.pendingTracks[trackName] = data[trackName];\n }\n }); // if sourcebuffers already created, do nothing ...\n\n if (sourceBufferCount) {\n return;\n }\n\n this.bufferCodecEventsExpected = Math.max(this.bufferCodecEventsExpected - 1, 0);\n\n if (this.mediaSource && this.mediaSource.readyState === 'open') {\n this.checkPendingTracks();\n }\n };\n\n _proto.appendChangeType = function appendChangeType(type, mimeType) {\n var _this4 = this;\n\n var operationQueue = this.operationQueue;\n var operation = {\n execute: function execute() {\n var sb = _this4.sourceBuffer[type];\n\n if (sb) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: changing \" + type + \" sourceBuffer type to \" + mimeType);\n sb.changeType(mimeType);\n }\n\n operationQueue.shiftAndExecuteNext(type);\n },\n onStart: function onStart() {},\n onComplete: function onComplete() {},\n onError: function onError(e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: Failed to change \" + type + \" SourceBuffer type\", e);\n }\n };\n operationQueue.append(operation, type);\n };\n\n _proto.onBufferAppending = function onBufferAppending(event, eventData) {\n var _this5 = this;\n\n var hls = this.hls,\n operationQueue = this.operationQueue,\n tracks = this.tracks;\n var data = eventData.data,\n type = eventData.type,\n frag = eventData.frag,\n part = eventData.part,\n chunkMeta = eventData.chunkMeta;\n var chunkStats = chunkMeta.buffering[type];\n var bufferAppendingStart = self.performance.now();\n chunkStats.start = bufferAppendingStart;\n var fragBuffering = frag.stats.buffering;\n var partBuffering = part ? part.stats.buffering : null;\n\n if (fragBuffering.start === 0) {\n fragBuffering.start = bufferAppendingStart;\n }\n\n if (partBuffering && partBuffering.start === 0) {\n partBuffering.start = bufferAppendingStart;\n } // TODO: Only update timestampOffset when audio/mpeg fragment or part is not contiguous with previously appended\n // Adjusting `SourceBuffer.timestampOffset` (desired point in the timeline where the next frames should be appended)\n // in Chrome browser when we detect MPEG audio container and time delta between level PTS and `SourceBuffer.timestampOffset`\n // is greater than 100ms (this is enough to handle seek for VOD or level change for LIVE videos).\n // More info here: https://github.com/video-dev/hls.js/issues/332#issuecomment-257986486\n\n\n var audioTrack = tracks.audio;\n var checkTimestampOffset = type === 'audio' && chunkMeta.id === 1 && (audioTrack === null || audioTrack === void 0 ? void 0 : audioTrack.container) === 'audio/mpeg';\n var operation = {\n execute: function execute() {\n chunkStats.executeStart = self.performance.now();\n\n if (checkTimestampOffset) {\n var sb = _this5.sourceBuffer[type];\n\n if (sb) {\n var delta = frag.start - sb.timestampOffset;\n\n if (Math.abs(delta) >= 0.1) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: Updating audio SourceBuffer timestampOffset to \" + frag.start + \" (delta: \" + delta + \") sn: \" + frag.sn + \")\");\n sb.timestampOffset = frag.start;\n }\n }\n }\n\n _this5.appendExecutor(data, type);\n },\n onStart: function onStart() {// logger.debug(`[buffer-controller]: ${type} SourceBuffer updatestart`);\n },\n onComplete: function onComplete() {\n // logger.debug(`[buffer-controller]: ${type} SourceBuffer updateend`);\n var end = self.performance.now();\n chunkStats.executeEnd = chunkStats.end = end;\n\n if (fragBuffering.first === 0) {\n fragBuffering.first = end;\n }\n\n if (partBuffering && partBuffering.first === 0) {\n partBuffering.first = end;\n }\n\n var sourceBuffer = _this5.sourceBuffer;\n var timeRanges = {};\n\n for (var _type in sourceBuffer) {\n timeRanges[_type] = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].getBuffered(sourceBuffer[_type]);\n }\n\n _this5.appendError = 0;\n\n _this5.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_APPENDED, {\n type: type,\n frag: frag,\n part: part,\n chunkMeta: chunkMeta,\n parent: frag.type,\n timeRanges: timeRanges\n });\n },\n onError: function onError(err) {\n // in case any error occured while appending, put back segment in segments table\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"[buffer-controller]: Error encountered while trying to append to the \" + type + \" SourceBuffer\", err);\n var event = {\n type: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorTypes\"].MEDIA_ERROR,\n parent: frag.type,\n details: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_APPEND_ERROR,\n err: err,\n fatal: false\n };\n\n if (err.code === DOMException.QUOTA_EXCEEDED_ERR) {\n // QuotaExceededError: http://www.w3.org/TR/html5/infrastructure.html#quotaexceedederror\n // let's stop appending any segments, and report BUFFER_FULL_ERROR error\n event.details = _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_FULL_ERROR;\n } else {\n _this5.appendError++;\n event.details = _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_APPEND_ERROR;\n /* with UHD content, we could get loop of quota exceeded error until\n browser is able to evict some data from sourcebuffer. Retrying can help recover.\n */\n\n if (_this5.appendError > hls.config.appendErrorMaxRetry) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"[buffer-controller]: Failed \" + hls.config.appendErrorMaxRetry + \" times to append segment in sourceBuffer\");\n event.fatal = true;\n hls.stopLoad();\n }\n }\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, event);\n }\n };\n operationQueue.append(operation, type);\n };\n\n _proto.onBufferFlushing = function onBufferFlushing(event, data) {\n var _this6 = this;\n\n var operationQueue = this.operationQueue;\n\n var flushOperation = function flushOperation(type) {\n return {\n execute: _this6.removeExecutor.bind(_this6, type, data.startOffset, data.endOffset),\n onStart: function onStart() {// logger.debug(`[buffer-controller]: Started flushing ${data.startOffset} -> ${data.endOffset} for ${type} Source Buffer`);\n },\n onComplete: function onComplete() {\n // logger.debug(`[buffer-controller]: Finished flushing ${data.startOffset} -> ${data.endOffset} for ${type} Source Buffer`);\n _this6.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHED, {\n type: type\n });\n },\n onError: function onError(e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: Failed to remove from \" + type + \" SourceBuffer\", e);\n }\n };\n };\n\n if (data.type) {\n operationQueue.append(flushOperation(data.type), data.type);\n } else {\n this.getSourceBufferTypes().forEach(function (type) {\n operationQueue.append(flushOperation(type), type);\n });\n }\n };\n\n _proto.onFragParsed = function onFragParsed(event, data) {\n var _this7 = this;\n\n var frag = data.frag,\n part = data.part;\n var buffersAppendedTo = [];\n var elementaryStreams = part ? part.elementaryStreams : frag.elementaryStreams;\n\n if (elementaryStreams[_loader_fragment__WEBPACK_IMPORTED_MODULE_6__[\"ElementaryStreamTypes\"].AUDIOVIDEO]) {\n buffersAppendedTo.push('audiovideo');\n } else {\n if (elementaryStreams[_loader_fragment__WEBPACK_IMPORTED_MODULE_6__[\"ElementaryStreamTypes\"].AUDIO]) {\n buffersAppendedTo.push('audio');\n }\n\n if (elementaryStreams[_loader_fragment__WEBPACK_IMPORTED_MODULE_6__[\"ElementaryStreamTypes\"].VIDEO]) {\n buffersAppendedTo.push('video');\n }\n }\n\n var onUnblocked = function onUnblocked() {\n var now = self.performance.now();\n frag.stats.buffering.end = now;\n\n if (part) {\n part.stats.buffering.end = now;\n }\n\n var stats = part ? part.stats : frag.stats;\n\n _this7.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_BUFFERED, {\n frag: frag,\n part: part,\n stats: stats,\n id: frag.type\n });\n };\n\n if (buffersAppendedTo.length === 0) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"Fragments must have at least one ElementaryStreamType set. type: \" + frag.type + \" level: \" + frag.level + \" sn: \" + frag.sn);\n }\n\n this.blockBuffers(onUnblocked, buffersAppendedTo);\n };\n\n _proto.onFragChanged = function onFragChanged(event, data) {\n this.flushBackBuffer();\n } // on BUFFER_EOS mark matching sourcebuffer(s) as ended and trigger checkEos()\n // an undefined data.type will mark all buffers as EOS.\n ;\n\n _proto.onBufferEos = function onBufferEos(event, data) {\n var _this8 = this;\n\n var ended = this.getSourceBufferTypes().reduce(function (acc, type) {\n var sb = _this8.sourceBuffer[type];\n\n if (!data.type || data.type === type) {\n if (sb && !sb.ended) {\n sb.ended = true;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: \" + type + \" sourceBuffer now EOS\");\n }\n }\n\n return acc && !!(!sb || sb.ended);\n }, true);\n\n if (ended) {\n this.blockBuffers(function () {\n var mediaSource = _this8.mediaSource;\n\n if (!mediaSource || mediaSource.readyState !== 'open') {\n return;\n } // Allow this to throw and be caught by the enqueueing function\n\n\n mediaSource.endOfStream();\n });\n }\n };\n\n _proto.onLevelUpdated = function onLevelUpdated(event, _ref) {\n var details = _ref.details;\n\n if (!details.fragments.length) {\n return;\n }\n\n this.details = details;\n\n if (this.getSourceBufferTypes().length) {\n this.blockBuffers(this.updateMediaElementDuration.bind(this));\n } else {\n this.updateMediaElementDuration();\n }\n };\n\n _proto.flushBackBuffer = function flushBackBuffer() {\n var hls = this.hls,\n details = this.details,\n media = this.media,\n sourceBuffer = this.sourceBuffer;\n\n if (!media || details === null) {\n return;\n }\n\n var sourceBufferTypes = this.getSourceBufferTypes();\n\n if (!sourceBufferTypes.length) {\n return;\n } // Support for deprecated liveBackBufferLength\n\n\n var backBufferLength = details.live && hls.config.liveBackBufferLength !== null ? hls.config.liveBackBufferLength : hls.config.backBufferLength;\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(backBufferLength) || backBufferLength < 0) {\n return;\n }\n\n var currentTime = media.currentTime;\n var targetDuration = details.levelTargetDuration;\n var maxBackBufferLength = Math.max(backBufferLength, targetDuration);\n var targetBackBufferPosition = Math.floor(currentTime / targetDuration) * targetDuration - maxBackBufferLength;\n sourceBufferTypes.forEach(function (type) {\n var sb = sourceBuffer[type];\n\n if (sb) {\n var buffered = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].getBuffered(sb); // when target buffer start exceeds actual buffer start\n\n if (buffered.length > 0 && targetBackBufferPosition > buffered.start(0)) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BACK_BUFFER_REACHED, {\n bufferEnd: targetBackBufferPosition\n }); // Support for deprecated event:\n\n if (details.live) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LIVE_BACK_BUFFER_REACHED, {\n bufferEnd: targetBackBufferPosition\n });\n }\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, {\n startOffset: 0,\n endOffset: targetBackBufferPosition,\n type: type\n });\n }\n }\n });\n }\n /**\n * Update Media Source duration to current level duration or override to Infinity if configuration parameter\n * 'liveDurationInfinity` is set to `true`\n * More details: https://github.com/video-dev/hls.js/issues/355\n */\n ;\n\n _proto.updateMediaElementDuration = function updateMediaElementDuration() {\n if (!this.details || !this.media || !this.mediaSource || this.mediaSource.readyState !== 'open') {\n return;\n }\n\n var details = this.details,\n hls = this.hls,\n media = this.media,\n mediaSource = this.mediaSource;\n var levelDuration = details.fragments[0].start + details.totalduration;\n var mediaDuration = media.duration;\n var msDuration = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(mediaSource.duration) ? mediaSource.duration : 0;\n\n if (details.live && hls.config.liveDurationInfinity) {\n // Override duration to Infinity\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: Media Source duration is set to Infinity');\n mediaSource.duration = Infinity;\n this.updateSeekableRange(details);\n } else if (levelDuration > msDuration && levelDuration > mediaDuration || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(mediaDuration)) {\n // levelDuration was the last value we set.\n // not using mediaSource.duration as the browser may tweak this value\n // only update Media Source duration if its value increase, this is to avoid\n // flushing already buffered portion when switching between quality level\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: Updating Media Source duration to \" + levelDuration.toFixed(3));\n mediaSource.duration = levelDuration;\n }\n };\n\n _proto.updateSeekableRange = function updateSeekableRange(levelDetails) {\n var mediaSource = this.mediaSource;\n var fragments = levelDetails.fragments;\n var len = fragments.length;\n\n if (len && levelDetails.live && mediaSource !== null && mediaSource !== void 0 && mediaSource.setLiveSeekableRange) {\n var start = Math.max(0, fragments[0].start);\n var end = Math.max(start, start + levelDetails.totalduration);\n mediaSource.setLiveSeekableRange(start, end);\n }\n };\n\n _proto.checkPendingTracks = function checkPendingTracks() {\n var bufferCodecEventsExpected = this.bufferCodecEventsExpected,\n operationQueue = this.operationQueue,\n pendingTracks = this.pendingTracks; // Check if we've received all of the expected bufferCodec events. When none remain, create all the sourceBuffers at once.\n // This is important because the MSE spec allows implementations to throw QuotaExceededErrors if creating new sourceBuffers after\n // data has been appended to existing ones.\n // 2 tracks is the max (one for audio, one for video). If we've reach this max go ahead and create the buffers.\n\n var pendingTracksCount = Object.keys(pendingTracks).length;\n\n if (pendingTracksCount && !bufferCodecEventsExpected || pendingTracksCount === 2) {\n // ok, let's create them now !\n this.createSourceBuffers(pendingTracks);\n this.pendingTracks = {}; // append any pending segments now !\n\n var buffers = this.getSourceBufferTypes();\n\n if (buffers.length === 0) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_INCOMPATIBLE_CODECS_ERROR,\n fatal: true,\n reason: 'could not create source buffer for media codec(s)'\n });\n return;\n }\n\n buffers.forEach(function (type) {\n operationQueue.executeNext(type);\n });\n }\n };\n\n _proto.createSourceBuffers = function createSourceBuffers(tracks) {\n var sourceBuffer = this.sourceBuffer,\n mediaSource = this.mediaSource;\n\n if (!mediaSource) {\n throw Error('createSourceBuffers called when mediaSource was null');\n }\n\n var tracksCreated = 0;\n\n for (var trackName in tracks) {\n if (!sourceBuffer[trackName]) {\n var track = tracks[trackName];\n\n if (!track) {\n throw Error(\"source buffer exists for track \" + trackName + \", however track does not\");\n } // use levelCodec as first priority\n\n\n var codec = track.levelCodec || track.codec;\n var mimeType = track.container + \";codecs=\" + codec;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: creating sourceBuffer(\" + mimeType + \")\");\n\n try {\n var sb = sourceBuffer[trackName] = mediaSource.addSourceBuffer(mimeType);\n var sbName = trackName;\n this.addBufferListener(sbName, 'updatestart', this._onSBUpdateStart);\n this.addBufferListener(sbName, 'updateend', this._onSBUpdateEnd);\n this.addBufferListener(sbName, 'error', this._onSBUpdateError);\n this.tracks[trackName] = {\n buffer: sb,\n codec: codec,\n container: track.container,\n levelCodec: track.levelCodec,\n metadata: track.metadata,\n id: track.id\n };\n tracksCreated++;\n } catch (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"[buffer-controller]: error while trying to add sourceBuffer: \" + err.message);\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_ADD_CODEC_ERROR,\n fatal: false,\n error: err,\n mimeType: mimeType\n });\n }\n }\n }\n\n if (tracksCreated) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_CREATED, {\n tracks: this.tracks\n });\n }\n } // Keep as arrow functions so that we can directly reference these functions directly as event listeners\n ;\n\n _proto._onSBUpdateStart = function _onSBUpdateStart(type) {\n var operationQueue = this.operationQueue;\n var operation = operationQueue.current(type);\n operation.onStart();\n };\n\n _proto._onSBUpdateEnd = function _onSBUpdateEnd(type) {\n var operationQueue = this.operationQueue;\n var operation = operationQueue.current(type);\n operation.onComplete();\n operationQueue.shiftAndExecuteNext(type);\n };\n\n _proto._onSBUpdateError = function _onSBUpdateError(type, event) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"[buffer-controller]: \" + type + \" SourceBuffer error\", event); // according to http://www.w3.org/TR/media-source/#sourcebuffer-append-error\n // SourceBuffer errors are not necessarily fatal; if so, the HTMLMediaElement will fire an error event\n\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_3__[\"ErrorDetails\"].BUFFER_APPENDING_ERROR,\n fatal: false\n }); // updateend is always fired after error, so we'll allow that to shift the current operation off of the queue\n\n var operation = this.operationQueue.current(type);\n\n if (operation) {\n operation.onError(event);\n }\n } // This method must result in an updateend event; if remove is not called, _onSBUpdateEnd must be called manually\n ;\n\n _proto.removeExecutor = function removeExecutor(type, startOffset, endOffset) {\n var media = this.media,\n mediaSource = this.mediaSource,\n operationQueue = this.operationQueue,\n sourceBuffer = this.sourceBuffer;\n var sb = sourceBuffer[type];\n\n if (!media || !mediaSource || !sb) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: Attempting to remove from the \" + type + \" SourceBuffer, but it does not exist\");\n operationQueue.shiftAndExecuteNext(type);\n return;\n }\n\n var mediaDuration = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(media.duration) ? media.duration : Infinity;\n var msDuration = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(mediaSource.duration) ? mediaSource.duration : Infinity;\n var removeStart = Math.max(0, startOffset);\n var removeEnd = Math.min(endOffset, mediaDuration, msDuration);\n\n if (removeEnd > removeStart) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"[buffer-controller]: Removing [\" + removeStart + \",\" + removeEnd + \"] from the \" + type + \" SourceBuffer\");\n console.assert(!sb.updating, type + \" sourceBuffer must not be updating\");\n sb.remove(removeStart, removeEnd);\n } else {\n // Cycle the queue\n operationQueue.shiftAndExecuteNext(type);\n }\n } // This method must result in an updateend event; if append is not called, _onSBUpdateEnd must be called manually\n ;\n\n _proto.appendExecutor = function appendExecutor(data, type) {\n var operationQueue = this.operationQueue,\n sourceBuffer = this.sourceBuffer;\n var sb = sourceBuffer[type];\n\n if (!sb) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"[buffer-controller]: Attempting to append to the \" + type + \" SourceBuffer, but it does not exist\");\n operationQueue.shiftAndExecuteNext(type);\n return;\n }\n\n sb.ended = false;\n console.assert(!sb.updating, type + \" sourceBuffer must not be updating\");\n sb.appendBuffer(data);\n } // Enqueues an operation to each SourceBuffer queue which, upon execution, resolves a promise. When all promises\n // resolve, the onUnblocked function is executed. Functions calling this method do not need to unblock the queue\n // upon completion, since we already do it here\n ;\n\n _proto.blockBuffers = function blockBuffers(onUnblocked, buffers) {\n var _this9 = this;\n\n if (buffers === void 0) {\n buffers = this.getSourceBufferTypes();\n }\n\n if (!buffers.length) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('[buffer-controller]: Blocking operation requested, but no SourceBuffers exist');\n Promise.resolve().then(onUnblocked);\n return;\n }\n\n var operationQueue = this.operationQueue; // logger.debug(`[buffer-controller]: Blocking ${buffers} SourceBuffer`);\n\n var blockingOperations = buffers.map(function (type) {\n return operationQueue.appendBlocker(type);\n });\n Promise.all(blockingOperations).then(function () {\n // logger.debug(`[buffer-controller]: Blocking operation resolved; unblocking ${buffers} SourceBuffer`);\n onUnblocked();\n buffers.forEach(function (type) {\n var sb = _this9.sourceBuffer[type]; // Only cycle the queue if the SB is not updating. There's a bug in Chrome which sets the SB updating flag to\n // true when changing the MediaSource duration (https://bugs.chromium.org/p/chromium/issues/detail?id=959359&can=2&q=mediasource%20duration)\n // While this is a workaround, it's probably useful to have around\n\n if (!sb || !sb.updating) {\n operationQueue.shiftAndExecuteNext(type);\n }\n });\n });\n };\n\n _proto.getSourceBufferTypes = function getSourceBufferTypes() {\n return Object.keys(this.sourceBuffer);\n };\n\n _proto.addBufferListener = function addBufferListener(type, event, fn) {\n var buffer = this.sourceBuffer[type];\n\n if (!buffer) {\n return;\n }\n\n var listener = fn.bind(this, type);\n this.listeners[type].push({\n event: event,\n listener: listener\n });\n buffer.addEventListener(event, listener);\n };\n\n _proto.removeBufferListeners = function removeBufferListeners(type) {\n var buffer = this.sourceBuffer[type];\n\n if (!buffer) {\n return;\n }\n\n this.listeners[type].forEach(function (l) {\n buffer.removeEventListener(l.event, l.listener);\n });\n };\n\n return BufferController;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/buffer-operation-queue.ts\":\n/*!**************************************************!*\\\n !*** ./src/controller/buffer-operation-queue.ts ***!\n \\**************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return BufferOperationQueue; });\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\nvar BufferOperationQueue = /*#__PURE__*/function () {\n function BufferOperationQueue(sourceBufferReference) {\n this.buffers = void 0;\n this.queues = {\n video: [],\n audio: [],\n audiovideo: []\n };\n this.buffers = sourceBufferReference;\n }\n\n var _proto = BufferOperationQueue.prototype;\n\n _proto.append = function append(operation, type) {\n var queue = this.queues[type];\n queue.push(operation);\n\n if (queue.length === 1 && this.buffers[type]) {\n this.executeNext(type);\n }\n };\n\n _proto.insertAbort = function insertAbort(operation, type) {\n var queue = this.queues[type];\n queue.unshift(operation);\n this.executeNext(type);\n };\n\n _proto.appendBlocker = function appendBlocker(type) {\n var execute;\n var promise = new Promise(function (resolve) {\n execute = resolve;\n });\n var operation = {\n execute: execute,\n onStart: function onStart() {},\n onComplete: function onComplete() {},\n onError: function onError() {}\n };\n this.append(operation, type);\n return promise;\n };\n\n _proto.executeNext = function executeNext(type) {\n var buffers = this.buffers,\n queues = this.queues;\n var sb = buffers[type];\n var queue = queues[type];\n\n if (queue.length) {\n var operation = queue[0];\n\n try {\n // Operations are expected to result in an 'updateend' event being fired. If not, the queue will lock. Operations\n // which do not end with this event must call _onSBUpdateEnd manually\n operation.execute();\n } catch (e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].warn('[buffer-operation-queue]: Unhandled exception executing the current operation');\n operation.onError(e); // Only shift the current operation off, otherwise the updateend handler will do this for us\n\n if (!sb || !sb.updating) {\n queue.shift();\n this.executeNext(type);\n }\n }\n }\n };\n\n _proto.shiftAndExecuteNext = function shiftAndExecuteNext(type) {\n this.queues[type].shift();\n this.executeNext(type);\n };\n\n _proto.current = function current(type) {\n return this.queues[type][0];\n };\n\n return BufferOperationQueue;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/cap-level-controller.ts\":\n/*!************************************************!*\\\n !*** ./src/controller/cap-level-controller.ts ***!\n \\************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n/*\n * cap stream level to media size dimension controller\n */\n\n\nvar CapLevelController = /*#__PURE__*/function () {\n function CapLevelController(hls) {\n this.autoLevelCapping = void 0;\n this.firstLevel = void 0;\n this.media = void 0;\n this.restrictedLevels = void 0;\n this.timer = void 0;\n this.hls = void 0;\n this.streamController = void 0;\n this.clientRect = void 0;\n this.hls = hls;\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.firstLevel = -1;\n this.media = null;\n this.restrictedLevels = [];\n this.timer = undefined;\n this.clientRect = null;\n this.registerListeners();\n }\n\n var _proto = CapLevelController.prototype;\n\n _proto.setStreamController = function setStreamController(streamController) {\n this.streamController = streamController;\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListener();\n\n if (this.hls.config.capLevelToPlayerSize) {\n this.stopCapping();\n }\n\n this.media = null;\n this.clientRect = null; // @ts-ignore\n\n this.hls = this.streamController = null;\n };\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FPS_DROP_LEVEL_CAPPING, this.onFpsDropLevelCapping, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_CODECS, this.onBufferCodecs, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n };\n\n _proto.unregisterListener = function unregisterListener() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FPS_DROP_LEVEL_CAPPING, this.onFpsDropLevelCapping, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_CODECS, this.onBufferCodecs, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n };\n\n _proto.onFpsDropLevelCapping = function onFpsDropLevelCapping(event, data) {\n // Don't add a restricted level more than once\n if (CapLevelController.isLevelAllowed(data.droppedLevel, this.restrictedLevels)) {\n this.restrictedLevels.push(data.droppedLevel);\n }\n };\n\n _proto.onMediaAttaching = function onMediaAttaching(event, data) {\n this.media = data.media instanceof HTMLVideoElement ? data.media : null;\n };\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n var hls = this.hls;\n this.restrictedLevels = [];\n this.firstLevel = data.firstLevel;\n\n if (hls.config.capLevelToPlayerSize && data.video) {\n // Start capping immediately if the manifest has signaled video codecs\n this.startCapping();\n }\n } // Only activate capping when playing a video stream; otherwise, multi-bitrate audio-only streams will be restricted\n // to the first level\n ;\n\n _proto.onBufferCodecs = function onBufferCodecs(event, data) {\n var hls = this.hls;\n\n if (hls.config.capLevelToPlayerSize && data.video) {\n // If the manifest did not signal a video codec capping has been deferred until we're certain video is present\n this.startCapping();\n }\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n this.stopCapping();\n };\n\n _proto.detectPlayerSize = function detectPlayerSize() {\n if (this.media && this.mediaHeight > 0 && this.mediaWidth > 0) {\n var levels = this.hls.levels;\n\n if (levels.length) {\n var hls = this.hls;\n hls.autoLevelCapping = this.getMaxLevel(levels.length - 1);\n\n if (hls.autoLevelCapping > this.autoLevelCapping && this.streamController) {\n // if auto level capping has a higher value for the previous one, flush the buffer using nextLevelSwitch\n // usually happen when the user go to the fullscreen mode.\n this.streamController.nextLevelSwitch();\n }\n\n this.autoLevelCapping = hls.autoLevelCapping;\n }\n }\n }\n /*\n * returns level should be the one with the dimensions equal or greater than the media (player) dimensions (so the video will be downscaled)\n */\n ;\n\n _proto.getMaxLevel = function getMaxLevel(capLevelIndex) {\n var _this = this;\n\n var levels = this.hls.levels;\n\n if (!levels.length) {\n return -1;\n }\n\n var validLevels = levels.filter(function (level, index) {\n return CapLevelController.isLevelAllowed(index, _this.restrictedLevels) && index <= capLevelIndex;\n });\n this.clientRect = null;\n return CapLevelController.getMaxLevelByMediaSize(validLevels, this.mediaWidth, this.mediaHeight);\n };\n\n _proto.startCapping = function startCapping() {\n if (this.timer) {\n // Don't reset capping if started twice; this can happen if the manifest signals a video codec\n return;\n }\n\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n this.hls.firstLevel = this.getMaxLevel(this.firstLevel);\n self.clearInterval(this.timer);\n this.timer = self.setInterval(this.detectPlayerSize.bind(this), 1000);\n this.detectPlayerSize();\n };\n\n _proto.stopCapping = function stopCapping() {\n this.restrictedLevels = [];\n this.firstLevel = -1;\n this.autoLevelCapping = Number.POSITIVE_INFINITY;\n\n if (this.timer) {\n self.clearInterval(this.timer);\n this.timer = undefined;\n }\n };\n\n _proto.getDimensions = function getDimensions() {\n if (this.clientRect) {\n return this.clientRect;\n }\n\n var media = this.media;\n var boundsRect = {\n width: 0,\n height: 0\n };\n\n if (media) {\n var clientRect = media.getBoundingClientRect();\n boundsRect.width = clientRect.width;\n boundsRect.height = clientRect.height;\n\n if (!boundsRect.width && !boundsRect.height) {\n // When the media element has no width or height (equivalent to not being in the DOM),\n // then use its width and height attributes (media.width, media.height)\n boundsRect.width = clientRect.right - clientRect.left || media.width || 0;\n boundsRect.height = clientRect.bottom - clientRect.top || media.height || 0;\n }\n }\n\n this.clientRect = boundsRect;\n return boundsRect;\n };\n\n CapLevelController.isLevelAllowed = function isLevelAllowed(level, restrictedLevels) {\n if (restrictedLevels === void 0) {\n restrictedLevels = [];\n }\n\n return restrictedLevels.indexOf(level) === -1;\n };\n\n CapLevelController.getMaxLevelByMediaSize = function getMaxLevelByMediaSize(levels, width, height) {\n if (!levels || !levels.length) {\n return -1;\n } // Levels can have the same dimensions but differing bandwidths - since levels are ordered, we can look to the next\n // to determine whether we've chosen the greatest bandwidth for the media's dimensions\n\n\n var atGreatestBandwidth = function atGreatestBandwidth(curLevel, nextLevel) {\n if (!nextLevel) {\n return true;\n }\n\n return curLevel.width !== nextLevel.width || curLevel.height !== nextLevel.height;\n }; // If we run through the loop without breaking, the media's dimensions are greater than every level, so default to\n // the max level\n\n\n var maxLevelIndex = levels.length - 1;\n\n for (var i = 0; i < levels.length; i += 1) {\n var level = levels[i];\n\n if ((level.width >= width || level.height >= height) && atGreatestBandwidth(level, levels[i + 1])) {\n maxLevelIndex = i;\n break;\n }\n }\n\n return maxLevelIndex;\n };\n\n _createClass(CapLevelController, [{\n key: \"mediaWidth\",\n get: function get() {\n return this.getDimensions().width * this.contentScaleFactor;\n }\n }, {\n key: \"mediaHeight\",\n get: function get() {\n return this.getDimensions().height * this.contentScaleFactor;\n }\n }, {\n key: \"contentScaleFactor\",\n get: function get() {\n var pixelRatio = 1;\n\n if (!this.hls.config.ignoreDevicePixelRatio) {\n try {\n pixelRatio = self.devicePixelRatio;\n } catch (e) {\n /* no-op */\n }\n }\n\n return pixelRatio;\n }\n }]);\n\n return CapLevelController;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (CapLevelController);\n\n/***/ }),\n\n/***/ \"./src/controller/cmcd-controller.ts\":\n/*!*******************************************!*\\\n !*** ./src/controller/cmcd-controller.ts ***!\n \\*******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return CMCDController; });\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _types_cmcd__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../types/cmcd */ \"./src/types/cmcd.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _createForOfIteratorHelperLoose(o, allowArrayLike) { var it = typeof Symbol !== \"undefined\" && o[Symbol.iterator] || o[\"@@iterator\"]; if (it) return (it = it.call(o)).next.bind(it); if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === \"number\") { if (it) o = it; var i = 0; return function () { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }; } throw new TypeError(\"Invalid attempt to iterate non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\n\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\n\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n/**\n * Controller to deal with Common Media Client Data (CMCD)\n * @see https://cdn.cta.tech/cta/media/media/resources/standards/pdfs/cta-5004-final.pdf\n */\n\nvar CMCDController = /*#__PURE__*/function () {\n // eslint-disable-line no-restricted-globals\n // eslint-disable-line no-restricted-globals\n function CMCDController(hls) {\n var _this = this;\n\n this.hls = void 0;\n this.config = void 0;\n this.media = void 0;\n this.sid = void 0;\n this.cid = void 0;\n this.useHeaders = false;\n this.initialized = false;\n this.starved = false;\n this.buffering = true;\n this.audioBuffer = void 0;\n this.videoBuffer = void 0;\n\n this.onWaiting = function () {\n if (_this.initialized) {\n _this.starved = true;\n }\n\n _this.buffering = true;\n };\n\n this.onPlaying = function () {\n if (!_this.initialized) {\n _this.initialized = true;\n }\n\n _this.buffering = false;\n };\n\n this.applyPlaylistData = function (context) {\n try {\n _this.apply(context, {\n ot: _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].MANIFEST,\n su: !_this.initialized\n });\n } catch (error) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn('Could not generate manifest CMCD data.', error);\n }\n };\n\n this.applyFragmentData = function (context) {\n try {\n var fragment = context.frag;\n var level = _this.hls.levels[fragment.level];\n\n var ot = _this.getObjectType(fragment);\n\n var data = {\n d: fragment.duration * 1000,\n ot: ot\n };\n\n if (ot === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].VIDEO || ot === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].AUDIO || ot == _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].MUXED) {\n data.br = level.bitrate / 1000;\n data.tb = _this.getTopBandwidth(ot) / 1000;\n data.bl = _this.getBufferLength(ot);\n }\n\n _this.apply(context, data);\n } catch (error) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn('Could not generate segment CMCD data.', error);\n }\n };\n\n this.hls = hls;\n var config = this.config = hls.config;\n var cmcd = config.cmcd;\n\n if (cmcd != null) {\n config.pLoader = this.createPlaylistLoader();\n config.fLoader = this.createFragmentLoader();\n this.sid = cmcd.sessionId || CMCDController.uuid();\n this.cid = cmcd.contentId;\n this.useHeaders = cmcd.useHeaders === true;\n this.registerListeners();\n }\n }\n\n var _proto = CMCDController.prototype;\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHED, this.onMediaDetached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHED, this.onMediaDetached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n this.onMediaDetached();\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners(); // @ts-ignore\n\n this.hls = this.config = this.audioBuffer = this.videoBuffer = null;\n };\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n this.media = data.media;\n this.media.addEventListener('waiting', this.onWaiting);\n this.media.addEventListener('playing', this.onPlaying);\n };\n\n _proto.onMediaDetached = function onMediaDetached() {\n if (!this.media) {\n return;\n }\n\n this.media.removeEventListener('waiting', this.onWaiting);\n this.media.removeEventListener('playing', this.onPlaying); // @ts-ignore\n\n this.media = null;\n };\n\n _proto.onBufferCreated = function onBufferCreated(event, data) {\n var _data$tracks$audio, _data$tracks$video;\n\n this.audioBuffer = (_data$tracks$audio = data.tracks.audio) === null || _data$tracks$audio === void 0 ? void 0 : _data$tracks$audio.buffer;\n this.videoBuffer = (_data$tracks$video = data.tracks.video) === null || _data$tracks$video === void 0 ? void 0 : _data$tracks$video.buffer;\n };\n\n /**\n * Create baseline CMCD data\n */\n _proto.createData = function createData() {\n var _this$media;\n\n return {\n v: _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDVersion\"],\n sf: _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDStreamingFormat\"].HLS,\n sid: this.sid,\n cid: this.cid,\n pr: (_this$media = this.media) === null || _this$media === void 0 ? void 0 : _this$media.playbackRate,\n mtp: this.hls.bandwidthEstimate / 1000\n };\n }\n /**\n * Apply CMCD data to a request.\n */\n ;\n\n _proto.apply = function apply(context, data) {\n if (data === void 0) {\n data = {};\n }\n\n // apply baseline data\n _extends(data, this.createData());\n\n var isVideo = data.ot === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].INIT || data.ot === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].VIDEO || data.ot === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].MUXED;\n\n if (this.starved && isVideo) {\n data.bs = true;\n data.su = true;\n this.starved = false;\n }\n\n if (data.su == null) {\n data.su = this.buffering;\n } // TODO: Implement rtp, nrr, nor, dl\n\n\n if (this.useHeaders) {\n var headers = CMCDController.toHeaders(data);\n\n if (!Object.keys(headers).length) {\n return;\n }\n\n if (!context.headers) {\n context.headers = {};\n }\n\n _extends(context.headers, headers);\n } else {\n var query = CMCDController.toQuery(data);\n\n if (!query) {\n return;\n }\n\n context.url = CMCDController.appendQueryToUri(context.url, query);\n }\n }\n /**\n * Apply CMCD data to a manifest request.\n */\n ;\n\n /**\n * The CMCD object type.\n */\n _proto.getObjectType = function getObjectType(fragment) {\n var type = fragment.type;\n\n if (type === 'subtitle') {\n return _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].TIMED_TEXT;\n }\n\n if (fragment.sn === 'initSegment') {\n return _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].INIT;\n }\n\n if (type === 'audio') {\n return _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].AUDIO;\n }\n\n if (type === 'main') {\n if (!this.hls.audioTracks.length) {\n return _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].MUXED;\n }\n\n return _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].VIDEO;\n }\n\n return undefined;\n }\n /**\n * Get the highest bitrate.\n */\n ;\n\n _proto.getTopBandwidth = function getTopBandwidth(type) {\n var bitrate = 0;\n var levels;\n var hls = this.hls;\n\n if (type === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].AUDIO) {\n levels = hls.audioTracks;\n } else {\n var max = hls.maxAutoLevel;\n var len = max > -1 ? max + 1 : hls.levels.length;\n levels = hls.levels.slice(0, len);\n }\n\n for (var _iterator = _createForOfIteratorHelperLoose(levels), _step; !(_step = _iterator()).done;) {\n var level = _step.value;\n\n if (level.bitrate > bitrate) {\n bitrate = level.bitrate;\n }\n }\n\n return bitrate > 0 ? bitrate : NaN;\n }\n /**\n * Get the buffer length for a media type in milliseconds\n */\n ;\n\n _proto.getBufferLength = function getBufferLength(type) {\n var media = this.hls.media;\n var buffer = type === _types_cmcd__WEBPACK_IMPORTED_MODULE_1__[\"CMCDObjectType\"].AUDIO ? this.audioBuffer : this.videoBuffer;\n\n if (!buffer || !media) {\n return NaN;\n }\n\n var info = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_2__[\"BufferHelper\"].bufferInfo(buffer, media.currentTime, this.config.maxBufferHole);\n return info.len * 1000;\n }\n /**\n * Create a playlist loader\n */\n ;\n\n _proto.createPlaylistLoader = function createPlaylistLoader() {\n var pLoader = this.config.pLoader;\n var apply = this.applyPlaylistData;\n var Ctor = pLoader || this.config.loader;\n return /*#__PURE__*/function () {\n function CmcdPlaylistLoader(config) {\n this.loader = void 0;\n this.loader = new Ctor(config);\n }\n\n var _proto2 = CmcdPlaylistLoader.prototype;\n\n _proto2.destroy = function destroy() {\n this.loader.destroy();\n };\n\n _proto2.abort = function abort() {\n this.loader.abort();\n };\n\n _proto2.load = function load(context, config, callbacks) {\n apply(context);\n this.loader.load(context, config, callbacks);\n };\n\n _createClass(CmcdPlaylistLoader, [{\n key: \"stats\",\n get: function get() {\n return this.loader.stats;\n }\n }, {\n key: \"context\",\n get: function get() {\n return this.loader.context;\n }\n }]);\n\n return CmcdPlaylistLoader;\n }();\n }\n /**\n * Create a playlist loader\n */\n ;\n\n _proto.createFragmentLoader = function createFragmentLoader() {\n var fLoader = this.config.fLoader;\n var apply = this.applyFragmentData;\n var Ctor = fLoader || this.config.loader;\n return /*#__PURE__*/function () {\n function CmcdFragmentLoader(config) {\n this.loader = void 0;\n this.loader = new Ctor(config);\n }\n\n var _proto3 = CmcdFragmentLoader.prototype;\n\n _proto3.destroy = function destroy() {\n this.loader.destroy();\n };\n\n _proto3.abort = function abort() {\n this.loader.abort();\n };\n\n _proto3.load = function load(context, config, callbacks) {\n apply(context);\n this.loader.load(context, config, callbacks);\n };\n\n _createClass(CmcdFragmentLoader, [{\n key: \"stats\",\n get: function get() {\n return this.loader.stats;\n }\n }, {\n key: \"context\",\n get: function get() {\n return this.loader.context;\n }\n }]);\n\n return CmcdFragmentLoader;\n }();\n }\n /**\n * Generate a random v4 UUI\n *\n * @returns {string}\n */\n ;\n\n CMCDController.uuid = function uuid() {\n var url = URL.createObjectURL(new Blob());\n var uuid = url.toString();\n URL.revokeObjectURL(url);\n return uuid.slice(uuid.lastIndexOf('/') + 1);\n }\n /**\n * Serialize a CMCD data object according to the rules defined in the\n * section 3.2 of\n * [CTA-5004](https://cdn.cta.tech/cta/media/media/resources/standards/pdfs/cta-5004-final.pdf).\n */\n ;\n\n CMCDController.serialize = function serialize(data) {\n var results = [];\n\n var isValid = function isValid(value) {\n return !Number.isNaN(value) && value != null && value !== '' && value !== false;\n };\n\n var toRounded = function toRounded(value) {\n return Math.round(value);\n };\n\n var toHundred = function toHundred(value) {\n return toRounded(value / 100) * 100;\n };\n\n var toUrlSafe = function toUrlSafe(value) {\n return encodeURIComponent(value);\n };\n\n var formatters = {\n br: toRounded,\n d: toRounded,\n bl: toHundred,\n dl: toHundred,\n mtp: toHundred,\n nor: toUrlSafe,\n rtp: toHundred,\n tb: toRounded\n };\n var keys = Object.keys(data || {}).sort();\n\n for (var _iterator2 = _createForOfIteratorHelperLoose(keys), _step2; !(_step2 = _iterator2()).done;) {\n var key = _step2.value;\n var value = data[key]; // ignore invalid values\n\n if (!isValid(value)) {\n continue;\n } // Version should only be reported if not equal to 1.\n\n\n if (key === 'v' && value === 1) {\n continue;\n } // Playback rate should only be sent if not equal to 1.\n\n\n if (key == 'pr' && value === 1) {\n continue;\n } // Certain values require special formatting\n\n\n var formatter = formatters[key];\n\n if (formatter) {\n value = formatter(value);\n } // Serialize the key/value pair\n\n\n var type = typeof value;\n var result = void 0;\n\n if (key === 'ot' || key === 'sf' || key === 'st') {\n result = key + \"=\" + value;\n } else if (type === 'boolean') {\n result = key;\n } else if (type === 'number') {\n result = key + \"=\" + value;\n } else {\n result = key + \"=\" + JSON.stringify(value);\n }\n\n results.push(result);\n }\n\n return results.join(',');\n }\n /**\n * Convert a CMCD data object to request headers according to the rules\n * defined in the section 2.1 and 3.2 of\n * [CTA-5004](https://cdn.cta.tech/cta/media/media/resources/standards/pdfs/cta-5004-final.pdf).\n */\n ;\n\n CMCDController.toHeaders = function toHeaders(data) {\n var keys = Object.keys(data);\n var headers = {};\n var headerNames = ['Object', 'Request', 'Session', 'Status'];\n var headerGroups = [{}, {}, {}, {}];\n var headerMap = {\n br: 0,\n d: 0,\n ot: 0,\n tb: 0,\n bl: 1,\n dl: 1,\n mtp: 1,\n nor: 1,\n nrr: 1,\n su: 1,\n cid: 2,\n pr: 2,\n sf: 2,\n sid: 2,\n st: 2,\n v: 2,\n bs: 3,\n rtp: 3\n };\n\n for (var _i = 0, _keys = keys; _i < _keys.length; _i++) {\n var key = _keys[_i];\n // Unmapped fields are mapped to the Request header\n var index = headerMap[key] != null ? headerMap[key] : 1;\n headerGroups[index][key] = data[key];\n }\n\n for (var i = 0; i < headerGroups.length; i++) {\n var value = CMCDController.serialize(headerGroups[i]);\n\n if (value) {\n headers[\"CMCD-\" + headerNames[i]] = value;\n }\n }\n\n return headers;\n }\n /**\n * Convert a CMCD data object to query args according to the rules\n * defined in the section 2.2 and 3.2 of\n * [CTA-5004](https://cdn.cta.tech/cta/media/media/resources/standards/pdfs/cta-5004-final.pdf).\n */\n ;\n\n CMCDController.toQuery = function toQuery(data) {\n return \"CMCD=\" + encodeURIComponent(CMCDController.serialize(data));\n }\n /**\n * Append query args to a uri.\n */\n ;\n\n CMCDController.appendQueryToUri = function appendQueryToUri(uri, query) {\n if (!query) {\n return uri;\n }\n\n var separator = uri.includes('?') ? '&' : '?';\n return \"\" + uri + separator + query;\n };\n\n return CMCDController;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/eme-controller.ts\":\n/*!******************************************!*\\\n !*** ./src/controller/eme-controller.ts ***!\n \\******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/mediakeys-helper */ \"./src/utils/mediakeys-helper.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n/**\n * @author Stephan Hesse | \n *\n * DRM support for Hls.js\n */\n\n\n\n\nvar MAX_LICENSE_REQUEST_FAILURES = 3;\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemConfiguration\n * @param {Array} audioCodecs List of required audio codecs to support\n * @param {Array} videoCodecs List of required video codecs to support\n * @param {object} drmSystemOptions Optional parameters/requirements for the key-system\n * @returns {Array} An array of supported configurations\n */\n\nvar createWidevineMediaKeySystemConfigurations = function createWidevineMediaKeySystemConfigurations(audioCodecs, videoCodecs, drmSystemOptions) {\n /* jshint ignore:line */\n var baseConfig = {\n // initDataTypes: ['keyids', 'mp4'],\n // label: \"\",\n // persistentState: \"not-allowed\", // or \"required\" ?\n // distinctiveIdentifier: \"not-allowed\", // or \"required\" ?\n // sessionTypes: ['temporary'],\n audioCapabilities: [],\n // { contentType: 'audio/mp4; codecs=\"mp4a.40.2\"' }\n videoCapabilities: [] // { contentType: 'video/mp4; codecs=\"avc1.42E01E\"' }\n\n };\n audioCodecs.forEach(function (codec) {\n baseConfig.audioCapabilities.push({\n contentType: \"audio/mp4; codecs=\\\"\" + codec + \"\\\"\",\n robustness: drmSystemOptions.audioRobustness || ''\n });\n });\n videoCodecs.forEach(function (codec) {\n baseConfig.videoCapabilities.push({\n contentType: \"video/mp4; codecs=\\\"\" + codec + \"\\\"\",\n robustness: drmSystemOptions.videoRobustness || ''\n });\n });\n return [baseConfig];\n};\n/**\n * The idea here is to handle key-system (and their respective platforms) specific configuration differences\n * in order to work with the local requestMediaKeySystemAccess method.\n *\n * We can also rule-out platform-related key-system support at this point by throwing an error.\n *\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @param {Array} audioCodecs List of required audio codecs to support\n * @param {Array} videoCodecs List of required video codecs to support\n * @throws will throw an error if a unknown key system is passed\n * @returns {Array} A non-empty Array of MediaKeySystemConfiguration objects\n */\n\n\nvar getSupportedMediaKeySystemConfigurations = function getSupportedMediaKeySystemConfigurations(keySystem, audioCodecs, videoCodecs, drmSystemOptions) {\n switch (keySystem) {\n case _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__[\"KeySystems\"].WIDEVINE:\n return createWidevineMediaKeySystemConfigurations(audioCodecs, videoCodecs, drmSystemOptions);\n\n default:\n throw new Error(\"Unknown key-system: \" + keySystem);\n }\n};\n\n/**\n * Controller to deal with encrypted media extensions (EME)\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Encrypted_Media_Extensions_API\n *\n * @class\n * @constructor\n */\nvar EMEController = /*#__PURE__*/function () {\n /**\n * @constructs\n * @param {Hls} hls Our Hls.js instance\n */\n function EMEController(hls) {\n this.hls = void 0;\n this._widevineLicenseUrl = void 0;\n this._licenseXhrSetup = void 0;\n this._licenseResponseCallback = void 0;\n this._emeEnabled = void 0;\n this._requestMediaKeySystemAccess = void 0;\n this._drmSystemOptions = void 0;\n this._config = void 0;\n this._mediaKeysList = [];\n this._media = null;\n this._hasSetMediaKeys = false;\n this._requestLicenseFailureCount = 0;\n this.mediaKeysPromise = null;\n this._onMediaEncrypted = this.onMediaEncrypted.bind(this);\n this.hls = hls;\n this._config = hls.config;\n this._widevineLicenseUrl = this._config.widevineLicenseUrl;\n this._licenseXhrSetup = this._config.licenseXhrSetup;\n this._licenseResponseCallback = this._config.licenseResponseCallback;\n this._emeEnabled = this._config.emeEnabled;\n this._requestMediaKeySystemAccess = this._config.requestMediaKeySystemAccessFunc;\n this._drmSystemOptions = this._config.drmSystemOptions;\n\n this._registerListeners();\n }\n\n var _proto = EMEController.prototype;\n\n _proto.destroy = function destroy() {\n this._unregisterListeners(); // @ts-ignore\n\n\n this.hls = this._onMediaEncrypted = null;\n this._requestMediaKeySystemAccess = null;\n };\n\n _proto._registerListeners = function _registerListeners() {\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHED, this.onMediaDetached, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHED, this.onMediaDetached, this);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n }\n /**\n * @param {string} keySystem Identifier for the key-system, see `KeySystems` enum\n * @returns {string} License server URL for key-system (if any configured, otherwise causes error)\n * @throws if a unsupported keysystem is passed\n */\n ;\n\n _proto.getLicenseServerUrl = function getLicenseServerUrl(keySystem) {\n switch (keySystem) {\n case _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__[\"KeySystems\"].WIDEVINE:\n if (!this._widevineLicenseUrl) {\n break;\n }\n\n return this._widevineLicenseUrl;\n }\n\n throw new Error(\"no license server URL configured for key-system \\\"\" + keySystem + \"\\\"\");\n }\n /**\n * Requests access object and adds it to our list upon success\n * @private\n * @param {string} keySystem System ID (see `KeySystems`)\n * @param {Array} audioCodecs List of required audio codecs to support\n * @param {Array} videoCodecs List of required video codecs to support\n * @throws When a unsupported KeySystem is passed\n */\n ;\n\n _proto._attemptKeySystemAccess = function _attemptKeySystemAccess(keySystem, audioCodecs, videoCodecs) {\n var _this = this;\n\n // This can throw, but is caught in event handler callpath\n var mediaKeySystemConfigs = getSupportedMediaKeySystemConfigurations(keySystem, audioCodecs, videoCodecs, this._drmSystemOptions);\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('Requesting encrypted media key-system access'); // expecting interface like window.navigator.requestMediaKeySystemAccess\n\n var keySystemAccessPromise = this.requestMediaKeySystemAccess(keySystem, mediaKeySystemConfigs);\n this.mediaKeysPromise = keySystemAccessPromise.then(function (mediaKeySystemAccess) {\n return _this._onMediaKeySystemAccessObtained(keySystem, mediaKeySystemAccess);\n });\n keySystemAccessPromise.catch(function (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"Failed to obtain key-system \\\"\" + keySystem + \"\\\" access:\", err);\n });\n };\n\n /**\n * Handles obtaining access to a key-system\n * @private\n * @param {string} keySystem\n * @param {MediaKeySystemAccess} mediaKeySystemAccess https://developer.mozilla.org/en-US/docs/Web/API/MediaKeySystemAccess\n */\n _proto._onMediaKeySystemAccessObtained = function _onMediaKeySystemAccessObtained(keySystem, mediaKeySystemAccess) {\n var _this2 = this;\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Access for key-system \\\"\" + keySystem + \"\\\" obtained\");\n var mediaKeysListItem = {\n mediaKeysSessionInitialized: false,\n mediaKeySystemAccess: mediaKeySystemAccess,\n mediaKeySystemDomain: keySystem\n };\n\n this._mediaKeysList.push(mediaKeysListItem);\n\n var mediaKeysPromise = Promise.resolve().then(function () {\n return mediaKeySystemAccess.createMediaKeys();\n }).then(function (mediaKeys) {\n mediaKeysListItem.mediaKeys = mediaKeys;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Media-keys created for key-system \\\"\" + keySystem + \"\\\"\");\n\n _this2._onMediaKeysCreated();\n\n return mediaKeys;\n });\n mediaKeysPromise.catch(function (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Failed to create media-keys:', err);\n });\n return mediaKeysPromise;\n }\n /**\n * Handles key-creation (represents access to CDM). We are going to create key-sessions upon this\n * for all existing keys where no session exists yet.\n *\n * @private\n */\n ;\n\n _proto._onMediaKeysCreated = function _onMediaKeysCreated() {\n var _this3 = this;\n\n // check for all key-list items if a session exists, otherwise, create one\n this._mediaKeysList.forEach(function (mediaKeysListItem) {\n if (!mediaKeysListItem.mediaKeysSession) {\n // mediaKeys is definitely initialized here\n mediaKeysListItem.mediaKeysSession = mediaKeysListItem.mediaKeys.createSession();\n\n _this3._onNewMediaKeySession(mediaKeysListItem.mediaKeysSession);\n }\n });\n }\n /**\n * @private\n * @param {*} keySession\n */\n ;\n\n _proto._onNewMediaKeySession = function _onNewMediaKeySession(keySession) {\n var _this4 = this;\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"New key-system session \" + keySession.sessionId);\n keySession.addEventListener('message', function (event) {\n _this4._onKeySessionMessage(keySession, event.message);\n }, false);\n }\n /**\n * @private\n * @param {MediaKeySession} keySession\n * @param {ArrayBuffer} message\n */\n ;\n\n _proto._onKeySessionMessage = function _onKeySessionMessage(keySession, message) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('Got EME message event, creating license request');\n\n this._requestLicense(message, function (data) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Received license data (length: \" + (data ? data.byteLength : data) + \"), updating key-session\");\n keySession.update(data).catch(function (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"Updating key-session failed: \" + err);\n });\n });\n }\n /**\n * @private\n * @param e {MediaEncryptedEvent}\n */\n ;\n\n _proto.onMediaEncrypted = function onMediaEncrypted(e) {\n var _this5 = this;\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Media is encrypted using \\\"\" + e.initDataType + \"\\\" init data type\");\n\n if (!this.mediaKeysPromise) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Fatal: Media is encrypted but no CDM access or no keys have been requested');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n var finallySetKeyAndStartSession = function finallySetKeyAndStartSession(mediaKeys) {\n if (!_this5._media) {\n return;\n }\n\n _this5._attemptSetMediaKeys(mediaKeys);\n\n _this5._generateRequestWithPreferredKeySession(e.initDataType, e.initData);\n }; // Could use `Promise.finally` but some Promise polyfills are missing it\n\n\n this.mediaKeysPromise.then(finallySetKeyAndStartSession).catch(finallySetKeyAndStartSession);\n }\n /**\n * @private\n */\n ;\n\n _proto._attemptSetMediaKeys = function _attemptSetMediaKeys(mediaKeys) {\n if (!this._media) {\n throw new Error('Attempted to set mediaKeys without first attaching a media element');\n }\n\n if (!this._hasSetMediaKeys) {\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n var keysListItem = this._mediaKeysList[0];\n\n if (!keysListItem || !keysListItem.mediaKeys) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Fatal: Media is encrypted but no CDM access or no keys have been obtained yet');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_KEYS,\n fatal: true\n });\n return;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('Setting keys for encrypted media');\n\n this._media.setMediaKeys(keysListItem.mediaKeys);\n\n this._hasSetMediaKeys = true;\n }\n }\n /**\n * @private\n */\n ;\n\n _proto._generateRequestWithPreferredKeySession = function _generateRequestWithPreferredKeySession(initDataType, initData) {\n var _this6 = this;\n\n // FIXME: see if we can/want/need-to really to deal with several potential key-sessions?\n var keysListItem = this._mediaKeysList[0];\n\n if (!keysListItem) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Fatal: Media is encrypted but not any key-system access has been obtained yet');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n if (keysListItem.mediaKeysSessionInitialized) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('Key-Session already initialized but requested again');\n return;\n }\n\n var keySession = keysListItem.mediaKeysSession;\n\n if (!keySession) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Fatal: Media is encrypted but no key-session existing');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_SESSION,\n fatal: true\n });\n return;\n } // initData is null if the media is not CORS-same-origin\n\n\n if (!initData) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('Fatal: initData required for generating a key session is null');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_INIT_DATA,\n fatal: true\n });\n return;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Generating key-session request for \\\"\" + initDataType + \"\\\" init data type\");\n keysListItem.mediaKeysSessionInitialized = true;\n keySession.generateRequest(initDataType, initData).then(function () {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].debug('Key-session generation succeeded');\n }).catch(function (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Error generating key-session request:', err);\n\n _this6.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_SESSION,\n fatal: false\n });\n });\n }\n /**\n * @private\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n * @returns {XMLHttpRequest} Unsent (but opened state) XHR object\n * @throws if XMLHttpRequest construction failed\n */\n ;\n\n _proto._createLicenseXhr = function _createLicenseXhr(url, keyMessage, callback) {\n var xhr = new XMLHttpRequest();\n xhr.responseType = 'arraybuffer';\n xhr.onreadystatechange = this._onLicenseRequestReadyStageChange.bind(this, xhr, url, keyMessage, callback);\n var licenseXhrSetup = this._licenseXhrSetup;\n\n if (licenseXhrSetup) {\n try {\n licenseXhrSetup.call(this.hls, xhr, url);\n licenseXhrSetup = undefined;\n } catch (e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(e);\n }\n }\n\n try {\n // if licenseXhrSetup did not yet call open, let's do it now\n if (!xhr.readyState) {\n xhr.open('POST', url, true);\n }\n\n if (licenseXhrSetup) {\n licenseXhrSetup.call(this.hls, xhr, url);\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n throw new Error(\"issue setting up KeySystem license XHR \" + e);\n }\n\n return xhr;\n }\n /**\n * @private\n * @param {XMLHttpRequest} xhr\n * @param {string} url License server URL\n * @param {ArrayBuffer} keyMessage Message data issued by key-system\n * @param {function} callback Called when XHR has succeeded\n */\n ;\n\n _proto._onLicenseRequestReadyStageChange = function _onLicenseRequestReadyStageChange(xhr, url, keyMessage, callback) {\n switch (xhr.readyState) {\n case 4:\n if (xhr.status === 200) {\n this._requestLicenseFailureCount = 0;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('License request succeeded');\n var _data = xhr.response;\n var licenseResponseCallback = this._licenseResponseCallback;\n\n if (licenseResponseCallback) {\n try {\n _data = licenseResponseCallback.call(this.hls, xhr, url);\n } catch (e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(e);\n }\n }\n\n callback(_data);\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"License Request XHR failed (\" + url + \"). Status: \" + xhr.status + \" (\" + xhr.statusText + \")\");\n this._requestLicenseFailureCount++;\n\n if (this._requestLicenseFailureCount > MAX_LICENSE_REQUEST_FAILURES) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n return;\n }\n\n var attemptsLeft = MAX_LICENSE_REQUEST_FAILURES - this._requestLicenseFailureCount + 1;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"Retrying license request, \" + attemptsLeft + \" attempts left\");\n\n this._requestLicense(keyMessage, callback);\n }\n\n break;\n }\n }\n /**\n * @private\n * @param {MediaKeysListItem} keysListItem\n * @param {ArrayBuffer} keyMessage\n * @returns {ArrayBuffer} Challenge data posted to license server\n * @throws if KeySystem is unsupported\n */\n ;\n\n _proto._generateLicenseRequestChallenge = function _generateLicenseRequestChallenge(keysListItem, keyMessage) {\n switch (keysListItem.mediaKeySystemDomain) {\n // case KeySystems.PLAYREADY:\n // from https://github.com/MicrosoftEdge/Demos/blob/master/eme/scripts/demo.js\n\n /*\n if (this.licenseType !== this.LICENSE_TYPE_WIDEVINE) {\n // For PlayReady CDMs, we need to dig the Challenge out of the XML.\n var keyMessageXml = new DOMParser().parseFromString(String.fromCharCode.apply(null, new Uint16Array(keyMessage)), 'application/xml');\n if (keyMessageXml.getElementsByTagName('Challenge')[0]) {\n challenge = atob(keyMessageXml.getElementsByTagName('Challenge')[0].childNodes[0].nodeValue);\n } else {\n throw 'Cannot find in key message';\n }\n var headerNames = keyMessageXml.getElementsByTagName('name');\n var headerValues = keyMessageXml.getElementsByTagName('value');\n if (headerNames.length !== headerValues.length) {\n throw 'Mismatched header / pair in key message';\n }\n for (var i = 0; i < headerNames.length; i++) {\n xhr.setRequestHeader(headerNames[i].childNodes[0].nodeValue, headerValues[i].childNodes[0].nodeValue);\n }\n }\n break;\n */\n case _utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__[\"KeySystems\"].WIDEVINE:\n // For Widevine CDMs, the challenge is the keyMessage.\n return keyMessage;\n }\n\n throw new Error(\"unsupported key-system: \" + keysListItem.mediaKeySystemDomain);\n }\n /**\n * @private\n * @param keyMessage\n * @param callback\n */\n ;\n\n _proto._requestLicense = function _requestLicense(keyMessage, callback) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('Requesting content license for key-system');\n var keysListItem = this._mediaKeysList[0];\n\n if (!keysListItem) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('Fatal error: Media is encrypted but no key-system access has been obtained yet');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_NO_ACCESS,\n fatal: true\n });\n return;\n }\n\n try {\n var _url = this.getLicenseServerUrl(keysListItem.mediaKeySystemDomain);\n\n var _xhr = this._createLicenseXhr(_url, keyMessage, callback);\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log(\"Sending license request to URL: \" + _url);\n\n var challenge = this._generateLicenseRequestChallenge(keysListItem, keyMessage);\n\n _xhr.send(challenge);\n } catch (e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error(\"Failure requesting DRM license: \" + e);\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].KEY_SYSTEM_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_SYSTEM_LICENSE_REQUEST_FAILED,\n fatal: true\n });\n }\n };\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n if (!this._emeEnabled) {\n return;\n }\n\n var media = data.media; // keep reference of media\n\n this._media = media;\n media.addEventListener('encrypted', this._onMediaEncrypted);\n };\n\n _proto.onMediaDetached = function onMediaDetached() {\n var media = this._media;\n var mediaKeysList = this._mediaKeysList;\n\n if (!media) {\n return;\n }\n\n media.removeEventListener('encrypted', this._onMediaEncrypted);\n this._media = null;\n this._mediaKeysList = []; // Close all sessions and remove media keys from the video element.\n\n Promise.all(mediaKeysList.map(function (mediaKeysListItem) {\n if (mediaKeysListItem.mediaKeysSession) {\n return mediaKeysListItem.mediaKeysSession.close().catch(function () {// Ignore errors when closing the sessions. Closing a session that\n // generated no key requests will throw an error.\n });\n }\n })).then(function () {\n return media.setMediaKeys(null);\n }).catch(function () {// Ignore any failures while removing media keys from the video element.\n });\n };\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n if (!this._emeEnabled) {\n return;\n }\n\n var audioCodecs = data.levels.map(function (level) {\n return level.audioCodec;\n }).filter(function (audioCodec) {\n return !!audioCodec;\n });\n var videoCodecs = data.levels.map(function (level) {\n return level.videoCodec;\n }).filter(function (videoCodec) {\n return !!videoCodec;\n });\n\n this._attemptKeySystemAccess(_utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__[\"KeySystems\"].WIDEVINE, audioCodecs, videoCodecs);\n };\n\n _createClass(EMEController, [{\n key: \"requestMediaKeySystemAccess\",\n get: function get() {\n if (!this._requestMediaKeySystemAccess) {\n throw new Error('No requestMediaKeySystemAccess function configured');\n }\n\n return this._requestMediaKeySystemAccess;\n }\n }]);\n\n return EMEController;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (EMEController);\n\n/***/ }),\n\n/***/ \"./src/controller/fps-controller.ts\":\n/*!******************************************!*\\\n !*** ./src/controller/fps-controller.ts ***!\n \\******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\nvar FPSController = /*#__PURE__*/function () {\n // stream controller must be provided as a dependency!\n function FPSController(hls) {\n this.hls = void 0;\n this.isVideoPlaybackQualityAvailable = false;\n this.timer = void 0;\n this.media = null;\n this.lastTime = void 0;\n this.lastDroppedFrames = 0;\n this.lastDecodedFrames = 0;\n this.streamController = void 0;\n this.hls = hls;\n this.registerListeners();\n }\n\n var _proto = FPSController.prototype;\n\n _proto.setStreamController = function setStreamController(streamController) {\n this.streamController = streamController;\n };\n\n _proto.registerListeners = function registerListeners() {\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching);\n };\n\n _proto.destroy = function destroy() {\n if (this.timer) {\n clearInterval(this.timer);\n }\n\n this.unregisterListeners();\n this.isVideoPlaybackQualityAvailable = false;\n this.media = null;\n };\n\n _proto.onMediaAttaching = function onMediaAttaching(event, data) {\n var config = this.hls.config;\n\n if (config.capLevelOnFPSDrop) {\n var media = data.media instanceof self.HTMLVideoElement ? data.media : null;\n this.media = media;\n\n if (media && typeof media.getVideoPlaybackQuality === 'function') {\n this.isVideoPlaybackQualityAvailable = true;\n }\n\n self.clearInterval(this.timer);\n this.timer = self.setInterval(this.checkFPSInterval.bind(this), config.fpsDroppedMonitoringPeriod);\n }\n };\n\n _proto.checkFPS = function checkFPS(video, decodedFrames, droppedFrames) {\n var currentTime = performance.now();\n\n if (decodedFrames) {\n if (this.lastTime) {\n var currentPeriod = currentTime - this.lastTime;\n var currentDropped = droppedFrames - this.lastDroppedFrames;\n var currentDecoded = decodedFrames - this.lastDecodedFrames;\n var droppedFPS = 1000 * currentDropped / currentPeriod;\n var hls = this.hls;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FPS_DROP, {\n currentDropped: currentDropped,\n currentDecoded: currentDecoded,\n totalDroppedFrames: droppedFrames\n });\n\n if (droppedFPS > 0) {\n // logger.log('checkFPS : droppedFPS/decodedFPS:' + droppedFPS/(1000 * currentDecoded / currentPeriod));\n if (currentDropped > hls.config.fpsDroppedMonitoringThreshold * currentDecoded) {\n var currentLevel = hls.currentLevel;\n _utils_logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].warn('drop FPS ratio greater than max allowed value for currentLevel: ' + currentLevel);\n\n if (currentLevel > 0 && (hls.autoLevelCapping === -1 || hls.autoLevelCapping >= currentLevel)) {\n currentLevel = currentLevel - 1;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FPS_DROP_LEVEL_CAPPING, {\n level: currentLevel,\n droppedLevel: hls.currentLevel\n });\n hls.autoLevelCapping = currentLevel;\n this.streamController.nextLevelSwitch();\n }\n }\n }\n }\n\n this.lastTime = currentTime;\n this.lastDroppedFrames = droppedFrames;\n this.lastDecodedFrames = decodedFrames;\n }\n };\n\n _proto.checkFPSInterval = function checkFPSInterval() {\n var video = this.media;\n\n if (video) {\n if (this.isVideoPlaybackQualityAvailable) {\n var videoPlaybackQuality = video.getVideoPlaybackQuality();\n this.checkFPS(video, videoPlaybackQuality.totalVideoFrames, videoPlaybackQuality.droppedVideoFrames);\n } else {\n // HTMLVideoElement doesn't include the webkit types\n this.checkFPS(video, video.webkitDecodedFrameCount, video.webkitDroppedFrameCount);\n }\n }\n };\n\n return FPSController;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (FPSController);\n\n/***/ }),\n\n/***/ \"./src/controller/fragment-finders.ts\":\n/*!********************************************!*\\\n !*** ./src/controller/fragment-finders.ts ***!\n \\********************************************/\n/*! exports provided: findFragmentByPDT, findFragmentByPTS, fragmentWithinToleranceTest, pdtWithinToleranceTest, findFragWithCC */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findFragmentByPDT\", function() { return findFragmentByPDT; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findFragmentByPTS\", function() { return findFragmentByPTS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"fragmentWithinToleranceTest\", function() { return fragmentWithinToleranceTest; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"pdtWithinToleranceTest\", function() { return pdtWithinToleranceTest; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findFragWithCC\", function() { return findFragWithCC; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _utils_binary_search__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/binary-search */ \"./src/utils/binary-search.ts\");\n\n\n\n/**\n * Returns first fragment whose endPdt value exceeds the given PDT.\n * @param {Array} fragments - The array of candidate fragments\n * @param {number|null} [PDTValue = null] - The PDT value which must be exceeded\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*|null} fragment - The best matching fragment\n */\nfunction findFragmentByPDT(fragments, PDTValue, maxFragLookUpTolerance) {\n if (PDTValue === null || !Array.isArray(fragments) || !fragments.length || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(PDTValue)) {\n return null;\n } // if less than start\n\n\n var startPDT = fragments[0].programDateTime;\n\n if (PDTValue < (startPDT || 0)) {\n return null;\n }\n\n var endPDT = fragments[fragments.length - 1].endProgramDateTime;\n\n if (PDTValue >= (endPDT || 0)) {\n return null;\n }\n\n maxFragLookUpTolerance = maxFragLookUpTolerance || 0;\n\n for (var seg = 0; seg < fragments.length; ++seg) {\n var frag = fragments[seg];\n\n if (pdtWithinToleranceTest(PDTValue, maxFragLookUpTolerance, frag)) {\n return frag;\n }\n }\n\n return null;\n}\n/**\n * Finds a fragment based on the SN of the previous fragment; or based on the needs of the current buffer.\n * This method compensates for small buffer gaps by applying a tolerance to the start of any candidate fragment, thus\n * breaking any traps which would cause the same fragment to be continuously selected within a small range.\n * @param {*} fragPrevious - The last frag successfully appended\n * @param {Array} fragments - The array of candidate fragments\n * @param {number} [bufferEnd = 0] - The end of the contiguous buffered range the playhead is currently within\n * @param {number} maxFragLookUpTolerance - The amount of time that a fragment's start/end can be within in order to be considered contiguous\n * @returns {*} foundFrag - The best matching fragment\n */\n\nfunction findFragmentByPTS(fragPrevious, fragments, bufferEnd, maxFragLookUpTolerance) {\n if (bufferEnd === void 0) {\n bufferEnd = 0;\n }\n\n if (maxFragLookUpTolerance === void 0) {\n maxFragLookUpTolerance = 0;\n }\n\n var fragNext = null;\n\n if (fragPrevious) {\n fragNext = fragments[fragPrevious.sn - fragments[0].sn + 1] || null;\n } else if (bufferEnd === 0 && fragments[0].start === 0) {\n fragNext = fragments[0];\n } // Prefer the next fragment if it's within tolerance\n\n\n if (fragNext && fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, fragNext) === 0) {\n return fragNext;\n } // We might be seeking past the tolerance so find the best match\n\n\n var foundFragment = _utils_binary_search__WEBPACK_IMPORTED_MODULE_1__[\"default\"].search(fragments, fragmentWithinToleranceTest.bind(null, bufferEnd, maxFragLookUpTolerance));\n\n if (foundFragment) {\n return foundFragment;\n } // If no match was found return the next fragment after fragPrevious, or null\n\n\n return fragNext;\n}\n/**\n * The test function used by the findFragmentBySn's BinarySearch to look for the best match to the current buffer conditions.\n * @param {*} candidate - The fragment to test\n * @param {number} [bufferEnd = 0] - The end of the current buffered range the playhead is currently within\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {number} - 0 if it matches, 1 if too low, -1 if too high\n */\n\nfunction fragmentWithinToleranceTest(bufferEnd, maxFragLookUpTolerance, candidate) {\n if (bufferEnd === void 0) {\n bufferEnd = 0;\n }\n\n if (maxFragLookUpTolerance === void 0) {\n maxFragLookUpTolerance = 0;\n }\n\n // offset should be within fragment boundary - config.maxFragLookUpTolerance\n // this is to cope with situations like\n // bufferEnd = 9.991\n // frag[Ø] : [0,10]\n // frag[1] : [10,20]\n // bufferEnd is within frag[0] range ... although what we are expecting is to return frag[1] here\n // frag start frag start+duration\n // |-----------------------------|\n // <---> <--->\n // ...--------><-----------------------------><---------....\n // previous frag matching fragment next frag\n // return -1 return 0 return 1\n // logger.log(`level/sn/start/end/bufEnd:${level}/${candidate.sn}/${candidate.start}/${(candidate.start+candidate.duration)}/${bufferEnd}`);\n // Set the lookup tolerance to be small enough to detect the current segment - ensures we don't skip over very small segments\n var candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0));\n\n if (candidate.start + candidate.duration - candidateLookupTolerance <= bufferEnd) {\n return 1;\n } else if (candidate.start - candidateLookupTolerance > bufferEnd && candidate.start) {\n // if maxFragLookUpTolerance will have negative value then don't return -1 for first element\n return -1;\n }\n\n return 0;\n}\n/**\n * The test function used by the findFragmentByPdt's BinarySearch to look for the best match to the current buffer conditions.\n * This function tests the candidate's program date time values, as represented in Unix time\n * @param {*} candidate - The fragment to test\n * @param {number} [pdtBufferEnd = 0] - The Unix time representing the end of the current buffered range\n * @param {number} [maxFragLookUpTolerance = 0] - The amount of time that a fragment's start can be within in order to be considered contiguous\n * @returns {boolean} True if contiguous, false otherwise\n */\n\nfunction pdtWithinToleranceTest(pdtBufferEnd, maxFragLookUpTolerance, candidate) {\n var candidateLookupTolerance = Math.min(maxFragLookUpTolerance, candidate.duration + (candidate.deltaPTS ? candidate.deltaPTS : 0)) * 1000; // endProgramDateTime can be null, default to zero\n\n var endProgramDateTime = candidate.endProgramDateTime || 0;\n return endProgramDateTime - candidateLookupTolerance > pdtBufferEnd;\n}\nfunction findFragWithCC(fragments, cc) {\n return _utils_binary_search__WEBPACK_IMPORTED_MODULE_1__[\"default\"].search(fragments, function (candidate) {\n if (candidate.cc < cc) {\n return 1;\n } else if (candidate.cc > cc) {\n return -1;\n } else {\n return 0;\n }\n });\n}\n\n/***/ }),\n\n/***/ \"./src/controller/fragment-tracker.ts\":\n/*!********************************************!*\\\n !*** ./src/controller/fragment-tracker.ts ***!\n \\********************************************/\n/*! exports provided: FragmentState, FragmentTracker */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"FragmentState\", function() { return FragmentState; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"FragmentTracker\", function() { return FragmentTracker; });\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n\n\nvar FragmentState;\n\n(function (FragmentState) {\n FragmentState[\"NOT_LOADED\"] = \"NOT_LOADED\";\n FragmentState[\"APPENDING\"] = \"APPENDING\";\n FragmentState[\"PARTIAL\"] = \"PARTIAL\";\n FragmentState[\"OK\"] = \"OK\";\n})(FragmentState || (FragmentState = {}));\n\nvar FragmentTracker = /*#__PURE__*/function () {\n function FragmentTracker(hls) {\n this.activeFragment = null;\n this.activeParts = null;\n this.fragments = Object.create(null);\n this.timeRanges = Object.create(null);\n this.bufferPadding = 0.2;\n this.hls = void 0;\n this.hls = hls;\n\n this._registerListeners();\n }\n\n var _proto = FragmentTracker.prototype;\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_APPENDED, this.onBufferAppended, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_APPENDED, this.onBufferAppended, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n };\n\n _proto.destroy = function destroy() {\n this._unregisterListeners(); // @ts-ignore\n\n\n this.fragments = this.timeRanges = null;\n }\n /**\n * Return a Fragment with an appended range that matches the position and levelType.\n * If not found any Fragment, return null\n */\n ;\n\n _proto.getAppendedFrag = function getAppendedFrag(position, levelType) {\n if (levelType === _types_loader__WEBPACK_IMPORTED_MODULE_1__[\"PlaylistLevelType\"].MAIN) {\n var activeFragment = this.activeFragment,\n activeParts = this.activeParts;\n\n if (!activeFragment) {\n return null;\n }\n\n if (activeParts) {\n for (var i = activeParts.length; i--;) {\n var activePart = activeParts[i];\n var appendedPTS = activePart ? activePart.end : activeFragment.appendedPTS;\n\n if (activePart.start <= position && appendedPTS !== undefined && position <= appendedPTS) {\n // 9 is a magic number. remove parts from lookup after a match but keep some short seeks back.\n if (i > 9) {\n this.activeParts = activeParts.slice(i - 9);\n }\n\n return activePart;\n }\n }\n } else if (activeFragment.start <= position && activeFragment.appendedPTS !== undefined && position <= activeFragment.appendedPTS) {\n return activeFragment;\n }\n }\n\n return this.getBufferedFrag(position, levelType);\n }\n /**\n * Return a buffered Fragment that matches the position and levelType.\n * A buffered Fragment is one whose loading, parsing and appending is done (completed or \"partial\" meaning aborted).\n * If not found any Fragment, return null\n */\n ;\n\n _proto.getBufferedFrag = function getBufferedFrag(position, levelType) {\n var fragments = this.fragments;\n var keys = Object.keys(fragments);\n\n for (var i = keys.length; i--;) {\n var fragmentEntity = fragments[keys[i]];\n\n if ((fragmentEntity === null || fragmentEntity === void 0 ? void 0 : fragmentEntity.body.type) === levelType && fragmentEntity.buffered) {\n var frag = fragmentEntity.body;\n\n if (frag.start <= position && position <= frag.end) {\n return frag;\n }\n }\n }\n\n return null;\n }\n /**\n * Partial fragments effected by coded frame eviction will be removed\n * The browser will unload parts of the buffer to free up memory for new buffer data\n * Fragments will need to be reloaded when the buffer is freed up, removing partial fragments will allow them to reload(since there might be parts that are still playable)\n */\n ;\n\n _proto.detectEvictedFragments = function detectEvictedFragments(elementaryStream, timeRange, playlistType) {\n var _this = this;\n\n // Check if any flagged fragments have been unloaded\n Object.keys(this.fragments).forEach(function (key) {\n var fragmentEntity = _this.fragments[key];\n\n if (!fragmentEntity) {\n return;\n }\n\n if (!fragmentEntity.buffered) {\n if (fragmentEntity.body.type === playlistType) {\n _this.removeFragment(fragmentEntity.body);\n }\n\n return;\n }\n\n var esData = fragmentEntity.range[elementaryStream];\n\n if (!esData) {\n return;\n }\n\n esData.time.some(function (time) {\n var isNotBuffered = !_this.isTimeBuffered(time.startPTS, time.endPTS, timeRange);\n\n if (isNotBuffered) {\n // Unregister partial fragment as it needs to load again to be reused\n _this.removeFragment(fragmentEntity.body);\n }\n\n return isNotBuffered;\n });\n });\n }\n /**\n * Checks if the fragment passed in is loaded in the buffer properly\n * Partially loaded fragments will be registered as a partial fragment\n */\n ;\n\n _proto.detectPartialFragments = function detectPartialFragments(data) {\n var _this2 = this;\n\n var timeRanges = this.timeRanges;\n var frag = data.frag,\n part = data.part;\n\n if (!timeRanges || frag.sn === 'initSegment') {\n return;\n }\n\n var fragKey = getFragmentKey(frag);\n var fragmentEntity = this.fragments[fragKey];\n\n if (!fragmentEntity) {\n return;\n }\n\n Object.keys(timeRanges).forEach(function (elementaryStream) {\n var streamInfo = frag.elementaryStreams[elementaryStream];\n\n if (!streamInfo) {\n return;\n }\n\n var timeRange = timeRanges[elementaryStream];\n var partial = part !== null || streamInfo.partial === true;\n fragmentEntity.range[elementaryStream] = _this2.getBufferedTimes(frag, part, partial, timeRange);\n });\n fragmentEntity.loaded = null;\n\n if (Object.keys(fragmentEntity.range).length) {\n fragmentEntity.buffered = true;\n } else {\n // remove fragment if nothing was appended\n this.removeFragment(fragmentEntity.body);\n }\n };\n\n _proto.fragBuffered = function fragBuffered(frag) {\n var fragKey = getFragmentKey(frag);\n var fragmentEntity = this.fragments[fragKey];\n\n if (fragmentEntity) {\n fragmentEntity.loaded = null;\n fragmentEntity.buffered = true;\n }\n };\n\n _proto.getBufferedTimes = function getBufferedTimes(fragment, part, partial, timeRange) {\n var buffered = {\n time: [],\n partial: partial\n };\n var startPTS = part ? part.start : fragment.start;\n var endPTS = part ? part.end : fragment.end;\n var minEndPTS = fragment.minEndPTS || endPTS;\n var maxStartPTS = fragment.maxStartPTS || startPTS;\n\n for (var i = 0; i < timeRange.length; i++) {\n var startTime = timeRange.start(i) - this.bufferPadding;\n var endTime = timeRange.end(i) + this.bufferPadding;\n\n if (maxStartPTS >= startTime && minEndPTS <= endTime) {\n // Fragment is entirely contained in buffer\n // No need to check the other timeRange times since it's completely playable\n buffered.time.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n break;\n } else if (startPTS < endTime && endPTS > startTime) {\n buffered.partial = true; // Check for intersection with buffer\n // Get playable sections of the fragment\n\n buffered.time.push({\n startPTS: Math.max(startPTS, timeRange.start(i)),\n endPTS: Math.min(endPTS, timeRange.end(i))\n });\n } else if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n break;\n }\n }\n\n return buffered;\n }\n /**\n * Gets the partial fragment for a certain time\n */\n ;\n\n _proto.getPartialFragment = function getPartialFragment(time) {\n var bestFragment = null;\n var timePadding;\n var startTime;\n var endTime;\n var bestOverlap = 0;\n var bufferPadding = this.bufferPadding,\n fragments = this.fragments;\n Object.keys(fragments).forEach(function (key) {\n var fragmentEntity = fragments[key];\n\n if (!fragmentEntity) {\n return;\n }\n\n if (isPartial(fragmentEntity)) {\n startTime = fragmentEntity.body.start - bufferPadding;\n endTime = fragmentEntity.body.end + bufferPadding;\n\n if (time >= startTime && time <= endTime) {\n // Use the fragment that has the most padding from start and end time\n timePadding = Math.min(time - startTime, endTime - time);\n\n if (bestOverlap <= timePadding) {\n bestFragment = fragmentEntity.body;\n bestOverlap = timePadding;\n }\n }\n }\n });\n return bestFragment;\n };\n\n _proto.getState = function getState(fragment) {\n var fragKey = getFragmentKey(fragment);\n var fragmentEntity = this.fragments[fragKey];\n\n if (fragmentEntity) {\n if (!fragmentEntity.buffered) {\n return FragmentState.APPENDING;\n } else if (isPartial(fragmentEntity)) {\n return FragmentState.PARTIAL;\n } else {\n return FragmentState.OK;\n }\n }\n\n return FragmentState.NOT_LOADED;\n };\n\n _proto.isTimeBuffered = function isTimeBuffered(startPTS, endPTS, timeRange) {\n var startTime;\n var endTime;\n\n for (var i = 0; i < timeRange.length; i++) {\n startTime = timeRange.start(i) - this.bufferPadding;\n endTime = timeRange.end(i) + this.bufferPadding;\n\n if (startPTS >= startTime && endPTS <= endTime) {\n return true;\n }\n\n if (endPTS <= startTime) {\n // No need to check the rest of the timeRange as it is in order\n return false;\n }\n }\n\n return false;\n };\n\n _proto.onFragLoaded = function onFragLoaded(event, data) {\n var frag = data.frag,\n part = data.part; // don't track initsegment (for which sn is not a number)\n // don't track frags used for bitrateTest, they're irrelevant.\n // don't track parts for memory efficiency\n\n if (frag.sn === 'initSegment' || frag.bitrateTest || part) {\n return;\n }\n\n var fragKey = getFragmentKey(frag);\n this.fragments[fragKey] = {\n body: frag,\n loaded: data,\n buffered: false,\n range: Object.create(null)\n };\n };\n\n _proto.onBufferAppended = function onBufferAppended(event, data) {\n var _this3 = this;\n\n var frag = data.frag,\n part = data.part,\n timeRanges = data.timeRanges;\n\n if (frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_1__[\"PlaylistLevelType\"].MAIN) {\n this.activeFragment = frag;\n\n if (part) {\n var activeParts = this.activeParts;\n\n if (!activeParts) {\n this.activeParts = activeParts = [];\n }\n\n activeParts.push(part);\n } else {\n this.activeParts = null;\n }\n } // Store the latest timeRanges loaded in the buffer\n\n\n this.timeRanges = timeRanges;\n Object.keys(timeRanges).forEach(function (elementaryStream) {\n var timeRange = timeRanges[elementaryStream];\n\n _this3.detectEvictedFragments(elementaryStream, timeRange);\n\n if (!part) {\n for (var i = 0; i < timeRange.length; i++) {\n frag.appendedPTS = Math.max(timeRange.end(i), frag.appendedPTS || 0);\n }\n }\n });\n };\n\n _proto.onFragBuffered = function onFragBuffered(event, data) {\n this.detectPartialFragments(data);\n };\n\n _proto.hasFragment = function hasFragment(fragment) {\n var fragKey = getFragmentKey(fragment);\n return !!this.fragments[fragKey];\n };\n\n _proto.removeFragmentsInRange = function removeFragmentsInRange(start, end, playlistType) {\n var _this4 = this;\n\n Object.keys(this.fragments).forEach(function (key) {\n var fragmentEntity = _this4.fragments[key];\n\n if (!fragmentEntity) {\n return;\n }\n\n if (fragmentEntity.buffered) {\n var frag = fragmentEntity.body;\n\n if (frag.type === playlistType && frag.start < end && frag.end > start) {\n _this4.removeFragment(frag);\n }\n }\n });\n };\n\n _proto.removeFragment = function removeFragment(fragment) {\n var fragKey = getFragmentKey(fragment);\n fragment.stats.loaded = 0;\n fragment.clearElementaryStreamInfo();\n delete this.fragments[fragKey];\n };\n\n _proto.removeAllFragments = function removeAllFragments() {\n this.fragments = Object.create(null);\n this.activeFragment = null;\n this.activeParts = null;\n };\n\n return FragmentTracker;\n}();\n\nfunction isPartial(fragmentEntity) {\n var _fragmentEntity$range, _fragmentEntity$range2;\n\n return fragmentEntity.buffered && (((_fragmentEntity$range = fragmentEntity.range.video) === null || _fragmentEntity$range === void 0 ? void 0 : _fragmentEntity$range.partial) || ((_fragmentEntity$range2 = fragmentEntity.range.audio) === null || _fragmentEntity$range2 === void 0 ? void 0 : _fragmentEntity$range2.partial));\n}\n\nfunction getFragmentKey(fragment) {\n return fragment.type + \"_\" + fragment.level + \"_\" + fragment.urlId + \"_\" + fragment.sn;\n}\n\n/***/ }),\n\n/***/ \"./src/controller/gap-controller.ts\":\n/*!******************************************!*\\\n !*** ./src/controller/gap-controller.ts ***!\n \\******************************************/\n/*! exports provided: STALL_MINIMUM_DURATION_MS, MAX_START_GAP_JUMP, SKIP_BUFFER_HOLE_STEP_SECONDS, SKIP_BUFFER_RANGE_START, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"STALL_MINIMUM_DURATION_MS\", function() { return STALL_MINIMUM_DURATION_MS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MAX_START_GAP_JUMP\", function() { return MAX_START_GAP_JUMP; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SKIP_BUFFER_HOLE_STEP_SECONDS\", function() { return SKIP_BUFFER_HOLE_STEP_SECONDS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SKIP_BUFFER_RANGE_START\", function() { return SKIP_BUFFER_RANGE_START; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return GapController; });\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\n\nvar STALL_MINIMUM_DURATION_MS = 250;\nvar MAX_START_GAP_JUMP = 2.0;\nvar SKIP_BUFFER_HOLE_STEP_SECONDS = 0.1;\nvar SKIP_BUFFER_RANGE_START = 0.05;\n\nvar GapController = /*#__PURE__*/function () {\n function GapController(config, media, fragmentTracker, hls) {\n this.config = void 0;\n this.media = null;\n this.fragmentTracker = void 0;\n this.hls = void 0;\n this.nudgeRetry = 0;\n this.stallReported = false;\n this.stalled = null;\n this.moved = false;\n this.seeking = false;\n this.config = config;\n this.media = media;\n this.fragmentTracker = fragmentTracker;\n this.hls = hls;\n }\n\n var _proto = GapController.prototype;\n\n _proto.destroy = function destroy() {\n this.media = null; // @ts-ignore\n\n this.hls = this.fragmentTracker = null;\n }\n /**\n * Checks if the playhead is stuck within a gap, and if so, attempts to free it.\n * A gap is an unbuffered range between two buffered ranges (or the start and the first buffered range).\n *\n * @param {number} lastCurrentTime Previously read playhead position\n */\n ;\n\n _proto.poll = function poll(lastCurrentTime, activeFrag) {\n var config = this.config,\n media = this.media,\n stalled = this.stalled;\n\n if (media === null) {\n return;\n }\n\n var currentTime = media.currentTime,\n seeking = media.seeking;\n var seeked = this.seeking && !seeking;\n var beginSeek = !this.seeking && seeking;\n this.seeking = seeking; // The playhead is moving, no-op\n\n if (currentTime !== lastCurrentTime) {\n this.moved = true;\n\n if (stalled !== null) {\n // The playhead is now moving, but was previously stalled\n if (this.stallReported) {\n var _stalledDuration = self.performance.now() - stalled;\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn(\"playback not stuck anymore @\" + currentTime + \", after \" + Math.round(_stalledDuration) + \"ms\");\n this.stallReported = false;\n }\n\n this.stalled = null;\n this.nudgeRetry = 0;\n }\n\n return;\n } // Clear stalled state when beginning or finishing seeking so that we don't report stalls coming out of a seek\n\n\n if (beginSeek || seeked) {\n this.stalled = null;\n } // The playhead should not be moving\n\n\n if (media.paused && !seeking || media.ended || media.playbackRate === 0 || !_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__[\"BufferHelper\"].getBuffered(media).length) {\n return;\n }\n\n var bufferInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__[\"BufferHelper\"].bufferInfo(media, currentTime, 0);\n var isBuffered = bufferInfo.len > 0;\n var nextStart = bufferInfo.nextStart || 0; // There is no playable buffer (seeked, waiting for buffer)\n\n if (!isBuffered && !nextStart) {\n return;\n }\n\n if (seeking) {\n // Waiting for seeking in a buffered range to complete\n var hasEnoughBuffer = bufferInfo.len > MAX_START_GAP_JUMP; // Next buffered range is too far ahead to jump to while still seeking\n\n var noBufferGap = !nextStart || activeFrag && activeFrag.start <= currentTime || nextStart - currentTime > MAX_START_GAP_JUMP && !this.fragmentTracker.getPartialFragment(currentTime);\n\n if (hasEnoughBuffer || noBufferGap) {\n return;\n } // Reset moved state when seeking to a point in or before a gap\n\n\n this.moved = false;\n } // Skip start gaps if we haven't played, but the last poll detected the start of a stall\n // The addition poll gives the browser a chance to jump the gap for us\n\n\n if (!this.moved && this.stalled !== null) {\n var _level$details;\n\n // Jump start gaps within jump threshold\n var startJump = Math.max(nextStart, bufferInfo.start || 0) - currentTime; // When joining a live stream with audio tracks, account for live playlist window sliding by allowing\n // a larger jump over start gaps caused by the audio-stream-controller buffering a start fragment\n // that begins over 1 target duration after the video start position.\n\n var level = this.hls.levels ? this.hls.levels[this.hls.currentLevel] : null;\n var isLive = level === null || level === void 0 ? void 0 : (_level$details = level.details) === null || _level$details === void 0 ? void 0 : _level$details.live;\n var maxStartGapJump = isLive ? level.details.targetduration * 2 : MAX_START_GAP_JUMP;\n\n if (startJump > 0 && startJump <= maxStartGapJump) {\n this._trySkipBufferHole(null);\n\n return;\n }\n } // Start tracking stall time\n\n\n var tnow = self.performance.now();\n\n if (stalled === null) {\n this.stalled = tnow;\n return;\n }\n\n var stalledDuration = tnow - stalled;\n\n if (!seeking && stalledDuration >= STALL_MINIMUM_DURATION_MS) {\n // Report stalling after trying to fix\n this._reportStall(bufferInfo);\n\n if (!this.media) {\n return;\n }\n }\n\n var bufferedWithHoles = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__[\"BufferHelper\"].bufferInfo(media, currentTime, config.maxBufferHole);\n\n this._tryFixBufferStall(bufferedWithHoles, stalledDuration);\n }\n /**\n * Detects and attempts to fix known buffer stalling issues.\n * @param bufferInfo - The properties of the current buffer.\n * @param stalledDurationMs - The amount of time Hls.js has been stalling for.\n * @private\n */\n ;\n\n _proto._tryFixBufferStall = function _tryFixBufferStall(bufferInfo, stalledDurationMs) {\n var config = this.config,\n fragmentTracker = this.fragmentTracker,\n media = this.media;\n\n if (media === null) {\n return;\n }\n\n var currentTime = media.currentTime;\n var partial = fragmentTracker.getPartialFragment(currentTime);\n\n if (partial) {\n // Try to skip over the buffer hole caused by a partial fragment\n // This method isn't limited by the size of the gap between buffered ranges\n var targetTime = this._trySkipBufferHole(partial); // we return here in this case, meaning\n // the branch below only executes when we don't handle a partial fragment\n\n\n if (targetTime || !this.media) {\n return;\n }\n } // if we haven't had to skip over a buffer hole of a partial fragment\n // we may just have to \"nudge\" the playlist as the browser decoding/rendering engine\n // needs to cross some sort of threshold covering all source-buffers content\n // to start playing properly.\n\n\n if (bufferInfo.len > config.maxBufferHole && stalledDurationMs > config.highBufferWatchdogPeriod * 1000) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn('Trying to nudge playhead over buffer-hole'); // Try to nudge currentTime over a buffer hole if we've been stalling for the configured amount of seconds\n // We only try to jump the hole if it's under the configured size\n // Reset stalled so to rearm watchdog timer\n\n this.stalled = null;\n\n this._tryNudgeBuffer();\n }\n }\n /**\n * Triggers a BUFFER_STALLED_ERROR event, but only once per stall period.\n * @param bufferLen - The playhead distance from the end of the current buffer segment.\n * @private\n */\n ;\n\n _proto._reportStall = function _reportStall(bufferInfo) {\n var hls = this.hls,\n media = this.media,\n stallReported = this.stallReported;\n\n if (!stallReported && media) {\n // Report stalled error once\n this.stallReported = true;\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn(\"Playback stalling at @\" + media.currentTime + \" due to low buffer (\" + JSON.stringify(bufferInfo) + \")\");\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].BUFFER_STALLED_ERROR,\n fatal: false,\n buffer: bufferInfo.len\n });\n }\n }\n /**\n * Attempts to fix buffer stalls by jumping over known gaps caused by partial fragments\n * @param partial - The partial fragment found at the current time (where playback is stalling).\n * @private\n */\n ;\n\n _proto._trySkipBufferHole = function _trySkipBufferHole(partial) {\n var config = this.config,\n hls = this.hls,\n media = this.media;\n\n if (media === null) {\n return 0;\n }\n\n var currentTime = media.currentTime;\n var lastEndTime = 0; // Check if currentTime is between unbuffered regions of partial fragments\n\n var buffered = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__[\"BufferHelper\"].getBuffered(media);\n\n for (var i = 0; i < buffered.length; i++) {\n var startTime = buffered.start(i);\n\n if (currentTime + config.maxBufferHole >= lastEndTime && currentTime < startTime) {\n var targetTime = Math.max(startTime + SKIP_BUFFER_RANGE_START, media.currentTime + SKIP_BUFFER_HOLE_STEP_SECONDS);\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn(\"skipping hole, adjusting currentTime from \" + currentTime + \" to \" + targetTime);\n this.moved = true;\n this.stalled = null;\n media.currentTime = targetTime;\n\n if (partial) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].BUFFER_SEEK_OVER_HOLE,\n fatal: false,\n reason: \"fragment loaded with buffer holes, seeking from \" + currentTime + \" to \" + targetTime,\n frag: partial\n });\n }\n\n return targetTime;\n }\n\n lastEndTime = buffered.end(i);\n }\n\n return 0;\n }\n /**\n * Attempts to fix buffer stalls by advancing the mediaElement's current time by a small amount.\n * @private\n */\n ;\n\n _proto._tryNudgeBuffer = function _tryNudgeBuffer() {\n var config = this.config,\n hls = this.hls,\n media = this.media,\n nudgeRetry = this.nudgeRetry;\n\n if (media === null) {\n return;\n }\n\n var currentTime = media.currentTime;\n this.nudgeRetry++;\n\n if (nudgeRetry < config.nudgeMaxRetry) {\n var targetTime = currentTime + (nudgeRetry + 1) * config.nudgeOffset; // playback stalled in buffered area ... let's nudge currentTime to try to overcome this\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn(\"Nudging 'currentTime' from \" + currentTime + \" to \" + targetTime);\n media.currentTime = targetTime;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].BUFFER_NUDGE_ON_STALL,\n fatal: false\n });\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].error(\"Playhead still not moving while enough data buffered @\" + currentTime + \" after \" + config.nudgeMaxRetry + \" nudges\");\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].BUFFER_STALLED_ERROR,\n fatal: true\n });\n }\n };\n\n return GapController;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/id3-track-controller.ts\":\n/*!************************************************!*\\\n !*** ./src/controller/id3-track-controller.ts ***!\n \\************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/texttrack-utils */ \"./src/utils/texttrack-utils.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n/* harmony import */ var _loader_date_range__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../loader/date-range */ \"./src/loader/date-range.ts\");\n/* harmony import */ var _types_demuxer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../types/demuxer */ \"./src/types/demuxer.ts\");\n\n\n\n\n\n\nvar MIN_CUE_DURATION = 0.25;\n\nfunction getCueClass() {\n // Attempt to recreate Safari functionality by creating\n // WebKitDataCue objects when available and store the decoded\n // ID3 data in the value property of the cue\n return self.WebKitDataCue || self.VTTCue || self.TextTrackCue;\n}\n\nfunction dateRangeDateToTimelineSeconds(date, offset) {\n return date.getTime() / 1000 - offset;\n}\n\nfunction hexToArrayBuffer(str) {\n return Uint8Array.from(str.replace(/^0x/, '').replace(/([\\da-fA-F]{2}) ?/g, '0x$1 ').replace(/ +$/, '').split(' ')).buffer;\n}\n\nvar ID3TrackController = /*#__PURE__*/function () {\n function ID3TrackController(hls) {\n this.hls = void 0;\n this.id3Track = null;\n this.media = null;\n this.dateRangeCuesAppended = {};\n this.hls = hls;\n\n this._registerListeners();\n }\n\n var _proto = ID3TrackController.prototype;\n\n _proto.destroy = function destroy() {\n this._unregisterListeners();\n\n this.id3Track = null;\n this.media = null;\n this.dateRangeCuesAppended = {}; // @ts-ignore\n\n this.hls = null;\n };\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSING_METADATA, this.onFragParsingMetadata, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSING_METADATA, this.onFragParsingMetadata, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated, this);\n } // Add ID3 metatadata text track.\n ;\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n this.media = data.media;\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n if (!this.id3Track) {\n return;\n }\n\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__[\"clearCurrentCues\"])(this.id3Track);\n this.id3Track = null;\n this.media = null;\n this.dateRangeCuesAppended = {};\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.dateRangeCuesAppended = {};\n };\n\n _proto.createTrack = function createTrack(media) {\n var track = this.getID3Track(media.textTracks);\n track.mode = 'hidden';\n return track;\n };\n\n _proto.getID3Track = function getID3Track(textTracks) {\n if (!this.media) {\n return;\n }\n\n for (var i = 0; i < textTracks.length; i++) {\n var textTrack = textTracks[i];\n\n if (textTrack.kind === 'metadata' && textTrack.label === 'id3') {\n // send 'addtrack' when reusing the textTrack for metadata,\n // same as what we do for captions\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__[\"sendAddTrackEvent\"])(textTrack, this.media);\n return textTrack;\n }\n }\n\n return this.media.addTextTrack('metadata', 'id3');\n };\n\n _proto.onFragParsingMetadata = function onFragParsingMetadata(event, data) {\n if (!this.media) {\n return;\n }\n\n var _this$hls$config = this.hls.config,\n enableEmsgMetadataCues = _this$hls$config.enableEmsgMetadataCues,\n enableID3MetadataCues = _this$hls$config.enableID3MetadataCues;\n\n if (!enableEmsgMetadataCues && !enableID3MetadataCues) {\n return;\n }\n\n var fragment = data.frag,\n samples = data.samples,\n details = data.details; // create track dynamically\n\n if (!this.id3Track) {\n this.id3Track = this.createTrack(this.media);\n } // VTTCue end time must be finite, so use playlist edge or fragment end until next fragment with same frame type is found\n\n\n var maxCueTime = details.edge || fragment.end;\n var Cue = getCueClass();\n var updateCueRanges = false;\n var frameTypesAdded = {};\n\n for (var i = 0; i < samples.length; i++) {\n var type = samples[i].type;\n\n if (type === _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].emsg && !enableEmsgMetadataCues || !enableID3MetadataCues) {\n continue;\n }\n\n var frames = _demux_id3__WEBPACK_IMPORTED_MODULE_3__[\"getID3Frames\"](samples[i].data);\n\n if (frames) {\n var startTime = samples[i].pts;\n var endTime = maxCueTime;\n var timeDiff = endTime - startTime;\n\n if (timeDiff <= 0) {\n endTime = startTime + MIN_CUE_DURATION;\n }\n\n for (var j = 0; j < frames.length; j++) {\n var frame = frames[j]; // Safari doesn't put the timestamp frame in the TextTrack\n\n if (!_demux_id3__WEBPACK_IMPORTED_MODULE_3__[\"isTimeStampFrame\"](frame)) {\n var cue = new Cue(startTime, endTime, '');\n cue.value = frame;\n\n if (type) {\n cue.type = type;\n }\n\n this.id3Track.addCue(cue);\n frameTypesAdded[frame.key] = null;\n updateCueRanges = true;\n }\n }\n }\n }\n\n if (updateCueRanges) {\n this.updateId3CueEnds(frameTypesAdded);\n }\n };\n\n _proto.updateId3CueEnds = function updateId3CueEnds(frameTypesAdded) {\n var _this$id3Track;\n\n // Update endTime of previous cue with same IDR frame.type (Ex: TXXX cue spans to next TXXX)\n var cues = (_this$id3Track = this.id3Track) === null || _this$id3Track === void 0 ? void 0 : _this$id3Track.cues;\n\n if (cues) {\n for (var i = cues.length; i--;) {\n var _cue$value;\n\n var cue = cues[i];\n var frameType = (_cue$value = cue.value) === null || _cue$value === void 0 ? void 0 : _cue$value.key;\n\n if (frameType && frameType in frameTypesAdded) {\n var startTime = frameTypesAdded[frameType];\n\n if (startTime && cue.endTime !== startTime) {\n cue.endTime = startTime;\n }\n\n frameTypesAdded[frameType] = cue.startTime;\n }\n }\n }\n };\n\n _proto.onBufferFlushing = function onBufferFlushing(event, _ref) {\n var startOffset = _ref.startOffset,\n endOffset = _ref.endOffset,\n type = _ref.type;\n var id3Track = this.id3Track,\n hls = this.hls;\n\n if (!hls) {\n return;\n }\n\n var _hls$config = hls.config,\n enableEmsgMetadataCues = _hls$config.enableEmsgMetadataCues,\n enableID3MetadataCues = _hls$config.enableID3MetadataCues;\n\n if (id3Track && (enableEmsgMetadataCues || enableID3MetadataCues)) {\n var predicate;\n\n if (type === 'audio') {\n predicate = function predicate(cue) {\n return cue.type === _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].audioId3 && enableID3MetadataCues;\n };\n } else if (type === 'video') {\n predicate = function predicate(cue) {\n return cue.type === _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].emsg && enableEmsgMetadataCues;\n };\n } else {\n predicate = function predicate(cue) {\n return cue.type === _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].audioId3 && enableID3MetadataCues || cue.type === _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].emsg && enableEmsgMetadataCues;\n };\n }\n\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__[\"removeCuesInRange\"])(id3Track, startOffset, endOffset, predicate);\n }\n };\n\n _proto.onLevelUpdated = function onLevelUpdated(event, _ref2) {\n var _this = this;\n\n var details = _ref2.details;\n\n if (!this.media || !details.hasProgramDateTime || !this.hls.config.enableDateRangeMetadataCues) {\n return;\n }\n\n var dateRangeCuesAppended = this.dateRangeCuesAppended,\n id3Track = this.id3Track;\n var dateRanges = details.dateRanges;\n var ids = Object.keys(dateRanges); // Remove cues from track not found in details.dateRanges\n\n if (id3Track) {\n var idsToRemove = Object.keys(dateRangeCuesAppended).filter(function (id) {\n return !ids.includes(id);\n });\n\n var _loop = function _loop(i) {\n var id = idsToRemove[i];\n Object.keys(dateRangeCuesAppended[id].cues).forEach(function (key) {\n id3Track.removeCue(dateRangeCuesAppended[id].cues[key]);\n });\n delete dateRangeCuesAppended[id];\n };\n\n for (var i = idsToRemove.length; i--;) {\n _loop(i);\n }\n } // Exit if the playlist does not have Date Ranges or does not have Program Date Time\n\n\n var lastFragment = details.fragments[details.fragments.length - 1];\n\n if (ids.length === 0 || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(lastFragment === null || lastFragment === void 0 ? void 0 : lastFragment.programDateTime)) {\n return;\n }\n\n if (!this.id3Track) {\n this.id3Track = this.createTrack(this.media);\n }\n\n var dateTimeOffset = lastFragment.programDateTime / 1000 - lastFragment.start;\n var maxCueTime = details.edge || lastFragment.end;\n var Cue = getCueClass();\n\n var _loop2 = function _loop2(_i) {\n var id = ids[_i];\n var dateRange = dateRanges[id];\n var appendedDateRangeCues = dateRangeCuesAppended[id];\n var cues = (appendedDateRangeCues === null || appendedDateRangeCues === void 0 ? void 0 : appendedDateRangeCues.cues) || {};\n var durationKnown = (appendedDateRangeCues === null || appendedDateRangeCues === void 0 ? void 0 : appendedDateRangeCues.durationKnown) || false;\n var startTime = dateRangeDateToTimelineSeconds(dateRange.startDate, dateTimeOffset);\n var endTime = maxCueTime;\n var endDate = dateRange.endDate;\n\n if (endDate) {\n endTime = dateRangeDateToTimelineSeconds(endDate, dateTimeOffset);\n durationKnown = true;\n } else if (dateRange.endOnNext && !durationKnown) {\n var nextDateRangeWithSameClass = ids.reduce(function (filterMapArray, id) {\n var candidate = dateRanges[id];\n\n if (candidate.class === dateRange.class && candidate.id !== id && candidate.startDate > dateRange.startDate) {\n filterMapArray.push(candidate);\n }\n\n return filterMapArray;\n }, []).sort(function (a, b) {\n return a.startDate.getTime() - b.startDate.getTime();\n })[0];\n\n if (nextDateRangeWithSameClass) {\n endTime = dateRangeDateToTimelineSeconds(nextDateRangeWithSameClass.startDate, dateTimeOffset);\n durationKnown = true;\n }\n }\n\n var attributes = Object.keys(dateRange.attr);\n\n for (var j = 0; j < attributes.length; j++) {\n var key = attributes[j];\n\n if (key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].ID || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].CLASS || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].START_DATE || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].DURATION || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].END_DATE || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].END_ON_NEXT) {\n continue;\n }\n\n var cue = cues[key];\n\n if (cue) {\n if (durationKnown && !appendedDateRangeCues.durationKnown) {\n cue.endTime = endTime;\n }\n } else {\n var data = dateRange.attr[key];\n cue = new Cue(startTime, endTime, '');\n\n if (key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].SCTE35_OUT || key === _loader_date_range__WEBPACK_IMPORTED_MODULE_4__[\"DateRangeAttribute\"].SCTE35_IN) {\n data = hexToArrayBuffer(data);\n }\n\n cue.value = {\n key: key,\n data: data\n };\n cue.type = _types_demuxer__WEBPACK_IMPORTED_MODULE_5__[\"MetadataSchema\"].dateRange;\n\n _this.id3Track.addCue(cue);\n\n cues[key] = cue;\n }\n }\n\n dateRangeCuesAppended[id] = {\n cues: cues,\n dateRange: dateRange,\n durationKnown: durationKnown\n };\n };\n\n for (var _i = 0; _i < ids.length; _i++) {\n _loop2(_i);\n }\n };\n\n return ID3TrackController;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (ID3TrackController);\n\n/***/ }),\n\n/***/ \"./src/controller/latency-controller.ts\":\n/*!**********************************************!*\\\n !*** ./src/controller/latency-controller.ts ***!\n \\**********************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return LatencyController; });\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\n\n\nvar LatencyController = /*#__PURE__*/function () {\n function LatencyController(hls) {\n var _this = this;\n\n this.hls = void 0;\n this.config = void 0;\n this.media = null;\n this.levelDetails = null;\n this.currentTime = 0;\n this.stallCount = 0;\n this._latency = null;\n\n this.timeupdateHandler = function () {\n return _this.timeupdate();\n };\n\n this.hls = hls;\n this.config = hls.config;\n this.registerListeners();\n }\n\n var _proto = LatencyController.prototype;\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.onMediaDetaching();\n this.levelDetails = null; // @ts-ignore\n\n this.hls = this.timeupdateHandler = null;\n };\n\n _proto.registerListeners = function registerListeners() {\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated, this);\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_UPDATED, this.onLevelUpdated);\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, this.onError);\n };\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n this.media = data.media;\n this.media.addEventListener('timeupdate', this.timeupdateHandler);\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n if (this.media) {\n this.media.removeEventListener('timeupdate', this.timeupdateHandler);\n this.media = null;\n }\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.levelDetails = null;\n this._latency = null;\n this.stallCount = 0;\n };\n\n _proto.onLevelUpdated = function onLevelUpdated(event, _ref) {\n var details = _ref.details;\n this.levelDetails = details;\n\n if (details.advanced) {\n this.timeupdate();\n }\n\n if (!details.live && this.media) {\n this.media.removeEventListener('timeupdate', this.timeupdateHandler);\n }\n };\n\n _proto.onError = function onError(event, data) {\n if (data.details !== _errors__WEBPACK_IMPORTED_MODULE_0__[\"ErrorDetails\"].BUFFER_STALLED_ERROR) {\n return;\n }\n\n this.stallCount++;\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('[playback-rate-controller]: Stall detected, adjusting target latency');\n };\n\n _proto.timeupdate = function timeupdate() {\n var media = this.media,\n levelDetails = this.levelDetails;\n\n if (!media || !levelDetails) {\n return;\n }\n\n this.currentTime = media.currentTime;\n var latency = this.computeLatency();\n\n if (latency === null) {\n return;\n }\n\n this._latency = latency; // Adapt playbackRate to meet target latency in low-latency mode\n\n var _this$config = this.config,\n lowLatencyMode = _this$config.lowLatencyMode,\n maxLiveSyncPlaybackRate = _this$config.maxLiveSyncPlaybackRate;\n\n if (!lowLatencyMode || maxLiveSyncPlaybackRate === 1) {\n return;\n }\n\n var targetLatency = this.targetLatency;\n\n if (targetLatency === null) {\n return;\n }\n\n var distanceFromTarget = latency - targetLatency; // Only adjust playbackRate when within one target duration of targetLatency\n // and more than one second from under-buffering.\n // Playback further than one target duration from target can be considered DVR playback.\n\n var liveMinLatencyDuration = Math.min(this.maxLatency, targetLatency + levelDetails.targetduration);\n var inLiveRange = distanceFromTarget < liveMinLatencyDuration;\n\n if (levelDetails.live && inLiveRange && distanceFromTarget > 0.05 && this.forwardBufferLength > 1) {\n var max = Math.min(2, Math.max(1.0, maxLiveSyncPlaybackRate));\n var rate = Math.round(2 / (1 + Math.exp(-0.75 * distanceFromTarget - this.edgeStalled)) * 20) / 20;\n media.playbackRate = Math.min(max, Math.max(1, rate));\n } else if (media.playbackRate !== 1 && media.playbackRate !== 0) {\n media.playbackRate = 1;\n }\n };\n\n _proto.estimateLiveEdge = function estimateLiveEdge() {\n var levelDetails = this.levelDetails;\n\n if (levelDetails === null) {\n return null;\n }\n\n return levelDetails.edge + levelDetails.age;\n };\n\n _proto.computeLatency = function computeLatency() {\n var liveEdge = this.estimateLiveEdge();\n\n if (liveEdge === null) {\n return null;\n }\n\n return liveEdge - this.currentTime;\n };\n\n _createClass(LatencyController, [{\n key: \"latency\",\n get: function get() {\n return this._latency || 0;\n }\n }, {\n key: \"maxLatency\",\n get: function get() {\n var config = this.config,\n levelDetails = this.levelDetails;\n\n if (config.liveMaxLatencyDuration !== undefined) {\n return config.liveMaxLatencyDuration;\n }\n\n return levelDetails ? config.liveMaxLatencyDurationCount * levelDetails.targetduration : 0;\n }\n }, {\n key: \"targetLatency\",\n get: function get() {\n var levelDetails = this.levelDetails;\n\n if (levelDetails === null) {\n return null;\n }\n\n var holdBack = levelDetails.holdBack,\n partHoldBack = levelDetails.partHoldBack,\n targetduration = levelDetails.targetduration;\n var _this$config2 = this.config,\n liveSyncDuration = _this$config2.liveSyncDuration,\n liveSyncDurationCount = _this$config2.liveSyncDurationCount,\n lowLatencyMode = _this$config2.lowLatencyMode;\n var userConfig = this.hls.userConfig;\n var targetLatency = lowLatencyMode ? partHoldBack || holdBack : holdBack;\n\n if (userConfig.liveSyncDuration || userConfig.liveSyncDurationCount || targetLatency === 0) {\n targetLatency = liveSyncDuration !== undefined ? liveSyncDuration : liveSyncDurationCount * targetduration;\n }\n\n var maxLiveSyncOnStallIncrease = targetduration;\n var liveSyncOnStallIncrease = 1.0;\n return targetLatency + Math.min(this.stallCount * liveSyncOnStallIncrease, maxLiveSyncOnStallIncrease);\n }\n }, {\n key: \"liveSyncPosition\",\n get: function get() {\n var liveEdge = this.estimateLiveEdge();\n var targetLatency = this.targetLatency;\n var levelDetails = this.levelDetails;\n\n if (liveEdge === null || targetLatency === null || levelDetails === null) {\n return null;\n }\n\n var edge = levelDetails.edge;\n var syncPosition = liveEdge - targetLatency - this.edgeStalled;\n var min = edge - levelDetails.totalduration;\n var max = edge - (this.config.lowLatencyMode && levelDetails.partTarget || levelDetails.targetduration);\n return Math.min(Math.max(min, syncPosition), max);\n }\n }, {\n key: \"drift\",\n get: function get() {\n var levelDetails = this.levelDetails;\n\n if (levelDetails === null) {\n return 1;\n }\n\n return levelDetails.drift;\n }\n }, {\n key: \"edgeStalled\",\n get: function get() {\n var levelDetails = this.levelDetails;\n\n if (levelDetails === null) {\n return 0;\n }\n\n var maxLevelUpdateAge = (this.config.lowLatencyMode && levelDetails.partTarget || levelDetails.targetduration) * 3;\n return Math.max(levelDetails.age - maxLevelUpdateAge, 0);\n }\n }, {\n key: \"forwardBufferLength\",\n get: function get() {\n var media = this.media,\n levelDetails = this.levelDetails;\n\n if (!media || !levelDetails) {\n return 0;\n }\n\n var bufferedRanges = media.buffered.length;\n return (bufferedRanges ? media.buffered.end(bufferedRanges - 1) : levelDetails.edge) - this.currentTime;\n }\n }]);\n\n return LatencyController;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/level-controller.ts\":\n/*!********************************************!*\\\n !*** ./src/controller/level-controller.ts ***!\n \\********************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return LevelController; });\n/* harmony import */ var _types_level__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../types/level */ \"./src/types/level.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_codecs__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/codecs */ \"./src/utils/codecs.ts\");\n/* harmony import */ var _level_helper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./level-helper */ \"./src/controller/level-helper.ts\");\n/* harmony import */ var _base_playlist_controller__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./base-playlist-controller */ \"./src/controller/base-playlist-controller.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n/*\n * Level Controller\n */\n\n\n\n\n\n\n\nvar chromeOrFirefox = /chrome|firefox/.test(navigator.userAgent.toLowerCase());\n\nvar LevelController = /*#__PURE__*/function (_BasePlaylistControll) {\n _inheritsLoose(LevelController, _BasePlaylistControll);\n\n function LevelController(hls) {\n var _this;\n\n _this = _BasePlaylistControll.call(this, hls, '[level-controller]') || this;\n _this._levels = [];\n _this._firstLevel = -1;\n _this._startLevel = void 0;\n _this.currentLevelIndex = -1;\n _this.manualLevelIndex = -1;\n _this.onParsedComplete = void 0;\n\n _this._registerListeners();\n\n return _this;\n }\n\n var _proto = LevelController.prototype;\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, this.onManifestLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].AUDIO_TRACK_SWITCHED, this.onAudioTrackSwitched, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, this.onManifestLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].AUDIO_TRACK_SWITCHED, this.onAudioTrackSwitched, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.destroy = function destroy() {\n this._unregisterListeners();\n\n this.manualLevelIndex = -1;\n this._levels.length = 0;\n\n _BasePlaylistControll.prototype.destroy.call(this);\n };\n\n _proto.startLoad = function startLoad() {\n var levels = this._levels; // clean up live level details to force reload them, and reset load errors\n\n levels.forEach(function (level) {\n level.loadError = 0;\n });\n\n _BasePlaylistControll.prototype.startLoad.call(this);\n };\n\n _proto.onManifestLoaded = function onManifestLoaded(event, data) {\n var levels = [];\n var audioTracks = [];\n var subtitleTracks = [];\n var bitrateStart;\n var levelSet = {};\n var levelFromSet;\n var resolutionFound = false;\n var videoCodecFound = false;\n var audioCodecFound = false; // regroup redundant levels together\n\n data.levels.forEach(function (levelParsed) {\n var attributes = levelParsed.attrs;\n resolutionFound = resolutionFound || !!(levelParsed.width && levelParsed.height);\n videoCodecFound = videoCodecFound || !!levelParsed.videoCodec;\n audioCodecFound = audioCodecFound || !!levelParsed.audioCodec; // erase audio codec info if browser does not support mp4a.40.34.\n // demuxer will autodetect codec and fallback to mpeg/audio\n\n if (chromeOrFirefox && levelParsed.audioCodec && levelParsed.audioCodec.indexOf('mp4a.40.34') !== -1) {\n levelParsed.audioCodec = undefined;\n }\n\n var levelKey = levelParsed.bitrate + \"-\" + levelParsed.attrs.RESOLUTION + \"-\" + levelParsed.attrs.CODECS;\n levelFromSet = levelSet[levelKey];\n\n if (!levelFromSet) {\n levelFromSet = new _types_level__WEBPACK_IMPORTED_MODULE_0__[\"Level\"](levelParsed);\n levelSet[levelKey] = levelFromSet;\n levels.push(levelFromSet);\n } else {\n levelFromSet.url.push(levelParsed.url);\n }\n\n if (attributes) {\n if (attributes.AUDIO) {\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"addGroupId\"])(levelFromSet, 'audio', attributes.AUDIO);\n }\n\n if (attributes.SUBTITLES) {\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"addGroupId\"])(levelFromSet, 'text', attributes.SUBTITLES);\n }\n }\n }); // remove audio-only level if we also have levels with video codecs or RESOLUTION signalled\n\n if ((resolutionFound || videoCodecFound) && audioCodecFound) {\n levels = levels.filter(function (_ref) {\n var videoCodec = _ref.videoCodec,\n width = _ref.width,\n height = _ref.height;\n return !!videoCodec || !!(width && height);\n });\n } // only keep levels with supported audio/video codecs\n\n\n levels = levels.filter(function (_ref2) {\n var audioCodec = _ref2.audioCodec,\n videoCodec = _ref2.videoCodec;\n return (!audioCodec || Object(_utils_codecs__WEBPACK_IMPORTED_MODULE_3__[\"isCodecSupportedInMp4\"])(audioCodec, 'audio')) && (!videoCodec || Object(_utils_codecs__WEBPACK_IMPORTED_MODULE_3__[\"isCodecSupportedInMp4\"])(videoCodec, 'video'));\n });\n\n if (data.audioTracks) {\n audioTracks = data.audioTracks.filter(function (track) {\n return !track.audioCodec || Object(_utils_codecs__WEBPACK_IMPORTED_MODULE_3__[\"isCodecSupportedInMp4\"])(track.audioCodec, 'audio');\n }); // Assign ids after filtering as array indices by group-id\n\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"assignTrackIdsByGroup\"])(audioTracks);\n }\n\n if (data.subtitles) {\n subtitleTracks = data.subtitles;\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"assignTrackIdsByGroup\"])(subtitleTracks);\n }\n\n if (levels.length > 0) {\n // start bitrate is the first bitrate of the manifest\n bitrateStart = levels[0].bitrate; // sort level on bitrate\n\n levels.sort(function (a, b) {\n return a.bitrate - b.bitrate;\n });\n this._levels = levels; // find index of first level in sorted levels\n\n for (var i = 0; i < levels.length; i++) {\n if (levels[i].bitrate === bitrateStart) {\n this._firstLevel = i;\n this.log(\"manifest loaded, \" + levels.length + \" level(s) found, first bitrate: \" + bitrateStart);\n break;\n }\n } // Audio is only alternate if manifest include a URI along with the audio group tag,\n // and this is not an audio-only stream where levels contain audio-only\n\n\n var audioOnly = audioCodecFound && !videoCodecFound;\n var edata = {\n levels: levels,\n audioTracks: audioTracks,\n subtitleTracks: subtitleTracks,\n firstLevel: this._firstLevel,\n stats: data.stats,\n audio: audioCodecFound,\n video: videoCodecFound,\n altAudio: !audioOnly && audioTracks.some(function (t) {\n return !!t.url;\n })\n };\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_PARSED, edata); // Initiate loading after all controllers have received MANIFEST_PARSED\n\n if (this.hls.config.autoStartLoad || this.hls.forceStartLoad) {\n this.hls.startLoad(this.hls.config.startPosition);\n }\n } else {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].MANIFEST_INCOMPATIBLE_CODECS_ERROR,\n fatal: true,\n url: data.url,\n reason: 'no level with compatible codecs found in manifest'\n });\n }\n };\n\n _proto.onError = function onError(event, data) {\n var _data$level;\n\n _BasePlaylistControll.prototype.onError.call(this, event, data);\n\n if (data.fatal) {\n return;\n } // Switch to redundant level when track fails to load\n\n\n var context = data.context;\n var level = this._levels[this.currentLevelIndex];\n\n if (context && (context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK && level.audioGroupIds && context.groupId === level.audioGroupIds[level.urlId] || context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK && level.textGroupIds && context.groupId === level.textGroupIds[level.urlId])) {\n this.redundantFailover(this.currentLevelIndex);\n return;\n }\n\n var levelError = false;\n var levelSwitch = true;\n var levelIndex; // try to recover not fatal errors\n\n switch (data.details) {\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].FRAG_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT:\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].KEY_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].KEY_LOAD_TIMEOUT:\n if (data.frag) {\n // Share fragment error count accross media options (main, audio, subs)\n // This allows for level based rendition switching when media option assets fail\n var variantLevelIndex = data.frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN ? data.frag.level : this.currentLevelIndex;\n var _level = this._levels[variantLevelIndex]; // Set levelIndex when we're out of fragment retries\n\n if (_level) {\n _level.fragmentError++;\n\n if (_level.fragmentError > this.hls.config.fragLoadingMaxRetry) {\n levelIndex = variantLevelIndex;\n }\n } else {\n levelIndex = variantLevelIndex;\n }\n }\n\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_LOAD_TIMEOUT:\n // Do not perform level switch if an error occurred using delivery directives\n // Attempt to reload level without directives first\n if (context) {\n if (context.deliveryDirectives) {\n levelSwitch = false;\n }\n\n levelIndex = context.level;\n }\n\n levelError = true;\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].REMUX_ALLOC_ERROR:\n levelIndex = (_data$level = data.level) != null ? _data$level : this.currentLevelIndex;\n levelError = true;\n break;\n }\n\n if (levelIndex !== undefined) {\n this.recoverLevel(data, levelIndex, levelError, levelSwitch);\n }\n }\n /**\n * Switch to a redundant stream if any available.\n * If redundant stream is not available, emergency switch down if ABR mode is enabled.\n */\n ;\n\n _proto.recoverLevel = function recoverLevel(errorEvent, levelIndex, levelError, levelSwitch) {\n var errorDetails = errorEvent.details;\n var level = this._levels[levelIndex];\n level.loadError++;\n\n if (levelError) {\n var retrying = this.retryLoadingOrFail(errorEvent);\n\n if (retrying) {\n // boolean used to inform stream controller not to switch back to IDLE on non fatal error\n errorEvent.levelRetry = true;\n } else {\n this.currentLevelIndex = -1;\n return;\n }\n }\n\n if (levelSwitch) {\n var redundantLevels = level.url.length; // Try redundant fail-over until level.loadError reaches redundantLevels\n\n if (redundantLevels > 1 && level.loadError < redundantLevels) {\n errorEvent.levelRetry = true;\n this.redundantFailover(levelIndex);\n } else if (this.manualLevelIndex === -1) {\n // Search for next level to retry\n var nextLevel = -1;\n var levels = this._levels;\n\n for (var i = levels.length; i--;) {\n var candidate = (i + this.currentLevelIndex) % levels.length;\n\n if (candidate !== this.currentLevelIndex && levels[candidate].loadError === 0) {\n nextLevel = candidate;\n break;\n }\n }\n\n if (nextLevel > -1 && this.currentLevelIndex !== nextLevel) {\n this.warn(errorDetails + \": switch to \" + nextLevel);\n errorEvent.levelRetry = true;\n this.hls.nextAutoLevel = nextLevel;\n }\n }\n }\n };\n\n _proto.redundantFailover = function redundantFailover(levelIndex) {\n var level = this._levels[levelIndex];\n var redundantLevels = level.url.length;\n\n if (redundantLevels > 1) {\n // Update the url id of all levels so that we stay on the same set of variants when level switching\n var newUrlId = (level.urlId + 1) % redundantLevels;\n this.warn(\"Switching to redundant URL-id \" + newUrlId);\n\n this._levels.forEach(function (level) {\n level.urlId = newUrlId;\n });\n\n this.level = levelIndex;\n }\n } // reset errors on the successful load of a fragment\n ;\n\n _proto.onFragLoaded = function onFragLoaded(event, _ref3) {\n var frag = _ref3.frag;\n\n if (frag !== undefined && frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN) {\n var level = this._levels[frag.level];\n\n if (level !== undefined) {\n level.fragmentError = 0;\n level.loadError = 0;\n }\n }\n };\n\n _proto.onLevelLoaded = function onLevelLoaded(event, data) {\n var _data$deliveryDirecti2;\n\n var level = data.level,\n details = data.details;\n var curLevel = this._levels[level];\n\n if (!curLevel) {\n var _data$deliveryDirecti;\n\n this.warn(\"Invalid level index \" + level);\n\n if ((_data$deliveryDirecti = data.deliveryDirectives) !== null && _data$deliveryDirecti !== void 0 && _data$deliveryDirecti.skip) {\n details.deltaUpdateFailed = true;\n }\n\n return;\n } // only process level loaded events matching with expected level\n\n\n if (level === this.currentLevelIndex) {\n // reset level load error counter on successful level loaded only if there is no issues with fragments\n if (curLevel.fragmentError === 0) {\n curLevel.loadError = 0;\n this.retryCount = 0;\n }\n\n this.playlistLoaded(level, data, curLevel.details);\n } else if ((_data$deliveryDirecti2 = data.deliveryDirectives) !== null && _data$deliveryDirecti2 !== void 0 && _data$deliveryDirecti2.skip) {\n // received a delta playlist update that cannot be merged\n details.deltaUpdateFailed = true;\n }\n };\n\n _proto.onAudioTrackSwitched = function onAudioTrackSwitched(event, data) {\n var currentLevel = this.hls.levels[this.currentLevelIndex];\n\n if (!currentLevel) {\n return;\n }\n\n if (currentLevel.audioGroupIds) {\n var urlId = -1;\n var audioGroupId = this.hls.audioTracks[data.id].groupId;\n\n for (var i = 0; i < currentLevel.audioGroupIds.length; i++) {\n if (currentLevel.audioGroupIds[i] === audioGroupId) {\n urlId = i;\n break;\n }\n }\n\n if (urlId !== currentLevel.urlId) {\n currentLevel.urlId = urlId;\n this.startLoad();\n }\n }\n };\n\n _proto.loadPlaylist = function loadPlaylist(hlsUrlParameters) {\n var level = this.currentLevelIndex;\n var currentLevel = this._levels[level];\n\n if (this.canLoad && currentLevel && currentLevel.url.length > 0) {\n var id = currentLevel.urlId;\n var url = currentLevel.url[id];\n\n if (hlsUrlParameters) {\n try {\n url = hlsUrlParameters.addDirectives(url);\n } catch (error) {\n this.warn(\"Could not construct new URL with HLS Delivery Directives: \" + error);\n }\n }\n\n this.log(\"Attempt loading level index \" + level + (hlsUrlParameters ? ' at sn ' + hlsUrlParameters.msn + ' part ' + hlsUrlParameters.part : '') + \" with URL-id \" + id + \" \" + url); // console.log('Current audio track group ID:', this.hls.audioTracks[this.hls.audioTrack].groupId);\n // console.log('New video quality level audio group id:', levelObject.attrs.AUDIO, level);\n\n this.clearTimer();\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADING, {\n url: url,\n level: level,\n id: id,\n deliveryDirectives: hlsUrlParameters || null\n });\n }\n };\n\n _proto.removeLevel = function removeLevel(levelIndex, urlId) {\n var filterLevelAndGroupByIdIndex = function filterLevelAndGroupByIdIndex(url, id) {\n return id !== urlId;\n };\n\n var levels = this._levels.filter(function (level, index) {\n if (index !== levelIndex) {\n return true;\n }\n\n if (level.url.length > 1 && urlId !== undefined) {\n level.url = level.url.filter(filterLevelAndGroupByIdIndex);\n\n if (level.audioGroupIds) {\n level.audioGroupIds = level.audioGroupIds.filter(filterLevelAndGroupByIdIndex);\n }\n\n if (level.textGroupIds) {\n level.textGroupIds = level.textGroupIds.filter(filterLevelAndGroupByIdIndex);\n }\n\n level.urlId = 0;\n return true;\n }\n\n return false;\n }).map(function (level, index) {\n var details = level.details;\n\n if (details !== null && details !== void 0 && details.fragments) {\n details.fragments.forEach(function (fragment) {\n fragment.level = index;\n });\n }\n\n return level;\n });\n\n this._levels = levels;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVELS_UPDATED, {\n levels: levels\n });\n };\n\n _createClass(LevelController, [{\n key: \"levels\",\n get: function get() {\n if (this._levels.length === 0) {\n return null;\n }\n\n return this._levels;\n }\n }, {\n key: \"level\",\n get: function get() {\n return this.currentLevelIndex;\n },\n set: function set(newLevel) {\n var _levels$newLevel;\n\n var levels = this._levels;\n\n if (levels.length === 0) {\n return;\n }\n\n if (this.currentLevelIndex === newLevel && (_levels$newLevel = levels[newLevel]) !== null && _levels$newLevel !== void 0 && _levels$newLevel.details) {\n return;\n } // check if level idx is valid\n\n\n if (newLevel < 0 || newLevel >= levels.length) {\n // invalid level id given, trigger error\n var fatal = newLevel < 0;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorTypes\"].OTHER_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_SWITCH_ERROR,\n level: newLevel,\n fatal: fatal,\n reason: 'invalid level idx'\n });\n\n if (fatal) {\n return;\n }\n\n newLevel = Math.min(newLevel, levels.length - 1);\n } // stopping live reloading timer if any\n\n\n this.clearTimer();\n var lastLevelIndex = this.currentLevelIndex;\n var lastLevel = levels[lastLevelIndex];\n var level = levels[newLevel];\n this.log(\"switching to level \" + newLevel + \" from \" + lastLevelIndex);\n this.currentLevelIndex = newLevel;\n\n var levelSwitchingData = _extends({}, level, {\n level: newLevel,\n maxBitrate: level.maxBitrate,\n uri: level.uri,\n urlId: level.urlId\n }); // @ts-ignore\n\n\n delete levelSwitchingData._urlId;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_SWITCHING, levelSwitchingData); // check if we need to load playlist for this level\n\n var levelDetails = level.details;\n\n if (!levelDetails || levelDetails.live) {\n // level not retrieved yet, or live playlist we need to (re)load it\n var hlsUrlParameters = this.switchParams(level.uri, lastLevel === null || lastLevel === void 0 ? void 0 : lastLevel.details);\n this.loadPlaylist(hlsUrlParameters);\n }\n }\n }, {\n key: \"manualLevel\",\n get: function get() {\n return this.manualLevelIndex;\n },\n set: function set(newLevel) {\n this.manualLevelIndex = newLevel;\n\n if (this._startLevel === undefined) {\n this._startLevel = newLevel;\n }\n\n if (newLevel !== -1) {\n this.level = newLevel;\n }\n }\n }, {\n key: \"firstLevel\",\n get: function get() {\n return this._firstLevel;\n },\n set: function set(newLevel) {\n this._firstLevel = newLevel;\n }\n }, {\n key: \"startLevel\",\n get: function get() {\n // hls.startLevel takes precedence over config.startLevel\n // if none of these values are defined, fallback on this._firstLevel (first quality level appearing in variant manifest)\n if (this._startLevel === undefined) {\n var configStartLevel = this.hls.config.startLevel;\n\n if (configStartLevel !== undefined) {\n return configStartLevel;\n } else {\n return this._firstLevel;\n }\n } else {\n return this._startLevel;\n }\n },\n set: function set(newLevel) {\n this._startLevel = newLevel;\n }\n }, {\n key: \"nextLoadLevel\",\n get: function get() {\n if (this.manualLevelIndex !== -1) {\n return this.manualLevelIndex;\n } else {\n return this.hls.nextAutoLevel;\n }\n },\n set: function set(nextLevel) {\n this.level = nextLevel;\n\n if (this.manualLevelIndex === -1) {\n this.hls.nextAutoLevel = nextLevel;\n }\n }\n }]);\n\n return LevelController;\n}(_base_playlist_controller__WEBPACK_IMPORTED_MODULE_5__[\"default\"]);\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/level-helper.ts\":\n/*!****************************************!*\\\n !*** ./src/controller/level-helper.ts ***!\n \\****************************************/\n/*! exports provided: addGroupId, assignTrackIdsByGroup, updatePTS, updateFragPTSDTS, mergeDetails, mapPartIntersection, mapFragmentIntersection, adjustSliding, addSliding, computeReloadInterval, getFragmentWithSN, getPartWith */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"addGroupId\", function() { return addGroupId; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"assignTrackIdsByGroup\", function() { return assignTrackIdsByGroup; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"updatePTS\", function() { return updatePTS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"updateFragPTSDTS\", function() { return updateFragPTSDTS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"mergeDetails\", function() { return mergeDetails; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"mapPartIntersection\", function() { return mapPartIntersection; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"mapFragmentIntersection\", function() { return mapFragmentIntersection; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"adjustSliding\", function() { return adjustSliding; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"addSliding\", function() { return addSliding; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"computeReloadInterval\", function() { return computeReloadInterval; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getFragmentWithSN\", function() { return getFragmentWithSN; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getPartWith\", function() { return getPartWith; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _loader_date_range__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../loader/date-range */ \"./src/loader/date-range.ts\");\n\n\n\n\n\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n/**\n * @module LevelHelper\n * Providing methods dealing with playlist sliding and drift\n * */\n\n\nfunction addGroupId(level, type, id) {\n switch (type) {\n case 'audio':\n if (!level.audioGroupIds) {\n level.audioGroupIds = [];\n }\n\n level.audioGroupIds.push(id);\n break;\n\n case 'text':\n if (!level.textGroupIds) {\n level.textGroupIds = [];\n }\n\n level.textGroupIds.push(id);\n break;\n }\n}\nfunction assignTrackIdsByGroup(tracks) {\n var groups = {};\n tracks.forEach(function (track) {\n var groupId = track.groupId || '';\n track.id = groups[groupId] = groups[groupId] || 0;\n groups[groupId]++;\n });\n}\nfunction updatePTS(fragments, fromIdx, toIdx) {\n var fragFrom = fragments[fromIdx];\n var fragTo = fragments[toIdx];\n updateFromToPTS(fragFrom, fragTo);\n}\n\nfunction updateFromToPTS(fragFrom, fragTo) {\n var fragToPTS = fragTo.startPTS; // if we know startPTS[toIdx]\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(fragToPTS)) {\n // update fragment duration.\n // it helps to fix drifts between playlist reported duration and fragment real duration\n var duration = 0;\n var frag;\n\n if (fragTo.sn > fragFrom.sn) {\n duration = fragToPTS - fragFrom.start;\n frag = fragFrom;\n } else {\n duration = fragFrom.start - fragToPTS;\n frag = fragTo;\n } // TODO? Drift can go either way, or the playlist could be completely accurate\n // console.assert(duration > 0,\n // `duration of ${duration} computed for frag ${frag.sn}, level ${frag.level}, there should be some duration drift between playlist and fragment!`);\n\n\n if (frag.duration !== duration) {\n frag.duration = duration;\n } // we dont know startPTS[toIdx]\n\n } else if (fragTo.sn > fragFrom.sn) {\n var contiguous = fragFrom.cc === fragTo.cc; // TODO: With part-loading end/durations we need to confirm the whole fragment is loaded before using (or setting) minEndPTS\n\n if (contiguous && fragFrom.minEndPTS) {\n fragTo.start = fragFrom.start + (fragFrom.minEndPTS - fragFrom.start);\n } else {\n fragTo.start = fragFrom.start + fragFrom.duration;\n }\n } else {\n fragTo.start = Math.max(fragFrom.start - fragTo.duration, 0);\n }\n}\n\nfunction updateFragPTSDTS(details, frag, startPTS, endPTS, startDTS, endDTS) {\n var parsedMediaDuration = endPTS - startPTS;\n\n if (parsedMediaDuration <= 0) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].warn('Fragment should have a positive duration', frag);\n endPTS = startPTS + frag.duration;\n endDTS = startDTS + frag.duration;\n }\n\n var maxStartPTS = startPTS;\n var minEndPTS = endPTS;\n var fragStartPts = frag.startPTS;\n var fragEndPts = frag.endPTS;\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(fragStartPts)) {\n // delta PTS between audio and video\n var deltaPTS = Math.abs(fragStartPts - startPTS);\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.deltaPTS)) {\n frag.deltaPTS = deltaPTS;\n } else {\n frag.deltaPTS = Math.max(deltaPTS, frag.deltaPTS);\n }\n\n maxStartPTS = Math.max(startPTS, fragStartPts);\n startPTS = Math.min(startPTS, fragStartPts);\n startDTS = Math.min(startDTS, frag.startDTS);\n minEndPTS = Math.min(endPTS, fragEndPts);\n endPTS = Math.max(endPTS, fragEndPts);\n endDTS = Math.max(endDTS, frag.endDTS);\n }\n\n frag.duration = endPTS - startPTS;\n var drift = startPTS - frag.start;\n frag.appendedPTS = endPTS;\n frag.start = frag.startPTS = startPTS;\n frag.maxStartPTS = maxStartPTS;\n frag.startDTS = startDTS;\n frag.endPTS = endPTS;\n frag.minEndPTS = minEndPTS;\n frag.endDTS = endDTS;\n var sn = frag.sn; // 'initSegment'\n // exit if sn out of range\n\n if (!details || sn < details.startSN || sn > details.endSN) {\n return 0;\n }\n\n var i;\n var fragIdx = sn - details.startSN;\n var fragments = details.fragments; // update frag reference in fragments array\n // rationale is that fragments array might not contain this frag object.\n // this will happen if playlist has been refreshed between frag loading and call to updateFragPTSDTS()\n // if we don't update frag, we won't be able to propagate PTS info on the playlist\n // resulting in invalid sliding computation\n\n fragments[fragIdx] = frag; // adjust fragment PTS/duration from seqnum-1 to frag 0\n\n for (i = fragIdx; i > 0; i--) {\n updateFromToPTS(fragments[i], fragments[i - 1]);\n } // adjust fragment PTS/duration from seqnum to last frag\n\n\n for (i = fragIdx; i < fragments.length - 1; i++) {\n updateFromToPTS(fragments[i], fragments[i + 1]);\n }\n\n if (details.fragmentHint) {\n updateFromToPTS(fragments[fragments.length - 1], details.fragmentHint);\n }\n\n details.PTSKnown = details.alignedSliding = true;\n return drift;\n}\nfunction mergeDetails(oldDetails, newDetails) {\n // Track the last initSegment processed. Initialize it to the last one on the timeline.\n var currentInitSegment = null;\n var oldFragments = oldDetails.fragments;\n\n for (var i = oldFragments.length - 1; i >= 0; i--) {\n var oldInit = oldFragments[i].initSegment;\n\n if (oldInit) {\n currentInitSegment = oldInit;\n break;\n }\n }\n\n if (oldDetails.fragmentHint) {\n // prevent PTS and duration from being adjusted on the next hint\n delete oldDetails.fragmentHint.endPTS;\n } // check if old/new playlists have fragments in common\n // loop through overlapping SN and update startPTS , cc, and duration if any found\n\n\n var ccOffset = 0;\n var PTSFrag;\n mapFragmentIntersection(oldDetails, newDetails, function (oldFrag, newFrag) {\n if (oldFrag.relurl) {\n // Do not compare CC if the old fragment has no url. This is a level.fragmentHint used by LL-HLS parts.\n // It maybe be off by 1 if it was created before any parts or discontinuity tags were appended to the end\n // of the playlist.\n ccOffset = oldFrag.cc - newFrag.cc;\n }\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(oldFrag.startPTS) && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(oldFrag.endPTS)) {\n newFrag.start = newFrag.startPTS = oldFrag.startPTS;\n newFrag.startDTS = oldFrag.startDTS;\n newFrag.appendedPTS = oldFrag.appendedPTS;\n newFrag.maxStartPTS = oldFrag.maxStartPTS;\n newFrag.endPTS = oldFrag.endPTS;\n newFrag.endDTS = oldFrag.endDTS;\n newFrag.minEndPTS = oldFrag.minEndPTS;\n newFrag.duration = oldFrag.endPTS - oldFrag.startPTS;\n\n if (newFrag.duration) {\n PTSFrag = newFrag;\n } // PTS is known when any segment has startPTS and endPTS\n\n\n newDetails.PTSKnown = newDetails.alignedSliding = true;\n }\n\n newFrag.elementaryStreams = oldFrag.elementaryStreams;\n newFrag.loader = oldFrag.loader;\n newFrag.stats = oldFrag.stats;\n newFrag.urlId = oldFrag.urlId;\n\n if (oldFrag.initSegment) {\n newFrag.initSegment = oldFrag.initSegment;\n currentInitSegment = oldFrag.initSegment;\n }\n });\n\n if (currentInitSegment) {\n var fragmentsToCheck = newDetails.fragmentHint ? newDetails.fragments.concat(newDetails.fragmentHint) : newDetails.fragments;\n fragmentsToCheck.forEach(function (frag) {\n var _currentInitSegment;\n\n if (!frag.initSegment || frag.initSegment.relurl === ((_currentInitSegment = currentInitSegment) === null || _currentInitSegment === void 0 ? void 0 : _currentInitSegment.relurl)) {\n frag.initSegment = currentInitSegment;\n }\n });\n }\n\n if (newDetails.skippedSegments) {\n newDetails.deltaUpdateFailed = newDetails.fragments.some(function (frag) {\n return !frag;\n });\n\n if (newDetails.deltaUpdateFailed) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].warn('[level-helper] Previous playlist missing segments skipped in delta playlist');\n\n for (var _i = newDetails.skippedSegments; _i--;) {\n newDetails.fragments.shift();\n }\n\n newDetails.startSN = newDetails.fragments[0].sn;\n newDetails.startCC = newDetails.fragments[0].cc;\n } else if (newDetails.canSkipDateRanges) {\n newDetails.dateRanges = mergeDateRanges(oldDetails.dateRanges, newDetails.dateRanges, newDetails.recentlyRemovedDateranges);\n }\n }\n\n var newFragments = newDetails.fragments;\n\n if (ccOffset) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].warn('discontinuity sliding from playlist, take drift into account');\n\n for (var _i2 = 0; _i2 < newFragments.length; _i2++) {\n newFragments[_i2].cc += ccOffset;\n }\n }\n\n if (newDetails.skippedSegments) {\n newDetails.startCC = newDetails.fragments[0].cc;\n } // Merge parts\n\n\n mapPartIntersection(oldDetails.partList, newDetails.partList, function (oldPart, newPart) {\n newPart.elementaryStreams = oldPart.elementaryStreams;\n newPart.stats = oldPart.stats;\n }); // if at least one fragment contains PTS info, recompute PTS information for all fragments\n\n if (PTSFrag) {\n updateFragPTSDTS(newDetails, PTSFrag, PTSFrag.startPTS, PTSFrag.endPTS, PTSFrag.startDTS, PTSFrag.endDTS);\n } else {\n // ensure that delta is within oldFragments range\n // also adjust sliding in case delta is 0 (we could have old=[50-60] and new=old=[50-61])\n // in that case we also need to adjust start offset of all fragments\n adjustSliding(oldDetails, newDetails);\n }\n\n if (newFragments.length) {\n newDetails.totalduration = newDetails.edge - newFragments[0].start;\n }\n\n newDetails.driftStartTime = oldDetails.driftStartTime;\n newDetails.driftStart = oldDetails.driftStart;\n var advancedDateTime = newDetails.advancedDateTime;\n\n if (newDetails.advanced && advancedDateTime) {\n var edge = newDetails.edge;\n\n if (!newDetails.driftStart) {\n newDetails.driftStartTime = advancedDateTime;\n newDetails.driftStart = edge;\n }\n\n newDetails.driftEndTime = advancedDateTime;\n newDetails.driftEnd = edge;\n } else {\n newDetails.driftEndTime = oldDetails.driftEndTime;\n newDetails.driftEnd = oldDetails.driftEnd;\n newDetails.advancedDateTime = oldDetails.advancedDateTime;\n }\n}\n\nfunction mergeDateRanges(oldDateRanges, deltaDateRanges, recentlyRemovedDateranges) {\n var dateRanges = _extends({}, oldDateRanges);\n\n if (recentlyRemovedDateranges) {\n recentlyRemovedDateranges.forEach(function (id) {\n delete dateRanges[id];\n });\n }\n\n Object.keys(deltaDateRanges).forEach(function (id) {\n var dateRange = new _loader_date_range__WEBPACK_IMPORTED_MODULE_2__[\"DateRange\"](deltaDateRanges[id].attr, dateRanges[id]);\n\n if (dateRange.isValid) {\n dateRanges[id] = dateRange;\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].warn(\"Ignoring invalid Playlist Delta Update DATERANGE tag: \\\"\" + JSON.stringify(deltaDateRanges[id].attr) + \"\\\"\");\n }\n });\n return dateRanges;\n}\n\nfunction mapPartIntersection(oldParts, newParts, intersectionFn) {\n if (oldParts && newParts) {\n var delta = 0;\n\n for (var i = 0, len = oldParts.length; i <= len; i++) {\n var _oldPart = oldParts[i];\n var _newPart = newParts[i + delta];\n\n if (_oldPart && _newPart && _oldPart.index === _newPart.index && _oldPart.fragment.sn === _newPart.fragment.sn) {\n intersectionFn(_oldPart, _newPart);\n } else {\n delta--;\n }\n }\n }\n}\nfunction mapFragmentIntersection(oldDetails, newDetails, intersectionFn) {\n var skippedSegments = newDetails.skippedSegments;\n var start = Math.max(oldDetails.startSN, newDetails.startSN) - newDetails.startSN;\n var end = (oldDetails.fragmentHint ? 1 : 0) + (skippedSegments ? newDetails.endSN : Math.min(oldDetails.endSN, newDetails.endSN)) - newDetails.startSN;\n var delta = newDetails.startSN - oldDetails.startSN;\n var newFrags = newDetails.fragmentHint ? newDetails.fragments.concat(newDetails.fragmentHint) : newDetails.fragments;\n var oldFrags = oldDetails.fragmentHint ? oldDetails.fragments.concat(oldDetails.fragmentHint) : oldDetails.fragments;\n\n for (var i = start; i <= end; i++) {\n var _oldFrag = oldFrags[delta + i];\n var _newFrag = newFrags[i];\n\n if (skippedSegments && !_newFrag && i < skippedSegments) {\n // Fill in skipped segments in delta playlist\n _newFrag = newDetails.fragments[i] = _oldFrag;\n }\n\n if (_oldFrag && _newFrag) {\n intersectionFn(_oldFrag, _newFrag);\n }\n }\n}\nfunction adjustSliding(oldDetails, newDetails) {\n var delta = newDetails.startSN + newDetails.skippedSegments - oldDetails.startSN;\n var oldFragments = oldDetails.fragments;\n\n if (delta < 0 || delta >= oldFragments.length) {\n return;\n }\n\n addSliding(newDetails, oldFragments[delta].start);\n}\nfunction addSliding(details, start) {\n if (start) {\n var fragments = details.fragments;\n\n for (var i = details.skippedSegments; i < fragments.length; i++) {\n fragments[i].start += start;\n }\n\n if (details.fragmentHint) {\n details.fragmentHint.start += start;\n }\n }\n}\nfunction computeReloadInterval(newDetails, stats) {\n var reloadInterval = 1000 * newDetails.levelTargetDuration;\n var reloadIntervalAfterMiss = reloadInterval / 2;\n var timeSinceLastModified = newDetails.age;\n var useLastModified = timeSinceLastModified > 0 && timeSinceLastModified < reloadInterval * 3;\n var roundTrip = stats.loading.end - stats.loading.start;\n var estimatedTimeUntilUpdate;\n var availabilityDelay = newDetails.availabilityDelay; // let estimate = 'average';\n\n if (newDetails.updated === false) {\n if (useLastModified) {\n // estimate = 'miss round trip';\n // We should have had a hit so try again in the time it takes to get a response,\n // but no less than 1/3 second.\n var minRetry = 333 * newDetails.misses;\n estimatedTimeUntilUpdate = Math.max(Math.min(reloadIntervalAfterMiss, roundTrip * 2), minRetry);\n newDetails.availabilityDelay = (newDetails.availabilityDelay || 0) + estimatedTimeUntilUpdate;\n } else {\n // estimate = 'miss half average';\n // follow HLS Spec, If the client reloads a Playlist file and finds that it has not\n // changed then it MUST wait for a period of one-half the target\n // duration before retrying.\n estimatedTimeUntilUpdate = reloadIntervalAfterMiss;\n }\n } else if (useLastModified) {\n // estimate = 'next modified date';\n // Get the closest we've been to timeSinceLastModified on update\n availabilityDelay = Math.min(availabilityDelay || reloadInterval / 2, timeSinceLastModified);\n newDetails.availabilityDelay = availabilityDelay;\n estimatedTimeUntilUpdate = availabilityDelay + reloadInterval - timeSinceLastModified;\n } else {\n estimatedTimeUntilUpdate = reloadInterval - roundTrip;\n } // console.log(`[computeReloadInterval] live reload ${newDetails.updated ? 'REFRESHED' : 'MISSED'}`,\n // '\\n method', estimate,\n // '\\n estimated time until update =>', estimatedTimeUntilUpdate,\n // '\\n average target duration', reloadInterval,\n // '\\n time since modified', timeSinceLastModified,\n // '\\n time round trip', roundTrip,\n // '\\n availability delay', availabilityDelay);\n\n\n return Math.round(estimatedTimeUntilUpdate);\n}\nfunction getFragmentWithSN(level, sn, fragCurrent) {\n if (!level || !level.details) {\n return null;\n }\n\n var levelDetails = level.details;\n var fragment = levelDetails.fragments[sn - levelDetails.startSN];\n\n if (fragment) {\n return fragment;\n }\n\n fragment = levelDetails.fragmentHint;\n\n if (fragment && fragment.sn === sn) {\n return fragment;\n }\n\n if (sn < levelDetails.startSN && fragCurrent && fragCurrent.sn === sn) {\n return fragCurrent;\n }\n\n return null;\n}\nfunction getPartWith(level, sn, partIndex) {\n if (!level || !level.details) {\n return null;\n }\n\n var partList = level.details.partList;\n\n if (partList) {\n for (var i = partList.length; i--;) {\n var part = partList[i];\n\n if (part.index === partIndex && part.fragment.sn === sn) {\n return part;\n }\n }\n }\n\n return null;\n}\n\n/***/ }),\n\n/***/ \"./src/controller/stream-controller.ts\":\n/*!*********************************************!*\\\n !*** ./src/controller/stream-controller.ts ***!\n \\*********************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return StreamController; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./base-stream-controller */ \"./src/controller/base-stream-controller.ts\");\n/* harmony import */ var _is_supported__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../is-supported */ \"./src/is-supported.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./fragment-tracker */ \"./src/controller/fragment-tracker.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _loader_fragment__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../loader/fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../demux/transmuxer-interface */ \"./src/demux/transmuxer-interface.ts\");\n/* harmony import */ var _types_transmuxer__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../types/transmuxer */ \"./src/types/transmuxer.ts\");\n/* harmony import */ var _gap_controller__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./gap-controller */ \"./src/controller/gap-controller.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n\n\n\n\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n\n\n\nvar TICK_INTERVAL = 100; // how often to tick in ms\n\nvar StreamController = /*#__PURE__*/function (_BaseStreamController) {\n _inheritsLoose(StreamController, _BaseStreamController);\n\n function StreamController(hls, fragmentTracker) {\n var _this;\n\n _this = _BaseStreamController.call(this, hls, fragmentTracker, '[stream-controller]') || this;\n _this.audioCodecSwap = false;\n _this.gapController = null;\n _this.level = -1;\n _this._forceStartLoad = false;\n _this.altAudio = false;\n _this.audioOnly = false;\n _this.fragPlaying = null;\n _this.onvplaying = null;\n _this.onvseeked = null;\n _this.fragLastKbps = 0;\n _this.couldBacktrack = false;\n _this.backtrackFragment = null;\n _this.audioCodecSwitch = false;\n _this.videoBuffer = null;\n\n _this._registerListeners();\n\n return _this;\n }\n\n var _proto = StreamController.prototype;\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_LOAD_EMERGENCY_ABORTED, this.onFragLoadEmergencyAborted, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, this.onError, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].AUDIO_TRACK_SWITCHING, this.onAudioTrackSwitching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].AUDIO_TRACK_SWITCHED, this.onAudioTrackSwitched, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_FLUSHED, this.onBufferFlushed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVELS_UPDATED, this.onLevelsUpdated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_LOAD_EMERGENCY_ABORTED, this.onFragLoadEmergencyAborted, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, this.onError, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].AUDIO_TRACK_SWITCHING, this.onAudioTrackSwitching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].AUDIO_TRACK_SWITCHED, this.onAudioTrackSwitched, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_CREATED, this.onBufferCreated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_FLUSHED, this.onBufferFlushed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVELS_UPDATED, this.onLevelsUpdated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_BUFFERED, this.onFragBuffered, this);\n };\n\n _proto.onHandlerDestroying = function onHandlerDestroying() {\n this._unregisterListeners();\n\n this.onMediaDetaching();\n };\n\n _proto.startLoad = function startLoad(startPosition) {\n if (this.levels) {\n var lastCurrentTime = this.lastCurrentTime,\n hls = this.hls;\n this.stopLoad();\n this.setInterval(TICK_INTERVAL);\n this.level = -1;\n this.fragLoadError = 0;\n\n if (!this.startFragRequested) {\n // determine load level\n var startLevel = hls.startLevel;\n\n if (startLevel === -1) {\n if (hls.config.testBandwidth && this.levels.length > 1) {\n // -1 : guess start Level by doing a bitrate test by loading first fragment of lowest quality level\n startLevel = 0;\n this.bitrateTest = true;\n } else {\n startLevel = hls.nextAutoLevel;\n }\n } // set new level to playlist loader : this will trigger start level load\n // hls.nextLoadLevel remains until it is set to a new value or until a new frag is successfully loaded\n\n\n this.level = hls.nextLoadLevel = startLevel;\n this.loadedmetadata = false;\n } // if startPosition undefined but lastCurrentTime set, set startPosition to last currentTime\n\n\n if (lastCurrentTime > 0 && startPosition === -1) {\n this.log(\"Override startPosition with lastCurrentTime @\" + lastCurrentTime.toFixed(3));\n startPosition = lastCurrentTime;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n this.nextLoadPosition = this.startPosition = this.lastCurrentTime = startPosition;\n this.tick();\n } else {\n this._forceStartLoad = true;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].STOPPED;\n }\n };\n\n _proto.stopLoad = function stopLoad() {\n this._forceStartLoad = false;\n\n _BaseStreamController.prototype.stopLoad.call(this);\n };\n\n _proto.doTick = function doTick() {\n switch (this.state) {\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE:\n this.doTickIdle();\n break;\n\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL:\n {\n var _levels$level;\n\n var levels = this.levels,\n level = this.level;\n var details = levels === null || levels === void 0 ? void 0 : (_levels$level = levels[level]) === null || _levels$level === void 0 ? void 0 : _levels$level.details;\n\n if (details && (!details.live || this.levelLastLoaded === this.level)) {\n if (this.waitForCdnTuneIn(details)) {\n break;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n break;\n }\n\n break;\n }\n\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING_WAITING_RETRY:\n {\n var _this$media;\n\n var now = self.performance.now();\n var retryDate = this.retryDate; // if current time is gt than retryDate, or if media seeking let's switch to IDLE state to retry loading\n\n if (!retryDate || now >= retryDate || (_this$media = this.media) !== null && _this$media !== void 0 && _this$media.seeking) {\n this.log('retryDate reached, switch back to IDLE state');\n this.resetStartWhenNotLoaded(this.level);\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n }\n break;\n\n default:\n break;\n } // check buffer\n // check/update current fragment\n\n\n this.onTickEnd();\n };\n\n _proto.onTickEnd = function onTickEnd() {\n _BaseStreamController.prototype.onTickEnd.call(this);\n\n this.checkBuffer();\n this.checkFragmentChanged();\n };\n\n _proto.doTickIdle = function doTickIdle() {\n var _frag$decryptdata, _frag$decryptdata2;\n\n var hls = this.hls,\n levelLastLoaded = this.levelLastLoaded,\n levels = this.levels,\n media = this.media;\n var config = hls.config,\n level = hls.nextLoadLevel; // if start level not parsed yet OR\n // if video not attached AND start fragment already requested OR start frag prefetch not enabled\n // exit loop, as we either need more info (level not parsed) or we need media to be attached to load new fragment\n\n if (levelLastLoaded === null || !media && (this.startFragRequested || !config.startFragPrefetch)) {\n return;\n } // If the \"main\" level is audio-only but we are loading an alternate track in the same group, do not load anything\n\n\n if (this.altAudio && this.audioOnly) {\n return;\n }\n\n if (!levels || !levels[level]) {\n return;\n }\n\n var levelInfo = levels[level]; // if buffer length is less than maxBufLen try to load a new fragment\n // set next load level : this will trigger a playlist load if needed\n\n this.level = hls.nextLoadLevel = level;\n var levelDetails = levelInfo.details; // if level info not retrieved yet, switch state and wait for level retrieval\n // if live playlist, ensure that new playlist has been refreshed to avoid loading/try to load\n // a useless and outdated fragment (that might even introduce load error if it is already out of the live playlist)\n\n if (!levelDetails || this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL || levelDetails.live && this.levelLastLoaded !== level) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL;\n return;\n }\n\n var bufferInfo = this.getMainFwdBufferInfo();\n\n if (bufferInfo === null) {\n return;\n }\n\n var bufferLen = bufferInfo.len; // compute max Buffer Length that we could get from this load level, based on level bitrate. don't buffer more than 60 MB and more than 30s\n\n var maxBufLen = this.getMaxBufferLength(levelInfo.maxBitrate); // Stay idle if we are still with buffer margins\n\n if (bufferLen >= maxBufLen) {\n return;\n }\n\n if (this._streamEnded(bufferInfo, levelDetails)) {\n var data = {};\n\n if (this.altAudio) {\n data.type = 'video';\n }\n\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_EOS, data);\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ENDED;\n return;\n }\n\n if (this.backtrackFragment && this.backtrackFragment.start > bufferInfo.end) {\n this.backtrackFragment = null;\n }\n\n var targetBufferTime = this.backtrackFragment ? this.backtrackFragment.start : bufferInfo.end;\n var frag = this.getNextFragment(targetBufferTime, levelDetails); // Avoid backtracking by loading an earlier segment in streams with segments that do not start with a key frame (flagged by `couldBacktrack`)\n\n if (this.couldBacktrack && !this.fragPrevious && frag && frag.sn !== 'initSegment' && this.fragmentTracker.getState(frag) !== _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__[\"FragmentState\"].OK) {\n var _this$backtrackFragme;\n\n var backtrackSn = ((_this$backtrackFragme = this.backtrackFragment) != null ? _this$backtrackFragme : frag).sn;\n var fragIdx = backtrackSn - levelDetails.startSN;\n var backtrackFrag = levelDetails.fragments[fragIdx - 1];\n\n if (backtrackFrag && frag.cc === backtrackFrag.cc) {\n frag = backtrackFrag;\n this.fragmentTracker.removeFragment(backtrackFrag);\n }\n } else if (this.backtrackFragment && bufferInfo.len) {\n this.backtrackFragment = null;\n } // Avoid loop loading by using nextLoadPosition set for backtracking\n\n\n if (frag && this.fragmentTracker.getState(frag) === _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__[\"FragmentState\"].OK && this.nextLoadPosition > targetBufferTime) {\n // Cleanup the fragment tracker before trying to find the next unbuffered fragment\n var type = this.audioOnly && !this.altAudio ? _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO : _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].VIDEO;\n\n if (media) {\n this.afterBufferFlushed(media, type, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n }\n\n frag = this.getNextFragment(this.nextLoadPosition, levelDetails);\n }\n\n if (!frag) {\n return;\n }\n\n if (frag.initSegment && !frag.initSegment.data && !this.bitrateTest) {\n frag = frag.initSegment;\n } // We want to load the key if we're dealing with an identity key, because we will decrypt\n // this content using the key we fetch. Other keys will be handled by the DRM CDM via EME.\n\n\n if (((_frag$decryptdata = frag.decryptdata) === null || _frag$decryptdata === void 0 ? void 0 : _frag$decryptdata.keyFormat) === 'identity' && !((_frag$decryptdata2 = frag.decryptdata) !== null && _frag$decryptdata2 !== void 0 && _frag$decryptdata2.key)) {\n this.loadKey(frag, levelDetails);\n } else {\n this.loadFragment(frag, levelDetails, targetBufferTime);\n }\n };\n\n _proto.loadFragment = function loadFragment(frag, levelDetails, targetBufferTime) {\n var _this$media2;\n\n // Check if fragment is not loaded\n var fragState = this.fragmentTracker.getState(frag);\n this.fragCurrent = frag;\n\n if (fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__[\"FragmentState\"].NOT_LOADED) {\n if (frag.sn === 'initSegment') {\n this._loadInitSegment(frag);\n } else if (this.bitrateTest) {\n this.log(\"Fragment \" + frag.sn + \" of level \" + frag.level + \" is being downloaded to test bitrate and will not be buffered\");\n\n this._loadBitrateTestFrag(frag);\n } else {\n this.startFragRequested = true;\n\n _BaseStreamController.prototype.loadFragment.call(this, frag, levelDetails, targetBufferTime);\n }\n } else if (fragState === _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__[\"FragmentState\"].APPENDING) {\n // Lower the buffer size and try again\n if (this.reduceMaxBufferLength(frag.duration)) {\n this.fragmentTracker.removeFragment(frag);\n }\n } else if (((_this$media2 = this.media) === null || _this$media2 === void 0 ? void 0 : _this$media2.buffered.length) === 0) {\n // Stop gap for bad tracker / buffer flush behavior\n this.fragmentTracker.removeAllFragments();\n }\n };\n\n _proto.getAppendedFrag = function getAppendedFrag(position) {\n var fragOrPart = this.fragmentTracker.getAppendedFrag(position, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n\n if (fragOrPart && 'fragment' in fragOrPart) {\n return fragOrPart.fragment;\n }\n\n return fragOrPart;\n };\n\n _proto.getBufferedFrag = function getBufferedFrag(position) {\n return this.fragmentTracker.getBufferedFrag(position, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n };\n\n _proto.followingBufferedFrag = function followingBufferedFrag(frag) {\n if (frag) {\n // try to get range of next fragment (500ms after this range)\n return this.getBufferedFrag(frag.end + 0.5);\n }\n\n return null;\n }\n /*\n on immediate level switch :\n - pause playback if playing\n - cancel any pending load request\n - and trigger a buffer flush\n */\n ;\n\n _proto.immediateLevelSwitch = function immediateLevelSwitch() {\n this.abortCurrentFrag();\n this.flushMainBuffer(0, Number.POSITIVE_INFINITY);\n }\n /**\n * try to switch ASAP without breaking video playback:\n * in order to ensure smooth but quick level switching,\n * we need to find the next flushable buffer range\n * we should take into account new segment fetch time\n */\n ;\n\n _proto.nextLevelSwitch = function nextLevelSwitch() {\n var levels = this.levels,\n media = this.media; // ensure that media is defined and that metadata are available (to retrieve currentTime)\n\n if (media !== null && media !== void 0 && media.readyState) {\n var fetchdelay;\n var fragPlayingCurrent = this.getAppendedFrag(media.currentTime);\n\n if (fragPlayingCurrent && fragPlayingCurrent.start > 1) {\n // flush buffer preceding current fragment (flush until current fragment start offset)\n // minus 1s to avoid video freezing, that could happen if we flush keyframe of current video ...\n this.flushMainBuffer(0, fragPlayingCurrent.start - 1);\n }\n\n if (!media.paused && levels) {\n // add a safety delay of 1s\n var nextLevelId = this.hls.nextLoadLevel;\n var nextLevel = levels[nextLevelId];\n var fragLastKbps = this.fragLastKbps;\n\n if (fragLastKbps && this.fragCurrent) {\n fetchdelay = this.fragCurrent.duration * nextLevel.maxBitrate / (1000 * fragLastKbps) + 1;\n } else {\n fetchdelay = 0;\n }\n } else {\n fetchdelay = 0;\n } // this.log('fetchdelay:'+fetchdelay);\n // find buffer range that will be reached once new fragment will be fetched\n\n\n var bufferedFrag = this.getBufferedFrag(media.currentTime + fetchdelay);\n\n if (bufferedFrag) {\n // we can flush buffer range following this one without stalling playback\n var nextBufferedFrag = this.followingBufferedFrag(bufferedFrag);\n\n if (nextBufferedFrag) {\n // if we are here, we can also cancel any loading/demuxing in progress, as they are useless\n this.abortCurrentFrag(); // start flush position is in next buffered frag. Leave some padding for non-independent segments and smoother playback.\n\n var maxStart = nextBufferedFrag.maxStartPTS ? nextBufferedFrag.maxStartPTS : nextBufferedFrag.start;\n var fragDuration = nextBufferedFrag.duration;\n var startPts = Math.max(bufferedFrag.end, maxStart + Math.min(Math.max(fragDuration - this.config.maxFragLookUpTolerance, fragDuration * 0.5), fragDuration * 0.75));\n this.flushMainBuffer(startPts, Number.POSITIVE_INFINITY);\n }\n }\n }\n };\n\n _proto.abortCurrentFrag = function abortCurrentFrag() {\n var fragCurrent = this.fragCurrent;\n this.fragCurrent = null;\n this.backtrackFragment = null;\n\n if (fragCurrent !== null && fragCurrent !== void 0 && fragCurrent.loader) {\n fragCurrent.loader.abort();\n }\n\n switch (this.state) {\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].KEY_LOADING:\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING:\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING_WAITING_RETRY:\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING:\n case _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSED:\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n break;\n }\n\n this.nextLoadPosition = this.getLoadPosition();\n };\n\n _proto.flushMainBuffer = function flushMainBuffer(startOffset, endOffset) {\n _BaseStreamController.prototype.flushMainBuffer.call(this, startOffset, endOffset, this.altAudio ? 'video' : null);\n };\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n _BaseStreamController.prototype.onMediaAttached.call(this, event, data);\n\n var media = data.media;\n this.onvplaying = this.onMediaPlaying.bind(this);\n this.onvseeked = this.onMediaSeeked.bind(this);\n media.addEventListener('playing', this.onvplaying);\n media.addEventListener('seeked', this.onvseeked);\n this.gapController = new _gap_controller__WEBPACK_IMPORTED_MODULE_10__[\"default\"](this.config, media, this.fragmentTracker, this.hls);\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n var media = this.media;\n\n if (media && this.onvplaying && this.onvseeked) {\n media.removeEventListener('playing', this.onvplaying);\n media.removeEventListener('seeked', this.onvseeked);\n this.onvplaying = this.onvseeked = null;\n this.videoBuffer = null;\n }\n\n this.fragPlaying = null;\n\n if (this.gapController) {\n this.gapController.destroy();\n this.gapController = null;\n }\n\n _BaseStreamController.prototype.onMediaDetaching.call(this);\n };\n\n _proto.onMediaPlaying = function onMediaPlaying() {\n // tick to speed up FRAG_CHANGED triggering\n this.tick();\n };\n\n _proto.onMediaSeeked = function onMediaSeeked() {\n var media = this.media;\n var currentTime = media ? media.currentTime : null;\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(currentTime)) {\n this.log(\"Media seeked to \" + currentTime.toFixed(3));\n } // tick to speed up FRAG_CHANGED triggering\n\n\n this.tick();\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n // reset buffer on manifest loading\n this.log('Trigger BUFFER_RESET');\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_RESET, undefined);\n this.fragmentTracker.removeAllFragments();\n this.couldBacktrack = false;\n this.startPosition = this.lastCurrentTime = 0;\n this.fragPlaying = null;\n this.backtrackFragment = null;\n };\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n var aac = false;\n var heaac = false;\n var codec;\n data.levels.forEach(function (level) {\n // detect if we have different kind of audio codecs used amongst playlists\n codec = level.audioCodec;\n\n if (codec) {\n if (codec.indexOf('mp4a.40.2') !== -1) {\n aac = true;\n }\n\n if (codec.indexOf('mp4a.40.5') !== -1) {\n heaac = true;\n }\n }\n });\n this.audioCodecSwitch = aac && heaac && !Object(_is_supported__WEBPACK_IMPORTED_MODULE_2__[\"changeTypeSupported\"])();\n\n if (this.audioCodecSwitch) {\n this.log('Both AAC/HE-AAC audio found in levels; declaring level codec as HE-AAC');\n }\n\n this.levels = data.levels;\n this.startFragRequested = false;\n };\n\n _proto.onLevelLoading = function onLevelLoading(event, data) {\n var levels = this.levels;\n\n if (!levels || this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE) {\n return;\n }\n\n var level = levels[data.level];\n\n if (!level.details || level.details.live && this.levelLastLoaded !== data.level || this.waitForCdnTuneIn(level.details)) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL;\n }\n };\n\n _proto.onLevelLoaded = function onLevelLoaded(event, data) {\n var _curLevel$details;\n\n var levels = this.levels;\n var newLevelId = data.level;\n var newDetails = data.details;\n var duration = newDetails.totalduration;\n\n if (!levels) {\n this.warn(\"Levels were reset while loading level \" + newLevelId);\n return;\n }\n\n this.log(\"Level \" + newLevelId + \" loaded [\" + newDetails.startSN + \",\" + newDetails.endSN + \"], cc [\" + newDetails.startCC + \", \" + newDetails.endCC + \"] duration:\" + duration);\n var fragCurrent = this.fragCurrent;\n\n if (fragCurrent && (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING || this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].FRAG_LOADING_WAITING_RETRY)) {\n if (fragCurrent.level !== data.level && fragCurrent.loader) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n this.backtrackFragment = null;\n fragCurrent.loader.abort();\n }\n }\n\n var curLevel = levels[newLevelId];\n var sliding = 0;\n\n if (newDetails.live || (_curLevel$details = curLevel.details) !== null && _curLevel$details !== void 0 && _curLevel$details.live) {\n if (!newDetails.fragments[0]) {\n newDetails.deltaUpdateFailed = true;\n }\n\n if (newDetails.deltaUpdateFailed) {\n return;\n }\n\n sliding = this.alignPlaylists(newDetails, curLevel.details);\n } // override level info\n\n\n curLevel.details = newDetails;\n this.levelLastLoaded = newLevelId;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVEL_UPDATED, {\n details: newDetails,\n level: newLevelId\n }); // only switch back to IDLE state if we were waiting for level to start downloading a new fragment\n\n if (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL) {\n if (this.waitForCdnTuneIn(newDetails)) {\n // Wait for Low-Latency CDN Tune-in\n return;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n\n if (!this.startFragRequested) {\n this.setStartPosition(newDetails, sliding);\n } else if (newDetails.live) {\n this.synchronizeToLiveEdge(newDetails);\n } // trigger handler right now\n\n\n this.tick();\n };\n\n _proto._handleFragmentLoadProgress = function _handleFragmentLoadProgress(data) {\n var _frag$initSegment;\n\n var frag = data.frag,\n part = data.part,\n payload = data.payload;\n var levels = this.levels;\n\n if (!levels) {\n this.warn(\"Levels were reset while fragment load was in progress. Fragment \" + frag.sn + \" of level \" + frag.level + \" will not be buffered\");\n return;\n }\n\n var currentLevel = levels[frag.level];\n var details = currentLevel.details;\n\n if (!details) {\n this.warn(\"Dropping fragment \" + frag.sn + \" of level \" + frag.level + \" after level details were reset\");\n return;\n }\n\n var videoCodec = currentLevel.videoCodec; // time Offset is accurate if level PTS is known, or if playlist is not sliding (not live)\n\n var accurateTimeOffset = details.PTSKnown || !details.live;\n var initSegmentData = (_frag$initSegment = frag.initSegment) === null || _frag$initSegment === void 0 ? void 0 : _frag$initSegment.data;\n\n var audioCodec = this._getAudioCodec(currentLevel); // transmux the MPEG-TS data to ISO-BMFF segments\n // this.log(`Transmuxing ${frag.sn} of [${details.startSN} ,${details.endSN}],level ${frag.level}, cc ${frag.cc}`);\n\n\n var transmuxer = this.transmuxer = this.transmuxer || new _demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_8__[\"default\"](this.hls, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN, this._handleTransmuxComplete.bind(this), this._handleTransmuxerFlush.bind(this));\n var partIndex = part ? part.index : -1;\n var partial = partIndex !== -1;\n var chunkMeta = new _types_transmuxer__WEBPACK_IMPORTED_MODULE_9__[\"ChunkMetadata\"](frag.level, frag.sn, frag.stats.chunkCount, payload.byteLength, partIndex, partial);\n var initPTS = this.initPTS[frag.cc];\n transmuxer.push(payload, initSegmentData, audioCodec, videoCodec, frag, part, details.totalduration, accurateTimeOffset, chunkMeta, initPTS);\n };\n\n _proto.onAudioTrackSwitching = function onAudioTrackSwitching(event, data) {\n // if any URL found on new audio track, it is an alternate audio track\n var fromAltAudio = this.altAudio;\n var altAudio = !!data.url;\n var trackId = data.id; // if we switch on main audio, ensure that main fragment scheduling is synced with media.buffered\n // don't do anything if we switch to alt audio: audio stream controller is handling it.\n // we will just have to change buffer scheduling on audioTrackSwitched\n\n if (!altAudio) {\n if (this.mediaBuffer !== this.media) {\n this.log('Switching on main audio, use media.buffered to schedule main fragment loading');\n this.mediaBuffer = this.media;\n var fragCurrent = this.fragCurrent; // we need to refill audio buffer from main: cancel any frag loading to speed up audio switch\n\n if (fragCurrent !== null && fragCurrent !== void 0 && fragCurrent.loader) {\n this.log('Switching to main audio track, cancel main fragment load');\n fragCurrent.loader.abort();\n } // destroy transmuxer to force init segment generation (following audio switch)\n\n\n this.resetTransmuxer(); // switch to IDLE state to load new fragment\n\n this.resetLoadingState();\n } else if (this.audioOnly) {\n // Reset audio transmuxer so when switching back to main audio we're not still appending where we left off\n this.resetTransmuxer();\n }\n\n var hls = this.hls; // If switching from alt to main audio, flush all audio and trigger track switched\n\n if (fromAltAudio) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_FLUSHING, {\n startOffset: 0,\n endOffset: Number.POSITIVE_INFINITY,\n type: 'audio'\n });\n }\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].AUDIO_TRACK_SWITCHED, {\n id: trackId\n });\n }\n };\n\n _proto.onAudioTrackSwitched = function onAudioTrackSwitched(event, data) {\n var trackId = data.id;\n var altAudio = !!this.hls.audioTracks[trackId].url;\n\n if (altAudio) {\n var videoBuffer = this.videoBuffer; // if we switched on alternate audio, ensure that main fragment scheduling is synced with video sourcebuffer buffered\n\n if (videoBuffer && this.mediaBuffer !== videoBuffer) {\n this.log('Switching on alternate audio, use video.buffered to schedule main fragment loading');\n this.mediaBuffer = videoBuffer;\n }\n }\n\n this.altAudio = altAudio;\n this.tick();\n };\n\n _proto.onBufferCreated = function onBufferCreated(event, data) {\n var tracks = data.tracks;\n var mediaTrack;\n var name;\n var alternate = false;\n\n for (var type in tracks) {\n var track = tracks[type];\n\n if (track.id === 'main') {\n name = type;\n mediaTrack = track; // keep video source buffer reference\n\n if (type === 'video') {\n var videoTrack = tracks[type];\n\n if (videoTrack) {\n this.videoBuffer = videoTrack.buffer;\n }\n }\n } else {\n alternate = true;\n }\n }\n\n if (alternate && mediaTrack) {\n this.log(\"Alternate track found, use \" + name + \".buffered to schedule main fragment loading\");\n this.mediaBuffer = mediaTrack.buffer;\n } else {\n this.mediaBuffer = this.media;\n }\n };\n\n _proto.onFragBuffered = function onFragBuffered(event, data) {\n var frag = data.frag,\n part = data.part;\n\n if (frag && frag.type !== _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN) {\n return;\n }\n\n if (this.fragContextChanged(frag)) {\n // If a level switch was requested while a fragment was buffering, it will emit the FRAG_BUFFERED event upon completion\n // Avoid setting state back to IDLE, since that will interfere with a level switch\n this.warn(\"Fragment \" + frag.sn + (part ? ' p: ' + part.index : '') + \" of level \" + frag.level + \" finished buffering, but was aborted. state: \" + this.state);\n\n if (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSED) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n\n return;\n }\n\n var stats = part ? part.stats : frag.stats;\n this.fragLastKbps = Math.round(8 * stats.total / (stats.buffering.end - stats.loading.first));\n\n if (frag.sn !== 'initSegment') {\n this.fragPrevious = frag;\n }\n\n this.fragBufferedComplete(frag, part);\n };\n\n _proto.onError = function onError(event, data) {\n switch (data.details) {\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].FRAG_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT:\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].KEY_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].KEY_LOAD_TIMEOUT:\n this.onFragmentOrKeyLoadError(_types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN, data);\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].LEVEL_LOAD_ERROR:\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].LEVEL_LOAD_TIMEOUT:\n if (this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ERROR) {\n if (data.fatal) {\n // if fatal error, stop processing\n this.warn(\"\" + data.details);\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].ERROR;\n } else {\n // in case of non fatal error while loading level, if level controller is not retrying to load level , switch back to IDLE\n if (!data.levelRetry && this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].WAITING_LEVEL) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n }\n }\n }\n\n break;\n\n case _errors__WEBPACK_IMPORTED_MODULE_11__[\"ErrorDetails\"].BUFFER_FULL_ERROR:\n // if in appending state\n if (data.parent === 'main' && (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING || this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSED)) {\n var flushBuffer = true;\n var bufferedInfo = this.getFwdBufferInfo(this.media, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN); // 0.5 : tolerance needed as some browsers stalls playback before reaching buffered end\n // reduce max buf len if current position is buffered\n\n if (bufferedInfo && bufferedInfo.len > 0.5) {\n flushBuffer = !this.reduceMaxBufferLength(bufferedInfo.len);\n }\n\n if (flushBuffer) {\n // current position is not buffered, but browser is still complaining about buffer full error\n // this happens on IE/Edge, refer to https://github.com/video-dev/hls.js/pull/708\n // in that case flush the whole buffer to recover\n this.warn('buffer full error also media.currentTime is not buffered, flush main'); // flush main buffer\n\n this.immediateLevelSwitch();\n } else {\n var fragCurrent = this.fragCurrent;\n this.abortCurrentFrag();\n\n if (fragCurrent) {\n this.flushMainBuffer(fragCurrent.start, Number.POSITIVE_INFINITY);\n this.nextLoadPosition = fragCurrent.start;\n }\n }\n\n this.resetTransmuxer();\n this.resetLoadingState();\n }\n\n break;\n\n default:\n break;\n }\n } // Checks the health of the buffer and attempts to resolve playback stalls.\n ;\n\n _proto.checkBuffer = function checkBuffer() {\n var media = this.media,\n gapController = this.gapController;\n\n if (!media || !gapController || !media.readyState) {\n // Exit early if we don't have media or if the media hasn't buffered anything yet (readyState 0)\n return;\n }\n\n if (this.loadedmetadata || !_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].getBuffered(media).length) {\n // Resolve gaps using the main buffer, whose ranges are the intersections of the A/V sourcebuffers\n var activeFrag = this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE ? this.fragCurrent : null;\n gapController.poll(this.lastCurrentTime, activeFrag);\n }\n\n this.lastCurrentTime = media.currentTime;\n };\n\n _proto.onFragLoadEmergencyAborted = function onFragLoadEmergencyAborted() {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE; // if loadedmetadata is not set, it means that we are emergency switch down on first frag\n // in that case, reset startFragRequested flag\n\n if (!this.loadedmetadata) {\n this.startFragRequested = false;\n this.nextLoadPosition = this.startPosition;\n }\n\n this.tickImmediate();\n };\n\n _proto.onBufferFlushed = function onBufferFlushed(event, _ref) {\n var type = _ref.type;\n\n if (type !== _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO || this.audioOnly && !this.altAudio) {\n var media = (type === _loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].VIDEO ? this.videoBuffer : this.mediaBuffer) || this.media;\n this.afterBufferFlushed(media, type, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n }\n };\n\n _proto.onLevelsUpdated = function onLevelsUpdated(event, data) {\n this.levels = data.levels;\n };\n\n _proto.swapAudioCodec = function swapAudioCodec() {\n this.audioCodecSwap = !this.audioCodecSwap;\n }\n /**\n * Seeks to the set startPosition if not equal to the mediaElement's current time.\n */\n ;\n\n _proto.seekToStartPos = function seekToStartPos() {\n var media = this.media;\n\n if (!media) {\n return;\n }\n\n var currentTime = media.currentTime;\n var startPosition = this.startPosition; // only adjust currentTime if different from startPosition or if startPosition not buffered\n // at that stage, there should be only one buffered range, as we reach that code after first fragment has been buffered\n\n if (startPosition >= 0 && currentTime < startPosition) {\n if (media.seeking) {\n this.log(\"could not seek to \" + startPosition + \", already seeking at \" + currentTime);\n return;\n }\n\n var buffered = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].getBuffered(media);\n var bufferStart = buffered.length ? buffered.start(0) : 0;\n var delta = bufferStart - startPosition;\n\n if (delta > 0 && (delta < this.config.maxBufferHole || delta < this.config.maxFragLookUpTolerance)) {\n this.log(\"adjusting start position by \" + delta + \" to match buffer start\");\n startPosition += delta;\n this.startPosition = startPosition;\n }\n\n this.log(\"seek to target start position \" + startPosition + \" from current time \" + currentTime);\n media.currentTime = startPosition;\n }\n };\n\n _proto._getAudioCodec = function _getAudioCodec(currentLevel) {\n var audioCodec = this.config.defaultAudioCodec || currentLevel.audioCodec;\n\n if (this.audioCodecSwap && audioCodec) {\n this.log('Swapping audio codec');\n\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n }\n\n return audioCodec;\n };\n\n _proto._loadBitrateTestFrag = function _loadBitrateTestFrag(frag) {\n var _this2 = this;\n\n frag.bitrateTest = true;\n\n this._doFragLoad(frag).then(function (data) {\n var hls = _this2.hls;\n\n if (!data || hls.nextLoadLevel || _this2.fragContextChanged(frag)) {\n return;\n }\n\n _this2.fragLoadError = 0;\n _this2.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n _this2.startFragRequested = false;\n _this2.bitrateTest = false;\n var stats = frag.stats; // Bitrate tests fragments are neither parsed nor buffered\n\n stats.parsing.start = stats.parsing.end = stats.buffering.start = stats.buffering.end = self.performance.now();\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_LOADED, data);\n frag.bitrateTest = false;\n });\n };\n\n _proto._handleTransmuxComplete = function _handleTransmuxComplete(transmuxResult) {\n var _id3$samples;\n\n var id = 'main';\n var hls = this.hls;\n var remuxResult = transmuxResult.remuxResult,\n chunkMeta = transmuxResult.chunkMeta;\n var context = this.getCurrentContext(chunkMeta);\n\n if (!context) {\n this.warn(\"The loading context changed while buffering fragment \" + chunkMeta.sn + \" of level \" + chunkMeta.level + \". This chunk will not be buffered.\");\n this.resetStartWhenNotLoaded(chunkMeta.level);\n return;\n }\n\n var frag = context.frag,\n part = context.part,\n level = context.level;\n var video = remuxResult.video,\n text = remuxResult.text,\n id3 = remuxResult.id3,\n initSegment = remuxResult.initSegment;\n var details = level.details; // The audio-stream-controller handles audio buffering if Hls.js is playing an alternate audio track\n\n var audio = this.altAudio ? undefined : remuxResult.audio; // Check if the current fragment has been aborted. We check this by first seeing if we're still playing the current level.\n // If we are, subsequently check if the currently loading fragment (fragCurrent) has changed.\n\n if (this.fragContextChanged(frag)) {\n return;\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING;\n\n if (initSegment) {\n if (initSegment.tracks) {\n this._bufferInitSegment(level, initSegment.tracks, frag, chunkMeta);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_PARSING_INIT_SEGMENT, {\n frag: frag,\n id: id,\n tracks: initSegment.tracks\n });\n } // This would be nice if Number.isFinite acted as a typeguard, but it doesn't. See: https://github.com/Microsoft/TypeScript/issues/10038\n\n\n var initPTS = initSegment.initPTS;\n var timescale = initSegment.timescale;\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(initPTS)) {\n this.initPTS[frag.cc] = initPTS;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].INIT_PTS_FOUND, {\n frag: frag,\n id: id,\n initPTS: initPTS,\n timescale: timescale\n });\n }\n } // Avoid buffering if backtracking this fragment\n\n\n if (video && remuxResult.independent !== false) {\n if (details) {\n var startPTS = video.startPTS,\n endPTS = video.endPTS,\n startDTS = video.startDTS,\n endDTS = video.endDTS;\n\n if (part) {\n part.elementaryStreams[video.type] = {\n startPTS: startPTS,\n endPTS: endPTS,\n startDTS: startDTS,\n endDTS: endDTS\n };\n } else {\n if (video.firstKeyFrame && video.independent) {\n this.couldBacktrack = true;\n }\n\n if (video.dropped && video.independent) {\n // Backtrack if dropped frames create a gap after currentTime\n var bufferInfo = this.getMainFwdBufferInfo();\n var targetBufferTime = (bufferInfo ? bufferInfo.end : this.getLoadPosition()) + this.config.maxBufferHole;\n var startTime = video.firstKeyFramePTS ? video.firstKeyFramePTS : startPTS;\n\n if (targetBufferTime < startTime - this.config.maxBufferHole) {\n this.backtrack(frag);\n return;\n } // Set video stream start to fragment start so that truncated samples do not distort the timeline, and mark it partial\n\n\n frag.setElementaryStreamInfo(video.type, frag.start, endPTS, frag.start, endDTS, true);\n }\n }\n\n frag.setElementaryStreamInfo(video.type, startPTS, endPTS, startDTS, endDTS);\n\n if (this.backtrackFragment) {\n this.backtrackFragment = frag;\n }\n\n this.bufferFragmentData(video, frag, part, chunkMeta);\n }\n } else if (remuxResult.independent === false) {\n this.backtrack(frag);\n return;\n }\n\n if (audio) {\n var _startPTS = audio.startPTS,\n _endPTS = audio.endPTS,\n _startDTS = audio.startDTS,\n _endDTS = audio.endDTS;\n\n if (part) {\n part.elementaryStreams[_loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO] = {\n startPTS: _startPTS,\n endPTS: _endPTS,\n startDTS: _startDTS,\n endDTS: _endDTS\n };\n }\n\n frag.setElementaryStreamInfo(_loader_fragment__WEBPACK_IMPORTED_MODULE_7__[\"ElementaryStreamTypes\"].AUDIO, _startPTS, _endPTS, _startDTS, _endDTS);\n this.bufferFragmentData(audio, frag, part, chunkMeta);\n }\n\n if (details && id3 !== null && id3 !== void 0 && (_id3$samples = id3.samples) !== null && _id3$samples !== void 0 && _id3$samples.length) {\n var emittedID3 = {\n id: id,\n frag: frag,\n details: details,\n samples: id3.samples\n };\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_PARSING_METADATA, emittedID3);\n }\n\n if (details && text) {\n var emittedText = {\n id: id,\n frag: frag,\n details: details,\n samples: text.samples\n };\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_PARSING_USERDATA, emittedText);\n }\n };\n\n _proto._bufferInitSegment = function _bufferInitSegment(currentLevel, tracks, frag, chunkMeta) {\n var _this3 = this;\n\n if (this.state !== _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].PARSING) {\n return;\n }\n\n this.audioOnly = !!tracks.audio && !tracks.video; // if audio track is expected to come from audio stream controller, discard any coming from main\n\n if (this.altAudio && !this.audioOnly) {\n delete tracks.audio;\n } // include levelCodec in audio and video tracks\n\n\n var audio = tracks.audio,\n video = tracks.video,\n audiovideo = tracks.audiovideo;\n\n if (audio) {\n var audioCodec = currentLevel.audioCodec;\n var ua = navigator.userAgent.toLowerCase();\n\n if (this.audioCodecSwitch) {\n if (audioCodec) {\n if (audioCodec.indexOf('mp4a.40.5') !== -1) {\n audioCodec = 'mp4a.40.2';\n } else {\n audioCodec = 'mp4a.40.5';\n }\n } // In the case that AAC and HE-AAC audio codecs are signalled in manifest,\n // force HE-AAC, as it seems that most browsers prefers it.\n // don't force HE-AAC if mono stream, or in Firefox\n\n\n if (audio.metadata.channelCount !== 1 && ua.indexOf('firefox') === -1) {\n audioCodec = 'mp4a.40.5';\n }\n } // HE-AAC is broken on Android, always signal audio codec as AAC even if variant manifest states otherwise\n\n\n if (ua.indexOf('android') !== -1 && audio.container !== 'audio/mpeg') {\n // Exclude mpeg audio\n audioCodec = 'mp4a.40.2';\n this.log(\"Android: force audio codec to \" + audioCodec);\n }\n\n if (currentLevel.audioCodec && currentLevel.audioCodec !== audioCodec) {\n this.log(\"Swapping manifest audio codec \\\"\" + currentLevel.audioCodec + \"\\\" for \\\"\" + audioCodec + \"\\\"\");\n }\n\n audio.levelCodec = audioCodec;\n audio.id = 'main';\n this.log(\"Init audio buffer, container:\" + audio.container + \", codecs[selected/level/parsed]=[\" + (audioCodec || '') + \"/\" + (currentLevel.audioCodec || '') + \"/\" + audio.codec + \"]\");\n }\n\n if (video) {\n video.levelCodec = currentLevel.videoCodec;\n video.id = 'main';\n this.log(\"Init video buffer, container:\" + video.container + \", codecs[level/parsed]=[\" + (currentLevel.videoCodec || '') + \"/\" + video.codec + \"]\");\n }\n\n if (audiovideo) {\n this.log(\"Init audiovideo buffer, container:\" + audiovideo.container + \", codecs[level/parsed]=[\" + (currentLevel.attrs.CODECS || '') + \"/\" + audiovideo.codec + \"]\");\n }\n\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_CODECS, tracks); // loop through tracks that are going to be provided to bufferController\n\n Object.keys(tracks).forEach(function (trackName) {\n var track = tracks[trackName];\n var initSegment = track.initSegment;\n\n if (initSegment !== null && initSegment !== void 0 && initSegment.byteLength) {\n _this3.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].BUFFER_APPENDING, {\n type: trackName,\n data: initSegment,\n frag: frag,\n part: null,\n chunkMeta: chunkMeta,\n parent: frag.type\n });\n }\n }); // trigger handler right now\n\n this.tick();\n };\n\n _proto.getMainFwdBufferInfo = function getMainFwdBufferInfo() {\n return this.getFwdBufferInfo(this.mediaBuffer ? this.mediaBuffer : this.media, _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN);\n };\n\n _proto.backtrack = function backtrack(frag) {\n this.couldBacktrack = true; // Causes findFragments to backtrack through fragments to find the keyframe\n\n this.backtrackFragment = frag;\n this.resetTransmuxer();\n this.flushBufferGap(frag);\n this.fragmentTracker.removeFragment(frag);\n this.fragPrevious = null;\n this.nextLoadPosition = frag.start;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"State\"].IDLE;\n };\n\n _proto.checkFragmentChanged = function checkFragmentChanged() {\n var video = this.media;\n var fragPlayingCurrent = null;\n\n if (video && video.readyState > 1 && video.seeking === false) {\n var currentTime = video.currentTime;\n /* if video element is in seeked state, currentTime can only increase.\n (assuming that playback rate is positive ...)\n As sometimes currentTime jumps back to zero after a\n media decode error, check this, to avoid seeking back to\n wrong position after a media decode error\n */\n\n if (_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].isBuffered(video, currentTime)) {\n fragPlayingCurrent = this.getAppendedFrag(currentTime);\n } else if (_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__[\"BufferHelper\"].isBuffered(video, currentTime + 0.1)) {\n /* ensure that FRAG_CHANGED event is triggered at startup,\n when first video frame is displayed and playback is paused.\n add a tolerance of 100ms, in case current position is not buffered,\n check if current pos+100ms is buffered and use that buffer range\n for FRAG_CHANGED event reporting */\n fragPlayingCurrent = this.getAppendedFrag(currentTime + 0.1);\n }\n\n if (fragPlayingCurrent) {\n this.backtrackFragment = null;\n var fragPlaying = this.fragPlaying;\n var fragCurrentLevel = fragPlayingCurrent.level;\n\n if (!fragPlaying || fragPlayingCurrent.sn !== fragPlaying.sn || fragPlaying.level !== fragCurrentLevel || fragPlayingCurrent.urlId !== fragPlaying.urlId) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].FRAG_CHANGED, {\n frag: fragPlayingCurrent\n });\n\n if (!fragPlaying || fragPlaying.level !== fragCurrentLevel) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].LEVEL_SWITCHED, {\n level: fragCurrentLevel\n });\n }\n\n this.fragPlaying = fragPlayingCurrent;\n }\n }\n }\n };\n\n _createClass(StreamController, [{\n key: \"nextLevel\",\n get: function get() {\n var frag = this.nextBufferedFrag;\n\n if (frag) {\n return frag.level;\n }\n\n return -1;\n }\n }, {\n key: \"currentFrag\",\n get: function get() {\n var media = this.media;\n\n if (media) {\n return this.fragPlaying || this.getAppendedFrag(media.currentTime);\n }\n\n return null;\n }\n }, {\n key: \"currentProgramDateTime\",\n get: function get() {\n var media = this.media;\n\n if (media) {\n var currentTime = media.currentTime;\n var frag = this.currentFrag;\n\n if (frag && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(currentTime) && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.programDateTime)) {\n var epocMs = frag.programDateTime + (currentTime - frag.start) * 1000;\n return new Date(epocMs);\n }\n }\n\n return null;\n }\n }, {\n key: \"currentLevel\",\n get: function get() {\n var frag = this.currentFrag;\n\n if (frag) {\n return frag.level;\n }\n\n return -1;\n }\n }, {\n key: \"nextBufferedFrag\",\n get: function get() {\n var frag = this.currentFrag;\n\n if (frag) {\n return this.followingBufferedFrag(frag);\n }\n\n return null;\n }\n }, {\n key: \"forceStartLoad\",\n get: function get() {\n return this._forceStartLoad;\n }\n }]);\n\n return StreamController;\n}(_base_stream_controller__WEBPACK_IMPORTED_MODULE_1__[\"default\"]);\n\n\n\n/***/ }),\n\n/***/ \"./src/controller/subtitle-stream-controller.ts\":\n/*!******************************************************!*\\\n !*** ./src/controller/subtitle-stream-controller.ts ***!\n \\******************************************************/\n/*! exports provided: SubtitleStreamController */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SubtitleStreamController\", function() { return SubtitleStreamController; });\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/buffer-helper */ \"./src/utils/buffer-helper.ts\");\n/* harmony import */ var _fragment_finders__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./fragment-finders */ \"./src/controller/fragment-finders.ts\");\n/* harmony import */ var _utils_discontinuities__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/discontinuities */ \"./src/utils/discontinuities.ts\");\n/* harmony import */ var _level_helper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./level-helper */ \"./src/controller/level-helper.ts\");\n/* harmony import */ var _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./fragment-tracker */ \"./src/controller/fragment-tracker.ts\");\n/* harmony import */ var _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./base-stream-controller */ \"./src/controller/base-stream-controller.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _types_level__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../types/level */ \"./src/types/level.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n\nvar TICK_INTERVAL = 500; // how often to tick in ms\n\nvar SubtitleStreamController = /*#__PURE__*/function (_BaseStreamController) {\n _inheritsLoose(SubtitleStreamController, _BaseStreamController);\n\n function SubtitleStreamController(hls, fragmentTracker) {\n var _this;\n\n _this = _BaseStreamController.call(this, hls, fragmentTracker, '[subtitle-stream-controller]') || this;\n _this.levels = [];\n _this.currentTrackId = -1;\n _this.tracksBuffered = [];\n _this.mainDetails = null;\n\n _this._registerListeners();\n\n return _this;\n }\n\n var _proto = SubtitleStreamController.prototype;\n\n _proto.onHandlerDestroying = function onHandlerDestroying() {\n this._unregisterListeners();\n\n this.mainDetails = null;\n };\n\n _proto._registerListeners = function _registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACKS_UPDATED, this.onSubtitleTracksUpdated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_SWITCH, this.onSubtitleTrackSwitch, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_LOADED, this.onSubtitleTrackLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_FRAG_PROCESSED, this.onSubtitleFragProcessed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n };\n\n _proto._unregisterListeners = function _unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADED, this.onLevelLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACKS_UPDATED, this.onSubtitleTracksUpdated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_SWITCH, this.onSubtitleTrackSwitch, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_LOADED, this.onSubtitleTrackLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_FRAG_PROCESSED, this.onSubtitleFragProcessed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n };\n\n _proto.startLoad = function startLoad() {\n this.stopLoad();\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE;\n this.setInterval(TICK_INTERVAL);\n this.tick();\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.mainDetails = null;\n this.fragmentTracker.removeAllFragments();\n };\n\n _proto.onLevelLoaded = function onLevelLoaded(event, data) {\n this.mainDetails = data.details;\n };\n\n _proto.onSubtitleFragProcessed = function onSubtitleFragProcessed(event, data) {\n var frag = data.frag,\n success = data.success;\n this.fragPrevious = frag;\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE;\n\n if (!success) {\n return;\n }\n\n var buffered = this.tracksBuffered[this.currentTrackId];\n\n if (!buffered) {\n return;\n } // Create/update a buffered array matching the interface used by BufferHelper.bufferedInfo\n // so we can re-use the logic used to detect how much has been buffered\n\n\n var timeRange;\n var fragStart = frag.start;\n\n for (var i = 0; i < buffered.length; i++) {\n if (fragStart >= buffered[i].start && fragStart <= buffered[i].end) {\n timeRange = buffered[i];\n break;\n }\n }\n\n var fragEnd = frag.start + frag.duration;\n\n if (timeRange) {\n timeRange.end = fragEnd;\n } else {\n timeRange = {\n start: fragStart,\n end: fragEnd\n };\n buffered.push(timeRange);\n }\n\n this.fragmentTracker.fragBuffered(frag);\n };\n\n _proto.onBufferFlushing = function onBufferFlushing(event, data) {\n var startOffset = data.startOffset,\n endOffset = data.endOffset;\n\n if (startOffset === 0 && endOffset !== Number.POSITIVE_INFINITY) {\n var currentTrackId = this.currentTrackId,\n levels = this.levels;\n\n if (!levels.length || !levels[currentTrackId] || !levels[currentTrackId].details) {\n return;\n }\n\n var trackDetails = levels[currentTrackId].details;\n var targetDuration = trackDetails.targetduration;\n var endOffsetSubtitles = endOffset - targetDuration;\n\n if (endOffsetSubtitles <= 0) {\n return;\n }\n\n data.endOffsetSubtitles = Math.max(0, endOffsetSubtitles);\n this.tracksBuffered.forEach(function (buffered) {\n for (var i = 0; i < buffered.length;) {\n if (buffered[i].end <= endOffsetSubtitles) {\n buffered.shift();\n continue;\n } else if (buffered[i].start < endOffsetSubtitles) {\n buffered[i].start = endOffsetSubtitles;\n } else {\n break;\n }\n\n i++;\n }\n });\n this.fragmentTracker.removeFragmentsInRange(startOffset, endOffsetSubtitles, _types_loader__WEBPACK_IMPORTED_MODULE_7__[\"PlaylistLevelType\"].SUBTITLE);\n }\n } // If something goes wrong, proceed to next frag, if we were processing one.\n ;\n\n _proto.onError = function onError(event, data) {\n var _this$fragCurrent;\n\n var frag = data.frag; // don't handle error not related to subtitle fragment\n\n if (!frag || frag.type !== _types_loader__WEBPACK_IMPORTED_MODULE_7__[\"PlaylistLevelType\"].SUBTITLE) {\n return;\n }\n\n if ((_this$fragCurrent = this.fragCurrent) !== null && _this$fragCurrent !== void 0 && _this$fragCurrent.loader) {\n this.fragCurrent.loader.abort();\n }\n\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE;\n } // Got all new subtitle levels.\n ;\n\n _proto.onSubtitleTracksUpdated = function onSubtitleTracksUpdated(event, _ref) {\n var _this2 = this;\n\n var subtitleTracks = _ref.subtitleTracks;\n this.tracksBuffered = [];\n this.levels = subtitleTracks.map(function (mediaPlaylist) {\n return new _types_level__WEBPACK_IMPORTED_MODULE_8__[\"Level\"](mediaPlaylist);\n });\n this.fragmentTracker.removeAllFragments();\n this.fragPrevious = null;\n this.levels.forEach(function (level) {\n _this2.tracksBuffered[level.id] = [];\n });\n this.mediaBuffer = null;\n };\n\n _proto.onSubtitleTrackSwitch = function onSubtitleTrackSwitch(event, data) {\n this.currentTrackId = data.id;\n\n if (!this.levels.length || this.currentTrackId === -1) {\n this.clearInterval();\n return;\n } // Check if track has the necessary details to load fragments\n\n\n var currentTrack = this.levels[this.currentTrackId];\n\n if (currentTrack !== null && currentTrack !== void 0 && currentTrack.details) {\n this.mediaBuffer = this.mediaBufferTimeRanges;\n } else {\n this.mediaBuffer = null;\n }\n\n if (currentTrack) {\n this.setInterval(TICK_INTERVAL);\n }\n } // Got a new set of subtitle fragments.\n ;\n\n _proto.onSubtitleTrackLoaded = function onSubtitleTrackLoaded(event, data) {\n var _track$details;\n\n var newDetails = data.details,\n trackId = data.id;\n var currentTrackId = this.currentTrackId,\n levels = this.levels;\n\n if (!levels.length) {\n return;\n }\n\n var track = levels[currentTrackId];\n\n if (trackId >= levels.length || trackId !== currentTrackId || !track) {\n return;\n }\n\n this.mediaBuffer = this.mediaBufferTimeRanges;\n\n if (newDetails.live || (_track$details = track.details) !== null && _track$details !== void 0 && _track$details.live) {\n var mainDetails = this.mainDetails;\n\n if (newDetails.deltaUpdateFailed || !mainDetails) {\n return;\n }\n\n var mainSlidingStartFragment = mainDetails.fragments[0];\n\n if (!track.details) {\n if (newDetails.hasProgramDateTime && mainDetails.hasProgramDateTime) {\n Object(_utils_discontinuities__WEBPACK_IMPORTED_MODULE_3__[\"alignMediaPlaylistByPDT\"])(newDetails, mainDetails);\n } else if (mainSlidingStartFragment) {\n // line up live playlist with main so that fragments in range are loaded\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"addSliding\"])(newDetails, mainSlidingStartFragment.start);\n }\n } else {\n var sliding = this.alignPlaylists(newDetails, track.details);\n\n if (sliding === 0 && mainSlidingStartFragment) {\n // realign with main when there is no overlap with last refresh\n Object(_level_helper__WEBPACK_IMPORTED_MODULE_4__[\"addSliding\"])(newDetails, mainSlidingStartFragment.start);\n }\n }\n }\n\n track.details = newDetails;\n this.levelLastLoaded = trackId; // trigger handler right now\n\n this.tick(); // If playlist is misaligned because of bad PDT or drift, delete details to resync with main on reload\n\n if (newDetails.live && !this.fragCurrent && this.media && this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE) {\n var foundFrag = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_2__[\"findFragmentByPTS\"])(null, newDetails.fragments, this.media.currentTime, 0);\n\n if (!foundFrag) {\n this.warn('Subtitle playlist not aligned with playback');\n track.details = undefined;\n }\n }\n };\n\n _proto._handleFragmentLoadComplete = function _handleFragmentLoadComplete(fragLoadedData) {\n var frag = fragLoadedData.frag,\n payload = fragLoadedData.payload;\n var decryptData = frag.decryptdata;\n var hls = this.hls;\n\n if (this.fragContextChanged(frag)) {\n return;\n } // check to see if the payload needs to be decrypted\n\n\n if (payload && payload.byteLength > 0 && decryptData && decryptData.key && decryptData.iv && decryptData.method === 'AES-128') {\n var startTime = performance.now(); // decrypt the subtitles\n\n this.decrypter.webCryptoDecrypt(new Uint8Array(payload), decryptData.key.buffer, decryptData.iv.buffer).then(function (decryptedData) {\n var endTime = performance.now();\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].FRAG_DECRYPTED, {\n frag: frag,\n payload: decryptedData,\n stats: {\n tstart: startTime,\n tdecrypt: endTime\n }\n });\n });\n }\n };\n\n _proto.doTick = function doTick() {\n if (!this.media) {\n this.state = _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE;\n return;\n }\n\n if (this.state === _base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"State\"].IDLE) {\n var currentTrackId = this.currentTrackId,\n levels = this.levels;\n\n if (!levels.length || !levels[currentTrackId] || !levels[currentTrackId].details) {\n return;\n } // Expand range of subs loaded by one target-duration in either direction to make up for misaligned playlists\n\n\n var trackDetails = levels[currentTrackId].details;\n var targetDuration = trackDetails.targetduration;\n var config = this.config,\n media = this.media;\n var bufferedInfo = _utils_buffer_helper__WEBPACK_IMPORTED_MODULE_1__[\"BufferHelper\"].bufferedInfo(this.tracksBuffered[this.currentTrackId] || [], media.currentTime - targetDuration, config.maxBufferHole);\n var targetBufferTime = bufferedInfo.end,\n bufferLen = bufferedInfo.len;\n var maxBufLen = this.getMaxBufferLength() + targetDuration;\n\n if (bufferLen > maxBufLen) {\n return;\n }\n\n console.assert(trackDetails, 'Subtitle track details are defined on idle subtitle stream controller tick');\n var fragments = trackDetails.fragments;\n var fragLen = fragments.length;\n var end = trackDetails.edge;\n var foundFrag;\n var fragPrevious = this.fragPrevious;\n\n if (targetBufferTime < end) {\n var maxFragLookUpTolerance = config.maxFragLookUpTolerance;\n foundFrag = Object(_fragment_finders__WEBPACK_IMPORTED_MODULE_2__[\"findFragmentByPTS\"])(fragPrevious, fragments, Math.max(fragments[0].start, targetBufferTime), maxFragLookUpTolerance);\n\n if (!foundFrag && fragPrevious && fragPrevious.start < fragments[0].start) {\n foundFrag = fragments[0];\n }\n } else {\n foundFrag = fragments[fragLen - 1];\n }\n\n foundFrag = this.mapToInitFragWhenRequired(foundFrag);\n\n if (!foundFrag) {\n return;\n } // only load if fragment is not loaded\n\n\n if (this.fragmentTracker.getState(foundFrag) !== _fragment_tracker__WEBPACK_IMPORTED_MODULE_5__[\"FragmentState\"].NOT_LOADED) {\n return;\n }\n\n if (foundFrag.encrypted) {\n this.loadKey(foundFrag, trackDetails);\n } else {\n this.loadFragment(foundFrag, trackDetails, targetBufferTime);\n }\n }\n };\n\n _proto.loadFragment = function loadFragment(frag, levelDetails, targetBufferTime) {\n this.fragCurrent = frag;\n\n if (frag.sn === 'initSegment') {\n this._loadInitSegment(frag);\n } else {\n _BaseStreamController.prototype.loadFragment.call(this, frag, levelDetails, targetBufferTime);\n }\n };\n\n _createClass(SubtitleStreamController, [{\n key: \"mediaBufferTimeRanges\",\n get: function get() {\n return new BufferableInstance(this.tracksBuffered[this.currentTrackId] || []);\n }\n }]);\n\n return SubtitleStreamController;\n}(_base_stream_controller__WEBPACK_IMPORTED_MODULE_6__[\"default\"]);\n\nvar BufferableInstance = function BufferableInstance(timeranges) {\n this.buffered = void 0;\n\n var getRange = function getRange(name, index, length) {\n index = index >>> 0;\n\n if (index > length - 1) {\n throw new DOMException(\"Failed to execute '\" + name + \"' on 'TimeRanges': The index provided (\" + index + \") is greater than the maximum bound (\" + length + \")\");\n }\n\n return timeranges[index][name];\n };\n\n this.buffered = {\n get length() {\n return timeranges.length;\n },\n\n end: function end(index) {\n return getRange('end', index, timeranges.length);\n },\n start: function start(index) {\n return getRange('start', index, timeranges.length);\n }\n };\n};\n\n/***/ }),\n\n/***/ \"./src/controller/subtitle-track-controller.ts\":\n/*!*****************************************************!*\\\n !*** ./src/controller/subtitle-track-controller.ts ***!\n \\*****************************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/texttrack-utils */ \"./src/utils/texttrack-utils.ts\");\n/* harmony import */ var _base_playlist_controller__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./base-playlist-controller */ \"./src/controller/base-playlist-controller.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\nvar SubtitleTrackController = /*#__PURE__*/function (_BasePlaylistControll) {\n _inheritsLoose(SubtitleTrackController, _BasePlaylistControll);\n\n function SubtitleTrackController(hls) {\n var _this;\n\n _this = _BasePlaylistControll.call(this, hls, '[subtitle-track-controller]') || this;\n _this.media = null;\n _this.tracks = [];\n _this.groupId = null;\n _this.tracksInGroup = [];\n _this.trackId = -1;\n _this.selectDefaultTrack = true;\n _this.queuedDefaultTrack = -1;\n\n _this.trackChangeListener = function () {\n return _this.onTextTracksChanged();\n };\n\n _this.asyncPollTrackChange = function () {\n return _this.pollTrackChange(0);\n };\n\n _this.useTextTrackPolling = false;\n _this.subtitlePollingInterval = -1;\n _this._subtitleDisplay = true;\n\n _this.registerListeners();\n\n return _this;\n }\n\n var _proto = SubtitleTrackController.prototype;\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.tracks.length = 0;\n this.tracksInGroup.length = 0;\n this.trackChangeListener = this.asyncPollTrackChange = null;\n\n _BasePlaylistControll.prototype.destroy.call(this);\n };\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_SWITCHING, this.onLevelSwitching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_LOADED, this.onSubtitleTrackLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_ATTACHED, this.onMediaAttached, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].MANIFEST_PARSED, this.onManifestParsed, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].LEVEL_SWITCHING, this.onLevelSwitching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_LOADED, this.onSubtitleTrackLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, this.onError, this);\n } // Listen for subtitle track change, then extract the current track ID.\n ;\n\n _proto.onMediaAttached = function onMediaAttached(event, data) {\n this.media = data.media;\n\n if (!this.media) {\n return;\n }\n\n if (this.queuedDefaultTrack > -1) {\n this.subtitleTrack = this.queuedDefaultTrack;\n this.queuedDefaultTrack = -1;\n }\n\n this.useTextTrackPolling = !(this.media.textTracks && 'onchange' in this.media.textTracks);\n\n if (this.useTextTrackPolling) {\n this.pollTrackChange(500);\n } else {\n this.media.textTracks.addEventListener('change', this.asyncPollTrackChange);\n }\n };\n\n _proto.pollTrackChange = function pollTrackChange(timeout) {\n self.clearInterval(this.subtitlePollingInterval);\n this.subtitlePollingInterval = self.setInterval(this.trackChangeListener, timeout);\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n if (!this.media) {\n return;\n }\n\n self.clearInterval(this.subtitlePollingInterval);\n\n if (!this.useTextTrackPolling) {\n this.media.textTracks.removeEventListener('change', this.asyncPollTrackChange);\n }\n\n if (this.trackId > -1) {\n this.queuedDefaultTrack = this.trackId;\n }\n\n var textTracks = filterSubtitleTracks(this.media.textTracks); // Clear loaded cues on media detachment from tracks\n\n textTracks.forEach(function (track) {\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_1__[\"clearCurrentCues\"])(track);\n }); // Disable all subtitle tracks before detachment so when reattached only tracks in that content are enabled.\n\n this.subtitleTrack = -1;\n this.media = null;\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.tracks = [];\n this.groupId = null;\n this.tracksInGroup = [];\n this.trackId = -1;\n this.selectDefaultTrack = true;\n } // Fired whenever a new manifest is loaded.\n ;\n\n _proto.onManifestParsed = function onManifestParsed(event, data) {\n this.tracks = data.subtitleTracks;\n };\n\n _proto.onSubtitleTrackLoaded = function onSubtitleTrackLoaded(event, data) {\n var id = data.id,\n details = data.details;\n var trackId = this.trackId;\n var currentTrack = this.tracksInGroup[trackId];\n\n if (!currentTrack) {\n this.warn(\"Invalid subtitle track id \" + id);\n return;\n }\n\n var curDetails = currentTrack.details;\n currentTrack.details = data.details;\n this.log(\"subtitle track \" + id + \" loaded [\" + details.startSN + \"-\" + details.endSN + \"]\");\n\n if (id === this.trackId) {\n this.retryCount = 0;\n this.playlistLoaded(id, data, curDetails);\n }\n };\n\n _proto.onLevelLoading = function onLevelLoading(event, data) {\n this.switchLevel(data.level);\n };\n\n _proto.onLevelSwitching = function onLevelSwitching(event, data) {\n this.switchLevel(data.level);\n };\n\n _proto.switchLevel = function switchLevel(levelIndex) {\n var levelInfo = this.hls.levels[levelIndex];\n\n if (!(levelInfo !== null && levelInfo !== void 0 && levelInfo.textGroupIds)) {\n return;\n }\n\n var textGroupId = levelInfo.textGroupIds[levelInfo.urlId];\n\n if (this.groupId !== textGroupId) {\n var lastTrack = this.tracksInGroup ? this.tracksInGroup[this.trackId] : undefined;\n var subtitleTracks = this.tracks.filter(function (track) {\n return !textGroupId || track.groupId === textGroupId;\n });\n this.tracksInGroup = subtitleTracks;\n var initialTrackId = this.findTrackId(lastTrack === null || lastTrack === void 0 ? void 0 : lastTrack.name) || this.findTrackId();\n this.groupId = textGroupId;\n var subtitleTracksUpdated = {\n subtitleTracks: subtitleTracks\n };\n this.log(\"Updating subtitle tracks, \" + subtitleTracks.length + \" track(s) found in \\\"\" + textGroupId + \"\\\" group-id\");\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACKS_UPDATED, subtitleTracksUpdated);\n\n if (initialTrackId !== -1) {\n this.setSubtitleTrack(initialTrackId, lastTrack);\n }\n }\n };\n\n _proto.findTrackId = function findTrackId(name) {\n var textTracks = this.tracksInGroup;\n\n for (var i = 0; i < textTracks.length; i++) {\n var track = textTracks[i];\n\n if (!this.selectDefaultTrack || track.default) {\n if (!name || name === track.name) {\n return track.id;\n }\n }\n }\n\n return -1;\n };\n\n _proto.onError = function onError(event, data) {\n _BasePlaylistControll.prototype.onError.call(this, event, data);\n\n if (data.fatal || !data.context) {\n return;\n }\n\n if (data.context.type === _types_loader__WEBPACK_IMPORTED_MODULE_3__[\"PlaylistContextType\"].SUBTITLE_TRACK && data.context.id === this.trackId && data.context.groupId === this.groupId) {\n this.retryLoadingOrFail(data);\n }\n }\n /** get alternate subtitle tracks list from playlist **/\n ;\n\n _proto.loadPlaylist = function loadPlaylist(hlsUrlParameters) {\n var currentTrack = this.tracksInGroup[this.trackId];\n\n if (this.shouldLoadTrack(currentTrack)) {\n var id = currentTrack.id;\n var groupId = currentTrack.groupId;\n var url = currentTrack.url;\n\n if (hlsUrlParameters) {\n try {\n url = hlsUrlParameters.addDirectives(url);\n } catch (error) {\n this.warn(\"Could not construct new URL with HLS Delivery Directives: \" + error);\n }\n }\n\n this.log(\"Loading subtitle playlist for id \" + id);\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_LOADING, {\n url: url,\n id: id,\n groupId: groupId,\n deliveryDirectives: hlsUrlParameters || null\n });\n }\n }\n /**\n * Disables the old subtitleTrack and sets current mode on the next subtitleTrack.\n * This operates on the DOM textTracks.\n * A value of -1 will disable all subtitle tracks.\n */\n ;\n\n _proto.toggleTrackModes = function toggleTrackModes(newId) {\n var _this2 = this;\n\n var media = this.media,\n trackId = this.trackId;\n\n if (!media) {\n return;\n }\n\n var textTracks = filterSubtitleTracks(media.textTracks);\n var groupTracks = textTracks.filter(function (track) {\n return track.groupId === _this2.groupId;\n });\n\n if (newId === -1) {\n [].slice.call(textTracks).forEach(function (track) {\n track.mode = 'disabled';\n });\n } else {\n var oldTrack = groupTracks[trackId];\n\n if (oldTrack) {\n oldTrack.mode = 'disabled';\n }\n }\n\n var nextTrack = groupTracks[newId];\n\n if (nextTrack) {\n nextTrack.mode = this.subtitleDisplay ? 'showing' : 'hidden';\n }\n }\n /**\n * This method is responsible for validating the subtitle index and periodically reloading if live.\n * Dispatches the SUBTITLE_TRACK_SWITCH event, which instructs the subtitle-stream-controller to load the selected track.\n */\n ;\n\n _proto.setSubtitleTrack = function setSubtitleTrack(newId, lastTrack) {\n var _tracks$newId;\n\n var tracks = this.tracksInGroup; // setting this.subtitleTrack will trigger internal logic\n // if media has not been attached yet, it will fail\n // we keep a reference to the default track id\n // and we'll set subtitleTrack when onMediaAttached is triggered\n\n if (!this.media) {\n this.queuedDefaultTrack = newId;\n return;\n }\n\n if (this.trackId !== newId) {\n this.toggleTrackModes(newId);\n } // exit if track id as already set or invalid\n\n\n if (this.trackId === newId && (newId === -1 || (_tracks$newId = tracks[newId]) !== null && _tracks$newId !== void 0 && _tracks$newId.details) || newId < -1 || newId >= tracks.length) {\n return;\n } // stopping live reloading timer if any\n\n\n this.clearTimer();\n var track = tracks[newId];\n this.log(\"Switching to subtitle track \" + newId);\n this.trackId = newId;\n\n if (track) {\n var id = track.id,\n _track$groupId = track.groupId,\n groupId = _track$groupId === void 0 ? '' : _track$groupId,\n name = track.name,\n type = track.type,\n url = track.url;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_SWITCH, {\n id: id,\n groupId: groupId,\n name: name,\n type: type,\n url: url\n });\n var hlsUrlParameters = this.switchParams(track.url, lastTrack === null || lastTrack === void 0 ? void 0 : lastTrack.details);\n this.loadPlaylist(hlsUrlParameters);\n } else {\n // switch to -1\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].SUBTITLE_TRACK_SWITCH, {\n id: newId\n });\n }\n };\n\n _proto.onTextTracksChanged = function onTextTracksChanged() {\n if (!this.useTextTrackPolling) {\n self.clearInterval(this.subtitlePollingInterval);\n } // Media is undefined when switching streams via loadSource()\n\n\n if (!this.media || !this.hls.config.renderTextTracksNatively) {\n return;\n }\n\n var trackId = -1;\n var tracks = filterSubtitleTracks(this.media.textTracks);\n\n for (var id = 0; id < tracks.length; id++) {\n if (tracks[id].mode === 'hidden') {\n // Do not break in case there is a following track with showing.\n trackId = id;\n } else if (tracks[id].mode === 'showing') {\n trackId = id;\n break;\n }\n } // Setting current subtitleTrack will invoke code.\n\n\n if (this.subtitleTrack !== trackId) {\n this.subtitleTrack = trackId;\n }\n };\n\n _createClass(SubtitleTrackController, [{\n key: \"subtitleDisplay\",\n get: function get() {\n return this._subtitleDisplay;\n },\n set: function set(value) {\n this._subtitleDisplay = value;\n\n if (this.trackId > -1) {\n this.toggleTrackModes(this.trackId);\n }\n }\n }, {\n key: \"subtitleTracks\",\n get: function get() {\n return this.tracksInGroup;\n }\n /** get/set index of the selected subtitle track (based on index in subtitle track lists) **/\n\n }, {\n key: \"subtitleTrack\",\n get: function get() {\n return this.trackId;\n },\n set: function set(newId) {\n this.selectDefaultTrack = false;\n var lastTrack = this.tracksInGroup ? this.tracksInGroup[this.trackId] : undefined;\n this.setSubtitleTrack(newId, lastTrack);\n }\n }]);\n\n return SubtitleTrackController;\n}(_base_playlist_controller__WEBPACK_IMPORTED_MODULE_2__[\"default\"]);\n\nfunction filterSubtitleTracks(textTrackList) {\n var tracks = [];\n\n for (var i = 0; i < textTrackList.length; i++) {\n var track = textTrackList[i]; // Edge adds a track without a label; we don't want to use it\n\n if (track.kind === 'subtitles' && track.label) {\n tracks.push(textTrackList[i]);\n }\n }\n\n return tracks;\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (SubtitleTrackController);\n\n/***/ }),\n\n/***/ \"./src/controller/timeline-controller.ts\":\n/*!***********************************************!*\\\n !*** ./src/controller/timeline-controller.ts ***!\n \\***********************************************/\n/*! exports provided: TimelineController */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"TimelineController\", function() { return TimelineController; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_cea_608_parser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/cea-608-parser */ \"./src/utils/cea-608-parser.ts\");\n/* harmony import */ var _utils_output_filter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/output-filter */ \"./src/utils/output-filter.ts\");\n/* harmony import */ var _utils_webvtt_parser__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/webvtt-parser */ \"./src/utils/webvtt-parser.ts\");\n/* harmony import */ var _utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/texttrack-utils */ \"./src/utils/texttrack-utils.ts\");\n/* harmony import */ var _utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils/imsc1-ttml-parser */ \"./src/utils/imsc1-ttml-parser.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\n\n\n\n\n\n\n\n\nvar TimelineController = /*#__PURE__*/function () {\n function TimelineController(hls) {\n this.hls = void 0;\n this.media = null;\n this.config = void 0;\n this.enabled = true;\n this.Cues = void 0;\n this.textTracks = [];\n this.tracks = [];\n this.initPTS = [];\n this.timescale = [];\n this.unparsedVttFrags = [];\n this.captionsTracks = {};\n this.nonNativeCaptionsTracks = {};\n this.cea608Parser1 = void 0;\n this.cea608Parser2 = void 0;\n this.lastSn = -1;\n this.lastPartIndex = -1;\n this.prevCC = -1;\n this.vttCCs = newVTTCCs();\n this.captionsProperties = void 0;\n this.hls = hls;\n this.config = hls.config;\n this.Cues = hls.config.cueHandler;\n this.captionsProperties = {\n textTrack1: {\n label: this.config.captionsTextTrack1Label,\n languageCode: this.config.captionsTextTrack1LanguageCode\n },\n textTrack2: {\n label: this.config.captionsTextTrack2Label,\n languageCode: this.config.captionsTextTrack2LanguageCode\n },\n textTrack3: {\n label: this.config.captionsTextTrack3Label,\n languageCode: this.config.captionsTextTrack3LanguageCode\n },\n textTrack4: {\n label: this.config.captionsTextTrack4Label,\n languageCode: this.config.captionsTextTrack4LanguageCode\n }\n };\n\n if (this.config.enableCEA708Captions) {\n var channel1 = new _utils_output_filter__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this, 'textTrack1');\n var channel2 = new _utils_output_filter__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this, 'textTrack2');\n var channel3 = new _utils_output_filter__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this, 'textTrack3');\n var channel4 = new _utils_output_filter__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this, 'textTrack4');\n this.cea608Parser1 = new _utils_cea_608_parser__WEBPACK_IMPORTED_MODULE_2__[\"default\"](1, channel1, channel2);\n this.cea608Parser2 = new _utils_cea_608_parser__WEBPACK_IMPORTED_MODULE_2__[\"default\"](3, channel3, channel4);\n }\n\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, this.onManifestLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACKS_UPDATED, this.onSubtitleTracksUpdated, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADING, this.onFragLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSING_USERDATA, this.onFragParsingUserdata, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_DECRYPTED, this.onFragDecrypted, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].INIT_PTS_FOUND, this.onInitPtsFound, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACKS_CLEARED, this.onSubtitleTracksCleared, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this);\n }\n\n var _proto = TimelineController.prototype;\n\n _proto.destroy = function destroy() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_ATTACHING, this.onMediaAttaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MEDIA_DETACHING, this.onMediaDetaching, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, this.onManifestLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACKS_UPDATED, this.onSubtitleTracksUpdated, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADING, this.onFragLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, this.onFragLoaded, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_PARSING_USERDATA, this.onFragParsingUserdata, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_DECRYPTED, this.onFragDecrypted, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].INIT_PTS_FOUND, this.onInitPtsFound, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACKS_CLEARED, this.onSubtitleTracksCleared, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].BUFFER_FLUSHING, this.onBufferFlushing, this); // @ts-ignore\n\n this.hls = this.config = this.cea608Parser1 = this.cea608Parser2 = null;\n };\n\n _proto.addCues = function addCues(trackName, startTime, endTime, screen, cueRanges) {\n // skip cues which overlap more than 50% with previously parsed time ranges\n var merged = false;\n\n for (var i = cueRanges.length; i--;) {\n var cueRange = cueRanges[i];\n var overlap = intersection(cueRange[0], cueRange[1], startTime, endTime);\n\n if (overlap >= 0) {\n cueRange[0] = Math.min(cueRange[0], startTime);\n cueRange[1] = Math.max(cueRange[1], endTime);\n merged = true;\n\n if (overlap / (endTime - startTime) > 0.5) {\n return;\n }\n }\n }\n\n if (!merged) {\n cueRanges.push([startTime, endTime]);\n }\n\n if (this.config.renderTextTracksNatively) {\n var track = this.captionsTracks[trackName];\n this.Cues.newCue(track, startTime, endTime, screen);\n } else {\n var cues = this.Cues.newCue(null, startTime, endTime, screen);\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].CUES_PARSED, {\n type: 'captions',\n cues: cues,\n track: trackName\n });\n }\n } // Triggered when an initial PTS is found; used for synchronisation of WebVTT.\n ;\n\n _proto.onInitPtsFound = function onInitPtsFound(event, _ref) {\n var _this = this;\n\n var frag = _ref.frag,\n id = _ref.id,\n initPTS = _ref.initPTS,\n timescale = _ref.timescale;\n var unparsedVttFrags = this.unparsedVttFrags;\n\n if (id === 'main') {\n this.initPTS[frag.cc] = initPTS;\n this.timescale[frag.cc] = timescale;\n } // Due to asynchronous processing, initial PTS may arrive later than the first VTT fragments are loaded.\n // Parse any unparsed fragments upon receiving the initial PTS.\n\n\n if (unparsedVttFrags.length) {\n this.unparsedVttFrags = [];\n unparsedVttFrags.forEach(function (frag) {\n _this.onFragLoaded(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, frag);\n });\n }\n };\n\n _proto.getExistingTrack = function getExistingTrack(trackName) {\n var media = this.media;\n\n if (media) {\n for (var i = 0; i < media.textTracks.length; i++) {\n var textTrack = media.textTracks[i];\n\n if (textTrack[trackName]) {\n return textTrack;\n }\n }\n }\n\n return null;\n };\n\n _proto.createCaptionsTrack = function createCaptionsTrack(trackName) {\n if (this.config.renderTextTracksNatively) {\n this.createNativeTrack(trackName);\n } else {\n this.createNonNativeTrack(trackName);\n }\n };\n\n _proto.createNativeTrack = function createNativeTrack(trackName) {\n if (this.captionsTracks[trackName]) {\n return;\n }\n\n var captionsProperties = this.captionsProperties,\n captionsTracks = this.captionsTracks,\n media = this.media;\n var _captionsProperties$t = captionsProperties[trackName],\n label = _captionsProperties$t.label,\n languageCode = _captionsProperties$t.languageCode; // Enable reuse of existing text track.\n\n var existingTrack = this.getExistingTrack(trackName);\n\n if (!existingTrack) {\n var textTrack = this.createTextTrack('captions', label, languageCode);\n\n if (textTrack) {\n // Set a special property on the track so we know it's managed by Hls.js\n textTrack[trackName] = true;\n captionsTracks[trackName] = textTrack;\n }\n } else {\n captionsTracks[trackName] = existingTrack;\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"clearCurrentCues\"])(captionsTracks[trackName]);\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"sendAddTrackEvent\"])(captionsTracks[trackName], media);\n }\n };\n\n _proto.createNonNativeTrack = function createNonNativeTrack(trackName) {\n if (this.nonNativeCaptionsTracks[trackName]) {\n return;\n } // Create a list of a single track for the provider to consume\n\n\n var trackProperties = this.captionsProperties[trackName];\n\n if (!trackProperties) {\n return;\n }\n\n var label = trackProperties.label;\n var track = {\n _id: trackName,\n label: label,\n kind: 'captions',\n default: trackProperties.media ? !!trackProperties.media.default : false,\n closedCaptions: trackProperties.media\n };\n this.nonNativeCaptionsTracks[trackName] = track;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].NON_NATIVE_TEXT_TRACKS_FOUND, {\n tracks: [track]\n });\n };\n\n _proto.createTextTrack = function createTextTrack(kind, label, lang) {\n var media = this.media;\n\n if (!media) {\n return;\n }\n\n return media.addTextTrack(kind, label, lang);\n };\n\n _proto.onMediaAttaching = function onMediaAttaching(event, data) {\n this.media = data.media;\n\n this._cleanTracks();\n };\n\n _proto.onMediaDetaching = function onMediaDetaching() {\n var captionsTracks = this.captionsTracks;\n Object.keys(captionsTracks).forEach(function (trackName) {\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"clearCurrentCues\"])(captionsTracks[trackName]);\n delete captionsTracks[trackName];\n });\n this.nonNativeCaptionsTracks = {};\n };\n\n _proto.onManifestLoading = function onManifestLoading() {\n this.lastSn = -1; // Detect discontinuity in fragment parsing\n\n this.lastPartIndex = -1;\n this.prevCC = -1;\n this.vttCCs = newVTTCCs(); // Detect discontinuity in subtitle manifests\n\n this._cleanTracks();\n\n this.tracks = [];\n this.captionsTracks = {};\n this.nonNativeCaptionsTracks = {};\n this.textTracks = [];\n this.unparsedVttFrags = this.unparsedVttFrags || [];\n this.initPTS = [];\n this.timescale = [];\n\n if (this.cea608Parser1 && this.cea608Parser2) {\n this.cea608Parser1.reset();\n this.cea608Parser2.reset();\n }\n };\n\n _proto._cleanTracks = function _cleanTracks() {\n // clear outdated subtitles\n var media = this.media;\n\n if (!media) {\n return;\n }\n\n var textTracks = media.textTracks;\n\n if (textTracks) {\n for (var i = 0; i < textTracks.length; i++) {\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"clearCurrentCues\"])(textTracks[i]);\n }\n }\n };\n\n _proto.onSubtitleTracksUpdated = function onSubtitleTracksUpdated(event, data) {\n var _this2 = this;\n\n this.textTracks = [];\n var tracks = data.subtitleTracks || [];\n var hasIMSC1 = tracks.some(function (track) {\n return track.textCodec === _utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__[\"IMSC1_CODEC\"];\n });\n\n if (this.config.enableWebVTT || hasIMSC1 && this.config.enableIMSC1) {\n var sameTracks = this.tracks && tracks && this.tracks.length === tracks.length;\n this.tracks = tracks || [];\n\n if (this.config.renderTextTracksNatively) {\n var inUseTracks = this.media ? this.media.textTracks : [];\n this.tracks.forEach(function (track, index) {\n var textTrack;\n\n if (index < inUseTracks.length) {\n var inUseTrack = null;\n\n for (var i = 0; i < inUseTracks.length; i++) {\n if (canReuseVttTextTrack(inUseTracks[i], track)) {\n inUseTrack = inUseTracks[i];\n break;\n }\n } // Reuse tracks with the same label, but do not reuse 608/708 tracks\n\n\n if (inUseTrack) {\n textTrack = inUseTrack;\n }\n }\n\n if (textTrack) {\n Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"clearCurrentCues\"])(textTrack);\n } else {\n var textTrackKind = _this2._captionsOrSubtitlesFromCharacteristics(track);\n\n textTrack = _this2.createTextTrack(textTrackKind, track.name, track.lang);\n\n if (textTrack) {\n textTrack.mode = 'disabled';\n }\n }\n\n if (textTrack) {\n textTrack.groupId = track.groupId;\n\n _this2.textTracks.push(textTrack);\n }\n });\n } else if (!sameTracks && this.tracks && this.tracks.length) {\n // Create a list of tracks for the provider to consume\n var tracksList = this.tracks.map(function (track) {\n return {\n label: track.name,\n kind: track.type.toLowerCase(),\n default: track.default,\n subtitleTrack: track\n };\n });\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].NON_NATIVE_TEXT_TRACKS_FOUND, {\n tracks: tracksList\n });\n }\n }\n };\n\n _proto._captionsOrSubtitlesFromCharacteristics = function _captionsOrSubtitlesFromCharacteristics(track) {\n var _track$attrs;\n\n if ((_track$attrs = track.attrs) !== null && _track$attrs !== void 0 && _track$attrs.CHARACTERISTICS) {\n var transcribesSpokenDialog = /transcribes-spoken-dialog/gi.test(track.attrs.CHARACTERISTICS);\n var describesMusicAndSound = /describes-music-and-sound/gi.test(track.attrs.CHARACTERISTICS);\n\n if (transcribesSpokenDialog && describesMusicAndSound) {\n return 'captions';\n }\n }\n\n return 'subtitles';\n };\n\n _proto.onManifestLoaded = function onManifestLoaded(event, data) {\n var _this3 = this;\n\n if (this.config.enableCEA708Captions && data.captions) {\n data.captions.forEach(function (captionsTrack) {\n var instreamIdMatch = /(?:CC|SERVICE)([1-4])/.exec(captionsTrack.instreamId);\n\n if (!instreamIdMatch) {\n return;\n }\n\n var trackName = \"textTrack\" + instreamIdMatch[1];\n var trackProperties = _this3.captionsProperties[trackName];\n\n if (!trackProperties) {\n return;\n }\n\n trackProperties.label = captionsTrack.name;\n\n if (captionsTrack.lang) {\n // optional attribute\n trackProperties.languageCode = captionsTrack.lang;\n }\n\n trackProperties.media = captionsTrack;\n });\n }\n };\n\n _proto.onFragLoading = function onFragLoading(event, data) {\n var cea608Parser1 = this.cea608Parser1,\n cea608Parser2 = this.cea608Parser2,\n lastSn = this.lastSn,\n lastPartIndex = this.lastPartIndex;\n\n if (!this.enabled || !(cea608Parser1 && cea608Parser2)) {\n return;\n } // if this frag isn't contiguous, clear the parser so cues with bad start/end times aren't added to the textTrack\n\n\n if (data.frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_8__[\"PlaylistLevelType\"].MAIN) {\n var _data$part$index, _data$part;\n\n var sn = data.frag.sn;\n var partIndex = (_data$part$index = data === null || data === void 0 ? void 0 : (_data$part = data.part) === null || _data$part === void 0 ? void 0 : _data$part.index) != null ? _data$part$index : -1;\n\n if (!(sn === lastSn + 1 || sn === lastSn && partIndex === lastPartIndex + 1)) {\n cea608Parser1.reset();\n cea608Parser2.reset();\n }\n\n this.lastSn = sn;\n this.lastPartIndex = partIndex;\n }\n };\n\n _proto.onFragLoaded = function onFragLoaded(event, data) {\n var frag = data.frag,\n payload = data.payload;\n var initPTS = this.initPTS,\n unparsedVttFrags = this.unparsedVttFrags;\n\n if (frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_8__[\"PlaylistLevelType\"].SUBTITLE) {\n // If fragment is subtitle type, parse as WebVTT.\n if (payload.byteLength) {\n // We need an initial synchronisation PTS. Store fragments as long as none has arrived.\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(initPTS[frag.cc])) {\n unparsedVttFrags.push(data);\n\n if (initPTS.length) {\n // finish unsuccessfully, otherwise the subtitle-stream-controller could be blocked from loading new frags.\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: false,\n frag: frag,\n error: new Error('Missing initial subtitle PTS')\n });\n }\n\n return;\n }\n\n var decryptData = frag.decryptdata; // fragment after decryption has a stats object\n\n var decrypted = ('stats' in data); // If the subtitles are not encrypted, parse VTTs now. Otherwise, we need to wait.\n\n if (decryptData == null || decryptData.key == null || decryptData.method !== 'AES-128' || decrypted) {\n var trackPlaylistMedia = this.tracks[frag.level];\n var vttCCs = this.vttCCs;\n\n if (!vttCCs[frag.cc]) {\n vttCCs[frag.cc] = {\n start: frag.start,\n prevCC: this.prevCC,\n new: true\n };\n this.prevCC = frag.cc;\n }\n\n if (trackPlaylistMedia && trackPlaylistMedia.textCodec === _utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__[\"IMSC1_CODEC\"]) {\n this._parseIMSC1(frag, payload);\n } else {\n this._parseVTTs(frag, payload, vttCCs);\n }\n }\n } else {\n // In case there is no payload, finish unsuccessfully.\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: false,\n frag: frag,\n error: new Error('Empty subtitle payload')\n });\n }\n }\n };\n\n _proto._parseIMSC1 = function _parseIMSC1(frag, payload) {\n var _this4 = this;\n\n var hls = this.hls;\n Object(_utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__[\"parseIMSC1\"])(payload, this.initPTS[frag.cc], this.timescale[frag.cc], function (cues) {\n _this4._appendCues(cues, frag.level);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: true,\n frag: frag\n });\n }, function (error) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"Failed to parse IMSC1: \" + error);\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: false,\n frag: frag,\n error: error\n });\n });\n };\n\n _proto._parseVTTs = function _parseVTTs(frag, payload, vttCCs) {\n var _frag$initSegment,\n _this5 = this;\n\n var hls = this.hls; // Parse the WebVTT file contents.\n\n var payloadWebVTT = (_frag$initSegment = frag.initSegment) !== null && _frag$initSegment !== void 0 && _frag$initSegment.data ? Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_7__[\"appendUint8Array\"])(frag.initSegment.data, new Uint8Array(payload)) : payload;\n Object(_utils_webvtt_parser__WEBPACK_IMPORTED_MODULE_4__[\"parseWebVTT\"])(payloadWebVTT, this.initPTS[frag.cc], this.timescale[frag.cc], vttCCs, frag.cc, frag.start, function (cues) {\n _this5._appendCues(cues, frag.level);\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: true,\n frag: frag\n });\n }, function (error) {\n _this5._fallbackToIMSC1(frag, payload); // Something went wrong while parsing. Trigger event with success false.\n\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"Failed to parse VTT cue: \" + error);\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_FRAG_PROCESSED, {\n success: false,\n frag: frag,\n error: error\n });\n });\n };\n\n _proto._fallbackToIMSC1 = function _fallbackToIMSC1(frag, payload) {\n var _this6 = this;\n\n // If textCodec is unknown, try parsing as IMSC1. Set textCodec based on the result\n var trackPlaylistMedia = this.tracks[frag.level];\n\n if (!trackPlaylistMedia.textCodec) {\n Object(_utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__[\"parseIMSC1\"])(payload, this.initPTS[frag.cc], this.timescale[frag.cc], function () {\n trackPlaylistMedia.textCodec = _utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__[\"IMSC1_CODEC\"];\n\n _this6._parseIMSC1(frag, payload);\n }, function () {\n trackPlaylistMedia.textCodec = 'wvtt';\n });\n }\n };\n\n _proto._appendCues = function _appendCues(cues, fragLevel) {\n var hls = this.hls;\n\n if (this.config.renderTextTracksNatively) {\n var textTrack = this.textTracks[fragLevel]; // WebVTTParser.parse is an async method and if the currently selected text track mode is set to \"disabled\"\n // before parsing is done then don't try to access currentTrack.cues.getCueById as cues will be null\n // and trying to access getCueById method of cues will throw an exception\n // Because we check if the mode is disabled, we can force check `cues` below. They can't be null.\n\n if (!textTrack || textTrack.mode === 'disabled') {\n return;\n }\n\n cues.forEach(function (cue) {\n return Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"addCueToTrack\"])(textTrack, cue);\n });\n } else {\n var currentTrack = this.tracks[fragLevel];\n\n if (!currentTrack) {\n return;\n }\n\n var track = currentTrack.default ? 'default' : 'subtitles' + fragLevel;\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].CUES_PARSED, {\n type: 'subtitles',\n cues: cues,\n track: track\n });\n }\n };\n\n _proto.onFragDecrypted = function onFragDecrypted(event, data) {\n var frag = data.frag;\n\n if (frag.type === _types_loader__WEBPACK_IMPORTED_MODULE_8__[\"PlaylistLevelType\"].SUBTITLE) {\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.initPTS[frag.cc])) {\n this.unparsedVttFrags.push(data);\n return;\n }\n\n this.onFragLoaded(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_LOADED, data);\n }\n };\n\n _proto.onSubtitleTracksCleared = function onSubtitleTracksCleared() {\n this.tracks = [];\n this.captionsTracks = {};\n };\n\n _proto.onFragParsingUserdata = function onFragParsingUserdata(event, data) {\n var cea608Parser1 = this.cea608Parser1,\n cea608Parser2 = this.cea608Parser2;\n\n if (!this.enabled || !(cea608Parser1 && cea608Parser2)) {\n return;\n } // If the event contains captions (found in the bytes property), push all bytes into the parser immediately\n // It will create the proper timestamps based on the PTS value\n\n\n for (var i = 0; i < data.samples.length; i++) {\n var ccBytes = data.samples[i].bytes;\n\n if (ccBytes) {\n var ccdatas = this.extractCea608Data(ccBytes);\n cea608Parser1.addData(data.samples[i].pts, ccdatas[0]);\n cea608Parser2.addData(data.samples[i].pts, ccdatas[1]);\n }\n }\n };\n\n _proto.onBufferFlushing = function onBufferFlushing(event, _ref2) {\n var startOffset = _ref2.startOffset,\n endOffset = _ref2.endOffset,\n endOffsetSubtitles = _ref2.endOffsetSubtitles,\n type = _ref2.type;\n var media = this.media;\n\n if (!media || media.currentTime < endOffset) {\n return;\n } // Clear 608 caption cues from the captions TextTracks when the video back buffer is flushed\n // Forward cues are never removed because we can loose streamed 608 content from recent fragments\n\n\n if (!type || type === 'video') {\n var captionsTracks = this.captionsTracks;\n Object.keys(captionsTracks).forEach(function (trackName) {\n return Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"removeCuesInRange\"])(captionsTracks[trackName], startOffset, endOffset);\n });\n }\n\n if (this.config.renderTextTracksNatively) {\n // Clear VTT/IMSC1 subtitle cues from the subtitle TextTracks when the back buffer is flushed\n if (startOffset === 0 && endOffsetSubtitles !== undefined) {\n var textTracks = this.textTracks;\n Object.keys(textTracks).forEach(function (trackName) {\n return Object(_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__[\"removeCuesInRange\"])(textTracks[trackName], startOffset, endOffsetSubtitles);\n });\n }\n }\n };\n\n _proto.extractCea608Data = function extractCea608Data(byteArray) {\n var actualCCBytes = [[], []];\n var count = byteArray[0] & 0x1f;\n var position = 2;\n\n for (var j = 0; j < count; j++) {\n var tmpByte = byteArray[position++];\n var ccbyte1 = 0x7f & byteArray[position++];\n var ccbyte2 = 0x7f & byteArray[position++];\n\n if (ccbyte1 === 0 && ccbyte2 === 0) {\n continue;\n }\n\n var ccValid = (0x04 & tmpByte) !== 0; // Support all four channels\n\n if (ccValid) {\n var ccType = 0x03 & tmpByte;\n\n if (0x00\n /* CEA608 field1*/\n === ccType || 0x01\n /* CEA608 field2*/\n === ccType) {\n // Exclude CEA708 CC data.\n actualCCBytes[ccType].push(ccbyte1);\n actualCCBytes[ccType].push(ccbyte2);\n }\n }\n }\n\n return actualCCBytes;\n };\n\n return TimelineController;\n}();\n\nfunction canReuseVttTextTrack(inUseTrack, manifestTrack) {\n return inUseTrack && inUseTrack.label === manifestTrack.name && !(inUseTrack.textTrack1 || inUseTrack.textTrack2);\n}\n\nfunction intersection(x1, x2, y1, y2) {\n return Math.min(x2, y2) - Math.max(x1, y1);\n}\n\nfunction newVTTCCs() {\n return {\n ccOffset: 0,\n presentationOffset: 0,\n 0: {\n start: 0,\n prevCC: -1,\n new: true\n }\n };\n}\n\n/***/ }),\n\n/***/ \"./src/crypt/aes-crypto.ts\":\n/*!*********************************!*\\\n !*** ./src/crypt/aes-crypto.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return AESCrypto; });\nvar AESCrypto = /*#__PURE__*/function () {\n function AESCrypto(subtle, iv) {\n this.subtle = void 0;\n this.aesIV = void 0;\n this.subtle = subtle;\n this.aesIV = iv;\n }\n\n var _proto = AESCrypto.prototype;\n\n _proto.decrypt = function decrypt(data, key) {\n return this.subtle.decrypt({\n name: 'AES-CBC',\n iv: this.aesIV\n }, key, data);\n };\n\n return AESCrypto;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/crypt/aes-decryptor.ts\":\n/*!************************************!*\\\n !*** ./src/crypt/aes-decryptor.ts ***!\n \\************************************/\n/*! exports provided: removePadding, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"removePadding\", function() { return removePadding; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return AESDecryptor; });\n/* harmony import */ var _utils_typed_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/typed-array */ \"./src/utils/typed-array.ts\");\n // PKCS7\n\nfunction removePadding(array) {\n var outputBytes = array.byteLength;\n var paddingBytes = outputBytes && new DataView(array.buffer).getUint8(outputBytes - 1);\n\n if (paddingBytes) {\n return Object(_utils_typed_array__WEBPACK_IMPORTED_MODULE_0__[\"sliceUint8\"])(array, 0, outputBytes - paddingBytes);\n }\n\n return array;\n}\n\nvar AESDecryptor = /*#__PURE__*/function () {\n function AESDecryptor() {\n this.rcon = [0x0, 0x1, 0x2, 0x4, 0x8, 0x10, 0x20, 0x40, 0x80, 0x1b, 0x36];\n this.subMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.invSubMix = [new Uint32Array(256), new Uint32Array(256), new Uint32Array(256), new Uint32Array(256)];\n this.sBox = new Uint32Array(256);\n this.invSBox = new Uint32Array(256);\n this.key = new Uint32Array(0);\n this.ksRows = 0;\n this.keySize = 0;\n this.keySchedule = void 0;\n this.invKeySchedule = void 0;\n this.initTable();\n } // Using view.getUint32() also swaps the byte order.\n\n\n var _proto = AESDecryptor.prototype;\n\n _proto.uint8ArrayToUint32Array_ = function uint8ArrayToUint32Array_(arrayBuffer) {\n var view = new DataView(arrayBuffer);\n var newArray = new Uint32Array(4);\n\n for (var i = 0; i < 4; i++) {\n newArray[i] = view.getUint32(i * 4);\n }\n\n return newArray;\n };\n\n _proto.initTable = function initTable() {\n var sBox = this.sBox;\n var invSBox = this.invSBox;\n var subMix = this.subMix;\n var subMix0 = subMix[0];\n var subMix1 = subMix[1];\n var subMix2 = subMix[2];\n var subMix3 = subMix[3];\n var invSubMix = this.invSubMix;\n var invSubMix0 = invSubMix[0];\n var invSubMix1 = invSubMix[1];\n var invSubMix2 = invSubMix[2];\n var invSubMix3 = invSubMix[3];\n var d = new Uint32Array(256);\n var x = 0;\n var xi = 0;\n var i = 0;\n\n for (i = 0; i < 256; i++) {\n if (i < 128) {\n d[i] = i << 1;\n } else {\n d[i] = i << 1 ^ 0x11b;\n }\n }\n\n for (i = 0; i < 256; i++) {\n var sx = xi ^ xi << 1 ^ xi << 2 ^ xi << 3 ^ xi << 4;\n sx = sx >>> 8 ^ sx & 0xff ^ 0x63;\n sBox[x] = sx;\n invSBox[sx] = x; // Compute multiplication\n\n var x2 = d[x];\n var x4 = d[x2];\n var x8 = d[x4]; // Compute sub/invSub bytes, mix columns tables\n\n var t = d[sx] * 0x101 ^ sx * 0x1010100;\n subMix0[x] = t << 24 | t >>> 8;\n subMix1[x] = t << 16 | t >>> 16;\n subMix2[x] = t << 8 | t >>> 24;\n subMix3[x] = t; // Compute inv sub bytes, inv mix columns tables\n\n t = x8 * 0x1010101 ^ x4 * 0x10001 ^ x2 * 0x101 ^ x * 0x1010100;\n invSubMix0[sx] = t << 24 | t >>> 8;\n invSubMix1[sx] = t << 16 | t >>> 16;\n invSubMix2[sx] = t << 8 | t >>> 24;\n invSubMix3[sx] = t; // Compute next counter\n\n if (!x) {\n x = xi = 1;\n } else {\n x = x2 ^ d[d[d[x8 ^ x2]]];\n xi ^= d[d[xi]];\n }\n }\n };\n\n _proto.expandKey = function expandKey(keyBuffer) {\n // convert keyBuffer to Uint32Array\n var key = this.uint8ArrayToUint32Array_(keyBuffer);\n var sameKey = true;\n var offset = 0;\n\n while (offset < key.length && sameKey) {\n sameKey = key[offset] === this.key[offset];\n offset++;\n }\n\n if (sameKey) {\n return;\n }\n\n this.key = key;\n var keySize = this.keySize = key.length;\n\n if (keySize !== 4 && keySize !== 6 && keySize !== 8) {\n throw new Error('Invalid aes key size=' + keySize);\n }\n\n var ksRows = this.ksRows = (keySize + 6 + 1) * 4;\n var ksRow;\n var invKsRow;\n var keySchedule = this.keySchedule = new Uint32Array(ksRows);\n var invKeySchedule = this.invKeySchedule = new Uint32Array(ksRows);\n var sbox = this.sBox;\n var rcon = this.rcon;\n var invSubMix = this.invSubMix;\n var invSubMix0 = invSubMix[0];\n var invSubMix1 = invSubMix[1];\n var invSubMix2 = invSubMix[2];\n var invSubMix3 = invSubMix[3];\n var prev;\n var t;\n\n for (ksRow = 0; ksRow < ksRows; ksRow++) {\n if (ksRow < keySize) {\n prev = keySchedule[ksRow] = key[ksRow];\n continue;\n }\n\n t = prev;\n\n if (ksRow % keySize === 0) {\n // Rot word\n t = t << 8 | t >>> 24; // Sub word\n\n t = sbox[t >>> 24] << 24 | sbox[t >>> 16 & 0xff] << 16 | sbox[t >>> 8 & 0xff] << 8 | sbox[t & 0xff]; // Mix Rcon\n\n t ^= rcon[ksRow / keySize | 0] << 24;\n } else if (keySize > 6 && ksRow % keySize === 4) {\n // Sub word\n t = sbox[t >>> 24] << 24 | sbox[t >>> 16 & 0xff] << 16 | sbox[t >>> 8 & 0xff] << 8 | sbox[t & 0xff];\n }\n\n keySchedule[ksRow] = prev = (keySchedule[ksRow - keySize] ^ t) >>> 0;\n }\n\n for (invKsRow = 0; invKsRow < ksRows; invKsRow++) {\n ksRow = ksRows - invKsRow;\n\n if (invKsRow & 3) {\n t = keySchedule[ksRow];\n } else {\n t = keySchedule[ksRow - 4];\n }\n\n if (invKsRow < 4 || ksRow <= 4) {\n invKeySchedule[invKsRow] = t;\n } else {\n invKeySchedule[invKsRow] = invSubMix0[sbox[t >>> 24]] ^ invSubMix1[sbox[t >>> 16 & 0xff]] ^ invSubMix2[sbox[t >>> 8 & 0xff]] ^ invSubMix3[sbox[t & 0xff]];\n }\n\n invKeySchedule[invKsRow] = invKeySchedule[invKsRow] >>> 0;\n }\n } // Adding this as a method greatly improves performance.\n ;\n\n _proto.networkToHostOrderSwap = function networkToHostOrderSwap(word) {\n return word << 24 | (word & 0xff00) << 8 | (word & 0xff0000) >> 8 | word >>> 24;\n };\n\n _proto.decrypt = function decrypt(inputArrayBuffer, offset, aesIV) {\n var nRounds = this.keySize + 6;\n var invKeySchedule = this.invKeySchedule;\n var invSBOX = this.invSBox;\n var invSubMix = this.invSubMix;\n var invSubMix0 = invSubMix[0];\n var invSubMix1 = invSubMix[1];\n var invSubMix2 = invSubMix[2];\n var invSubMix3 = invSubMix[3];\n var initVector = this.uint8ArrayToUint32Array_(aesIV);\n var initVector0 = initVector[0];\n var initVector1 = initVector[1];\n var initVector2 = initVector[2];\n var initVector3 = initVector[3];\n var inputInt32 = new Int32Array(inputArrayBuffer);\n var outputInt32 = new Int32Array(inputInt32.length);\n var t0, t1, t2, t3;\n var s0, s1, s2, s3;\n var inputWords0, inputWords1, inputWords2, inputWords3;\n var ksRow, i;\n var swapWord = this.networkToHostOrderSwap;\n\n while (offset < inputInt32.length) {\n inputWords0 = swapWord(inputInt32[offset]);\n inputWords1 = swapWord(inputInt32[offset + 1]);\n inputWords2 = swapWord(inputInt32[offset + 2]);\n inputWords3 = swapWord(inputInt32[offset + 3]);\n s0 = inputWords0 ^ invKeySchedule[0];\n s1 = inputWords3 ^ invKeySchedule[1];\n s2 = inputWords2 ^ invKeySchedule[2];\n s3 = inputWords1 ^ invKeySchedule[3];\n ksRow = 4; // Iterate through the rounds of decryption\n\n for (i = 1; i < nRounds; i++) {\n t0 = invSubMix0[s0 >>> 24] ^ invSubMix1[s1 >> 16 & 0xff] ^ invSubMix2[s2 >> 8 & 0xff] ^ invSubMix3[s3 & 0xff] ^ invKeySchedule[ksRow];\n t1 = invSubMix0[s1 >>> 24] ^ invSubMix1[s2 >> 16 & 0xff] ^ invSubMix2[s3 >> 8 & 0xff] ^ invSubMix3[s0 & 0xff] ^ invKeySchedule[ksRow + 1];\n t2 = invSubMix0[s2 >>> 24] ^ invSubMix1[s3 >> 16 & 0xff] ^ invSubMix2[s0 >> 8 & 0xff] ^ invSubMix3[s1 & 0xff] ^ invKeySchedule[ksRow + 2];\n t3 = invSubMix0[s3 >>> 24] ^ invSubMix1[s0 >> 16 & 0xff] ^ invSubMix2[s1 >> 8 & 0xff] ^ invSubMix3[s2 & 0xff] ^ invKeySchedule[ksRow + 3]; // Update state\n\n s0 = t0;\n s1 = t1;\n s2 = t2;\n s3 = t3;\n ksRow = ksRow + 4;\n } // Shift rows, sub bytes, add round key\n\n\n t0 = invSBOX[s0 >>> 24] << 24 ^ invSBOX[s1 >> 16 & 0xff] << 16 ^ invSBOX[s2 >> 8 & 0xff] << 8 ^ invSBOX[s3 & 0xff] ^ invKeySchedule[ksRow];\n t1 = invSBOX[s1 >>> 24] << 24 ^ invSBOX[s2 >> 16 & 0xff] << 16 ^ invSBOX[s3 >> 8 & 0xff] << 8 ^ invSBOX[s0 & 0xff] ^ invKeySchedule[ksRow + 1];\n t2 = invSBOX[s2 >>> 24] << 24 ^ invSBOX[s3 >> 16 & 0xff] << 16 ^ invSBOX[s0 >> 8 & 0xff] << 8 ^ invSBOX[s1 & 0xff] ^ invKeySchedule[ksRow + 2];\n t3 = invSBOX[s3 >>> 24] << 24 ^ invSBOX[s0 >> 16 & 0xff] << 16 ^ invSBOX[s1 >> 8 & 0xff] << 8 ^ invSBOX[s2 & 0xff] ^ invKeySchedule[ksRow + 3]; // Write\n\n outputInt32[offset] = swapWord(t0 ^ initVector0);\n outputInt32[offset + 1] = swapWord(t3 ^ initVector1);\n outputInt32[offset + 2] = swapWord(t2 ^ initVector2);\n outputInt32[offset + 3] = swapWord(t1 ^ initVector3); // reset initVector to last 4 unsigned int\n\n initVector0 = inputWords0;\n initVector1 = inputWords1;\n initVector2 = inputWords2;\n initVector3 = inputWords3;\n offset = offset + 4;\n }\n\n return outputInt32.buffer;\n };\n\n return AESDecryptor;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/crypt/decrypter.ts\":\n/*!********************************!*\\\n !*** ./src/crypt/decrypter.ts ***!\n \\********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Decrypter; });\n/* harmony import */ var _aes_crypto__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./aes-crypto */ \"./src/crypt/aes-crypto.ts\");\n/* harmony import */ var _fast_aes_key__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./fast-aes-key */ \"./src/crypt/fast-aes-key.ts\");\n/* harmony import */ var _aes_decryptor__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./aes-decryptor */ \"./src/crypt/aes-decryptor.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _utils_typed_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/typed-array */ \"./src/utils/typed-array.ts\");\n\n\n\n\n\n\nvar CHUNK_SIZE = 16; // 16 bytes, 128 bits\n\nvar Decrypter = /*#__PURE__*/function () {\n function Decrypter(observer, config, _temp) {\n var _ref = _temp === void 0 ? {} : _temp,\n _ref$removePKCS7Paddi = _ref.removePKCS7Padding,\n removePKCS7Padding = _ref$removePKCS7Paddi === void 0 ? true : _ref$removePKCS7Paddi;\n\n this.logEnabled = true;\n this.observer = void 0;\n this.config = void 0;\n this.removePKCS7Padding = void 0;\n this.subtle = null;\n this.softwareDecrypter = null;\n this.key = null;\n this.fastAesKey = null;\n this.remainderData = null;\n this.currentIV = null;\n this.currentResult = null;\n this.observer = observer;\n this.config = config;\n this.removePKCS7Padding = removePKCS7Padding; // built in decryptor expects PKCS7 padding\n\n if (removePKCS7Padding) {\n try {\n var browserCrypto = self.crypto;\n\n if (browserCrypto) {\n this.subtle = browserCrypto.subtle || browserCrypto.webkitSubtle;\n }\n } catch (e) {\n /* no-op */\n }\n }\n\n if (this.subtle === null) {\n this.config.enableSoftwareAES = true;\n }\n }\n\n var _proto = Decrypter.prototype;\n\n _proto.destroy = function destroy() {\n // @ts-ignore\n this.observer = null;\n };\n\n _proto.isSync = function isSync() {\n return this.config.enableSoftwareAES;\n };\n\n _proto.flush = function flush() {\n var currentResult = this.currentResult;\n\n if (!currentResult) {\n this.reset();\n return;\n }\n\n var data = new Uint8Array(currentResult);\n this.reset();\n\n if (this.removePKCS7Padding) {\n return Object(_aes_decryptor__WEBPACK_IMPORTED_MODULE_2__[\"removePadding\"])(data);\n }\n\n return data;\n };\n\n _proto.reset = function reset() {\n this.currentResult = null;\n this.currentIV = null;\n this.remainderData = null;\n\n if (this.softwareDecrypter) {\n this.softwareDecrypter = null;\n }\n };\n\n _proto.decrypt = function decrypt(data, key, iv, callback) {\n if (this.config.enableSoftwareAES) {\n this.softwareDecrypt(new Uint8Array(data), key, iv);\n var decryptResult = this.flush();\n\n if (decryptResult) {\n callback(decryptResult.buffer);\n }\n } else {\n this.webCryptoDecrypt(new Uint8Array(data), key, iv).then(callback);\n }\n };\n\n _proto.softwareDecrypt = function softwareDecrypt(data, key, iv) {\n var currentIV = this.currentIV,\n currentResult = this.currentResult,\n remainderData = this.remainderData;\n this.logOnce('JS AES decrypt'); // The output is staggered during progressive parsing - the current result is cached, and emitted on the next call\n // This is done in order to strip PKCS7 padding, which is found at the end of each segment. We only know we've reached\n // the end on flush(), but by that time we have already received all bytes for the segment.\n // Progressive decryption does not work with WebCrypto\n\n if (remainderData) {\n data = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"appendUint8Array\"])(remainderData, data);\n this.remainderData = null;\n } // Byte length must be a multiple of 16 (AES-128 = 128 bit blocks = 16 bytes)\n\n\n var currentChunk = this.getValidChunk(data);\n\n if (!currentChunk.length) {\n return null;\n }\n\n if (currentIV) {\n iv = currentIV;\n }\n\n var softwareDecrypter = this.softwareDecrypter;\n\n if (!softwareDecrypter) {\n softwareDecrypter = this.softwareDecrypter = new _aes_decryptor__WEBPACK_IMPORTED_MODULE_2__[\"default\"]();\n }\n\n softwareDecrypter.expandKey(key);\n var result = currentResult;\n this.currentResult = softwareDecrypter.decrypt(currentChunk.buffer, 0, iv);\n this.currentIV = Object(_utils_typed_array__WEBPACK_IMPORTED_MODULE_5__[\"sliceUint8\"])(currentChunk, -16).buffer;\n\n if (!result) {\n return null;\n }\n\n return result;\n };\n\n _proto.webCryptoDecrypt = function webCryptoDecrypt(data, key, iv) {\n var _this = this;\n\n var subtle = this.subtle;\n\n if (this.key !== key || !this.fastAesKey) {\n this.key = key;\n this.fastAesKey = new _fast_aes_key__WEBPACK_IMPORTED_MODULE_1__[\"default\"](subtle, key);\n }\n\n return this.fastAesKey.expandKey().then(function (aesKey) {\n // decrypt using web crypto\n if (!subtle) {\n return Promise.reject(new Error('web crypto not initialized'));\n }\n\n var crypto = new _aes_crypto__WEBPACK_IMPORTED_MODULE_0__[\"default\"](subtle, iv);\n return crypto.decrypt(data.buffer, aesKey);\n }).catch(function (err) {\n return _this.onWebCryptoError(err, data, key, iv);\n });\n };\n\n _proto.onWebCryptoError = function onWebCryptoError(err, data, key, iv) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn('[decrypter.ts]: WebCrypto Error, disable WebCrypto API:', err);\n this.config.enableSoftwareAES = true;\n this.logEnabled = true;\n return this.softwareDecrypt(data, key, iv);\n };\n\n _proto.getValidChunk = function getValidChunk(data) {\n var currentChunk = data;\n var splitPoint = data.length - data.length % CHUNK_SIZE;\n\n if (splitPoint !== data.length) {\n currentChunk = Object(_utils_typed_array__WEBPACK_IMPORTED_MODULE_5__[\"sliceUint8\"])(data, 0, splitPoint);\n this.remainderData = Object(_utils_typed_array__WEBPACK_IMPORTED_MODULE_5__[\"sliceUint8\"])(data, splitPoint);\n }\n\n return currentChunk;\n };\n\n _proto.logOnce = function logOnce(msg) {\n if (!this.logEnabled) {\n return;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log(\"[decrypter.ts]: \" + msg);\n this.logEnabled = false;\n };\n\n return Decrypter;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/crypt/fast-aes-key.ts\":\n/*!***********************************!*\\\n !*** ./src/crypt/fast-aes-key.ts ***!\n \\***********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return FastAESKey; });\nvar FastAESKey = /*#__PURE__*/function () {\n function FastAESKey(subtle, key) {\n this.subtle = void 0;\n this.key = void 0;\n this.subtle = subtle;\n this.key = key;\n }\n\n var _proto = FastAESKey.prototype;\n\n _proto.expandKey = function expandKey() {\n return this.subtle.importKey('raw', this.key, {\n name: 'AES-CBC'\n }, false, ['encrypt', 'decrypt']);\n };\n\n return FastAESKey;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/demux/aacdemuxer.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/aacdemuxer.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _base_audio_demuxer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./base-audio-demuxer */ \"./src/demux/base-audio-demuxer.ts\");\n/* harmony import */ var _adts__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./adts */ \"./src/demux/adts.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n/**\n * AAC demuxer\n */\n\n\n\n\n\nvar AACDemuxer = /*#__PURE__*/function (_BaseAudioDemuxer) {\n _inheritsLoose(AACDemuxer, _BaseAudioDemuxer);\n\n function AACDemuxer(observer, config) {\n var _this;\n\n _this = _BaseAudioDemuxer.call(this) || this;\n _this.observer = void 0;\n _this.config = void 0;\n _this.observer = observer;\n _this.config = config;\n return _this;\n }\n\n var _proto = AACDemuxer.prototype;\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec, trackDuration) {\n _BaseAudioDemuxer.prototype.resetInitSegment.call(this, initSegment, audioCodec, videoCodec, trackDuration);\n\n this._audioTrack = {\n container: 'audio/adts',\n type: 'audio',\n id: 2,\n pid: -1,\n sequenceNumber: 0,\n segmentCodec: 'aac',\n samples: [],\n manifestCodec: audioCodec,\n duration: trackDuration,\n inputTimeScale: 90000,\n dropped: 0\n };\n } // Source for probe info - https://wiki.multimedia.cx/index.php?title=ADTS\n ;\n\n AACDemuxer.probe = function probe(data) {\n if (!data) {\n return false;\n } // Check for the ADTS sync word\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n\n\n var id3Data = _demux_id3__WEBPACK_IMPORTED_MODULE_3__[\"getID3Data\"](data, 0) || [];\n var offset = id3Data.length;\n\n for (var length = data.length; offset < length; offset++) {\n if (_adts__WEBPACK_IMPORTED_MODULE_1__[\"probe\"](data, offset)) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('ADTS sync word found !');\n return true;\n }\n }\n\n return false;\n };\n\n _proto.canParse = function canParse(data, offset) {\n return _adts__WEBPACK_IMPORTED_MODULE_1__[\"canParse\"](data, offset);\n };\n\n _proto.appendFrame = function appendFrame(track, data, offset) {\n _adts__WEBPACK_IMPORTED_MODULE_1__[\"initTrackConfig\"](track, this.observer, data, offset, track.manifestCodec);\n var frame = _adts__WEBPACK_IMPORTED_MODULE_1__[\"appendFrame\"](track, data, offset, this.basePTS, this.frameIndex);\n\n if (frame && frame.missing === 0) {\n return frame;\n }\n };\n\n return AACDemuxer;\n}(_base_audio_demuxer__WEBPACK_IMPORTED_MODULE_0__[\"default\"]);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (AACDemuxer);\n\n/***/ }),\n\n/***/ \"./src/demux/adts.ts\":\n/*!***************************!*\\\n !*** ./src/demux/adts.ts ***!\n \\***************************/\n/*! exports provided: getAudioConfig, isHeaderPattern, getHeaderLength, getFullFrameLength, canGetFrameLength, isHeader, canParse, probe, initTrackConfig, getFrameDuration, parseFrameHeader, appendFrame */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getAudioConfig\", function() { return getAudioConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isHeaderPattern\", function() { return isHeaderPattern; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getHeaderLength\", function() { return getHeaderLength; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getFullFrameLength\", function() { return getFullFrameLength; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"canGetFrameLength\", function() { return canGetFrameLength; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isHeader\", function() { return isHeader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"canParse\", function() { return canParse; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"probe\", function() { return probe; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"initTrackConfig\", function() { return initTrackConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getFrameDuration\", function() { return getFrameDuration; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseFrameHeader\", function() { return parseFrameHeader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"appendFrame\", function() { return appendFrame; });\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/**\n * ADTS parser helper\n * @link https://wiki.multimedia.cx/index.php?title=ADTS\n */\n\n\n\nfunction getAudioConfig(observer, data, offset, audioCodec) {\n var adtsObjectType;\n var adtsExtensionSamplingIndex;\n var adtsChanelConfig;\n var config;\n var userAgent = navigator.userAgent.toLowerCase();\n var manifestCodec = audioCodec;\n var adtsSampleingRates = [96000, 88200, 64000, 48000, 44100, 32000, 24000, 22050, 16000, 12000, 11025, 8000, 7350]; // byte 2\n\n adtsObjectType = ((data[offset + 2] & 0xc0) >>> 6) + 1;\n var adtsSamplingIndex = (data[offset + 2] & 0x3c) >>> 2;\n\n if (adtsSamplingIndex > adtsSampleingRates.length - 1) {\n observer.trigger(_events__WEBPACK_IMPORTED_MODULE_2__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_PARSING_ERROR,\n fatal: true,\n reason: \"invalid ADTS sampling index:\" + adtsSamplingIndex\n });\n return;\n }\n\n adtsChanelConfig = (data[offset + 2] & 0x01) << 2; // byte 3\n\n adtsChanelConfig |= (data[offset + 3] & 0xc0) >>> 6;\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].log(\"manifest codec:\" + audioCodec + \", ADTS type:\" + adtsObjectType + \", samplingIndex:\" + adtsSamplingIndex); // firefox: freq less than 24kHz = AAC SBR (HE-AAC)\n\n if (/firefox/i.test(userAgent)) {\n if (adtsSamplingIndex >= 6) {\n adtsObjectType = 5;\n config = new Array(4); // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n\n adtsExtensionSamplingIndex = adtsSamplingIndex - 3;\n } else {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSamplingIndex = adtsSamplingIndex;\n } // Android : always use AAC\n\n } else if (userAgent.indexOf('android') !== -1) {\n adtsObjectType = 2;\n config = new Array(2);\n adtsExtensionSamplingIndex = adtsSamplingIndex;\n } else {\n /* for other browsers (Chrome/Vivaldi/Opera ...)\n always force audio type to be HE-AAC SBR, as some browsers do not support audio codec switch properly (like Chrome ...)\n */\n adtsObjectType = 5;\n config = new Array(4); // if (manifest codec is HE-AAC or HE-AACv2) OR (manifest codec not specified AND frequency less than 24kHz)\n\n if (audioCodec && (audioCodec.indexOf('mp4a.40.29') !== -1 || audioCodec.indexOf('mp4a.40.5') !== -1) || !audioCodec && adtsSamplingIndex >= 6) {\n // HE-AAC uses SBR (Spectral Band Replication) , high frequencies are constructed from low frequencies\n // there is a factor 2 between frame sample rate and output sample rate\n // multiply frequency by 2 (see table below, equivalent to substract 3)\n adtsExtensionSamplingIndex = adtsSamplingIndex - 3;\n } else {\n // if (manifest codec is AAC) AND (frequency less than 24kHz AND nb channel is 1) OR (manifest codec not specified and mono audio)\n // Chrome fails to play back with low frequency AAC LC mono when initialized with HE-AAC. This is not a problem with stereo.\n if (audioCodec && audioCodec.indexOf('mp4a.40.2') !== -1 && (adtsSamplingIndex >= 6 && adtsChanelConfig === 1 || /vivaldi/i.test(userAgent)) || !audioCodec && adtsChanelConfig === 1) {\n adtsObjectType = 2;\n config = new Array(2);\n }\n\n adtsExtensionSamplingIndex = adtsSamplingIndex;\n }\n }\n /* refer to http://wiki.multimedia.cx/index.php?title=MPEG-4_Audio#Audio_Specific_Config\n ISO 14496-3 (AAC).pdf - Table 1.13 — Syntax of AudioSpecificConfig()\n Audio Profile / Audio Object Type\n 0: Null\n 1: AAC Main\n 2: AAC LC (Low Complexity)\n 3: AAC SSR (Scalable Sample Rate)\n 4: AAC LTP (Long Term Prediction)\n 5: SBR (Spectral Band Replication)\n 6: AAC Scalable\n sampling freq\n 0: 96000 Hz\n 1: 88200 Hz\n 2: 64000 Hz\n 3: 48000 Hz\n 4: 44100 Hz\n 5: 32000 Hz\n 6: 24000 Hz\n 7: 22050 Hz\n 8: 16000 Hz\n 9: 12000 Hz\n 10: 11025 Hz\n 11: 8000 Hz\n 12: 7350 Hz\n 13: Reserved\n 14: Reserved\n 15: frequency is written explictly\n Channel Configurations\n These are the channel configurations:\n 0: Defined in AOT Specifc Config\n 1: 1 channel: front-center\n 2: 2 channels: front-left, front-right\n */\n // audioObjectType = profile => profile, the MPEG-4 Audio Object Type minus 1\n\n\n config[0] = adtsObjectType << 3; // samplingFrequencyIndex\n\n config[0] |= (adtsSamplingIndex & 0x0e) >> 1;\n config[1] |= (adtsSamplingIndex & 0x01) << 7; // channelConfiguration\n\n config[1] |= adtsChanelConfig << 3;\n\n if (adtsObjectType === 5) {\n // adtsExtensionSampleingIndex\n config[1] |= (adtsExtensionSamplingIndex & 0x0e) >> 1;\n config[2] = (adtsExtensionSamplingIndex & 0x01) << 7; // adtsObjectType (force to 2, chrome is checking that object type is less than 5 ???\n // https://chromium.googlesource.com/chromium/src.git/+/master/media/formats/mp4/aac.cc\n\n config[2] |= 2 << 2;\n config[3] = 0;\n }\n\n return {\n config: config,\n samplerate: adtsSampleingRates[adtsSamplingIndex],\n channelCount: adtsChanelConfig,\n codec: 'mp4a.40.' + adtsObjectType,\n manifestCodec: manifestCodec\n };\n}\nfunction isHeaderPattern(data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xf6) === 0xf0;\n}\nfunction getHeaderLength(data, offset) {\n return data[offset + 1] & 0x01 ? 7 : 9;\n}\nfunction getFullFrameLength(data, offset) {\n return (data[offset + 3] & 0x03) << 11 | data[offset + 4] << 3 | (data[offset + 5] & 0xe0) >>> 5;\n}\nfunction canGetFrameLength(data, offset) {\n return offset + 5 < data.length;\n}\nfunction isHeader(data, offset) {\n // Look for ADTS header | 1111 1111 | 1111 X00X | where X can be either 0 or 1\n // Layer bits (position 14 and 15) in header should be always 0 for ADTS\n // More info https://wiki.multimedia.cx/index.php?title=ADTS\n return offset + 1 < data.length && isHeaderPattern(data, offset);\n}\nfunction canParse(data, offset) {\n return canGetFrameLength(data, offset) && isHeaderPattern(data, offset) && getFullFrameLength(data, offset) <= data.length - offset;\n}\nfunction probe(data, offset) {\n // same as isHeader but we also check that ADTS frame follows last ADTS frame\n // or end of data is reached\n if (isHeader(data, offset)) {\n // ADTS header Length\n var headerLength = getHeaderLength(data, offset);\n\n if (offset + headerLength >= data.length) {\n return false;\n } // ADTS frame Length\n\n\n var frameLength = getFullFrameLength(data, offset);\n\n if (frameLength <= headerLength) {\n return false;\n }\n\n var newOffset = offset + frameLength;\n return newOffset === data.length || isHeader(data, newOffset);\n }\n\n return false;\n}\nfunction initTrackConfig(track, observer, data, offset, audioCodec) {\n if (!track.samplerate) {\n var config = getAudioConfig(observer, data, offset, audioCodec);\n\n if (!config) {\n return;\n }\n\n track.config = config.config;\n track.samplerate = config.samplerate;\n track.channelCount = config.channelCount;\n track.codec = config.codec;\n track.manifestCodec = config.manifestCodec;\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].log(\"parsed codec:\" + track.codec + \", rate:\" + config.samplerate + \", channels:\" + config.channelCount);\n }\n}\nfunction getFrameDuration(samplerate) {\n return 1024 * 90000 / samplerate;\n}\nfunction parseFrameHeader(data, offset) {\n // The protection skip bit tells us if we have 2 bytes of CRC data at the end of the ADTS header\n var headerLength = getHeaderLength(data, offset);\n\n if (offset + headerLength <= data.length) {\n // retrieve frame size\n var frameLength = getFullFrameLength(data, offset) - headerLength;\n\n if (frameLength > 0) {\n // logger.log(`AAC frame, offset/length/total/pts:${offset+headerLength}/${frameLength}/${data.byteLength}`);\n return {\n headerLength: headerLength,\n frameLength: frameLength\n };\n }\n }\n}\nfunction appendFrame(track, data, offset, pts, frameIndex) {\n var frameDuration = getFrameDuration(track.samplerate);\n var stamp = pts + frameIndex * frameDuration;\n var header = parseFrameHeader(data, offset);\n var unit;\n\n if (header) {\n var frameLength = header.frameLength,\n headerLength = header.headerLength;\n\n var _length = headerLength + frameLength;\n\n var missing = Math.max(0, offset + _length - data.length); // logger.log(`AAC frame ${frameIndex}, pts:${stamp} length@offset/total: ${frameLength}@${offset+headerLength}/${data.byteLength} missing: ${missing}`);\n\n if (missing) {\n unit = new Uint8Array(_length - headerLength);\n unit.set(data.subarray(offset + headerLength, data.length), 0);\n } else {\n unit = data.subarray(offset + headerLength, offset + _length);\n }\n\n var _sample = {\n unit: unit,\n pts: stamp\n };\n\n if (!missing) {\n track.samples.push(_sample);\n }\n\n return {\n sample: _sample,\n length: _length,\n missing: missing\n };\n } // overflow incomplete header\n\n\n var length = data.length - offset;\n unit = new Uint8Array(length);\n unit.set(data.subarray(offset, data.length), 0);\n var sample = {\n unit: unit,\n pts: stamp\n };\n return {\n sample: sample,\n length: length,\n missing: -1\n };\n}\n\n/***/ }),\n\n/***/ \"./src/demux/base-audio-demuxer.ts\":\n/*!*****************************************!*\\\n !*** ./src/demux/base-audio-demuxer.ts ***!\n \\*****************************************/\n/*! exports provided: initPTSFn, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"initPTSFn\", function() { return initPTSFn; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n/* harmony import */ var _types_demuxer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../types/demuxer */ \"./src/types/demuxer.ts\");\n/* harmony import */ var _dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./dummy-demuxed-track */ \"./src/demux/dummy-demuxed-track.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _utils_typed_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/typed-array */ \"./src/utils/typed-array.ts\");\n\n\n\n\n\n\n\n\nvar BaseAudioDemuxer = /*#__PURE__*/function () {\n function BaseAudioDemuxer() {\n this._audioTrack = void 0;\n this._id3Track = void 0;\n this.frameIndex = 0;\n this.cachedData = null;\n this.basePTS = null;\n this.initPTS = null;\n }\n\n var _proto = BaseAudioDemuxer.prototype;\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec, trackDuration) {\n this._id3Track = {\n type: 'id3',\n id: 3,\n pid: -1,\n inputTimeScale: 90000,\n sequenceNumber: 0,\n samples: [],\n dropped: 0\n };\n };\n\n _proto.resetTimeStamp = function resetTimeStamp(deaultTimestamp) {\n this.initPTS = deaultTimestamp;\n this.resetContiguity();\n };\n\n _proto.resetContiguity = function resetContiguity() {\n this.basePTS = null;\n this.frameIndex = 0;\n };\n\n _proto.canParse = function canParse(data, offset) {\n return false;\n };\n\n _proto.appendFrame = function appendFrame(track, data, offset) {} // feed incoming data to the front of the parsing pipeline\n ;\n\n _proto.demux = function demux(data, timeOffset) {\n if (this.cachedData) {\n data = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"appendUint8Array\"])(this.cachedData, data);\n this.cachedData = null;\n }\n\n var id3Data = _demux_id3__WEBPACK_IMPORTED_MODULE_1__[\"getID3Data\"](data, 0);\n var offset = id3Data ? id3Data.length : 0;\n var lastDataIndex;\n var pts;\n var track = this._audioTrack;\n var id3Track = this._id3Track;\n var timestamp = id3Data ? _demux_id3__WEBPACK_IMPORTED_MODULE_1__[\"getTimeStamp\"](id3Data) : undefined;\n var length = data.length;\n\n if (this.basePTS === null || this.frameIndex === 0 && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(timestamp)) {\n this.basePTS = initPTSFn(timestamp, timeOffset, this.initPTS);\n } // more expressive than alternative: id3Data?.length\n\n\n if (id3Data && id3Data.length > 0) {\n id3Track.samples.push({\n pts: this.basePTS,\n dts: this.basePTS,\n data: id3Data,\n type: _types_demuxer__WEBPACK_IMPORTED_MODULE_2__[\"MetadataSchema\"].audioId3\n });\n }\n\n pts = this.basePTS;\n\n while (offset < length) {\n if (this.canParse(data, offset)) {\n var frame = this.appendFrame(track, data, offset);\n\n if (frame) {\n this.frameIndex++;\n pts = frame.sample.pts;\n offset += frame.length;\n lastDataIndex = offset;\n } else {\n offset = length;\n }\n } else if (_demux_id3__WEBPACK_IMPORTED_MODULE_1__[\"canParse\"](data, offset)) {\n // after a ID3.canParse, a call to ID3.getID3Data *should* always returns some data\n id3Data = _demux_id3__WEBPACK_IMPORTED_MODULE_1__[\"getID3Data\"](data, offset);\n id3Track.samples.push({\n pts: pts,\n dts: pts,\n data: id3Data,\n type: _types_demuxer__WEBPACK_IMPORTED_MODULE_2__[\"MetadataSchema\"].audioId3\n });\n offset += id3Data.length;\n lastDataIndex = offset;\n } else {\n offset++;\n }\n\n if (offset === length && lastDataIndex !== length) {\n var partialData = Object(_utils_typed_array__WEBPACK_IMPORTED_MODULE_5__[\"sliceUint8\"])(data, lastDataIndex);\n\n if (this.cachedData) {\n this.cachedData = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"appendUint8Array\"])(this.cachedData, partialData);\n } else {\n this.cachedData = partialData;\n }\n }\n }\n\n return {\n audioTrack: track,\n videoTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])(),\n id3Track: id3Track,\n textTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])()\n };\n };\n\n _proto.demuxSampleAes = function demuxSampleAes(data, keyData, timeOffset) {\n return Promise.reject(new Error(\"[\" + this + \"] This demuxer does not support Sample-AES decryption\"));\n };\n\n _proto.flush = function flush(timeOffset) {\n // Parse cache in case of remaining frames.\n var cachedData = this.cachedData;\n\n if (cachedData) {\n this.cachedData = null;\n this.demux(cachedData, 0);\n }\n\n return {\n audioTrack: this._audioTrack,\n videoTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])(),\n id3Track: this._id3Track,\n textTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])()\n };\n };\n\n _proto.destroy = function destroy() {};\n\n return BaseAudioDemuxer;\n}();\n/**\n * Initialize PTS\n *

\n * use timestamp unless it is undefined, NaN or Infinity\n *

\n */\n\n\nvar initPTSFn = function initPTSFn(timestamp, timeOffset, initPTS) {\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(timestamp)) {\n return timestamp * 90;\n }\n\n return timeOffset * 90000 + (initPTS || 0);\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (BaseAudioDemuxer);\n\n/***/ }),\n\n/***/ \"./src/demux/chunk-cache.ts\":\n/*!**********************************!*\\\n !*** ./src/demux/chunk-cache.ts ***!\n \\**********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return ChunkCache; });\nvar ChunkCache = /*#__PURE__*/function () {\n function ChunkCache() {\n this.chunks = [];\n this.dataLength = 0;\n }\n\n var _proto = ChunkCache.prototype;\n\n _proto.push = function push(chunk) {\n this.chunks.push(chunk);\n this.dataLength += chunk.length;\n };\n\n _proto.flush = function flush() {\n var chunks = this.chunks,\n dataLength = this.dataLength;\n var result;\n\n if (!chunks.length) {\n return new Uint8Array(0);\n } else if (chunks.length === 1) {\n result = chunks[0];\n } else {\n result = concatUint8Arrays(chunks, dataLength);\n }\n\n this.reset();\n return result;\n };\n\n _proto.reset = function reset() {\n this.chunks.length = 0;\n this.dataLength = 0;\n };\n\n return ChunkCache;\n}();\n\n\n\nfunction concatUint8Arrays(chunks, dataLength) {\n var result = new Uint8Array(dataLength);\n var offset = 0;\n\n for (var i = 0; i < chunks.length; i++) {\n var chunk = chunks[i];\n result.set(chunk, offset);\n offset += chunk.length;\n }\n\n return result;\n}\n\n/***/ }),\n\n/***/ \"./src/demux/dummy-demuxed-track.ts\":\n/*!******************************************!*\\\n !*** ./src/demux/dummy-demuxed-track.ts ***!\n \\******************************************/\n/*! exports provided: dummyTrack */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"dummyTrack\", function() { return dummyTrack; });\nfunction dummyTrack(type, inputTimeScale) {\n if (type === void 0) {\n type = '';\n }\n\n if (inputTimeScale === void 0) {\n inputTimeScale = 90000;\n }\n\n return {\n type: type,\n id: -1,\n pid: -1,\n inputTimeScale: inputTimeScale,\n sequenceNumber: -1,\n samples: [],\n dropped: 0\n };\n}\n\n/***/ }),\n\n/***/ \"./src/demux/exp-golomb.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/exp-golomb.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/**\n * Parser for exponential Golomb codes, a variable-bitwidth number encoding scheme used by h264.\n */\n\n\nvar ExpGolomb = /*#__PURE__*/function () {\n function ExpGolomb(data) {\n this.data = void 0;\n this.bytesAvailable = void 0;\n this.word = void 0;\n this.bitsAvailable = void 0;\n this.data = data; // the number of bytes left to examine in this.data\n\n this.bytesAvailable = data.byteLength; // the current word being examined\n\n this.word = 0; // :uint\n // the number of bits left to examine in the current word\n\n this.bitsAvailable = 0; // :uint\n } // ():void\n\n\n var _proto = ExpGolomb.prototype;\n\n _proto.loadWord = function loadWord() {\n var data = this.data;\n var bytesAvailable = this.bytesAvailable;\n var position = data.byteLength - bytesAvailable;\n var workingBytes = new Uint8Array(4);\n var availableBytes = Math.min(4, bytesAvailable);\n\n if (availableBytes === 0) {\n throw new Error('no bytes available');\n }\n\n workingBytes.set(data.subarray(position, position + availableBytes));\n this.word = new DataView(workingBytes.buffer).getUint32(0); // track the amount of this.data that has been processed\n\n this.bitsAvailable = availableBytes * 8;\n this.bytesAvailable -= availableBytes;\n } // (count:int):void\n ;\n\n _proto.skipBits = function skipBits(count) {\n var skipBytes; // :int\n\n if (this.bitsAvailable > count) {\n this.word <<= count;\n this.bitsAvailable -= count;\n } else {\n count -= this.bitsAvailable;\n skipBytes = count >> 3;\n count -= skipBytes >> 3;\n this.bytesAvailable -= skipBytes;\n this.loadWord();\n this.word <<= count;\n this.bitsAvailable -= count;\n }\n } // (size:int):uint\n ;\n\n _proto.readBits = function readBits(size) {\n var bits = Math.min(this.bitsAvailable, size); // :uint\n\n var valu = this.word >>> 32 - bits; // :uint\n\n if (size > 32) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].error('Cannot read more than 32 bits at a time');\n }\n\n this.bitsAvailable -= bits;\n\n if (this.bitsAvailable > 0) {\n this.word <<= bits;\n } else if (this.bytesAvailable > 0) {\n this.loadWord();\n }\n\n bits = size - bits;\n\n if (bits > 0 && this.bitsAvailable) {\n return valu << bits | this.readBits(bits);\n } else {\n return valu;\n }\n } // ():uint\n ;\n\n _proto.skipLZ = function skipLZ() {\n var leadingZeroCount; // :uint\n\n for (leadingZeroCount = 0; leadingZeroCount < this.bitsAvailable; ++leadingZeroCount) {\n if ((this.word & 0x80000000 >>> leadingZeroCount) !== 0) {\n // the first bit of working word is 1\n this.word <<= leadingZeroCount;\n this.bitsAvailable -= leadingZeroCount;\n return leadingZeroCount;\n }\n } // we exhausted word and still have not found a 1\n\n\n this.loadWord();\n return leadingZeroCount + this.skipLZ();\n } // ():void\n ;\n\n _proto.skipUEG = function skipUEG() {\n this.skipBits(1 + this.skipLZ());\n } // ():void\n ;\n\n _proto.skipEG = function skipEG() {\n this.skipBits(1 + this.skipLZ());\n } // ():uint\n ;\n\n _proto.readUEG = function readUEG() {\n var clz = this.skipLZ(); // :uint\n\n return this.readBits(clz + 1) - 1;\n } // ():int\n ;\n\n _proto.readEG = function readEG() {\n var valu = this.readUEG(); // :int\n\n if (0x01 & valu) {\n // the number is odd if the low order bit is set\n return 1 + valu >>> 1; // add 1 to make it even, and divide by 2\n } else {\n return -1 * (valu >>> 1); // divide by two then make it negative\n }\n } // Some convenience functions\n // :Boolean\n ;\n\n _proto.readBoolean = function readBoolean() {\n return this.readBits(1) === 1;\n } // ():int\n ;\n\n _proto.readUByte = function readUByte() {\n return this.readBits(8);\n } // ():int\n ;\n\n _proto.readUShort = function readUShort() {\n return this.readBits(16);\n } // ():int\n ;\n\n _proto.readUInt = function readUInt() {\n return this.readBits(32);\n }\n /**\n * Advance the ExpGolomb decoder past a scaling list. The scaling\n * list is optionally transmitted as part of a sequence parameter\n * set and is not relevant to transmuxing.\n * @param count the number of entries in this scaling list\n * @see Recommendation ITU-T H.264, Section 7.3.2.1.1.1\n */\n ;\n\n _proto.skipScalingList = function skipScalingList(count) {\n var lastScale = 8;\n var nextScale = 8;\n var deltaScale;\n\n for (var j = 0; j < count; j++) {\n if (nextScale !== 0) {\n deltaScale = this.readEG();\n nextScale = (lastScale + deltaScale + 256) % 256;\n }\n\n lastScale = nextScale === 0 ? lastScale : nextScale;\n }\n }\n /**\n * Read a sequence parameter set and return some interesting video\n * properties. A sequence parameter set is the H264 metadata that\n * describes the properties of upcoming video frames.\n * @param data {Uint8Array} the bytes of a sequence parameter set\n * @return {object} an object with configuration parsed from the\n * sequence parameter set, including the dimensions of the\n * associated video frames.\n */\n ;\n\n _proto.readSPS = function readSPS() {\n var frameCropLeftOffset = 0;\n var frameCropRightOffset = 0;\n var frameCropTopOffset = 0;\n var frameCropBottomOffset = 0;\n var numRefFramesInPicOrderCntCycle;\n var scalingListCount;\n var i;\n var readUByte = this.readUByte.bind(this);\n var readBits = this.readBits.bind(this);\n var readUEG = this.readUEG.bind(this);\n var readBoolean = this.readBoolean.bind(this);\n var skipBits = this.skipBits.bind(this);\n var skipEG = this.skipEG.bind(this);\n var skipUEG = this.skipUEG.bind(this);\n var skipScalingList = this.skipScalingList.bind(this);\n readUByte();\n var profileIdc = readUByte(); // profile_idc\n\n readBits(5); // profileCompat constraint_set[0-4]_flag, u(5)\n\n skipBits(3); // reserved_zero_3bits u(3),\n\n readUByte(); // level_idc u(8)\n\n skipUEG(); // seq_parameter_set_id\n // some profiles have more optional data we don't need\n\n if (profileIdc === 100 || profileIdc === 110 || profileIdc === 122 || profileIdc === 244 || profileIdc === 44 || profileIdc === 83 || profileIdc === 86 || profileIdc === 118 || profileIdc === 128) {\n var chromaFormatIdc = readUEG();\n\n if (chromaFormatIdc === 3) {\n skipBits(1);\n } // separate_colour_plane_flag\n\n\n skipUEG(); // bit_depth_luma_minus8\n\n skipUEG(); // bit_depth_chroma_minus8\n\n skipBits(1); // qpprime_y_zero_transform_bypass_flag\n\n if (readBoolean()) {\n // seq_scaling_matrix_present_flag\n scalingListCount = chromaFormatIdc !== 3 ? 8 : 12;\n\n for (i = 0; i < scalingListCount; i++) {\n if (readBoolean()) {\n // seq_scaling_list_present_flag[ i ]\n if (i < 6) {\n skipScalingList(16);\n } else {\n skipScalingList(64);\n }\n }\n }\n }\n }\n\n skipUEG(); // log2_max_frame_num_minus4\n\n var picOrderCntType = readUEG();\n\n if (picOrderCntType === 0) {\n readUEG(); // log2_max_pic_order_cnt_lsb_minus4\n } else if (picOrderCntType === 1) {\n skipBits(1); // delta_pic_order_always_zero_flag\n\n skipEG(); // offset_for_non_ref_pic\n\n skipEG(); // offset_for_top_to_bottom_field\n\n numRefFramesInPicOrderCntCycle = readUEG();\n\n for (i = 0; i < numRefFramesInPicOrderCntCycle; i++) {\n skipEG();\n } // offset_for_ref_frame[ i ]\n\n }\n\n skipUEG(); // max_num_ref_frames\n\n skipBits(1); // gaps_in_frame_num_value_allowed_flag\n\n var picWidthInMbsMinus1 = readUEG();\n var picHeightInMapUnitsMinus1 = readUEG();\n var frameMbsOnlyFlag = readBits(1);\n\n if (frameMbsOnlyFlag === 0) {\n skipBits(1);\n } // mb_adaptive_frame_field_flag\n\n\n skipBits(1); // direct_8x8_inference_flag\n\n if (readBoolean()) {\n // frame_cropping_flag\n frameCropLeftOffset = readUEG();\n frameCropRightOffset = readUEG();\n frameCropTopOffset = readUEG();\n frameCropBottomOffset = readUEG();\n }\n\n var pixelRatio = [1, 1];\n\n if (readBoolean()) {\n // vui_parameters_present_flag\n if (readBoolean()) {\n // aspect_ratio_info_present_flag\n var aspectRatioIdc = readUByte();\n\n switch (aspectRatioIdc) {\n case 1:\n pixelRatio = [1, 1];\n break;\n\n case 2:\n pixelRatio = [12, 11];\n break;\n\n case 3:\n pixelRatio = [10, 11];\n break;\n\n case 4:\n pixelRatio = [16, 11];\n break;\n\n case 5:\n pixelRatio = [40, 33];\n break;\n\n case 6:\n pixelRatio = [24, 11];\n break;\n\n case 7:\n pixelRatio = [20, 11];\n break;\n\n case 8:\n pixelRatio = [32, 11];\n break;\n\n case 9:\n pixelRatio = [80, 33];\n break;\n\n case 10:\n pixelRatio = [18, 11];\n break;\n\n case 11:\n pixelRatio = [15, 11];\n break;\n\n case 12:\n pixelRatio = [64, 33];\n break;\n\n case 13:\n pixelRatio = [160, 99];\n break;\n\n case 14:\n pixelRatio = [4, 3];\n break;\n\n case 15:\n pixelRatio = [3, 2];\n break;\n\n case 16:\n pixelRatio = [2, 1];\n break;\n\n case 255:\n {\n pixelRatio = [readUByte() << 8 | readUByte(), readUByte() << 8 | readUByte()];\n break;\n }\n }\n }\n }\n\n return {\n width: Math.ceil((picWidthInMbsMinus1 + 1) * 16 - frameCropLeftOffset * 2 - frameCropRightOffset * 2),\n height: (2 - frameMbsOnlyFlag) * (picHeightInMapUnitsMinus1 + 1) * 16 - (frameMbsOnlyFlag ? 2 : 4) * (frameCropTopOffset + frameCropBottomOffset),\n pixelRatio: pixelRatio\n };\n };\n\n _proto.readSliceType = function readSliceType() {\n // skip NALu type\n this.readUByte(); // discard first_mb_in_slice\n\n this.readUEG(); // return slice_type\n\n return this.readUEG();\n };\n\n return ExpGolomb;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (ExpGolomb);\n\n/***/ }),\n\n/***/ \"./src/demux/id3.ts\":\n/*!**************************!*\\\n !*** ./src/demux/id3.ts ***!\n \\**************************/\n/*! exports provided: isHeader, isFooter, getID3Data, canParse, getTimeStamp, isTimeStampFrame, getID3Frames, decodeFrame, utf8ArrayToStr, testables */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isHeader\", function() { return isHeader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isFooter\", function() { return isFooter; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getID3Data\", function() { return getID3Data; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"canParse\", function() { return canParse; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getTimeStamp\", function() { return getTimeStamp; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isTimeStampFrame\", function() { return isTimeStampFrame; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getID3Frames\", function() { return getID3Frames; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"decodeFrame\", function() { return decodeFrame; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"utf8ArrayToStr\", function() { return utf8ArrayToStr; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"testables\", function() { return testables; });\n// breaking up those two types in order to clarify what is happening in the decoding path.\n\n/**\n * Returns true if an ID3 header can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 header is found\n */\nvar isHeader = function isHeader(data, offset) {\n /*\n * http://id3.org/id3v2.3.0\n * [0] = 'I'\n * [1] = 'D'\n * [2] = '3'\n * [3,4] = {Version}\n * [5] = {Flags}\n * [6-9] = {ID3 Size}\n *\n * An ID3v2 tag can be detected with the following pattern:\n * $49 44 33 yy yy xx zz zz zz zz\n * Where yy is less than $FF, xx is the 'flags' byte and zz is less than $80\n */\n if (offset + 10 <= data.length) {\n // look for 'ID3' identifier\n if (data[offset] === 0x49 && data[offset + 1] === 0x44 && data[offset + 2] === 0x33) {\n // check version is within range\n if (data[offset + 3] < 0xff && data[offset + 4] < 0xff) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n};\n/**\n * Returns true if an ID3 footer can be found at offset in data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {boolean} - True if an ID3 footer is found\n */\n\nvar isFooter = function isFooter(data, offset) {\n /*\n * The footer is a copy of the header, but with a different identifier\n */\n if (offset + 10 <= data.length) {\n // look for '3DI' identifier\n if (data[offset] === 0x33 && data[offset + 1] === 0x44 && data[offset + 2] === 0x49) {\n // check version is within range\n if (data[offset + 3] < 0xff && data[offset + 4] < 0xff) {\n // check size is within range\n if (data[offset + 6] < 0x80 && data[offset + 7] < 0x80 && data[offset + 8] < 0x80 && data[offset + 9] < 0x80) {\n return true;\n }\n }\n }\n }\n\n return false;\n};\n/**\n * Returns any adjacent ID3 tags found in data starting at offset, as one block of data\n * @param {Uint8Array} data - The data to search in\n * @param {number} offset - The offset at which to start searching\n * @return {Uint8Array | undefined} - The block of data containing any ID3 tags found\n * or *undefined* if no header is found at the starting offset\n */\n\nvar getID3Data = function getID3Data(data, offset) {\n var front = offset;\n var length = 0;\n\n while (isHeader(data, offset)) {\n // ID3 header is 10 bytes\n length += 10;\n var size = readSize(data, offset + 6);\n length += size;\n\n if (isFooter(data, offset + 10)) {\n // ID3 footer is 10 bytes\n length += 10;\n }\n\n offset += length;\n }\n\n if (length > 0) {\n return data.subarray(front, front + length);\n }\n\n return undefined;\n};\n\nvar readSize = function readSize(data, offset) {\n var size = 0;\n size = (data[offset] & 0x7f) << 21;\n size |= (data[offset + 1] & 0x7f) << 14;\n size |= (data[offset + 2] & 0x7f) << 7;\n size |= data[offset + 3] & 0x7f;\n return size;\n};\n\nvar canParse = function canParse(data, offset) {\n return isHeader(data, offset) && readSize(data, offset + 6) + 10 <= data.length - offset;\n};\n/**\n * Searches for the Elementary Stream timestamp found in the ID3 data chunk\n * @param {Uint8Array} data - Block of data containing one or more ID3 tags\n * @return {number | undefined} - The timestamp\n */\n\nvar getTimeStamp = function getTimeStamp(data) {\n var frames = getID3Frames(data);\n\n for (var i = 0; i < frames.length; i++) {\n var frame = frames[i];\n\n if (isTimeStampFrame(frame)) {\n return readTimeStamp(frame);\n }\n }\n\n return undefined;\n};\n/**\n * Returns true if the ID3 frame is an Elementary Stream timestamp frame\n * @param {ID3 frame} frame\n */\n\nvar isTimeStampFrame = function isTimeStampFrame(frame) {\n return frame && frame.key === 'PRIV' && frame.info === 'com.apple.streaming.transportStreamTimestamp';\n};\n\nvar getFrameData = function getFrameData(data) {\n /*\n Frame ID $xx xx xx xx (four characters)\n Size $xx xx xx xx\n Flags $xx xx\n */\n var type = String.fromCharCode(data[0], data[1], data[2], data[3]);\n var size = readSize(data, 4); // skip frame id, size, and flags\n\n var offset = 10;\n return {\n type: type,\n size: size,\n data: data.subarray(offset, offset + size)\n };\n};\n/**\n * Returns an array of ID3 frames found in all the ID3 tags in the id3Data\n * @param {Uint8Array} id3Data - The ID3 data containing one or more ID3 tags\n * @return {ID3.Frame[]} - Array of ID3 frame objects\n */\n\n\nvar getID3Frames = function getID3Frames(id3Data) {\n var offset = 0;\n var frames = [];\n\n while (isHeader(id3Data, offset)) {\n var size = readSize(id3Data, offset + 6); // skip past ID3 header\n\n offset += 10;\n var end = offset + size; // loop through frames in the ID3 tag\n\n while (offset + 8 < end) {\n var frameData = getFrameData(id3Data.subarray(offset));\n var frame = decodeFrame(frameData);\n\n if (frame) {\n frames.push(frame);\n } // skip frame header and frame data\n\n\n offset += frameData.size + 10;\n }\n\n if (isFooter(id3Data, offset)) {\n offset += 10;\n }\n }\n\n return frames;\n};\nvar decodeFrame = function decodeFrame(frame) {\n if (frame.type === 'PRIV') {\n return decodePrivFrame(frame);\n } else if (frame.type[0] === 'W') {\n return decodeURLFrame(frame);\n }\n\n return decodeTextFrame(frame);\n};\n\nvar decodePrivFrame = function decodePrivFrame(frame) {\n /*\n Format: \\0\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n var owner = utf8ArrayToStr(frame.data, true);\n var privateData = new Uint8Array(frame.data.subarray(owner.length + 1));\n return {\n key: frame.type,\n info: owner,\n data: privateData.buffer\n };\n};\n\nvar decodeTextFrame = function decodeTextFrame(frame) {\n if (frame.size < 2) {\n return undefined;\n }\n\n if (frame.type === 'TXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{Value}\n */\n var index = 1;\n var description = utf8ArrayToStr(frame.data.subarray(index), true);\n index += description.length + 1;\n var value = utf8ArrayToStr(frame.data.subarray(index));\n return {\n key: frame.type,\n info: description,\n data: value\n };\n }\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Value}\n */\n\n\n var text = utf8ArrayToStr(frame.data.subarray(1));\n return {\n key: frame.type,\n data: text\n };\n};\n\nvar decodeURLFrame = function decodeURLFrame(frame) {\n if (frame.type === 'WXXX') {\n /*\n Format:\n [0] = {Text Encoding}\n [1-?] = {Description}\\0{URL}\n */\n if (frame.size < 2) {\n return undefined;\n }\n\n var index = 1;\n var description = utf8ArrayToStr(frame.data.subarray(index), true);\n index += description.length + 1;\n var value = utf8ArrayToStr(frame.data.subarray(index));\n return {\n key: frame.type,\n info: description,\n data: value\n };\n }\n /*\n Format:\n [0-?] = {URL}\n */\n\n\n var url = utf8ArrayToStr(frame.data);\n return {\n key: frame.type,\n data: url\n };\n};\n\nvar readTimeStamp = function readTimeStamp(timeStampFrame) {\n if (timeStampFrame.data.byteLength === 8) {\n var data = new Uint8Array(timeStampFrame.data); // timestamp is 33 bit expressed as a big-endian eight-octet number,\n // with the upper 31 bits set to zero.\n\n var pts33Bit = data[3] & 0x1;\n var timestamp = (data[4] << 23) + (data[5] << 15) + (data[6] << 7) + data[7];\n timestamp /= 45;\n\n if (pts33Bit) {\n timestamp += 47721858.84;\n } // 2^32 / 90\n\n\n return Math.round(timestamp);\n }\n\n return undefined;\n}; // http://stackoverflow.com/questions/8936984/uint8array-to-string-in-javascript/22373197\n// http://www.onicos.com/staff/iz/amuse/javascript/expert/utf.txt\n\n/* utf.js - UTF-8 <=> UTF-16 convertion\n *\n * Copyright (C) 1999 Masanao Izumo \n * Version: 1.0\n * LastModified: Dec 25 1999\n * This library is free. You can redistribute it and/or modify it.\n */\n\n\nvar utf8ArrayToStr = function utf8ArrayToStr(array, exitOnNull) {\n if (exitOnNull === void 0) {\n exitOnNull = false;\n }\n\n var decoder = getTextDecoder();\n\n if (decoder) {\n var decoded = decoder.decode(array);\n\n if (exitOnNull) {\n // grab up to the first null\n var idx = decoded.indexOf('\\0');\n return idx !== -1 ? decoded.substring(0, idx) : decoded;\n } // remove any null characters\n\n\n return decoded.replace(/\\0/g, '');\n }\n\n var len = array.length;\n var c;\n var char2;\n var char3;\n var out = '';\n var i = 0;\n\n while (i < len) {\n c = array[i++];\n\n if (c === 0x00 && exitOnNull) {\n return out;\n } else if (c === 0x00 || c === 0x03) {\n // If the character is 3 (END_OF_TEXT) or 0 (NULL) then skip it\n continue;\n }\n\n switch (c >> 4) {\n case 0:\n case 1:\n case 2:\n case 3:\n case 4:\n case 5:\n case 6:\n case 7:\n // 0xxxxxxx\n out += String.fromCharCode(c);\n break;\n\n case 12:\n case 13:\n // 110x xxxx 10xx xxxx\n char2 = array[i++];\n out += String.fromCharCode((c & 0x1f) << 6 | char2 & 0x3f);\n break;\n\n case 14:\n // 1110 xxxx 10xx xxxx 10xx xxxx\n char2 = array[i++];\n char3 = array[i++];\n out += String.fromCharCode((c & 0x0f) << 12 | (char2 & 0x3f) << 6 | (char3 & 0x3f) << 0);\n break;\n\n default:\n }\n }\n\n return out;\n};\nvar testables = {\n decodeTextFrame: decodeTextFrame\n};\nvar decoder;\n\nfunction getTextDecoder() {\n if (!decoder && typeof self.TextDecoder !== 'undefined') {\n decoder = new self.TextDecoder('utf-8');\n }\n\n return decoder;\n}\n\n/***/ }),\n\n/***/ \"./src/demux/mp3demuxer.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/mp3demuxer.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _base_audio_demuxer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./base-audio-demuxer */ \"./src/demux/base-audio-demuxer.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _mpegaudio__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./mpegaudio */ \"./src/demux/mpegaudio.ts\");\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n/**\n * MP3 demuxer\n */\n\n\n\n\n\nvar MP3Demuxer = /*#__PURE__*/function (_BaseAudioDemuxer) {\n _inheritsLoose(MP3Demuxer, _BaseAudioDemuxer);\n\n function MP3Demuxer() {\n return _BaseAudioDemuxer.apply(this, arguments) || this;\n }\n\n var _proto = MP3Demuxer.prototype;\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec, trackDuration) {\n _BaseAudioDemuxer.prototype.resetInitSegment.call(this, initSegment, audioCodec, videoCodec, trackDuration);\n\n this._audioTrack = {\n container: 'audio/mpeg',\n type: 'audio',\n id: 2,\n pid: -1,\n sequenceNumber: 0,\n segmentCodec: 'mp3',\n samples: [],\n manifestCodec: audioCodec,\n duration: trackDuration,\n inputTimeScale: 90000,\n dropped: 0\n };\n };\n\n MP3Demuxer.probe = function probe(data) {\n if (!data) {\n return false;\n } // check if data contains ID3 timestamp and MPEG sync word\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n\n\n var id3Data = _demux_id3__WEBPACK_IMPORTED_MODULE_1__[\"getID3Data\"](data, 0) || [];\n var offset = id3Data.length;\n\n for (var length = data.length; offset < length; offset++) {\n if (_mpegaudio__WEBPACK_IMPORTED_MODULE_3__[\"probe\"](data, offset)) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].log('MPEG Audio sync word found !');\n return true;\n }\n }\n\n return false;\n };\n\n _proto.canParse = function canParse(data, offset) {\n return _mpegaudio__WEBPACK_IMPORTED_MODULE_3__[\"canParse\"](data, offset);\n };\n\n _proto.appendFrame = function appendFrame(track, data, offset) {\n if (this.basePTS === null) {\n return;\n }\n\n return _mpegaudio__WEBPACK_IMPORTED_MODULE_3__[\"appendFrame\"](track, data, offset, this.basePTS, this.frameIndex);\n };\n\n return MP3Demuxer;\n}(_base_audio_demuxer__WEBPACK_IMPORTED_MODULE_0__[\"default\"]);\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (MP3Demuxer);\n\n/***/ }),\n\n/***/ \"./src/demux/mp4demuxer.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/mp4demuxer.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _types_demuxer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../types/demuxer */ \"./src/types/demuxer.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./dummy-demuxed-track */ \"./src/demux/dummy-demuxed-track.ts\");\n\n\n/**\n * MP4 demuxer\n */\n\n\n\nvar emsgSchemePattern = /\\/emsg[-/]ID3/i;\n\nvar MP4Demuxer = /*#__PURE__*/function () {\n function MP4Demuxer(observer, config) {\n this.remainderData = null;\n this.timeOffset = 0;\n this.config = void 0;\n this.videoTrack = void 0;\n this.audioTrack = void 0;\n this.id3Track = void 0;\n this.txtTrack = void 0;\n this.config = config;\n }\n\n var _proto = MP4Demuxer.prototype;\n\n _proto.resetTimeStamp = function resetTimeStamp() {};\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec, trackDuration) {\n var initData = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"parseInitSegment\"])(initSegment);\n var videoTrack = this.videoTrack = Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])('video', 1);\n var audioTrack = this.audioTrack = Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])('audio', 1);\n var captionTrack = this.txtTrack = Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])('text', 1);\n this.id3Track = Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])('id3', 1);\n this.timeOffset = 0;\n\n if (initData.video) {\n var _initData$video = initData.video,\n id = _initData$video.id,\n timescale = _initData$video.timescale,\n codec = _initData$video.codec;\n videoTrack.id = id;\n videoTrack.timescale = captionTrack.timescale = timescale;\n videoTrack.codec = codec;\n }\n\n if (initData.audio) {\n var _initData$audio = initData.audio,\n _id = _initData$audio.id,\n _timescale = _initData$audio.timescale,\n _codec = _initData$audio.codec;\n audioTrack.id = _id;\n audioTrack.timescale = _timescale;\n audioTrack.codec = _codec;\n }\n\n captionTrack.id = _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"RemuxerTrackIdConfig\"].text;\n videoTrack.sampleDuration = 0;\n videoTrack.duration = audioTrack.duration = trackDuration;\n };\n\n _proto.resetContiguity = function resetContiguity() {};\n\n MP4Demuxer.probe = function probe(data) {\n // ensure we find a moof box in the first 16 kB\n data = data.length > 16384 ? data.subarray(0, 16384) : data;\n return Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"findBox\"])(data, ['moof']).length > 0;\n };\n\n _proto.demux = function demux(data, timeOffset) {\n this.timeOffset = timeOffset; // Load all data into the avc track. The CMAF remuxer will look for the data in the samples object; the rest of the fields do not matter\n\n var videoSamples = data;\n var videoTrack = this.videoTrack;\n var textTrack = this.txtTrack;\n\n if (this.config.progressive) {\n // Split the bytestream into two ranges: one encompassing all data up until the start of the last moof, and everything else.\n // This is done to guarantee that we're sending valid data to MSE - when demuxing progressively, we have no guarantee\n // that the fetch loader gives us flush moof+mdat pairs. If we push jagged data to MSE, it will throw an exception.\n if (this.remainderData) {\n videoSamples = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"appendUint8Array\"])(this.remainderData, data);\n }\n\n var segmentedData = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"segmentValidRange\"])(videoSamples);\n this.remainderData = segmentedData.remainder;\n videoTrack.samples = segmentedData.valid || new Uint8Array();\n } else {\n videoTrack.samples = videoSamples;\n }\n\n var id3Track = this.extractID3Track(videoTrack, timeOffset);\n textTrack.samples = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"parseSamples\"])(timeOffset, videoTrack);\n return {\n videoTrack: videoTrack,\n audioTrack: this.audioTrack,\n id3Track: id3Track,\n textTrack: this.txtTrack\n };\n };\n\n _proto.flush = function flush() {\n var timeOffset = this.timeOffset;\n var videoTrack = this.videoTrack;\n var textTrack = this.txtTrack;\n videoTrack.samples = this.remainderData || new Uint8Array();\n this.remainderData = null;\n var id3Track = this.extractID3Track(videoTrack, this.timeOffset);\n textTrack.samples = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"parseSamples\"])(timeOffset, videoTrack);\n return {\n videoTrack: videoTrack,\n audioTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])(),\n id3Track: id3Track,\n textTrack: Object(_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__[\"dummyTrack\"])()\n };\n };\n\n _proto.extractID3Track = function extractID3Track(videoTrack, timeOffset) {\n var id3Track = this.id3Track;\n\n if (videoTrack.samples.length) {\n var emsgs = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"findBox\"])(videoTrack.samples, ['emsg']);\n\n if (emsgs) {\n emsgs.forEach(function (data) {\n var emsgInfo = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"parseEmsg\"])(data);\n\n if (emsgSchemePattern.test(emsgInfo.schemeIdUri)) {\n var pts = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(emsgInfo.presentationTime) ? emsgInfo.presentationTime / emsgInfo.timeScale : timeOffset + emsgInfo.presentationTimeDelta / emsgInfo.timeScale;\n var payload = emsgInfo.payload;\n id3Track.samples.push({\n data: payload,\n len: payload.byteLength,\n dts: pts,\n pts: pts,\n type: _types_demuxer__WEBPACK_IMPORTED_MODULE_1__[\"MetadataSchema\"].emsg\n });\n }\n });\n }\n }\n\n return id3Track;\n };\n\n _proto.demuxSampleAes = function demuxSampleAes(data, keyData, timeOffset) {\n return Promise.reject(new Error('The MP4 demuxer does not support SAMPLE-AES decryption'));\n };\n\n _proto.destroy = function destroy() {};\n\n return MP4Demuxer;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (MP4Demuxer);\n\n/***/ }),\n\n/***/ \"./src/demux/mpegaudio.ts\":\n/*!********************************!*\\\n !*** ./src/demux/mpegaudio.ts ***!\n \\********************************/\n/*! exports provided: appendFrame, parseHeader, isHeaderPattern, isHeader, canParse, probe */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"appendFrame\", function() { return appendFrame; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseHeader\", function() { return parseHeader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isHeaderPattern\", function() { return isHeaderPattern; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isHeader\", function() { return isHeader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"canParse\", function() { return canParse; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"probe\", function() { return probe; });\n/**\n * MPEG parser helper\n */\nvar chromeVersion = null;\nvar BitratesMap = [32, 64, 96, 128, 160, 192, 224, 256, 288, 320, 352, 384, 416, 448, 32, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 384, 32, 40, 48, 56, 64, 80, 96, 112, 128, 160, 192, 224, 256, 320, 32, 48, 56, 64, 80, 96, 112, 128, 144, 160, 176, 192, 224, 256, 8, 16, 24, 32, 40, 48, 56, 64, 80, 96, 112, 128, 144, 160];\nvar SamplingRateMap = [44100, 48000, 32000, 22050, 24000, 16000, 11025, 12000, 8000];\nvar SamplesCoefficients = [// MPEG 2.5\n[0, // Reserved\n72, // Layer3\n144, // Layer2\n12 // Layer1\n], // Reserved\n[0, // Reserved\n0, // Layer3\n0, // Layer2\n0 // Layer1\n], // MPEG 2\n[0, // Reserved\n72, // Layer3\n144, // Layer2\n12 // Layer1\n], // MPEG 1\n[0, // Reserved\n144, // Layer3\n144, // Layer2\n12 // Layer1\n]];\nvar BytesInSlot = [0, // Reserved\n1, // Layer3\n1, // Layer2\n4 // Layer1\n];\nfunction appendFrame(track, data, offset, pts, frameIndex) {\n // Using http://www.datavoyage.com/mpgscript/mpeghdr.htm as a reference\n if (offset + 24 > data.length) {\n return;\n }\n\n var header = parseHeader(data, offset);\n\n if (header && offset + header.frameLength <= data.length) {\n var frameDuration = header.samplesPerFrame * 90000 / header.sampleRate;\n var stamp = pts + frameIndex * frameDuration;\n var sample = {\n unit: data.subarray(offset, offset + header.frameLength),\n pts: stamp,\n dts: stamp\n };\n track.config = [];\n track.channelCount = header.channelCount;\n track.samplerate = header.sampleRate;\n track.samples.push(sample);\n return {\n sample: sample,\n length: header.frameLength,\n missing: 0\n };\n }\n}\nfunction parseHeader(data, offset) {\n var mpegVersion = data[offset + 1] >> 3 & 3;\n var mpegLayer = data[offset + 1] >> 1 & 3;\n var bitRateIndex = data[offset + 2] >> 4 & 15;\n var sampleRateIndex = data[offset + 2] >> 2 & 3;\n\n if (mpegVersion !== 1 && bitRateIndex !== 0 && bitRateIndex !== 15 && sampleRateIndex !== 3) {\n var paddingBit = data[offset + 2] >> 1 & 1;\n var channelMode = data[offset + 3] >> 6;\n var columnInBitrates = mpegVersion === 3 ? 3 - mpegLayer : mpegLayer === 3 ? 3 : 4;\n var bitRate = BitratesMap[columnInBitrates * 14 + bitRateIndex - 1] * 1000;\n var columnInSampleRates = mpegVersion === 3 ? 0 : mpegVersion === 2 ? 1 : 2;\n var sampleRate = SamplingRateMap[columnInSampleRates * 3 + sampleRateIndex];\n var channelCount = channelMode === 3 ? 1 : 2; // If bits of channel mode are `11` then it is a single channel (Mono)\n\n var sampleCoefficient = SamplesCoefficients[mpegVersion][mpegLayer];\n var bytesInSlot = BytesInSlot[mpegLayer];\n var samplesPerFrame = sampleCoefficient * 8 * bytesInSlot;\n var frameLength = Math.floor(sampleCoefficient * bitRate / sampleRate + paddingBit) * bytesInSlot;\n\n if (chromeVersion === null) {\n var userAgent = navigator.userAgent || '';\n var result = userAgent.match(/Chrome\\/(\\d+)/i);\n chromeVersion = result ? parseInt(result[1]) : 0;\n }\n\n var needChromeFix = !!chromeVersion && chromeVersion <= 87;\n\n if (needChromeFix && mpegLayer === 2 && bitRate >= 224000 && channelMode === 0) {\n // Work around bug in Chromium by setting channelMode to dual-channel (01) instead of stereo (00)\n data[offset + 3] = data[offset + 3] | 0x80;\n }\n\n return {\n sampleRate: sampleRate,\n channelCount: channelCount,\n frameLength: frameLength,\n samplesPerFrame: samplesPerFrame\n };\n }\n}\nfunction isHeaderPattern(data, offset) {\n return data[offset] === 0xff && (data[offset + 1] & 0xe0) === 0xe0 && (data[offset + 1] & 0x06) !== 0x00;\n}\nfunction isHeader(data, offset) {\n // Look for MPEG header | 1111 1111 | 111X XYZX | where X can be either 0 or 1 and Y or Z should be 1\n // Layer bits (position 14 and 15) in header should be always different from 0 (Layer I or Layer II or Layer III)\n // More info http://www.mp3-tech.org/programmer/frame_header.html\n return offset + 1 < data.length && isHeaderPattern(data, offset);\n}\nfunction canParse(data, offset) {\n var headerSize = 4;\n return isHeaderPattern(data, offset) && headerSize <= data.length - offset;\n}\nfunction probe(data, offset) {\n // same as isHeader but we also check that MPEG frame follows last MPEG frame\n // or end of data is reached\n if (offset + 1 < data.length && isHeaderPattern(data, offset)) {\n // MPEG header Length\n var headerLength = 4; // MPEG frame Length\n\n var header = parseHeader(data, offset);\n var frameLength = headerLength;\n\n if (header !== null && header !== void 0 && header.frameLength) {\n frameLength = header.frameLength;\n }\n\n var newOffset = offset + frameLength;\n return newOffset === data.length || isHeader(data, newOffset);\n }\n\n return false;\n}\n\n/***/ }),\n\n/***/ \"./src/demux/sample-aes.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/sample-aes.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _crypt_decrypter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../crypt/decrypter */ \"./src/crypt/decrypter.ts\");\n/* harmony import */ var _tsdemuxer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./tsdemuxer */ \"./src/demux/tsdemuxer.ts\");\n/**\n * SAMPLE-AES decrypter\n */\n\n\n\nvar SampleAesDecrypter = /*#__PURE__*/function () {\n function SampleAesDecrypter(observer, config, keyData) {\n this.keyData = void 0;\n this.decrypter = void 0;\n this.keyData = keyData;\n this.decrypter = new _crypt_decrypter__WEBPACK_IMPORTED_MODULE_0__[\"default\"](observer, config, {\n removePKCS7Padding: false\n });\n }\n\n var _proto = SampleAesDecrypter.prototype;\n\n _proto.decryptBuffer = function decryptBuffer(encryptedData, callback) {\n this.decrypter.decrypt(encryptedData, this.keyData.key.buffer, this.keyData.iv.buffer, callback);\n } // AAC - encrypt all full 16 bytes blocks starting from offset 16\n ;\n\n _proto.decryptAacSample = function decryptAacSample(samples, sampleIndex, callback, sync) {\n var curUnit = samples[sampleIndex].unit;\n\n if (curUnit.length <= 16) {\n // No encrypted portion in this sample (first 16 bytes is not\n // encrypted, see https://developer.apple.com/library/archive/documentation/AudioVideo/Conceptual/HLS_Sample_Encryption/Encryption/Encryption.html),\n return;\n }\n\n var encryptedData = curUnit.subarray(16, curUnit.length - curUnit.length % 16);\n var encryptedBuffer = encryptedData.buffer.slice(encryptedData.byteOffset, encryptedData.byteOffset + encryptedData.length);\n var localthis = this;\n this.decryptBuffer(encryptedBuffer, function (decryptedBuffer) {\n var decryptedData = new Uint8Array(decryptedBuffer);\n curUnit.set(decryptedData, 16);\n\n if (!sync) {\n localthis.decryptAacSamples(samples, sampleIndex + 1, callback);\n }\n });\n };\n\n _proto.decryptAacSamples = function decryptAacSamples(samples, sampleIndex, callback) {\n for (;; sampleIndex++) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n if (samples[sampleIndex].unit.length < 32) {\n continue;\n }\n\n var sync = this.decrypter.isSync();\n this.decryptAacSample(samples, sampleIndex, callback, sync);\n\n if (!sync) {\n return;\n }\n }\n } // AVC - encrypt one 16 bytes block out of ten, starting from offset 32\n ;\n\n _proto.getAvcEncryptedData = function getAvcEncryptedData(decodedData) {\n var encryptedDataLen = Math.floor((decodedData.length - 48) / 160) * 16 + 16;\n var encryptedData = new Int8Array(encryptedDataLen);\n var outputPos = 0;\n\n for (var inputPos = 32; inputPos < decodedData.length - 16; inputPos += 160, outputPos += 16) {\n encryptedData.set(decodedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return encryptedData;\n };\n\n _proto.getAvcDecryptedUnit = function getAvcDecryptedUnit(decodedData, decryptedData) {\n var uint8DecryptedData = new Uint8Array(decryptedData);\n var inputPos = 0;\n\n for (var outputPos = 32; outputPos < decodedData.length - 16; outputPos += 160, inputPos += 16) {\n decodedData.set(uint8DecryptedData.subarray(inputPos, inputPos + 16), outputPos);\n }\n\n return decodedData;\n };\n\n _proto.decryptAvcSample = function decryptAvcSample(samples, sampleIndex, unitIndex, callback, curUnit, sync) {\n var decodedData = Object(_tsdemuxer__WEBPACK_IMPORTED_MODULE_1__[\"discardEPB\"])(curUnit.data);\n var encryptedData = this.getAvcEncryptedData(decodedData);\n var localthis = this;\n this.decryptBuffer(encryptedData.buffer, function (decryptedBuffer) {\n curUnit.data = localthis.getAvcDecryptedUnit(decodedData, decryptedBuffer);\n\n if (!sync) {\n localthis.decryptAvcSamples(samples, sampleIndex, unitIndex + 1, callback);\n }\n });\n };\n\n _proto.decryptAvcSamples = function decryptAvcSamples(samples, sampleIndex, unitIndex, callback) {\n if (samples instanceof Uint8Array) {\n throw new Error('Cannot decrypt samples of type Uint8Array');\n }\n\n for (;; sampleIndex++, unitIndex = 0) {\n if (sampleIndex >= samples.length) {\n callback();\n return;\n }\n\n var curUnits = samples[sampleIndex].units;\n\n for (;; unitIndex++) {\n if (unitIndex >= curUnits.length) {\n break;\n }\n\n var curUnit = curUnits[unitIndex];\n\n if (curUnit.data.length <= 48 || curUnit.type !== 1 && curUnit.type !== 5) {\n continue;\n }\n\n var sync = this.decrypter.isSync();\n this.decryptAvcSample(samples, sampleIndex, unitIndex, callback, curUnit, sync);\n\n if (!sync) {\n return;\n }\n }\n }\n };\n\n return SampleAesDecrypter;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (SampleAesDecrypter);\n\n/***/ }),\n\n/***/ \"./src/demux/transmuxer-interface.ts\":\n/*!*******************************************!*\\\n !*** ./src/demux/transmuxer-interface.ts ***!\n \\*******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return TransmuxerInterface; });\n/* harmony import */ var webworkify_webpack__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! webworkify-webpack */ \"./node_modules/webworkify-webpack/index.js\");\n/* harmony import */ var webworkify_webpack__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(webworkify_webpack__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../demux/transmuxer */ \"./src/demux/transmuxer.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/mediasource-helper */ \"./src/utils/mediasource-helper.ts\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! eventemitter3 */ \"./node_modules/eventemitter3/index.js\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(eventemitter3__WEBPACK_IMPORTED_MODULE_6__);\n\n\n\n\n\n\n\nvar MediaSource = Object(_utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_5__[\"getMediaSource\"])() || {\n isTypeSupported: function isTypeSupported() {\n return false;\n }\n};\n\nvar TransmuxerInterface = /*#__PURE__*/function () {\n function TransmuxerInterface(hls, id, onTransmuxComplete, onFlush) {\n var _this = this;\n\n this.hls = void 0;\n this.id = void 0;\n this.observer = void 0;\n this.frag = null;\n this.part = null;\n this.worker = void 0;\n this.onwmsg = void 0;\n this.transmuxer = null;\n this.onTransmuxComplete = void 0;\n this.onFlush = void 0;\n this.hls = hls;\n this.id = id;\n this.onTransmuxComplete = onTransmuxComplete;\n this.onFlush = onFlush;\n var config = hls.config;\n\n var forwardMessage = function forwardMessage(ev, data) {\n data = data || {};\n data.frag = _this.frag;\n data.id = _this.id;\n hls.trigger(ev, data);\n }; // forward events to main thread\n\n\n this.observer = new eventemitter3__WEBPACK_IMPORTED_MODULE_6__[\"EventEmitter\"]();\n this.observer.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_DECRYPTED, forwardMessage);\n this.observer.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, forwardMessage);\n var typeSupported = {\n mp4: MediaSource.isTypeSupported('video/mp4'),\n mpeg: MediaSource.isTypeSupported('audio/mpeg'),\n mp3: MediaSource.isTypeSupported('audio/mp4; codecs=\"mp3\"')\n }; // navigator.vendor is not always available in Web Worker\n // refer to https://developer.mozilla.org/en-US/docs/Web/API/WorkerGlobalScope/navigator\n\n var vendor = navigator.vendor;\n\n if (config.enableWorker && typeof Worker !== 'undefined') {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log('demuxing in webworker');\n var worker;\n\n try {\n worker = this.worker = webworkify_webpack__WEBPACK_IMPORTED_MODULE_0__(/*require.resolve*/(/*! ../demux/transmuxer-worker.ts */ \"./src/demux/transmuxer-worker.ts\"));\n this.onwmsg = this.onWorkerMessage.bind(this);\n worker.addEventListener('message', this.onwmsg);\n\n worker.onerror = function (event) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorTypes\"].OTHER_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorDetails\"].INTERNAL_EXCEPTION,\n fatal: true,\n event: 'demuxerWorker',\n error: new Error(event.message + \" (\" + event.filename + \":\" + event.lineno + \")\")\n });\n };\n\n worker.postMessage({\n cmd: 'init',\n typeSupported: typeSupported,\n vendor: vendor,\n id: id,\n config: JSON.stringify(config)\n });\n } catch (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn('Error in worker:', err);\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].error('Error while initializing DemuxerWorker, fallback to inline');\n\n if (worker) {\n // revoke the Object URL that was used to create transmuxer worker, so as not to leak it\n self.URL.revokeObjectURL(worker.objectURL);\n }\n\n this.transmuxer = new _demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.observer, typeSupported, config, vendor, id);\n this.worker = null;\n }\n } else {\n this.transmuxer = new _demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.observer, typeSupported, config, vendor, id);\n }\n }\n\n var _proto = TransmuxerInterface.prototype;\n\n _proto.destroy = function destroy() {\n var w = this.worker;\n\n if (w) {\n w.removeEventListener('message', this.onwmsg);\n w.terminate();\n this.worker = null;\n this.onwmsg = undefined;\n } else {\n var transmuxer = this.transmuxer;\n\n if (transmuxer) {\n transmuxer.destroy();\n this.transmuxer = null;\n }\n }\n\n var observer = this.observer;\n\n if (observer) {\n observer.removeAllListeners();\n }\n\n this.frag = null; // @ts-ignore\n\n this.observer = null; // @ts-ignore\n\n this.hls = null;\n };\n\n _proto.push = function push(data, initSegmentData, audioCodec, videoCodec, frag, part, duration, accurateTimeOffset, chunkMeta, defaultInitPTS) {\n var _frag$initSegment,\n _lastFrag$initSegment,\n _this2 = this;\n\n chunkMeta.transmuxing.start = self.performance.now();\n var transmuxer = this.transmuxer,\n worker = this.worker;\n var timeOffset = part ? part.start : frag.start;\n var decryptdata = frag.decryptdata;\n var lastFrag = this.frag;\n var discontinuity = !(lastFrag && frag.cc === lastFrag.cc);\n var trackSwitch = !(lastFrag && chunkMeta.level === lastFrag.level);\n var snDiff = lastFrag ? chunkMeta.sn - lastFrag.sn : -1;\n var partDiff = this.part ? chunkMeta.part - this.part.index : -1;\n var progressive = snDiff === 0 && chunkMeta.id > 1 && chunkMeta.id === (lastFrag === null || lastFrag === void 0 ? void 0 : lastFrag.stats.chunkCount);\n var contiguous = !trackSwitch && (snDiff === 1 || snDiff === 0 && (partDiff === 1 || progressive && partDiff <= 0));\n var now = self.performance.now();\n\n if (trackSwitch || snDiff || frag.stats.parsing.start === 0) {\n frag.stats.parsing.start = now;\n }\n\n if (part && (partDiff || !contiguous)) {\n part.stats.parsing.start = now;\n }\n\n var initSegmentChange = !(lastFrag && ((_frag$initSegment = frag.initSegment) === null || _frag$initSegment === void 0 ? void 0 : _frag$initSegment.url) === ((_lastFrag$initSegment = lastFrag.initSegment) === null || _lastFrag$initSegment === void 0 ? void 0 : _lastFrag$initSegment.url));\n var state = new _demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"TransmuxState\"](discontinuity, contiguous, accurateTimeOffset, trackSwitch, timeOffset, initSegmentChange);\n\n if (!contiguous || discontinuity || initSegmentChange) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log(\"[transmuxer-interface, \" + frag.type + \"]: Starting new transmux session for sn: \" + chunkMeta.sn + \" p: \" + chunkMeta.part + \" level: \" + chunkMeta.level + \" id: \" + chunkMeta.id + \"\\n discontinuity: \" + discontinuity + \"\\n trackSwitch: \" + trackSwitch + \"\\n contiguous: \" + contiguous + \"\\n accurateTimeOffset: \" + accurateTimeOffset + \"\\n timeOffset: \" + timeOffset + \"\\n initSegmentChange: \" + initSegmentChange);\n var config = new _demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"TransmuxConfig\"](audioCodec, videoCodec, initSegmentData, duration, defaultInitPTS);\n this.configureTransmuxer(config);\n }\n\n this.frag = frag;\n this.part = part; // Frags with sn of 'initSegment' are not transmuxed\n\n if (worker) {\n // post fragment payload as transferable objects for ArrayBuffer (no copy)\n worker.postMessage({\n cmd: 'demux',\n data: data,\n decryptdata: decryptdata,\n chunkMeta: chunkMeta,\n state: state\n }, data instanceof ArrayBuffer ? [data] : []);\n } else if (transmuxer) {\n var _transmuxResult = transmuxer.push(data, decryptdata, chunkMeta, state);\n\n if (Object(_demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"isPromise\"])(_transmuxResult)) {\n _transmuxResult.then(function (data) {\n _this2.handleTransmuxComplete(data);\n });\n } else {\n this.handleTransmuxComplete(_transmuxResult);\n }\n }\n };\n\n _proto.flush = function flush(chunkMeta) {\n var _this3 = this;\n\n chunkMeta.transmuxing.start = self.performance.now();\n var transmuxer = this.transmuxer,\n worker = this.worker;\n\n if (worker) {\n worker.postMessage({\n cmd: 'flush',\n chunkMeta: chunkMeta\n });\n } else if (transmuxer) {\n var _transmuxResult2 = transmuxer.flush(chunkMeta);\n\n if (Object(_demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__[\"isPromise\"])(_transmuxResult2)) {\n _transmuxResult2.then(function (data) {\n _this3.handleFlushResult(data, chunkMeta);\n });\n } else {\n this.handleFlushResult(_transmuxResult2, chunkMeta);\n }\n }\n };\n\n _proto.handleFlushResult = function handleFlushResult(results, chunkMeta) {\n var _this4 = this;\n\n results.forEach(function (result) {\n _this4.handleTransmuxComplete(result);\n });\n this.onFlush(chunkMeta);\n };\n\n _proto.onWorkerMessage = function onWorkerMessage(ev) {\n var data = ev.data;\n var hls = this.hls;\n\n switch (data.event) {\n case 'init':\n {\n // revoke the Object URL that was used to create transmuxer worker, so as not to leak it\n self.URL.revokeObjectURL(this.worker.objectURL);\n break;\n }\n\n case 'transmuxComplete':\n {\n this.handleTransmuxComplete(data.data);\n break;\n }\n\n case 'flush':\n {\n this.onFlush(data.data);\n break;\n }\n // pass logs from the worker thread to the main logger\n\n case 'workerLog':\n if (_utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"][data.data.logType]) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"][data.data.logType](data.data.message);\n }\n\n break;\n\n /* falls through */\n\n default:\n {\n data.data = data.data || {};\n data.data.frag = this.frag;\n data.data.id = this.id;\n hls.trigger(data.event, data.data);\n break;\n }\n }\n };\n\n _proto.configureTransmuxer = function configureTransmuxer(config) {\n var worker = this.worker,\n transmuxer = this.transmuxer;\n\n if (worker) {\n worker.postMessage({\n cmd: 'configure',\n config: config\n });\n } else if (transmuxer) {\n transmuxer.configure(config);\n }\n };\n\n _proto.handleTransmuxComplete = function handleTransmuxComplete(result) {\n result.chunkMeta.transmuxing.end = self.performance.now();\n this.onTransmuxComplete(result);\n };\n\n return TransmuxerInterface;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/demux/transmuxer-worker.ts\":\n/*!****************************************!*\\\n !*** ./src/demux/transmuxer-worker.ts ***!\n \\****************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return TransmuxerWorker; });\n/* harmony import */ var _demux_transmuxer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../demux/transmuxer */ \"./src/demux/transmuxer.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! eventemitter3 */ \"./node_modules/eventemitter3/index.js\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(eventemitter3__WEBPACK_IMPORTED_MODULE_3__);\n\n\n\n\nfunction TransmuxerWorker(self) {\n var observer = new eventemitter3__WEBPACK_IMPORTED_MODULE_3__[\"EventEmitter\"]();\n\n var forwardMessage = function forwardMessage(ev, data) {\n self.postMessage({\n event: ev,\n data: data\n });\n }; // forward events to main thread\n\n\n observer.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].FRAG_DECRYPTED, forwardMessage);\n observer.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, forwardMessage); // forward logger events to main thread\n\n var forwardWorkerLogs = function forwardWorkerLogs() {\n var _loop = function _loop(logFn) {\n var func = function func(message) {\n forwardMessage('workerLog', {\n logType: logFn,\n message: message\n });\n };\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"][logFn] = func;\n };\n\n for (var logFn in _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"]) {\n _loop(logFn);\n }\n };\n\n self.addEventListener('message', function (ev) {\n var data = ev.data;\n\n switch (data.cmd) {\n case 'init':\n {\n var config = JSON.parse(data.config);\n self.transmuxer = new _demux_transmuxer__WEBPACK_IMPORTED_MODULE_0__[\"default\"](observer, data.typeSupported, config, data.vendor, data.id);\n Object(_utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"enableLogs\"])(config.debug);\n forwardWorkerLogs();\n forwardMessage('init', null);\n break;\n }\n\n case 'configure':\n {\n self.transmuxer.configure(data.config);\n break;\n }\n\n case 'demux':\n {\n var transmuxResult = self.transmuxer.push(data.data, data.decryptdata, data.chunkMeta, data.state);\n\n if (Object(_demux_transmuxer__WEBPACK_IMPORTED_MODULE_0__[\"isPromise\"])(transmuxResult)) {\n transmuxResult.then(function (data) {\n emitTransmuxComplete(self, data);\n });\n } else {\n emitTransmuxComplete(self, transmuxResult);\n }\n\n break;\n }\n\n case 'flush':\n {\n var id = data.chunkMeta;\n\n var _transmuxResult = self.transmuxer.flush(id);\n\n if (Object(_demux_transmuxer__WEBPACK_IMPORTED_MODULE_0__[\"isPromise\"])(_transmuxResult)) {\n _transmuxResult.then(function (results) {\n handleFlushResult(self, results, id);\n });\n } else {\n handleFlushResult(self, _transmuxResult, id);\n }\n\n break;\n }\n\n default:\n break;\n }\n });\n}\n\nfunction emitTransmuxComplete(self, transmuxResult) {\n if (isEmptyResult(transmuxResult.remuxResult)) {\n return false;\n }\n\n var transferable = [];\n var _transmuxResult$remux = transmuxResult.remuxResult,\n audio = _transmuxResult$remux.audio,\n video = _transmuxResult$remux.video;\n\n if (audio) {\n addToTransferable(transferable, audio);\n }\n\n if (video) {\n addToTransferable(transferable, video);\n }\n\n self.postMessage({\n event: 'transmuxComplete',\n data: transmuxResult\n }, transferable);\n return true;\n} // Converts data to a transferable object https://developers.google.com/web/updates/2011/12/Transferable-Objects-Lightning-Fast)\n// in order to minimize message passing overhead\n\n\nfunction addToTransferable(transferable, track) {\n if (track.data1) {\n transferable.push(track.data1.buffer);\n }\n\n if (track.data2) {\n transferable.push(track.data2.buffer);\n }\n}\n\nfunction handleFlushResult(self, results, chunkMeta) {\n var parsed = results.reduce(function (parsed, result) {\n return emitTransmuxComplete(self, result) || parsed;\n }, false);\n\n if (!parsed) {\n // Emit at least one \"transmuxComplete\" message even if media is not found to update stream-controller state to PARSING\n self.postMessage({\n event: 'transmuxComplete',\n data: results[0]\n });\n }\n\n self.postMessage({\n event: 'flush',\n data: chunkMeta\n });\n}\n\nfunction isEmptyResult(remuxResult) {\n return !remuxResult.audio && !remuxResult.video && !remuxResult.text && !remuxResult.id3 && !remuxResult.initSegment;\n}\n\n/***/ }),\n\n/***/ \"./src/demux/transmuxer.ts\":\n/*!*********************************!*\\\n !*** ./src/demux/transmuxer.ts ***!\n \\*********************************/\n/*! exports provided: default, isPromise, TransmuxConfig, TransmuxState */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Transmuxer; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isPromise\", function() { return isPromise; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"TransmuxConfig\", function() { return TransmuxConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"TransmuxState\", function() { return TransmuxState; });\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _crypt_decrypter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../crypt/decrypter */ \"./src/crypt/decrypter.ts\");\n/* harmony import */ var _demux_aacdemuxer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../demux/aacdemuxer */ \"./src/demux/aacdemuxer.ts\");\n/* harmony import */ var _demux_mp4demuxer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../demux/mp4demuxer */ \"./src/demux/mp4demuxer.ts\");\n/* harmony import */ var _demux_tsdemuxer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../demux/tsdemuxer */ \"./src/demux/tsdemuxer.ts\");\n/* harmony import */ var _demux_mp3demuxer__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../demux/mp3demuxer */ \"./src/demux/mp3demuxer.ts\");\n/* harmony import */ var _remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../remux/mp4-remuxer */ \"./src/remux/mp4-remuxer.ts\");\n/* harmony import */ var _remux_passthrough_remuxer__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../remux/passthrough-remuxer */ \"./src/remux/passthrough-remuxer.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\n\n\n\n\n\n\n\nvar now; // performance.now() not available on WebWorker, at least on Safari Desktop\n\ntry {\n now = self.performance.now.bind(self.performance);\n} catch (err) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].debug('Unable to use Performance API on this environment');\n now = self.Date.now;\n}\n\nvar muxConfig = [{\n demux: _demux_tsdemuxer__WEBPACK_IMPORTED_MODULE_5__[\"default\"],\n remux: _remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_7__[\"default\"]\n}, {\n demux: _demux_mp4demuxer__WEBPACK_IMPORTED_MODULE_4__[\"default\"],\n remux: _remux_passthrough_remuxer__WEBPACK_IMPORTED_MODULE_8__[\"default\"]\n}, {\n demux: _demux_aacdemuxer__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n remux: _remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_7__[\"default\"]\n}, {\n demux: _demux_mp3demuxer__WEBPACK_IMPORTED_MODULE_6__[\"default\"],\n remux: _remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_7__[\"default\"]\n}];\n\nvar Transmuxer = /*#__PURE__*/function () {\n function Transmuxer(observer, typeSupported, config, vendor, id) {\n this.observer = void 0;\n this.typeSupported = void 0;\n this.config = void 0;\n this.vendor = void 0;\n this.id = void 0;\n this.demuxer = void 0;\n this.remuxer = void 0;\n this.decrypter = void 0;\n this.probe = void 0;\n this.decryptionPromise = null;\n this.transmuxConfig = void 0;\n this.currentTransmuxState = void 0;\n this.observer = observer;\n this.typeSupported = typeSupported;\n this.config = config;\n this.vendor = vendor;\n this.id = id;\n }\n\n var _proto = Transmuxer.prototype;\n\n _proto.configure = function configure(transmuxConfig) {\n this.transmuxConfig = transmuxConfig;\n\n if (this.decrypter) {\n this.decrypter.reset();\n }\n };\n\n _proto.push = function push(data, decryptdata, chunkMeta, state) {\n var _this = this;\n\n var stats = chunkMeta.transmuxing;\n stats.executeStart = now();\n var uintData = new Uint8Array(data);\n var config = this.config,\n currentTransmuxState = this.currentTransmuxState,\n transmuxConfig = this.transmuxConfig;\n\n if (state) {\n this.currentTransmuxState = state;\n }\n\n var _ref = state || currentTransmuxState,\n contiguous = _ref.contiguous,\n discontinuity = _ref.discontinuity,\n trackSwitch = _ref.trackSwitch,\n accurateTimeOffset = _ref.accurateTimeOffset,\n timeOffset = _ref.timeOffset,\n initSegmentChange = _ref.initSegmentChange;\n\n var audioCodec = transmuxConfig.audioCodec,\n videoCodec = transmuxConfig.videoCodec,\n defaultInitPts = transmuxConfig.defaultInitPts,\n duration = transmuxConfig.duration,\n initSegmentData = transmuxConfig.initSegmentData; // Reset muxers before probing to ensure that their state is clean, even if flushing occurs before a successful probe\n\n if (discontinuity || trackSwitch || initSegmentChange) {\n this.resetInitSegment(initSegmentData, audioCodec, videoCodec, duration);\n }\n\n if (discontinuity || initSegmentChange) {\n this.resetInitialTimestamp(defaultInitPts);\n }\n\n if (!contiguous) {\n this.resetContiguity();\n }\n\n var keyData = getEncryptionType(uintData, decryptdata);\n\n if (keyData && keyData.method === 'AES-128') {\n var decrypter = this.getDecrypter(); // Software decryption is synchronous; webCrypto is not\n\n if (config.enableSoftwareAES) {\n // Software decryption is progressive. Progressive decryption may not return a result on each call. Any cached\n // data is handled in the flush() call\n var decryptedData = decrypter.softwareDecrypt(uintData, keyData.key.buffer, keyData.iv.buffer);\n\n if (!decryptedData) {\n stats.executeEnd = now();\n return emptyResult(chunkMeta);\n }\n\n uintData = new Uint8Array(decryptedData);\n } else {\n this.decryptionPromise = decrypter.webCryptoDecrypt(uintData, keyData.key.buffer, keyData.iv.buffer).then(function (decryptedData) {\n // Calling push here is important; if flush() is called while this is still resolving, this ensures that\n // the decrypted data has been transmuxed\n var result = _this.push(decryptedData, null, chunkMeta);\n\n _this.decryptionPromise = null;\n return result;\n });\n return this.decryptionPromise;\n }\n }\n\n if (this.needsProbing(uintData, discontinuity, trackSwitch)) {\n this.configureTransmuxer(uintData, transmuxConfig);\n }\n\n var result = this.transmux(uintData, keyData, timeOffset, accurateTimeOffset, chunkMeta);\n var currentState = this.currentTransmuxState;\n currentState.contiguous = true;\n currentState.discontinuity = false;\n currentState.trackSwitch = false;\n stats.executeEnd = now();\n return result;\n } // Due to data caching, flush calls can produce more than one TransmuxerResult (hence the Array type)\n ;\n\n _proto.flush = function flush(chunkMeta) {\n var _this2 = this;\n\n var stats = chunkMeta.transmuxing;\n stats.executeStart = now();\n var decrypter = this.decrypter,\n currentTransmuxState = this.currentTransmuxState,\n decryptionPromise = this.decryptionPromise;\n\n if (decryptionPromise) {\n // Upon resolution, the decryption promise calls push() and returns its TransmuxerResult up the stack. Therefore\n // only flushing is required for async decryption\n return decryptionPromise.then(function () {\n return _this2.flush(chunkMeta);\n });\n }\n\n var transmuxResults = [];\n var timeOffset = currentTransmuxState.timeOffset;\n\n if (decrypter) {\n // The decrypter may have data cached, which needs to be demuxed. In this case we'll have two TransmuxResults\n // This happens in the case that we receive only 1 push call for a segment (either for non-progressive downloads,\n // or for progressive downloads with small segments)\n var decryptedData = decrypter.flush();\n\n if (decryptedData) {\n // Push always returns a TransmuxerResult if decryptdata is null\n transmuxResults.push(this.push(decryptedData, null, chunkMeta));\n }\n }\n\n var demuxer = this.demuxer,\n remuxer = this.remuxer;\n\n if (!demuxer || !remuxer) {\n // If probing failed, then Hls.js has been given content its not able to handle\n this.observer.emit(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, _events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_PARSING_ERROR,\n fatal: true,\n reason: 'no demux matching with content found'\n });\n stats.executeEnd = now();\n return [emptyResult(chunkMeta)];\n }\n\n var demuxResultOrPromise = demuxer.flush(timeOffset);\n\n if (isPromise(demuxResultOrPromise)) {\n // Decrypt final SAMPLE-AES samples\n return demuxResultOrPromise.then(function (demuxResult) {\n _this2.flushRemux(transmuxResults, demuxResult, chunkMeta);\n\n return transmuxResults;\n });\n }\n\n this.flushRemux(transmuxResults, demuxResultOrPromise, chunkMeta);\n return transmuxResults;\n };\n\n _proto.flushRemux = function flushRemux(transmuxResults, demuxResult, chunkMeta) {\n var audioTrack = demuxResult.audioTrack,\n videoTrack = demuxResult.videoTrack,\n id3Track = demuxResult.id3Track,\n textTrack = demuxResult.textTrack;\n var _this$currentTransmux = this.currentTransmuxState,\n accurateTimeOffset = _this$currentTransmux.accurateTimeOffset,\n timeOffset = _this$currentTransmux.timeOffset;\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"[transmuxer.ts]: Flushed fragment \" + chunkMeta.sn + (chunkMeta.part > -1 ? ' p: ' + chunkMeta.part : '') + \" of level \" + chunkMeta.level);\n var remuxResult = this.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, accurateTimeOffset, true, this.id);\n transmuxResults.push({\n remuxResult: remuxResult,\n chunkMeta: chunkMeta\n });\n chunkMeta.transmuxing.executeEnd = now();\n };\n\n _proto.resetInitialTimestamp = function resetInitialTimestamp(defaultInitPts) {\n var demuxer = this.demuxer,\n remuxer = this.remuxer;\n\n if (!demuxer || !remuxer) {\n return;\n }\n\n demuxer.resetTimeStamp(defaultInitPts);\n remuxer.resetTimeStamp(defaultInitPts);\n };\n\n _proto.resetContiguity = function resetContiguity() {\n var demuxer = this.demuxer,\n remuxer = this.remuxer;\n\n if (!demuxer || !remuxer) {\n return;\n }\n\n demuxer.resetContiguity();\n remuxer.resetNextTimestamp();\n };\n\n _proto.resetInitSegment = function resetInitSegment(initSegmentData, audioCodec, videoCodec, trackDuration) {\n var demuxer = this.demuxer,\n remuxer = this.remuxer;\n\n if (!demuxer || !remuxer) {\n return;\n }\n\n demuxer.resetInitSegment(initSegmentData, audioCodec, videoCodec, trackDuration);\n remuxer.resetInitSegment(initSegmentData, audioCodec, videoCodec);\n };\n\n _proto.destroy = function destroy() {\n if (this.demuxer) {\n this.demuxer.destroy();\n this.demuxer = undefined;\n }\n\n if (this.remuxer) {\n this.remuxer.destroy();\n this.remuxer = undefined;\n }\n };\n\n _proto.transmux = function transmux(data, keyData, timeOffset, accurateTimeOffset, chunkMeta) {\n var result;\n\n if (keyData && keyData.method === 'SAMPLE-AES') {\n result = this.transmuxSampleAes(data, keyData, timeOffset, accurateTimeOffset, chunkMeta);\n } else {\n result = this.transmuxUnencrypted(data, timeOffset, accurateTimeOffset, chunkMeta);\n }\n\n return result;\n };\n\n _proto.transmuxUnencrypted = function transmuxUnencrypted(data, timeOffset, accurateTimeOffset, chunkMeta) {\n var _demux = this.demuxer.demux(data, timeOffset, false, !this.config.progressive),\n audioTrack = _demux.audioTrack,\n videoTrack = _demux.videoTrack,\n id3Track = _demux.id3Track,\n textTrack = _demux.textTrack;\n\n var remuxResult = this.remuxer.remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, accurateTimeOffset, false, this.id);\n return {\n remuxResult: remuxResult,\n chunkMeta: chunkMeta\n };\n };\n\n _proto.transmuxSampleAes = function transmuxSampleAes(data, decryptData, timeOffset, accurateTimeOffset, chunkMeta) {\n var _this3 = this;\n\n return this.demuxer.demuxSampleAes(data, decryptData, timeOffset).then(function (demuxResult) {\n var remuxResult = _this3.remuxer.remux(demuxResult.audioTrack, demuxResult.videoTrack, demuxResult.id3Track, demuxResult.textTrack, timeOffset, accurateTimeOffset, false, _this3.id);\n\n return {\n remuxResult: remuxResult,\n chunkMeta: chunkMeta\n };\n });\n };\n\n _proto.configureTransmuxer = function configureTransmuxer(data, transmuxConfig) {\n var config = this.config,\n observer = this.observer,\n typeSupported = this.typeSupported,\n vendor = this.vendor;\n var audioCodec = transmuxConfig.audioCodec,\n defaultInitPts = transmuxConfig.defaultInitPts,\n duration = transmuxConfig.duration,\n initSegmentData = transmuxConfig.initSegmentData,\n videoCodec = transmuxConfig.videoCodec; // probe for content type\n\n var mux;\n\n for (var i = 0, len = muxConfig.length; i < len; i++) {\n if (muxConfig[i].demux.probe(data)) {\n mux = muxConfig[i];\n break;\n }\n }\n\n if (!mux) {\n // If probing previous configs fail, use mp4 passthrough\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].warn('Failed to find demuxer by probing frag, treating as mp4 passthrough');\n mux = {\n demux: _demux_mp4demuxer__WEBPACK_IMPORTED_MODULE_4__[\"default\"],\n remux: _remux_passthrough_remuxer__WEBPACK_IMPORTED_MODULE_8__[\"default\"]\n };\n } // so let's check that current remuxer and demuxer are still valid\n\n\n var demuxer = this.demuxer;\n var remuxer = this.remuxer;\n var Remuxer = mux.remux;\n var Demuxer = mux.demux;\n\n if (!remuxer || !(remuxer instanceof Remuxer)) {\n this.remuxer = new Remuxer(observer, config, typeSupported, vendor);\n }\n\n if (!demuxer || !(demuxer instanceof Demuxer)) {\n this.demuxer = new Demuxer(observer, config, typeSupported);\n this.probe = Demuxer.probe;\n } // Ensure that muxers are always initialized with an initSegment\n\n\n this.resetInitSegment(initSegmentData, audioCodec, videoCodec, duration);\n this.resetInitialTimestamp(defaultInitPts);\n };\n\n _proto.needsProbing = function needsProbing(data, discontinuity, trackSwitch) {\n // in case of continuity change, or track switch\n // we might switch from content type (AAC container to TS container, or TS to fmp4 for example)\n return !this.demuxer || !this.remuxer || discontinuity || trackSwitch;\n };\n\n _proto.getDecrypter = function getDecrypter() {\n var decrypter = this.decrypter;\n\n if (!decrypter) {\n decrypter = this.decrypter = new _crypt_decrypter__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this.observer, this.config);\n }\n\n return decrypter;\n };\n\n return Transmuxer;\n}();\n\n\n\nfunction getEncryptionType(data, decryptData) {\n var encryptionType = null;\n\n if (data.byteLength > 0 && decryptData != null && decryptData.key != null && decryptData.iv !== null && decryptData.method != null) {\n encryptionType = decryptData;\n }\n\n return encryptionType;\n}\n\nvar emptyResult = function emptyResult(chunkMeta) {\n return {\n remuxResult: {},\n chunkMeta: chunkMeta\n };\n};\n\nfunction isPromise(p) {\n return 'then' in p && p.then instanceof Function;\n}\nvar TransmuxConfig = function TransmuxConfig(audioCodec, videoCodec, initSegmentData, duration, defaultInitPts) {\n this.audioCodec = void 0;\n this.videoCodec = void 0;\n this.initSegmentData = void 0;\n this.duration = void 0;\n this.defaultInitPts = void 0;\n this.audioCodec = audioCodec;\n this.videoCodec = videoCodec;\n this.initSegmentData = initSegmentData;\n this.duration = duration;\n this.defaultInitPts = defaultInitPts;\n};\nvar TransmuxState = function TransmuxState(discontinuity, contiguous, accurateTimeOffset, trackSwitch, timeOffset, initSegmentChange) {\n this.discontinuity = void 0;\n this.contiguous = void 0;\n this.accurateTimeOffset = void 0;\n this.trackSwitch = void 0;\n this.timeOffset = void 0;\n this.initSegmentChange = void 0;\n this.discontinuity = discontinuity;\n this.contiguous = contiguous;\n this.accurateTimeOffset = accurateTimeOffset;\n this.trackSwitch = trackSwitch;\n this.timeOffset = timeOffset;\n this.initSegmentChange = initSegmentChange;\n};\n\n/***/ }),\n\n/***/ \"./src/demux/tsdemuxer.ts\":\n/*!********************************!*\\\n !*** ./src/demux/tsdemuxer.ts ***!\n \\********************************/\n/*! exports provided: discardEPB, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"discardEPB\", function() { return discardEPB; });\n/* harmony import */ var _adts__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./adts */ \"./src/demux/adts.ts\");\n/* harmony import */ var _mpegaudio__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./mpegaudio */ \"./src/demux/mpegaudio.ts\");\n/* harmony import */ var _exp_golomb__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./exp-golomb */ \"./src/demux/exp-golomb.ts\");\n/* harmony import */ var _sample_aes__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./sample-aes */ \"./src/demux/sample-aes.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _types_demuxer__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../types/demuxer */ \"./src/types/demuxer.ts\");\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n/**\n * highly optimized TS demuxer:\n * parse PAT, PMT\n * extract PES packet from audio and video PIDs\n * extract AVC/H264 NAL units and AAC/ADTS samples from PES packet\n * trigger the remuxer upon parsing completion\n * it also tries to workaround as best as it can audio codec switch (HE-AAC to AAC and vice versa), without having to restart the MediaSource.\n * it also controls the remuxing process :\n * upon discontinuity or level switch detection, it will also notifies the remuxer so that it can reset its state.\n */\n\n\n\n\n\n\n\n\n\n\nvar TSDemuxer = /*#__PURE__*/function () {\n function TSDemuxer(observer, config, typeSupported) {\n this.observer = void 0;\n this.config = void 0;\n this.typeSupported = void 0;\n this.sampleAes = null;\n this.pmtParsed = false;\n this.audioCodec = void 0;\n this.videoCodec = void 0;\n this._duration = 0;\n this._pmtId = -1;\n this._avcTrack = void 0;\n this._audioTrack = void 0;\n this._id3Track = void 0;\n this._txtTrack = void 0;\n this.aacOverFlow = null;\n this.avcSample = null;\n this.remainderData = null;\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n }\n\n TSDemuxer.probe = function probe(data) {\n // a TS init segment should contain at least 2 TS packets: PAT and PMT, each starting with 0x47\n return data[0] === 0x47 && data[188] === 0x47;\n }\n /**\n * Creates a track model internal to demuxer used to drive remuxing input\n *\n * @param type 'audio' | 'video' | 'id3' | 'text'\n * @param duration\n * @return TSDemuxer's internal track model\n */\n ;\n\n TSDemuxer.createTrack = function createTrack(type, duration) {\n return {\n container: type === 'video' || type === 'audio' ? 'video/mp2t' : undefined,\n type: type,\n id: _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_5__[\"RemuxerTrackIdConfig\"][type],\n pid: -1,\n inputTimeScale: 90000,\n sequenceNumber: 0,\n samples: [],\n dropped: 0,\n duration: type === 'audio' ? duration : undefined\n };\n }\n /**\n * Initializes a new init segment on the demuxer/remuxer interface. Needed for discontinuities/track-switches (or at stream start)\n * Resets all internal track instances of the demuxer.\n */\n ;\n\n var _proto = TSDemuxer.prototype;\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec, trackDuration) {\n this.pmtParsed = false;\n this._pmtId = -1;\n this._avcTrack = TSDemuxer.createTrack('video');\n this._audioTrack = TSDemuxer.createTrack('audio', trackDuration);\n this._id3Track = TSDemuxer.createTrack('id3');\n this._txtTrack = TSDemuxer.createTrack('text');\n this._audioTrack.segmentCodec = 'aac'; // flush any partial content\n\n this.aacOverFlow = null;\n this.avcSample = null;\n this.remainderData = null;\n this.audioCodec = audioCodec;\n this.videoCodec = videoCodec;\n this._duration = trackDuration;\n };\n\n _proto.resetTimeStamp = function resetTimeStamp() {};\n\n _proto.resetContiguity = function resetContiguity() {\n var _audioTrack = this._audioTrack,\n _avcTrack = this._avcTrack,\n _id3Track = this._id3Track;\n\n if (_audioTrack) {\n _audioTrack.pesData = null;\n }\n\n if (_avcTrack) {\n _avcTrack.pesData = null;\n }\n\n if (_id3Track) {\n _id3Track.pesData = null;\n }\n\n this.aacOverFlow = null;\n };\n\n _proto.demux = function demux(data, timeOffset, isSampleAes, flush) {\n if (isSampleAes === void 0) {\n isSampleAes = false;\n }\n\n if (flush === void 0) {\n flush = false;\n }\n\n if (!isSampleAes) {\n this.sampleAes = null;\n }\n\n var pes;\n var videoTrack = this._avcTrack;\n var audioTrack = this._audioTrack;\n var id3Track = this._id3Track;\n var textTrack = this._txtTrack;\n var avcId = videoTrack.pid;\n var avcData = videoTrack.pesData;\n var audioId = audioTrack.pid;\n var id3Id = id3Track.pid;\n var audioData = audioTrack.pesData;\n var id3Data = id3Track.pesData;\n var unknownPID = null;\n var pmtParsed = this.pmtParsed;\n var pmtId = this._pmtId;\n var len = data.length;\n\n if (this.remainderData) {\n data = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_5__[\"appendUint8Array\"])(this.remainderData, data);\n len = data.length;\n this.remainderData = null;\n }\n\n if (len < 188 && !flush) {\n this.remainderData = data;\n return {\n audioTrack: audioTrack,\n videoTrack: videoTrack,\n id3Track: id3Track,\n textTrack: textTrack\n };\n }\n\n len -= len % 188;\n\n if (len < data.byteLength && !flush) {\n this.remainderData = new Uint8Array(data.buffer, len, data.buffer.byteLength - len);\n } // loop through TS packets\n\n\n var tsPacketErrors = 0;\n\n for (var start = 0; start < len; start += 188) {\n if (data[start] === 0x47) {\n var stt = !!(data[start + 1] & 0x40); // pid is a 13-bit field starting at the last bit of TS[1]\n\n var pid = ((data[start + 1] & 0x1f) << 8) + data[start + 2];\n var atf = (data[start + 3] & 0x30) >> 4; // if an adaption field is present, its length is specified by the fifth byte of the TS packet header.\n\n var offset = void 0;\n\n if (atf > 1) {\n offset = start + 5 + data[start + 4]; // continue if there is only adaptation field\n\n if (offset === start + 188) {\n continue;\n }\n } else {\n offset = start + 4;\n }\n\n switch (pid) {\n case avcId:\n if (stt) {\n if (avcData && (pes = parsePES(avcData))) {\n this.parseAVCPES(videoTrack, textTrack, pes, false);\n }\n\n avcData = {\n data: [],\n size: 0\n };\n }\n\n if (avcData) {\n avcData.data.push(data.subarray(offset, start + 188));\n avcData.size += start + 188 - offset;\n }\n\n break;\n\n case audioId:\n if (stt) {\n if (audioData && (pes = parsePES(audioData))) {\n switch (audioTrack.segmentCodec) {\n case 'aac':\n this.parseAACPES(audioTrack, pes);\n break;\n\n case 'mp3':\n this.parseMPEGPES(audioTrack, pes);\n break;\n }\n }\n\n audioData = {\n data: [],\n size: 0\n };\n }\n\n if (audioData) {\n audioData.data.push(data.subarray(offset, start + 188));\n audioData.size += start + 188 - offset;\n }\n\n break;\n\n case id3Id:\n if (stt) {\n if (id3Data && (pes = parsePES(id3Data))) {\n this.parseID3PES(id3Track, pes);\n }\n\n id3Data = {\n data: [],\n size: 0\n };\n }\n\n if (id3Data) {\n id3Data.data.push(data.subarray(offset, start + 188));\n id3Data.size += start + 188 - offset;\n }\n\n break;\n\n case 0:\n if (stt) {\n offset += data[offset] + 1;\n }\n\n pmtId = this._pmtId = parsePAT(data, offset);\n break;\n\n case pmtId:\n {\n if (stt) {\n offset += data[offset] + 1;\n }\n\n var parsedPIDs = parsePMT(data, offset, this.typeSupported, isSampleAes); // only update track id if track PID found while parsing PMT\n // this is to avoid resetting the PID to -1 in case\n // track PID transiently disappears from the stream\n // this could happen in case of transient missing audio samples for example\n // NOTE this is only the PID of the track as found in TS,\n // but we are not using this for MP4 track IDs.\n\n avcId = parsedPIDs.avc;\n\n if (avcId > 0) {\n videoTrack.pid = avcId;\n }\n\n audioId = parsedPIDs.audio;\n\n if (audioId > 0) {\n audioTrack.pid = audioId;\n audioTrack.segmentCodec = parsedPIDs.segmentCodec;\n }\n\n id3Id = parsedPIDs.id3;\n\n if (id3Id > 0) {\n id3Track.pid = id3Id;\n }\n\n if (unknownPID !== null && !pmtParsed) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log(\"unknown PID '\" + unknownPID + \"' in TS found\");\n unknownPID = null;\n }\n\n pmtParsed = this.pmtParsed = true;\n break;\n }\n\n case 17:\n case 0x1fff:\n break;\n\n default:\n unknownPID = pid;\n break;\n }\n } else {\n tsPacketErrors++;\n }\n }\n\n if (tsPacketErrors > 0) {\n this.observer.emit(_events__WEBPACK_IMPORTED_MODULE_4__[\"Events\"].ERROR, _events__WEBPACK_IMPORTED_MODULE_4__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_7__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_7__[\"ErrorDetails\"].FRAG_PARSING_ERROR,\n fatal: false,\n reason: \"Found \" + tsPacketErrors + \" TS packet/s that do not start with 0x47\"\n });\n }\n\n videoTrack.pesData = avcData;\n audioTrack.pesData = audioData;\n id3Track.pesData = id3Data;\n var demuxResult = {\n audioTrack: audioTrack,\n videoTrack: videoTrack,\n id3Track: id3Track,\n textTrack: textTrack\n };\n\n if (flush) {\n this.extractRemainingSamples(demuxResult);\n }\n\n return demuxResult;\n };\n\n _proto.flush = function flush() {\n var remainderData = this.remainderData;\n this.remainderData = null;\n var result;\n\n if (remainderData) {\n result = this.demux(remainderData, -1, false, true);\n } else {\n result = {\n videoTrack: this._avcTrack,\n audioTrack: this._audioTrack,\n id3Track: this._id3Track,\n textTrack: this._txtTrack\n };\n }\n\n this.extractRemainingSamples(result);\n\n if (this.sampleAes) {\n return this.decrypt(result, this.sampleAes);\n }\n\n return result;\n };\n\n _proto.extractRemainingSamples = function extractRemainingSamples(demuxResult) {\n var audioTrack = demuxResult.audioTrack,\n videoTrack = demuxResult.videoTrack,\n id3Track = demuxResult.id3Track,\n textTrack = demuxResult.textTrack;\n var avcData = videoTrack.pesData;\n var audioData = audioTrack.pesData;\n var id3Data = id3Track.pesData; // try to parse last PES packets\n\n var pes;\n\n if (avcData && (pes = parsePES(avcData))) {\n this.parseAVCPES(videoTrack, textTrack, pes, true);\n videoTrack.pesData = null;\n } else {\n // either avcData null or PES truncated, keep it for next frag parsing\n videoTrack.pesData = avcData;\n }\n\n if (audioData && (pes = parsePES(audioData))) {\n switch (audioTrack.segmentCodec) {\n case 'aac':\n this.parseAACPES(audioTrack, pes);\n break;\n\n case 'mp3':\n this.parseMPEGPES(audioTrack, pes);\n break;\n }\n\n audioTrack.pesData = null;\n } else {\n if (audioData !== null && audioData !== void 0 && audioData.size) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log('last AAC PES packet truncated,might overlap between fragments');\n } // either audioData null or PES truncated, keep it for next frag parsing\n\n\n audioTrack.pesData = audioData;\n }\n\n if (id3Data && (pes = parsePES(id3Data))) {\n this.parseID3PES(id3Track, pes);\n id3Track.pesData = null;\n } else {\n // either id3Data null or PES truncated, keep it for next frag parsing\n id3Track.pesData = id3Data;\n }\n };\n\n _proto.demuxSampleAes = function demuxSampleAes(data, keyData, timeOffset) {\n var demuxResult = this.demux(data, timeOffset, true, !this.config.progressive);\n var sampleAes = this.sampleAes = new _sample_aes__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this.observer, this.config, keyData);\n return this.decrypt(demuxResult, sampleAes);\n };\n\n _proto.decrypt = function decrypt(demuxResult, sampleAes) {\n return new Promise(function (resolve) {\n var audioTrack = demuxResult.audioTrack,\n videoTrack = demuxResult.videoTrack;\n\n if (audioTrack.samples && audioTrack.segmentCodec === 'aac') {\n sampleAes.decryptAacSamples(audioTrack.samples, 0, function () {\n if (videoTrack.samples) {\n sampleAes.decryptAvcSamples(videoTrack.samples, 0, 0, function () {\n resolve(demuxResult);\n });\n } else {\n resolve(demuxResult);\n }\n });\n } else if (videoTrack.samples) {\n sampleAes.decryptAvcSamples(videoTrack.samples, 0, 0, function () {\n resolve(demuxResult);\n });\n }\n });\n };\n\n _proto.destroy = function destroy() {\n this._duration = 0;\n };\n\n _proto.parseAVCPES = function parseAVCPES(track, textTrack, pes, last) {\n var _this = this;\n\n var units = this.parseAVCNALu(track, pes.data);\n var debug = false;\n var avcSample = this.avcSample;\n var push;\n var spsfound = false; // free pes.data to save up some memory\n\n pes.data = null; // if new NAL units found and last sample still there, let's push ...\n // this helps parsing streams with missing AUD (only do this if AUD never found)\n\n if (avcSample && units.length && !track.audFound) {\n pushAccessUnit(avcSample, track);\n avcSample = this.avcSample = createAVCSample(false, pes.pts, pes.dts, '');\n }\n\n units.forEach(function (unit) {\n switch (unit.type) {\n // NDR\n case 1:\n {\n push = true;\n\n if (!avcSample) {\n avcSample = _this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'NDR ';\n }\n\n avcSample.frame = true;\n var data = unit.data; // only check slice type to detect KF in case SPS found in same packet (any keyframe is preceded by SPS ...)\n\n if (spsfound && data.length > 4) {\n // retrieve slice type by parsing beginning of NAL unit (follow H264 spec, slice_header definition) to detect keyframe embedded in NDR\n var sliceType = new _exp_golomb__WEBPACK_IMPORTED_MODULE_2__[\"default\"](data).readSliceType(); // 2 : I slice, 4 : SI slice, 7 : I slice, 9: SI slice\n // SI slice : A slice that is coded using intra prediction only and using quantisation of the prediction samples.\n // An SI slice can be coded such that its decoded samples can be constructed identically to an SP slice.\n // I slice: A slice that is not an SI slice that is decoded using intra prediction only.\n // if (sliceType === 2 || sliceType === 7) {\n\n if (sliceType === 2 || sliceType === 4 || sliceType === 7 || sliceType === 9) {\n avcSample.key = true;\n }\n }\n\n break; // IDR\n }\n\n case 5:\n push = true; // handle PES not starting with AUD\n\n if (!avcSample) {\n avcSample = _this.avcSample = createAVCSample(true, pes.pts, pes.dts, '');\n }\n\n if (debug) {\n avcSample.debug += 'IDR ';\n }\n\n avcSample.key = true;\n avcSample.frame = true;\n break;\n // SEI\n\n case 6:\n {\n push = true;\n\n if (debug && avcSample) {\n avcSample.debug += 'SEI ';\n }\n\n Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_5__[\"parseSEIMessageFromNALu\"])(discardEPB(unit.data), pes.pts, textTrack.samples);\n break; // SPS\n }\n\n case 7:\n push = true;\n spsfound = true;\n\n if (debug && avcSample) {\n avcSample.debug += 'SPS ';\n }\n\n if (!track.sps) {\n var expGolombDecoder = new _exp_golomb__WEBPACK_IMPORTED_MODULE_2__[\"default\"](unit.data);\n var config = expGolombDecoder.readSPS();\n track.width = config.width;\n track.height = config.height;\n track.pixelRatio = config.pixelRatio; // TODO: `track.sps` is defined as a `number[]`, but we're setting it to a `Uint8Array[]`.\n\n track.sps = [unit.data];\n track.duration = _this._duration;\n var codecarray = unit.data.subarray(1, 4);\n var codecstring = 'avc1.';\n\n for (var i = 0; i < 3; i++) {\n var h = codecarray[i].toString(16);\n\n if (h.length < 2) {\n h = '0' + h;\n }\n\n codecstring += h;\n }\n\n track.codec = codecstring;\n }\n\n break;\n // PPS\n\n case 8:\n push = true;\n\n if (debug && avcSample) {\n avcSample.debug += 'PPS ';\n }\n\n if (!track.pps) {\n // TODO: `track.pss` is defined as a `number[]`, but we're setting it to a `Uint8Array[]`.\n track.pps = [unit.data];\n }\n\n break;\n // AUD\n\n case 9:\n push = false;\n track.audFound = true;\n\n if (avcSample) {\n pushAccessUnit(avcSample, track);\n }\n\n avcSample = _this.avcSample = createAVCSample(false, pes.pts, pes.dts, debug ? 'AUD ' : '');\n break;\n // Filler Data\n\n case 12:\n push = true;\n break;\n\n default:\n push = false;\n\n if (avcSample) {\n avcSample.debug += 'unknown NAL ' + unit.type + ' ';\n }\n\n break;\n }\n\n if (avcSample && push) {\n var _units = avcSample.units;\n\n _units.push(unit);\n }\n }); // if last PES packet, push samples\n\n if (last && avcSample) {\n pushAccessUnit(avcSample, track);\n this.avcSample = null;\n }\n };\n\n _proto.getLastNalUnit = function getLastNalUnit(samples) {\n var _avcSample;\n\n var avcSample = this.avcSample;\n var lastUnit; // try to fallback to previous sample if current one is empty\n\n if (!avcSample || avcSample.units.length === 0) {\n avcSample = samples[samples.length - 1];\n }\n\n if ((_avcSample = avcSample) !== null && _avcSample !== void 0 && _avcSample.units) {\n var units = avcSample.units;\n lastUnit = units[units.length - 1];\n }\n\n return lastUnit;\n };\n\n _proto.parseAVCNALu = function parseAVCNALu(track, array) {\n var len = array.byteLength;\n var state = track.naluState || 0;\n var lastState = state;\n var units = [];\n var i = 0;\n var value;\n var overflow;\n var unitType;\n var lastUnitStart = -1;\n var lastUnitType = 0; // logger.log('PES:' + Hex.hexDump(array));\n\n if (state === -1) {\n // special use case where we found 3 or 4-byte start codes exactly at the end of previous PES packet\n lastUnitStart = 0; // NALu type is value read from offset 0\n\n lastUnitType = array[0] & 0x1f;\n state = 0;\n i = 1;\n }\n\n while (i < len) {\n value = array[i++]; // optimization. state 0 and 1 are the predominant case. let's handle them outside of the switch/case\n\n if (!state) {\n state = value ? 0 : 1;\n continue;\n }\n\n if (state === 1) {\n state = value ? 0 : 2;\n continue;\n } // here we have state either equal to 2 or 3\n\n\n if (!value) {\n state = 3;\n } else if (value === 1) {\n if (lastUnitStart >= 0) {\n var unit = {\n data: array.subarray(lastUnitStart, i - state - 1),\n type: lastUnitType\n }; // logger.log('pushing NALU, type/size:' + unit.type + '/' + unit.data.byteLength);\n\n units.push(unit);\n } else {\n // lastUnitStart is undefined => this is the first start code found in this PES packet\n // first check if start code delimiter is overlapping between 2 PES packets,\n // ie it started in last packet (lastState not zero)\n // and ended at the beginning of this PES packet (i <= 4 - lastState)\n var lastUnit = this.getLastNalUnit(track.samples);\n\n if (lastUnit) {\n if (lastState && i <= 4 - lastState) {\n // start delimiter overlapping between PES packets\n // strip start delimiter bytes from the end of last NAL unit\n // check if lastUnit had a state different from zero\n if (lastUnit.state) {\n // strip last bytes\n lastUnit.data = lastUnit.data.subarray(0, lastUnit.data.byteLength - lastState);\n }\n } // If NAL units are not starting right at the beginning of the PES packet, push preceding data into previous NAL unit.\n\n\n overflow = i - state - 1;\n\n if (overflow > 0) {\n // logger.log('first NALU found with overflow:' + overflow);\n var tmp = new Uint8Array(lastUnit.data.byteLength + overflow);\n tmp.set(lastUnit.data, 0);\n tmp.set(array.subarray(0, overflow), lastUnit.data.byteLength);\n lastUnit.data = tmp;\n lastUnit.state = 0;\n }\n }\n } // check if we can read unit type\n\n\n if (i < len) {\n unitType = array[i] & 0x1f; // logger.log('find NALU @ offset:' + i + ',type:' + unitType);\n\n lastUnitStart = i;\n lastUnitType = unitType;\n state = 0;\n } else {\n // not enough byte to read unit type. let's read it on next PES parsing\n state = -1;\n }\n } else {\n state = 0;\n }\n }\n\n if (lastUnitStart >= 0 && state >= 0) {\n var _unit = {\n data: array.subarray(lastUnitStart, len),\n type: lastUnitType,\n state: state\n };\n units.push(_unit); // logger.log('pushing NALU, type/size/state:' + unit.type + '/' + unit.data.byteLength + '/' + state);\n } // no NALu found\n\n\n if (units.length === 0) {\n // append pes.data to previous NAL unit\n var _lastUnit = this.getLastNalUnit(track.samples);\n\n if (_lastUnit) {\n var _tmp = new Uint8Array(_lastUnit.data.byteLength + array.byteLength);\n\n _tmp.set(_lastUnit.data, 0);\n\n _tmp.set(array, _lastUnit.data.byteLength);\n\n _lastUnit.data = _tmp;\n }\n }\n\n track.naluState = state;\n return units;\n };\n\n _proto.parseAACPES = function parseAACPES(track, pes) {\n var startOffset = 0;\n var aacOverFlow = this.aacOverFlow;\n var data = pes.data;\n\n if (aacOverFlow) {\n this.aacOverFlow = null;\n var frameMissingBytes = aacOverFlow.missing;\n var sampleLength = aacOverFlow.sample.unit.byteLength; // logger.log(`AAC: append overflowing ${sampleLength} bytes to beginning of new PES`);\n\n if (frameMissingBytes === -1) {\n var tmp = new Uint8Array(sampleLength + data.byteLength);\n tmp.set(aacOverFlow.sample.unit, 0);\n tmp.set(data, sampleLength);\n data = tmp;\n } else {\n var frameOverflowBytes = sampleLength - frameMissingBytes;\n aacOverFlow.sample.unit.set(data.subarray(0, frameMissingBytes), frameOverflowBytes);\n track.samples.push(aacOverFlow.sample);\n startOffset = aacOverFlow.missing;\n }\n } // look for ADTS header (0xFFFx)\n\n\n var offset;\n var len;\n\n for (offset = startOffset, len = data.length; offset < len - 1; offset++) {\n if (_adts__WEBPACK_IMPORTED_MODULE_0__[\"isHeader\"](data, offset)) {\n break;\n }\n } // if ADTS header does not start straight from the beginning of the PES payload, raise an error\n\n\n if (offset !== startOffset) {\n var reason;\n var fatal;\n\n if (offset < len - 1) {\n reason = \"AAC PES did not start with ADTS header,offset:\" + offset;\n fatal = false;\n } else {\n reason = 'no ADTS header found in AAC PES';\n fatal = true;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn(\"parsing error:\" + reason);\n this.observer.emit(_events__WEBPACK_IMPORTED_MODULE_4__[\"Events\"].ERROR, _events__WEBPACK_IMPORTED_MODULE_4__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_7__[\"ErrorTypes\"].MEDIA_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_7__[\"ErrorDetails\"].FRAG_PARSING_ERROR,\n fatal: fatal,\n reason: reason\n });\n\n if (fatal) {\n return;\n }\n }\n\n _adts__WEBPACK_IMPORTED_MODULE_0__[\"initTrackConfig\"](track, this.observer, data, offset, this.audioCodec);\n var pts;\n\n if (pes.pts !== undefined) {\n pts = pes.pts;\n } else if (aacOverFlow) {\n // if last AAC frame is overflowing, we should ensure timestamps are contiguous:\n // first sample PTS should be equal to last sample PTS + frameDuration\n var frameDuration = _adts__WEBPACK_IMPORTED_MODULE_0__[\"getFrameDuration\"](track.samplerate);\n pts = aacOverFlow.sample.pts + frameDuration;\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn('[tsdemuxer]: AAC PES unknown PTS');\n return;\n } // scan for aac samples\n\n\n var frameIndex = 0;\n var frame;\n\n while (offset < len) {\n frame = _adts__WEBPACK_IMPORTED_MODULE_0__[\"appendFrame\"](track, data, offset, pts, frameIndex);\n offset += frame.length;\n\n if (!frame.missing) {\n frameIndex++;\n\n for (; offset < len - 1; offset++) {\n if (_adts__WEBPACK_IMPORTED_MODULE_0__[\"isHeader\"](data, offset)) {\n break;\n }\n }\n } else {\n this.aacOverFlow = frame;\n break;\n }\n }\n };\n\n _proto.parseMPEGPES = function parseMPEGPES(track, pes) {\n var data = pes.data;\n var length = data.length;\n var frameIndex = 0;\n var offset = 0;\n var pts = pes.pts;\n\n if (pts === undefined) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn('[tsdemuxer]: MPEG PES unknown PTS');\n return;\n }\n\n while (offset < length) {\n if (_mpegaudio__WEBPACK_IMPORTED_MODULE_1__[\"isHeader\"](data, offset)) {\n var frame = _mpegaudio__WEBPACK_IMPORTED_MODULE_1__[\"appendFrame\"](track, data, offset, pts, frameIndex);\n\n if (frame) {\n offset += frame.length;\n frameIndex++;\n } else {\n // logger.log('Unable to parse Mpeg audio frame');\n break;\n }\n } else {\n // nothing found, keep looking\n offset++;\n }\n }\n };\n\n _proto.parseID3PES = function parseID3PES(id3Track, pes) {\n if (pes.pts === undefined) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn('[tsdemuxer]: ID3 PES unknown PTS');\n return;\n }\n\n var id3Sample = _extends({}, pes, {\n type: this._avcTrack ? _types_demuxer__WEBPACK_IMPORTED_MODULE_8__[\"MetadataSchema\"].emsg : _types_demuxer__WEBPACK_IMPORTED_MODULE_8__[\"MetadataSchema\"].audioId3\n });\n\n id3Track.samples.push(id3Sample);\n };\n\n return TSDemuxer;\n}();\n\nfunction createAVCSample(key, pts, dts, debug) {\n return {\n key: key,\n frame: false,\n pts: pts,\n dts: dts,\n units: [],\n debug: debug,\n length: 0\n };\n}\n\nfunction parsePAT(data, offset) {\n // skip the PSI header and parse the first PMT entry\n return (data[offset + 10] & 0x1f) << 8 | data[offset + 11]; // logger.log('PMT PID:' + this._pmtId);\n}\n\nfunction parsePMT(data, offset, typeSupported, isSampleAes) {\n var result = {\n audio: -1,\n avc: -1,\n id3: -1,\n segmentCodec: 'aac'\n };\n var sectionLength = (data[offset + 1] & 0x0f) << 8 | data[offset + 2];\n var tableEnd = offset + 3 + sectionLength - 4; // to determine where the table is, we have to figure out how\n // long the program info descriptors are\n\n var programInfoLength = (data[offset + 10] & 0x0f) << 8 | data[offset + 11]; // advance the offset to the first entry in the mapping table\n\n offset += 12 + programInfoLength;\n\n while (offset < tableEnd) {\n var pid = (data[offset + 1] & 0x1f) << 8 | data[offset + 2];\n\n switch (data[offset]) {\n case 0xcf:\n // SAMPLE-AES AAC\n if (!isSampleAes) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log('ADTS AAC with AES-128-CBC frame encryption found in unencrypted stream');\n break;\n }\n\n /* falls through */\n\n case 0x0f:\n // ISO/IEC 13818-7 ADTS AAC (MPEG-2 lower bit-rate audio)\n // logger.log('AAC PID:' + pid);\n if (result.audio === -1) {\n result.audio = pid;\n }\n\n break;\n // Packetized metadata (ID3)\n\n case 0x15:\n // logger.log('ID3 PID:' + pid);\n if (result.id3 === -1) {\n result.id3 = pid;\n }\n\n break;\n\n case 0xdb:\n // SAMPLE-AES AVC\n if (!isSampleAes) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log('H.264 with AES-128-CBC slice encryption found in unencrypted stream');\n break;\n }\n\n /* falls through */\n\n case 0x1b:\n // ITU-T Rec. H.264 and ISO/IEC 14496-10 (lower bit-rate video)\n // logger.log('AVC PID:' + pid);\n if (result.avc === -1) {\n result.avc = pid;\n }\n\n break;\n // ISO/IEC 11172-3 (MPEG-1 audio)\n // or ISO/IEC 13818-3 (MPEG-2 halved sample rate audio)\n\n case 0x03:\n case 0x04:\n // logger.log('MPEG PID:' + pid);\n if (typeSupported.mpeg !== true && typeSupported.mp3 !== true) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log('MPEG audio found, not supported in this browser');\n } else if (result.audio === -1) {\n result.audio = pid;\n result.segmentCodec = 'mp3';\n }\n\n break;\n\n case 0x24:\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn('Unsupported HEVC stream type found');\n break;\n\n default:\n // logger.log('unknown stream type:' + data[offset]);\n break;\n } // move to the next table entry\n // skip past the elementary stream descriptors, if present\n\n\n offset += ((data[offset + 3] & 0x0f) << 8 | data[offset + 4]) + 5;\n }\n\n return result;\n}\n\nfunction parsePES(stream) {\n var i = 0;\n var frag;\n var pesLen;\n var pesHdrLen;\n var pesPts;\n var pesDts;\n var data = stream.data; // safety check\n\n if (!stream || stream.size === 0) {\n return null;\n } // we might need up to 19 bytes to read PES header\n // if first chunk of data is less than 19 bytes, let's merge it with following ones until we get 19 bytes\n // usually only one merge is needed (and this is rare ...)\n\n\n while (data[0].length < 19 && data.length > 1) {\n var newData = new Uint8Array(data[0].length + data[1].length);\n newData.set(data[0]);\n newData.set(data[1], data[0].length);\n data[0] = newData;\n data.splice(1, 1);\n } // retrieve PTS/DTS from first fragment\n\n\n frag = data[0];\n var pesPrefix = (frag[0] << 16) + (frag[1] << 8) + frag[2];\n\n if (pesPrefix === 1) {\n pesLen = (frag[4] << 8) + frag[5]; // if PES parsed length is not zero and greater than total received length, stop parsing. PES might be truncated\n // minus 6 : PES header size\n\n if (pesLen && pesLen > stream.size - 6) {\n return null;\n }\n\n var pesFlags = frag[7];\n\n if (pesFlags & 0xc0) {\n /* PES header described here : http://dvd.sourceforge.net/dvdinfo/pes-hdr.html\n as PTS / DTS is 33 bit we cannot use bitwise operator in JS,\n as Bitwise operators treat their operands as a sequence of 32 bits */\n pesPts = (frag[9] & 0x0e) * 536870912 + // 1 << 29\n (frag[10] & 0xff) * 4194304 + // 1 << 22\n (frag[11] & 0xfe) * 16384 + // 1 << 14\n (frag[12] & 0xff) * 128 + // 1 << 7\n (frag[13] & 0xfe) / 2;\n\n if (pesFlags & 0x40) {\n pesDts = (frag[14] & 0x0e) * 536870912 + // 1 << 29\n (frag[15] & 0xff) * 4194304 + // 1 << 22\n (frag[16] & 0xfe) * 16384 + // 1 << 14\n (frag[17] & 0xff) * 128 + // 1 << 7\n (frag[18] & 0xfe) / 2;\n\n if (pesPts - pesDts > 60 * 90000) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].warn(Math.round((pesPts - pesDts) / 90000) + \"s delta between PTS and DTS, align them\");\n pesPts = pesDts;\n }\n } else {\n pesDts = pesPts;\n }\n }\n\n pesHdrLen = frag[8]; // 9 bytes : 6 bytes for PES header + 3 bytes for PES extension\n\n var payloadStartOffset = pesHdrLen + 9;\n\n if (stream.size <= payloadStartOffset) {\n return null;\n }\n\n stream.size -= payloadStartOffset; // reassemble PES packet\n\n var pesData = new Uint8Array(stream.size);\n\n for (var j = 0, dataLen = data.length; j < dataLen; j++) {\n frag = data[j];\n var len = frag.byteLength;\n\n if (payloadStartOffset) {\n if (payloadStartOffset > len) {\n // trim full frag if PES header bigger than frag\n payloadStartOffset -= len;\n continue;\n } else {\n // trim partial frag if PES header smaller than frag\n frag = frag.subarray(payloadStartOffset);\n len -= payloadStartOffset;\n payloadStartOffset = 0;\n }\n }\n\n pesData.set(frag, i);\n i += len;\n }\n\n if (pesLen) {\n // payload size : remove PES header + PES extension\n pesLen -= pesHdrLen + 3;\n }\n\n return {\n data: pesData,\n pts: pesPts,\n dts: pesDts,\n len: pesLen\n };\n }\n\n return null;\n}\n\nfunction pushAccessUnit(avcSample, avcTrack) {\n if (avcSample.units.length && avcSample.frame) {\n // if sample does not have PTS/DTS, patch with last sample PTS/DTS\n if (avcSample.pts === undefined) {\n var samples = avcTrack.samples;\n var nbSamples = samples.length;\n\n if (nbSamples) {\n var lastSample = samples[nbSamples - 1];\n avcSample.pts = lastSample.pts;\n avcSample.dts = lastSample.dts;\n } else {\n // dropping samples, no timestamp found\n avcTrack.dropped++;\n return;\n }\n }\n\n avcTrack.samples.push(avcSample);\n }\n\n if (avcSample.debug.length) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_6__[\"logger\"].log(avcSample.pts + '/' + avcSample.dts + ':' + avcSample.debug);\n }\n}\n/**\n * remove Emulation Prevention bytes from a RBSP\n */\n\n\nfunction discardEPB(data) {\n var length = data.byteLength;\n var EPBPositions = [];\n var i = 1; // Find all `Emulation Prevention Bytes`\n\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n EPBPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n } // If no Emulation Prevention Bytes were found just return the original\n // array\n\n\n if (EPBPositions.length === 0) {\n return data;\n } // Create a new array to hold the NAL unit data\n\n\n var newLength = length - EPBPositions.length;\n var newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === EPBPositions[0]) {\n // Skip this byte\n sourceIndex++; // Remove this position index\n\n EPBPositions.shift();\n }\n\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n}\n/* harmony default export */ __webpack_exports__[\"default\"] = (TSDemuxer);\n\n/***/ }),\n\n/***/ \"./src/errors.ts\":\n/*!***********************!*\\\n !*** ./src/errors.ts ***!\n \\***********************/\n/*! exports provided: ErrorTypes, ErrorDetails */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ErrorTypes\", function() { return ErrorTypes; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ErrorDetails\", function() { return ErrorDetails; });\nvar ErrorTypes;\n/**\n * @enum {ErrorDetails}\n * @typedef {string} ErrorDetail\n */\n\n(function (ErrorTypes) {\n ErrorTypes[\"NETWORK_ERROR\"] = \"networkError\";\n ErrorTypes[\"MEDIA_ERROR\"] = \"mediaError\";\n ErrorTypes[\"KEY_SYSTEM_ERROR\"] = \"keySystemError\";\n ErrorTypes[\"MUX_ERROR\"] = \"muxError\";\n ErrorTypes[\"OTHER_ERROR\"] = \"otherError\";\n})(ErrorTypes || (ErrorTypes = {}));\n\nvar ErrorDetails;\n\n(function (ErrorDetails) {\n ErrorDetails[\"KEY_SYSTEM_NO_KEYS\"] = \"keySystemNoKeys\";\n ErrorDetails[\"KEY_SYSTEM_NO_ACCESS\"] = \"keySystemNoAccess\";\n ErrorDetails[\"KEY_SYSTEM_NO_SESSION\"] = \"keySystemNoSession\";\n ErrorDetails[\"KEY_SYSTEM_LICENSE_REQUEST_FAILED\"] = \"keySystemLicenseRequestFailed\";\n ErrorDetails[\"KEY_SYSTEM_NO_INIT_DATA\"] = \"keySystemNoInitData\";\n ErrorDetails[\"MANIFEST_LOAD_ERROR\"] = \"manifestLoadError\";\n ErrorDetails[\"MANIFEST_LOAD_TIMEOUT\"] = \"manifestLoadTimeOut\";\n ErrorDetails[\"MANIFEST_PARSING_ERROR\"] = \"manifestParsingError\";\n ErrorDetails[\"MANIFEST_INCOMPATIBLE_CODECS_ERROR\"] = \"manifestIncompatibleCodecsError\";\n ErrorDetails[\"LEVEL_EMPTY_ERROR\"] = \"levelEmptyError\";\n ErrorDetails[\"LEVEL_LOAD_ERROR\"] = \"levelLoadError\";\n ErrorDetails[\"LEVEL_LOAD_TIMEOUT\"] = \"levelLoadTimeOut\";\n ErrorDetails[\"LEVEL_SWITCH_ERROR\"] = \"levelSwitchError\";\n ErrorDetails[\"AUDIO_TRACK_LOAD_ERROR\"] = \"audioTrackLoadError\";\n ErrorDetails[\"AUDIO_TRACK_LOAD_TIMEOUT\"] = \"audioTrackLoadTimeOut\";\n ErrorDetails[\"SUBTITLE_LOAD_ERROR\"] = \"subtitleTrackLoadError\";\n ErrorDetails[\"SUBTITLE_TRACK_LOAD_TIMEOUT\"] = \"subtitleTrackLoadTimeOut\";\n ErrorDetails[\"FRAG_LOAD_ERROR\"] = \"fragLoadError\";\n ErrorDetails[\"FRAG_LOAD_TIMEOUT\"] = \"fragLoadTimeOut\";\n ErrorDetails[\"FRAG_DECRYPT_ERROR\"] = \"fragDecryptError\";\n ErrorDetails[\"FRAG_PARSING_ERROR\"] = \"fragParsingError\";\n ErrorDetails[\"REMUX_ALLOC_ERROR\"] = \"remuxAllocError\";\n ErrorDetails[\"KEY_LOAD_ERROR\"] = \"keyLoadError\";\n ErrorDetails[\"KEY_LOAD_TIMEOUT\"] = \"keyLoadTimeOut\";\n ErrorDetails[\"BUFFER_ADD_CODEC_ERROR\"] = \"bufferAddCodecError\";\n ErrorDetails[\"BUFFER_INCOMPATIBLE_CODECS_ERROR\"] = \"bufferIncompatibleCodecsError\";\n ErrorDetails[\"BUFFER_APPEND_ERROR\"] = \"bufferAppendError\";\n ErrorDetails[\"BUFFER_APPENDING_ERROR\"] = \"bufferAppendingError\";\n ErrorDetails[\"BUFFER_STALLED_ERROR\"] = \"bufferStalledError\";\n ErrorDetails[\"BUFFER_FULL_ERROR\"] = \"bufferFullError\";\n ErrorDetails[\"BUFFER_SEEK_OVER_HOLE\"] = \"bufferSeekOverHole\";\n ErrorDetails[\"BUFFER_NUDGE_ON_STALL\"] = \"bufferNudgeOnStall\";\n ErrorDetails[\"INTERNAL_EXCEPTION\"] = \"internalException\";\n ErrorDetails[\"INTERNAL_ABORTED\"] = \"aborted\";\n ErrorDetails[\"UNKNOWN\"] = \"unknown\";\n})(ErrorDetails || (ErrorDetails = {}));\n\n/***/ }),\n\n/***/ \"./src/events.ts\":\n/*!***********************!*\\\n !*** ./src/events.ts ***!\n \\***********************/\n/*! exports provided: Events */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Events\", function() { return Events; });\n/**\n * @readonly\n * @enum {string}\n */\nvar Events;\n\n(function (Events) {\n Events[\"MEDIA_ATTACHING\"] = \"hlsMediaAttaching\";\n Events[\"MEDIA_ATTACHED\"] = \"hlsMediaAttached\";\n Events[\"MEDIA_DETACHING\"] = \"hlsMediaDetaching\";\n Events[\"MEDIA_DETACHED\"] = \"hlsMediaDetached\";\n Events[\"BUFFER_RESET\"] = \"hlsBufferReset\";\n Events[\"BUFFER_CODECS\"] = \"hlsBufferCodecs\";\n Events[\"BUFFER_CREATED\"] = \"hlsBufferCreated\";\n Events[\"BUFFER_APPENDING\"] = \"hlsBufferAppending\";\n Events[\"BUFFER_APPENDED\"] = \"hlsBufferAppended\";\n Events[\"BUFFER_EOS\"] = \"hlsBufferEos\";\n Events[\"BUFFER_FLUSHING\"] = \"hlsBufferFlushing\";\n Events[\"BUFFER_FLUSHED\"] = \"hlsBufferFlushed\";\n Events[\"MANIFEST_LOADING\"] = \"hlsManifestLoading\";\n Events[\"MANIFEST_LOADED\"] = \"hlsManifestLoaded\";\n Events[\"MANIFEST_PARSED\"] = \"hlsManifestParsed\";\n Events[\"LEVEL_SWITCHING\"] = \"hlsLevelSwitching\";\n Events[\"LEVEL_SWITCHED\"] = \"hlsLevelSwitched\";\n Events[\"LEVEL_LOADING\"] = \"hlsLevelLoading\";\n Events[\"LEVEL_LOADED\"] = \"hlsLevelLoaded\";\n Events[\"LEVEL_UPDATED\"] = \"hlsLevelUpdated\";\n Events[\"LEVEL_PTS_UPDATED\"] = \"hlsLevelPtsUpdated\";\n Events[\"LEVELS_UPDATED\"] = \"hlsLevelsUpdated\";\n Events[\"AUDIO_TRACKS_UPDATED\"] = \"hlsAudioTracksUpdated\";\n Events[\"AUDIO_TRACK_SWITCHING\"] = \"hlsAudioTrackSwitching\";\n Events[\"AUDIO_TRACK_SWITCHED\"] = \"hlsAudioTrackSwitched\";\n Events[\"AUDIO_TRACK_LOADING\"] = \"hlsAudioTrackLoading\";\n Events[\"AUDIO_TRACK_LOADED\"] = \"hlsAudioTrackLoaded\";\n Events[\"SUBTITLE_TRACKS_UPDATED\"] = \"hlsSubtitleTracksUpdated\";\n Events[\"SUBTITLE_TRACKS_CLEARED\"] = \"hlsSubtitleTracksCleared\";\n Events[\"SUBTITLE_TRACK_SWITCH\"] = \"hlsSubtitleTrackSwitch\";\n Events[\"SUBTITLE_TRACK_LOADING\"] = \"hlsSubtitleTrackLoading\";\n Events[\"SUBTITLE_TRACK_LOADED\"] = \"hlsSubtitleTrackLoaded\";\n Events[\"SUBTITLE_FRAG_PROCESSED\"] = \"hlsSubtitleFragProcessed\";\n Events[\"CUES_PARSED\"] = \"hlsCuesParsed\";\n Events[\"NON_NATIVE_TEXT_TRACKS_FOUND\"] = \"hlsNonNativeTextTracksFound\";\n Events[\"INIT_PTS_FOUND\"] = \"hlsInitPtsFound\";\n Events[\"FRAG_LOADING\"] = \"hlsFragLoading\";\n Events[\"FRAG_LOAD_EMERGENCY_ABORTED\"] = \"hlsFragLoadEmergencyAborted\";\n Events[\"FRAG_LOADED\"] = \"hlsFragLoaded\";\n Events[\"FRAG_DECRYPTED\"] = \"hlsFragDecrypted\";\n Events[\"FRAG_PARSING_INIT_SEGMENT\"] = \"hlsFragParsingInitSegment\";\n Events[\"FRAG_PARSING_USERDATA\"] = \"hlsFragParsingUserdata\";\n Events[\"FRAG_PARSING_METADATA\"] = \"hlsFragParsingMetadata\";\n Events[\"FRAG_PARSED\"] = \"hlsFragParsed\";\n Events[\"FRAG_BUFFERED\"] = \"hlsFragBuffered\";\n Events[\"FRAG_CHANGED\"] = \"hlsFragChanged\";\n Events[\"FPS_DROP\"] = \"hlsFpsDrop\";\n Events[\"FPS_DROP_LEVEL_CAPPING\"] = \"hlsFpsDropLevelCapping\";\n Events[\"ERROR\"] = \"hlsError\";\n Events[\"DESTROYING\"] = \"hlsDestroying\";\n Events[\"KEY_LOADING\"] = \"hlsKeyLoading\";\n Events[\"KEY_LOADED\"] = \"hlsKeyLoaded\";\n Events[\"LIVE_BACK_BUFFER_REACHED\"] = \"hlsLiveBackBufferReached\";\n Events[\"BACK_BUFFER_REACHED\"] = \"hlsBackBufferReached\";\n})(Events || (Events = {}));\n\n/***/ }),\n\n/***/ \"./src/hls.ts\":\n/*!********************!*\\\n !*** ./src/hls.ts ***!\n \\********************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return Hls; });\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! url-toolkit */ \"./node_modules/url-toolkit/src/url-toolkit.js\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(url_toolkit__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _loader_playlist_loader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./loader/playlist-loader */ \"./src/loader/playlist-loader.ts\");\n/* harmony import */ var _loader_key_loader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./loader/key-loader */ \"./src/loader/key-loader.ts\");\n/* harmony import */ var _controller_id3_track_controller__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./controller/id3-track-controller */ \"./src/controller/id3-track-controller.ts\");\n/* harmony import */ var _controller_latency_controller__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./controller/latency-controller */ \"./src/controller/latency-controller.ts\");\n/* harmony import */ var _controller_level_controller__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./controller/level-controller */ \"./src/controller/level-controller.ts\");\n/* harmony import */ var _controller_fragment_tracker__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./controller/fragment-tracker */ \"./src/controller/fragment-tracker.ts\");\n/* harmony import */ var _controller_stream_controller__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./controller/stream-controller */ \"./src/controller/stream-controller.ts\");\n/* harmony import */ var _is_supported__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./is-supported */ \"./src/is-supported.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _config__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./config */ \"./src/config.ts\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! eventemitter3 */ \"./node_modules/eventemitter3/index.js\");\n/* harmony import */ var eventemitter3__WEBPACK_IMPORTED_MODULE_11___default = /*#__PURE__*/__webpack_require__.n(eventemitter3__WEBPACK_IMPORTED_MODULE_11__);\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./errors */ \"./src/errors.ts\");\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n/**\n * @module Hls\n * @class\n * @constructor\n */\nvar Hls = /*#__PURE__*/function () {\n Hls.isSupported = function isSupported() {\n return Object(_is_supported__WEBPACK_IMPORTED_MODULE_8__[\"isSupported\"])();\n };\n\n /**\n * Creates an instance of an HLS client that can attach to exactly one `HTMLMediaElement`.\n *\n * @constructs Hls\n * @param {HlsConfig} config\n */\n function Hls(userConfig) {\n if (userConfig === void 0) {\n userConfig = {};\n }\n\n this.config = void 0;\n this.userConfig = void 0;\n this.coreComponents = void 0;\n this.networkControllers = void 0;\n this._emitter = new eventemitter3__WEBPACK_IMPORTED_MODULE_11__[\"EventEmitter\"]();\n this._autoLevelCapping = void 0;\n this.abrController = void 0;\n this.bufferController = void 0;\n this.capLevelController = void 0;\n this.latencyController = void 0;\n this.levelController = void 0;\n this.streamController = void 0;\n this.audioTrackController = void 0;\n this.subtitleTrackController = void 0;\n this.emeController = void 0;\n this.cmcdController = void 0;\n this._media = null;\n this.url = null;\n var config = this.config = Object(_config__WEBPACK_IMPORTED_MODULE_10__[\"mergeConfig\"])(Hls.DefaultConfig, userConfig);\n this.userConfig = userConfig;\n Object(_utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"enableLogs\"])(config.debug);\n this._autoLevelCapping = -1;\n\n if (config.progressive) {\n Object(_config__WEBPACK_IMPORTED_MODULE_10__[\"enableStreamingMode\"])(config);\n } // core controllers and network loaders\n\n\n var ConfigAbrController = config.abrController,\n ConfigBufferController = config.bufferController,\n ConfigCapLevelController = config.capLevelController,\n ConfigFpsController = config.fpsController;\n var abrController = this.abrController = new ConfigAbrController(this);\n var bufferController = this.bufferController = new ConfigBufferController(this);\n var capLevelController = this.capLevelController = new ConfigCapLevelController(this);\n var fpsController = new ConfigFpsController(this);\n var playListLoader = new _loader_playlist_loader__WEBPACK_IMPORTED_MODULE_1__[\"default\"](this);\n var keyLoader = new _loader_key_loader__WEBPACK_IMPORTED_MODULE_2__[\"default\"](this);\n var id3TrackController = new _controller_id3_track_controller__WEBPACK_IMPORTED_MODULE_3__[\"default\"](this); // network controllers\n\n var levelController = this.levelController = new _controller_level_controller__WEBPACK_IMPORTED_MODULE_5__[\"default\"](this); // FragmentTracker must be defined before StreamController because the order of event handling is important\n\n var fragmentTracker = new _controller_fragment_tracker__WEBPACK_IMPORTED_MODULE_6__[\"FragmentTracker\"](this);\n var streamController = this.streamController = new _controller_stream_controller__WEBPACK_IMPORTED_MODULE_7__[\"default\"](this, fragmentTracker); // Cap level controller uses streamController to flush the buffer\n\n capLevelController.setStreamController(streamController); // fpsController uses streamController to switch when frames are being dropped\n\n fpsController.setStreamController(streamController);\n var networkControllers = [playListLoader, keyLoader, levelController, streamController];\n this.networkControllers = networkControllers;\n var coreComponents = [abrController, bufferController, capLevelController, fpsController, id3TrackController, fragmentTracker];\n this.audioTrackController = this.createController(config.audioTrackController, null, networkControllers);\n this.createController(config.audioStreamController, fragmentTracker, networkControllers); // subtitleTrackController must be defined before because the order of event handling is important\n\n this.subtitleTrackController = this.createController(config.subtitleTrackController, null, networkControllers);\n this.createController(config.subtitleStreamController, fragmentTracker, networkControllers);\n this.createController(config.timelineController, null, coreComponents);\n this.emeController = this.createController(config.emeController, null, coreComponents);\n this.cmcdController = this.createController(config.cmcdController, null, coreComponents);\n this.latencyController = this.createController(_controller_latency_controller__WEBPACK_IMPORTED_MODULE_4__[\"default\"], null, coreComponents);\n this.coreComponents = coreComponents;\n }\n\n var _proto = Hls.prototype;\n\n _proto.createController = function createController(ControllerClass, fragmentTracker, components) {\n if (ControllerClass) {\n var controllerInstance = fragmentTracker ? new ControllerClass(this, fragmentTracker) : new ControllerClass(this);\n\n if (components) {\n components.push(controllerInstance);\n }\n\n return controllerInstance;\n }\n\n return null;\n } // Delegate the EventEmitter through the public API of Hls.js\n ;\n\n _proto.on = function on(event, listener, context) {\n if (context === void 0) {\n context = this;\n }\n\n this._emitter.on(event, listener, context);\n };\n\n _proto.once = function once(event, listener, context) {\n if (context === void 0) {\n context = this;\n }\n\n this._emitter.once(event, listener, context);\n };\n\n _proto.removeAllListeners = function removeAllListeners(event) {\n this._emitter.removeAllListeners(event);\n };\n\n _proto.off = function off(event, listener, context, once) {\n if (context === void 0) {\n context = this;\n }\n\n this._emitter.off(event, listener, context, once);\n };\n\n _proto.listeners = function listeners(event) {\n return this._emitter.listeners(event);\n };\n\n _proto.emit = function emit(event, name, eventObject) {\n return this._emitter.emit(event, name, eventObject);\n };\n\n _proto.trigger = function trigger(event, eventObject) {\n if (this.config.debug) {\n return this.emit(event, event, eventObject);\n } else {\n try {\n return this.emit(event, event, eventObject);\n } catch (e) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].error('An internal error happened while handling event ' + event + '. Error message: \"' + e.message + '\". Here is a stacktrace:', e);\n this.trigger(_events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorTypes\"].OTHER_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"].INTERNAL_EXCEPTION,\n fatal: false,\n event: event,\n error: e\n });\n }\n }\n\n return false;\n };\n\n _proto.listenerCount = function listenerCount(event) {\n return this._emitter.listenerCount(event);\n }\n /**\n * Dispose of the instance\n */\n ;\n\n _proto.destroy = function destroy() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('destroy');\n this.trigger(_events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"].DESTROYING, undefined);\n this.detachMedia();\n this.removeAllListeners();\n this._autoLevelCapping = -1;\n this.url = null;\n this.networkControllers.forEach(function (component) {\n return component.destroy();\n });\n this.networkControllers.length = 0;\n this.coreComponents.forEach(function (component) {\n return component.destroy();\n });\n this.coreComponents.length = 0;\n }\n /**\n * Attaches Hls.js to a media element\n * @param {HTMLMediaElement} media\n */\n ;\n\n _proto.attachMedia = function attachMedia(media) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('attachMedia');\n this._media = media;\n this.trigger(_events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"].MEDIA_ATTACHING, {\n media: media\n });\n }\n /**\n * Detach Hls.js from the media\n */\n ;\n\n _proto.detachMedia = function detachMedia() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('detachMedia');\n this.trigger(_events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"].MEDIA_DETACHING, undefined);\n this._media = null;\n }\n /**\n * Set the source URL. Can be relative or absolute.\n * @param {string} url\n */\n ;\n\n _proto.loadSource = function loadSource(url) {\n this.stopLoad();\n var media = this.media;\n var loadedSource = this.url;\n var loadingSource = this.url = url_toolkit__WEBPACK_IMPORTED_MODULE_0__[\"buildAbsoluteURL\"](self.location.href, url, {\n alwaysNormalize: true\n });\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"loadSource:\" + loadingSource);\n\n if (media && loadedSource && loadedSource !== loadingSource && this.bufferController.hasSourceTypes()) {\n this.detachMedia();\n this.attachMedia(media);\n } // when attaching to a source URL, trigger a playlist load\n\n\n this.trigger(_events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"].MANIFEST_LOADING, {\n url: url\n });\n }\n /**\n * Start loading data from the stream source.\n * Depending on default config, client starts loading automatically when a source is set.\n *\n * @param {number} startPosition Set the start position to stream from\n * @default -1 None (from earliest point)\n */\n ;\n\n _proto.startLoad = function startLoad(startPosition) {\n if (startPosition === void 0) {\n startPosition = -1;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"startLoad(\" + startPosition + \")\");\n this.networkControllers.forEach(function (controller) {\n controller.startLoad(startPosition);\n });\n }\n /**\n * Stop loading of any stream data.\n */\n ;\n\n _proto.stopLoad = function stopLoad() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('stopLoad');\n this.networkControllers.forEach(function (controller) {\n controller.stopLoad();\n });\n }\n /**\n * Swap through possible audio codecs in the stream (for example to switch from stereo to 5.1)\n */\n ;\n\n _proto.swapAudioCodec = function swapAudioCodec() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('swapAudioCodec');\n this.streamController.swapAudioCodec();\n }\n /**\n * When the media-element fails, this allows to detach and then re-attach it\n * as one call (convenience method).\n *\n * Automatic recovery of media-errors by this process is configurable.\n */\n ;\n\n _proto.recoverMediaError = function recoverMediaError() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log('recoverMediaError');\n var media = this._media;\n this.detachMedia();\n\n if (media) {\n this.attachMedia(media);\n }\n };\n\n _proto.removeLevel = function removeLevel(levelIndex, urlId) {\n if (urlId === void 0) {\n urlId = 0;\n }\n\n this.levelController.removeLevel(levelIndex, urlId);\n }\n /**\n * @type {Level[]}\n */\n ;\n\n _createClass(Hls, [{\n key: \"levels\",\n get: function get() {\n var levels = this.levelController.levels;\n return levels ? levels : [];\n }\n /**\n * Index of quality level currently played\n * @type {number}\n */\n\n }, {\n key: \"currentLevel\",\n get: function get() {\n return this.streamController.currentLevel;\n }\n /**\n * Set quality level index immediately .\n * This will flush the current buffer to replace the quality asap.\n * That means playback will interrupt at least shortly to re-buffer and re-sync eventually.\n * @type {number} -1 for automatic level selection\n */\n ,\n set: function set(newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set currentLevel:\" + newLevel);\n this.loadLevel = newLevel;\n this.abrController.clearTimer();\n this.streamController.immediateLevelSwitch();\n }\n /**\n * Index of next quality level loaded as scheduled by stream controller.\n * @type {number}\n */\n\n }, {\n key: \"nextLevel\",\n get: function get() {\n return this.streamController.nextLevel;\n }\n /**\n * Set quality level index for next loaded data.\n * This will switch the video quality asap, without interrupting playback.\n * May abort current loading of data, and flush parts of buffer (outside currently played fragment region).\n * @type {number} -1 for automatic level selection\n */\n ,\n set: function set(newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set nextLevel:\" + newLevel);\n this.levelController.manualLevel = newLevel;\n this.streamController.nextLevelSwitch();\n }\n /**\n * Return the quality level of the currently or last (of none is loaded currently) segment\n * @type {number}\n */\n\n }, {\n key: \"loadLevel\",\n get: function get() {\n return this.levelController.level;\n }\n /**\n * Set quality level index for next loaded data in a conservative way.\n * This will switch the quality without flushing, but interrupt current loading.\n * Thus the moment when the quality switch will appear in effect will only be after the already existing buffer.\n * @type {number} newLevel -1 for automatic level selection\n */\n ,\n set: function set(newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set loadLevel:\" + newLevel);\n this.levelController.manualLevel = newLevel;\n }\n /**\n * get next quality level loaded\n * @type {number}\n */\n\n }, {\n key: \"nextLoadLevel\",\n get: function get() {\n return this.levelController.nextLoadLevel;\n }\n /**\n * Set quality level of next loaded segment in a fully \"non-destructive\" way.\n * Same as `loadLevel` but will wait for next switch (until current loading is done).\n * @type {number} level\n */\n ,\n set: function set(level) {\n this.levelController.nextLoadLevel = level;\n }\n /**\n * Return \"first level\": like a default level, if not set,\n * falls back to index of first level referenced in manifest\n * @type {number}\n */\n\n }, {\n key: \"firstLevel\",\n get: function get() {\n return Math.max(this.levelController.firstLevel, this.minAutoLevel);\n }\n /**\n * Sets \"first-level\", see getter.\n * @type {number}\n */\n ,\n set: function set(newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set firstLevel:\" + newLevel);\n this.levelController.firstLevel = newLevel;\n }\n /**\n * Return start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number}\n */\n\n }, {\n key: \"startLevel\",\n get: function get() {\n return this.levelController.startLevel;\n }\n /**\n * set start level (level of first fragment that will be played back)\n * if not overrided by user, first level appearing in manifest will be used as start level\n * if -1 : automatic start level selection, playback will start from level matching download bandwidth\n * (determined from download of first segment)\n * @type {number} newLevel\n */\n ,\n set: function set(newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set startLevel:\" + newLevel); // if not in automatic start level detection, ensure startLevel is greater than minAutoLevel\n\n if (newLevel !== -1) {\n newLevel = Math.max(newLevel, this.minAutoLevel);\n }\n\n this.levelController.startLevel = newLevel;\n }\n /**\n * Get the current setting for capLevelToPlayerSize\n *\n * @type {boolean}\n */\n\n }, {\n key: \"capLevelToPlayerSize\",\n get: function get() {\n return this.config.capLevelToPlayerSize;\n }\n /**\n * set dynamically set capLevelToPlayerSize against (`CapLevelController`)\n *\n * @type {boolean}\n */\n ,\n set: function set(shouldStartCapping) {\n var newCapLevelToPlayerSize = !!shouldStartCapping;\n\n if (newCapLevelToPlayerSize !== this.config.capLevelToPlayerSize) {\n if (newCapLevelToPlayerSize) {\n this.capLevelController.startCapping(); // If capping occurs, nextLevelSwitch will happen based on size.\n } else {\n this.capLevelController.stopCapping();\n this.autoLevelCapping = -1;\n this.streamController.nextLevelSwitch(); // Now we're uncapped, get the next level asap.\n }\n\n this.config.capLevelToPlayerSize = newCapLevelToPlayerSize;\n }\n }\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n\n }, {\n key: \"autoLevelCapping\",\n get: function get() {\n return this._autoLevelCapping;\n }\n /**\n * get bandwidth estimate\n * @type {number}\n */\n ,\n set:\n /**\n * Capping/max level value that should be used by automatic level selection algorithm (`ABRController`)\n * @type {number}\n */\n function set(newLevel) {\n if (this._autoLevelCapping !== newLevel) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_9__[\"logger\"].log(\"set autoLevelCapping:\" + newLevel);\n this._autoLevelCapping = newLevel;\n }\n }\n /**\n * True when automatic level selection enabled\n * @type {boolean}\n */\n\n }, {\n key: \"bandwidthEstimate\",\n get: function get() {\n var bwEstimator = this.abrController.bwEstimator;\n\n if (!bwEstimator) {\n return NaN;\n }\n\n return bwEstimator.getEstimate();\n }\n }, {\n key: \"autoLevelEnabled\",\n get: function get() {\n return this.levelController.manualLevel === -1;\n }\n /**\n * Level set manually (if any)\n * @type {number}\n */\n\n }, {\n key: \"manualLevel\",\n get: function get() {\n return this.levelController.manualLevel;\n }\n /**\n * min level selectable in auto mode according to config.minAutoBitrate\n * @type {number}\n */\n\n }, {\n key: \"minAutoLevel\",\n get: function get() {\n var levels = this.levels,\n minAutoBitrate = this.config.minAutoBitrate;\n if (!levels) return 0;\n var len = levels.length;\n\n for (var i = 0; i < len; i++) {\n if (levels[i].maxBitrate >= minAutoBitrate) {\n return i;\n }\n }\n\n return 0;\n }\n /**\n * max level selectable in auto mode according to autoLevelCapping\n * @type {number}\n */\n\n }, {\n key: \"maxAutoLevel\",\n get: function get() {\n var levels = this.levels,\n autoLevelCapping = this.autoLevelCapping;\n var maxAutoLevel;\n\n if (autoLevelCapping === -1 && levels && levels.length) {\n maxAutoLevel = levels.length - 1;\n } else {\n maxAutoLevel = autoLevelCapping;\n }\n\n return maxAutoLevel;\n }\n /**\n * next automatically selected quality level\n * @type {number}\n */\n\n }, {\n key: \"nextAutoLevel\",\n get: function get() {\n // ensure next auto level is between min and max auto level\n return Math.min(Math.max(this.abrController.nextAutoLevel, this.minAutoLevel), this.maxAutoLevel);\n }\n /**\n * this setter is used to force next auto level.\n * this is useful to force a switch down in auto mode:\n * in case of load error on level N, hls.js can set nextAutoLevel to N-1 for example)\n * forced value is valid for one fragment. upon successful frag loading at forced level,\n * this value will be resetted to -1 by ABR controller.\n * @type {number}\n */\n ,\n set: function set(nextLevel) {\n this.abrController.nextAutoLevel = Math.max(this.minAutoLevel, nextLevel);\n }\n /**\n * get the datetime value relative to media.currentTime for the active level Program Date Time if present\n * @type {Date}\n */\n\n }, {\n key: \"playingDate\",\n get: function get() {\n return this.streamController.currentProgramDateTime;\n }\n /**\n * @type {AudioTrack[]}\n */\n\n }, {\n key: \"audioTracks\",\n get: function get() {\n var audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTracks : [];\n }\n /**\n * index of the selected audio track (index in audio track lists)\n * @type {number}\n */\n\n }, {\n key: \"audioTrack\",\n get: function get() {\n var audioTrackController = this.audioTrackController;\n return audioTrackController ? audioTrackController.audioTrack : -1;\n }\n /**\n * selects an audio track, based on its index in audio track lists\n * @type {number}\n */\n ,\n set: function set(audioTrackId) {\n var audioTrackController = this.audioTrackController;\n\n if (audioTrackController) {\n audioTrackController.audioTrack = audioTrackId;\n }\n }\n /**\n * get alternate subtitle tracks list from playlist\n * @type {MediaPlaylist[]}\n */\n\n }, {\n key: \"subtitleTracks\",\n get: function get() {\n var subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTracks : [];\n }\n /**\n * index of the selected subtitle track (index in subtitle track lists)\n * @type {number}\n */\n\n }, {\n key: \"subtitleTrack\",\n get: function get() {\n var subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleTrack : -1;\n },\n set:\n /**\n * select an subtitle track, based on its index in subtitle track lists\n * @type {number}\n */\n function set(subtitleTrackId) {\n var subtitleTrackController = this.subtitleTrackController;\n\n if (subtitleTrackController) {\n subtitleTrackController.subtitleTrack = subtitleTrackId;\n }\n }\n /**\n * @type {boolean}\n */\n\n }, {\n key: \"media\",\n get: function get() {\n return this._media;\n }\n }, {\n key: \"subtitleDisplay\",\n get: function get() {\n var subtitleTrackController = this.subtitleTrackController;\n return subtitleTrackController ? subtitleTrackController.subtitleDisplay : false;\n }\n /**\n * Enable/disable subtitle display rendering\n * @type {boolean}\n */\n ,\n set: function set(value) {\n var subtitleTrackController = this.subtitleTrackController;\n\n if (subtitleTrackController) {\n subtitleTrackController.subtitleDisplay = value;\n }\n }\n /**\n * get mode for Low-Latency HLS loading\n * @type {boolean}\n */\n\n }, {\n key: \"lowLatencyMode\",\n get: function get() {\n return this.config.lowLatencyMode;\n }\n /**\n * Enable/disable Low-Latency HLS part playlist and segment loading, and start live streams at playlist PART-HOLD-BACK rather than HOLD-BACK.\n * @type {boolean}\n */\n ,\n set: function set(mode) {\n this.config.lowLatencyMode = mode;\n }\n /**\n * position (in seconds) of live sync point (ie edge of live position minus safety delay defined by ```hls.config.liveSyncDuration```)\n * @type {number}\n */\n\n }, {\n key: \"liveSyncPosition\",\n get: function get() {\n return this.latencyController.liveSyncPosition;\n }\n /**\n * estimated position (in seconds) of live edge (ie edge of live playlist plus time sync playlist advanced)\n * returns 0 before first playlist is loaded\n * @type {number}\n */\n\n }, {\n key: \"latency\",\n get: function get() {\n return this.latencyController.latency;\n }\n /**\n * maximum distance from the edge before the player seeks forward to ```hls.liveSyncPosition```\n * configured using ```liveMaxLatencyDurationCount``` (multiple of target duration) or ```liveMaxLatencyDuration```\n * returns 0 before first playlist is loaded\n * @type {number}\n */\n\n }, {\n key: \"maxLatency\",\n get: function get() {\n return this.latencyController.maxLatency;\n }\n /**\n * target distance from the edge as calculated by the latency controller\n * @type {number}\n */\n\n }, {\n key: \"targetLatency\",\n get: function get() {\n return this.latencyController.targetLatency;\n }\n /**\n * the rate at which the edge of the current live playlist is advancing or 1 if there is none\n * @type {number}\n */\n\n }, {\n key: \"drift\",\n get: function get() {\n return this.latencyController.drift;\n }\n /**\n * set to true when startLoad is called before MANIFEST_PARSED event\n * @type {boolean}\n */\n\n }, {\n key: \"forceStartLoad\",\n get: function get() {\n return this.streamController.forceStartLoad;\n }\n }], [{\n key: \"version\",\n get: function get() {\n return undefined;\n }\n }, {\n key: \"Events\",\n get: function get() {\n return _events__WEBPACK_IMPORTED_MODULE_12__[\"Events\"];\n }\n }, {\n key: \"ErrorTypes\",\n get: function get() {\n return _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorTypes\"];\n }\n }, {\n key: \"ErrorDetails\",\n get: function get() {\n return _errors__WEBPACK_IMPORTED_MODULE_13__[\"ErrorDetails\"];\n }\n }, {\n key: \"DefaultConfig\",\n get: function get() {\n if (!Hls.defaultConfig) {\n return _config__WEBPACK_IMPORTED_MODULE_10__[\"hlsDefaultConfig\"];\n }\n\n return Hls.defaultConfig;\n }\n /**\n * @type {HlsConfig}\n */\n ,\n set: function set(defaultConfig) {\n Hls.defaultConfig = defaultConfig;\n }\n }]);\n\n return Hls;\n}();\n\nHls.defaultConfig = void 0;\n\n\n/***/ }),\n\n/***/ \"./src/is-supported.ts\":\n/*!*****************************!*\\\n !*** ./src/is-supported.ts ***!\n \\*****************************/\n/*! exports provided: isSupported, changeTypeSupported */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isSupported\", function() { return isSupported; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"changeTypeSupported\", function() { return changeTypeSupported; });\n/* harmony import */ var _utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./utils/mediasource-helper */ \"./src/utils/mediasource-helper.ts\");\n\n\nfunction getSourceBuffer() {\n return self.SourceBuffer || self.WebKitSourceBuffer;\n}\n\nfunction isSupported() {\n var mediaSource = Object(_utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_0__[\"getMediaSource\"])();\n\n if (!mediaSource) {\n return false;\n }\n\n var sourceBuffer = getSourceBuffer();\n var isTypeSupported = mediaSource && typeof mediaSource.isTypeSupported === 'function' && mediaSource.isTypeSupported('video/mp4; codecs=\"avc1.42E01E,mp4a.40.2\"'); // if SourceBuffer is exposed ensure its API is valid\n // safari and old version of Chrome doe not expose SourceBuffer globally so checking SourceBuffer.prototype is impossible\n\n var sourceBufferValidAPI = !sourceBuffer || sourceBuffer.prototype && typeof sourceBuffer.prototype.appendBuffer === 'function' && typeof sourceBuffer.prototype.remove === 'function';\n return !!isTypeSupported && !!sourceBufferValidAPI;\n}\nfunction changeTypeSupported() {\n var _sourceBuffer$prototy;\n\n var sourceBuffer = getSourceBuffer();\n return typeof (sourceBuffer === null || sourceBuffer === void 0 ? void 0 : (_sourceBuffer$prototy = sourceBuffer.prototype) === null || _sourceBuffer$prototy === void 0 ? void 0 : _sourceBuffer$prototy.changeType) === 'function';\n}\n\n/***/ }),\n\n/***/ \"./src/loader/date-range.ts\":\n/*!**********************************!*\\\n !*** ./src/loader/date-range.ts ***!\n \\**********************************/\n/*! exports provided: DateRangeAttribute, DateRange */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DateRangeAttribute\", function() { return DateRangeAttribute; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DateRange\", function() { return DateRange; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _utils_attr_list__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/attr-list */ \"./src/utils/attr-list.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\nvar DateRangeAttribute;\n\n(function (DateRangeAttribute) {\n DateRangeAttribute[\"ID\"] = \"ID\";\n DateRangeAttribute[\"CLASS\"] = \"CLASS\";\n DateRangeAttribute[\"START_DATE\"] = \"START-DATE\";\n DateRangeAttribute[\"DURATION\"] = \"DURATION\";\n DateRangeAttribute[\"END_DATE\"] = \"END-DATE\";\n DateRangeAttribute[\"END_ON_NEXT\"] = \"END-ON-NEXT\";\n DateRangeAttribute[\"PLANNED_DURATION\"] = \"PLANNED-DURATION\";\n DateRangeAttribute[\"SCTE35_OUT\"] = \"SCTE35-OUT\";\n DateRangeAttribute[\"SCTE35_IN\"] = \"SCTE35-IN\";\n})(DateRangeAttribute || (DateRangeAttribute = {}));\n\nvar DateRange = /*#__PURE__*/function () {\n function DateRange(dateRangeAttr, dateRangeWithSameId) {\n this.attr = void 0;\n this._startDate = void 0;\n this._endDate = void 0;\n this._badValueForSameId = void 0;\n\n if (dateRangeWithSameId) {\n var previousAttr = dateRangeWithSameId.attr;\n\n for (var key in previousAttr) {\n if (Object.prototype.hasOwnProperty.call(dateRangeAttr, key) && dateRangeAttr[key] !== previousAttr[key]) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"DATERANGE tag attribute: \\\"\" + key + \"\\\" does not match for tags with ID: \\\"\" + dateRangeAttr.ID + \"\\\"\");\n this._badValueForSameId = key;\n break;\n }\n } // Merge DateRange tags with the same ID\n\n\n dateRangeAttr = _extends(new _utils_attr_list__WEBPACK_IMPORTED_MODULE_1__[\"AttrList\"]({}), previousAttr, dateRangeAttr);\n }\n\n this.attr = dateRangeAttr;\n this._startDate = new Date(dateRangeAttr[DateRangeAttribute.START_DATE]);\n\n if (DateRangeAttribute.END_DATE in this.attr) {\n var endDate = new Date(this.attr[DateRangeAttribute.END_DATE]);\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(endDate.getTime())) {\n this._endDate = endDate;\n }\n }\n }\n\n _createClass(DateRange, [{\n key: \"id\",\n get: function get() {\n return this.attr.ID;\n }\n }, {\n key: \"class\",\n get: function get() {\n return this.attr.CLASS;\n }\n }, {\n key: \"startDate\",\n get: function get() {\n return this._startDate;\n }\n }, {\n key: \"endDate\",\n get: function get() {\n if (this._endDate) {\n return this._endDate;\n }\n\n var duration = this.duration;\n\n if (duration !== null) {\n return new Date(this._startDate.getTime() + duration * 1000);\n }\n\n return null;\n }\n }, {\n key: \"duration\",\n get: function get() {\n if (DateRangeAttribute.DURATION in this.attr) {\n var duration = this.attr.decimalFloatingPoint(DateRangeAttribute.DURATION);\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(duration)) {\n return duration;\n }\n } else if (this._endDate) {\n return (this._endDate.getTime() - this._startDate.getTime()) / 1000;\n }\n\n return null;\n }\n }, {\n key: \"plannedDuration\",\n get: function get() {\n if (DateRangeAttribute.PLANNED_DURATION in this.attr) {\n return this.attr.decimalFloatingPoint(DateRangeAttribute.PLANNED_DURATION);\n }\n\n return null;\n }\n }, {\n key: \"endOnNext\",\n get: function get() {\n return this.attr.bool(DateRangeAttribute.END_ON_NEXT);\n }\n }, {\n key: \"isValid\",\n get: function get() {\n return !!this.id && !this._badValueForSameId && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.startDate.getTime()) && (this.duration === null || this.duration >= 0) && (!this.endOnNext || !!this.class);\n }\n }]);\n\n return DateRange;\n}();\n\n/***/ }),\n\n/***/ \"./src/loader/fragment-loader.ts\":\n/*!***************************************!*\\\n !*** ./src/loader/fragment-loader.ts ***!\n \\***************************************/\n/*! exports provided: default, LoadError */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return FragmentLoader; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"LoadError\", function() { return LoadError; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n\n\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\n\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct.bind(); } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\n\nvar MIN_CHUNK_SIZE = Math.pow(2, 17); // 128kb\n\nvar FragmentLoader = /*#__PURE__*/function () {\n function FragmentLoader(config) {\n this.config = void 0;\n this.loader = null;\n this.partLoadTimeout = -1;\n this.config = config;\n }\n\n var _proto = FragmentLoader.prototype;\n\n _proto.destroy = function destroy() {\n if (this.loader) {\n this.loader.destroy();\n this.loader = null;\n }\n };\n\n _proto.abort = function abort() {\n if (this.loader) {\n // Abort the loader for current fragment. Only one may load at any given time\n this.loader.abort();\n }\n };\n\n _proto.load = function load(frag, _onProgress) {\n var _this = this;\n\n var url = frag.url;\n\n if (!url) {\n return Promise.reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_LOAD_ERROR,\n fatal: false,\n frag: frag,\n networkDetails: null\n }, \"Fragment does not have a \" + (url ? 'part list' : 'url')));\n }\n\n this.abort();\n var config = this.config;\n var FragmentILoader = config.fLoader;\n var DefaultILoader = config.loader;\n return new Promise(function (resolve, reject) {\n if (_this.loader) {\n _this.loader.destroy();\n }\n\n var loader = _this.loader = frag.loader = FragmentILoader ? new FragmentILoader(config) : new DefaultILoader(config);\n var loaderContext = createLoaderContext(frag);\n var loaderConfig = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: 0,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout,\n highWaterMark: frag.sn === 'initSegment' ? Infinity : MIN_CHUNK_SIZE\n }; // Assign frag stats to the loader's stats reference\n\n frag.stats = loader.stats;\n loader.load(loaderContext, loaderConfig, {\n onSuccess: function onSuccess(response, stats, context, networkDetails) {\n _this.resetLoader(frag, loader);\n\n resolve({\n frag: frag,\n part: null,\n payload: response.data,\n networkDetails: networkDetails\n });\n },\n onError: function onError(response, context, networkDetails) {\n _this.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_LOAD_ERROR,\n fatal: false,\n frag: frag,\n response: response,\n networkDetails: networkDetails\n }));\n },\n onAbort: function onAbort(stats, context, networkDetails) {\n _this.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].INTERNAL_ABORTED,\n fatal: false,\n frag: frag,\n networkDetails: networkDetails\n }));\n },\n onTimeout: function onTimeout(response, context, networkDetails) {\n _this.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT,\n fatal: false,\n frag: frag,\n networkDetails: networkDetails\n }));\n },\n onProgress: function onProgress(stats, context, data, networkDetails) {\n if (_onProgress) {\n _onProgress({\n frag: frag,\n part: null,\n payload: data,\n networkDetails: networkDetails\n });\n }\n }\n });\n });\n };\n\n _proto.loadPart = function loadPart(frag, part, onProgress) {\n var _this2 = this;\n\n this.abort();\n var config = this.config;\n var FragmentILoader = config.fLoader;\n var DefaultILoader = config.loader;\n return new Promise(function (resolve, reject) {\n if (_this2.loader) {\n _this2.loader.destroy();\n }\n\n var loader = _this2.loader = frag.loader = FragmentILoader ? new FragmentILoader(config) : new DefaultILoader(config);\n var loaderContext = createLoaderContext(frag, part);\n var loaderConfig = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: 0,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout,\n highWaterMark: MIN_CHUNK_SIZE\n }; // Assign part stats to the loader's stats reference\n\n part.stats = loader.stats;\n loader.load(loaderContext, loaderConfig, {\n onSuccess: function onSuccess(response, stats, context, networkDetails) {\n _this2.resetLoader(frag, loader);\n\n _this2.updateStatsFromPart(frag, part);\n\n var partLoadedData = {\n frag: frag,\n part: part,\n payload: response.data,\n networkDetails: networkDetails\n };\n onProgress(partLoadedData);\n resolve(partLoadedData);\n },\n onError: function onError(response, context, networkDetails) {\n _this2.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_LOAD_ERROR,\n fatal: false,\n frag: frag,\n part: part,\n response: response,\n networkDetails: networkDetails\n }));\n },\n onAbort: function onAbort(stats, context, networkDetails) {\n frag.stats.aborted = part.stats.aborted;\n\n _this2.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].INTERNAL_ABORTED,\n fatal: false,\n frag: frag,\n part: part,\n networkDetails: networkDetails\n }));\n },\n onTimeout: function onTimeout(response, context, networkDetails) {\n _this2.resetLoader(frag, loader);\n\n reject(new LoadError({\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].FRAG_LOAD_TIMEOUT,\n fatal: false,\n frag: frag,\n part: part,\n networkDetails: networkDetails\n }));\n }\n });\n });\n };\n\n _proto.updateStatsFromPart = function updateStatsFromPart(frag, part) {\n var fragStats = frag.stats;\n var partStats = part.stats;\n var partTotal = partStats.total;\n fragStats.loaded += partStats.loaded;\n\n if (partTotal) {\n var estTotalParts = Math.round(frag.duration / part.duration);\n var estLoadedParts = Math.min(Math.round(fragStats.loaded / partTotal), estTotalParts);\n var estRemainingParts = estTotalParts - estLoadedParts;\n var estRemainingBytes = estRemainingParts * Math.round(fragStats.loaded / estLoadedParts);\n fragStats.total = fragStats.loaded + estRemainingBytes;\n } else {\n fragStats.total = Math.max(fragStats.loaded, fragStats.total);\n }\n\n var fragLoading = fragStats.loading;\n var partLoading = partStats.loading;\n\n if (fragLoading.start) {\n // add to fragment loader latency\n fragLoading.first += partLoading.first - partLoading.start;\n } else {\n fragLoading.start = partLoading.start;\n fragLoading.first = partLoading.first;\n }\n\n fragLoading.end = partLoading.end;\n };\n\n _proto.resetLoader = function resetLoader(frag, loader) {\n frag.loader = null;\n\n if (this.loader === loader) {\n self.clearTimeout(this.partLoadTimeout);\n this.loader = null;\n }\n\n loader.destroy();\n };\n\n return FragmentLoader;\n}();\n\n\n\nfunction createLoaderContext(frag, part) {\n if (part === void 0) {\n part = null;\n }\n\n var segment = part || frag;\n var loaderContext = {\n frag: frag,\n part: part,\n responseType: 'arraybuffer',\n url: segment.url,\n headers: {},\n rangeStart: 0,\n rangeEnd: 0\n };\n var start = segment.byteRangeStartOffset;\n var end = segment.byteRangeEndOffset;\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(start) && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(end)) {\n loaderContext.rangeStart = start;\n loaderContext.rangeEnd = end;\n }\n\n return loaderContext;\n}\n\nvar LoadError = /*#__PURE__*/function (_Error) {\n _inheritsLoose(LoadError, _Error);\n\n function LoadError(data) {\n var _this3;\n\n for (var _len = arguments.length, params = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n params[_key - 1] = arguments[_key];\n }\n\n _this3 = _Error.call.apply(_Error, [this].concat(params)) || this;\n _this3.data = void 0;\n _this3.data = data;\n return _this3;\n }\n\n return LoadError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n\n/***/ }),\n\n/***/ \"./src/loader/fragment.ts\":\n/*!********************************!*\\\n !*** ./src/loader/fragment.ts ***!\n \\********************************/\n/*! exports provided: ElementaryStreamTypes, BaseSegment, Fragment, Part */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ElementaryStreamTypes\", function() { return ElementaryStreamTypes; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"BaseSegment\", function() { return BaseSegment; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Fragment\", function() { return Fragment; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Part\", function() { return Part; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! url-toolkit */ \"./node_modules/url-toolkit/src/url-toolkit.js\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(url_toolkit__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _level_key__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./level-key */ \"./src/loader/level-key.ts\");\n/* harmony import */ var _load_stats__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./load-stats */ \"./src/loader/load-stats.ts\");\n\n\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\n\n\n\nvar ElementaryStreamTypes;\n\n(function (ElementaryStreamTypes) {\n ElementaryStreamTypes[\"AUDIO\"] = \"audio\";\n ElementaryStreamTypes[\"VIDEO\"] = \"video\";\n ElementaryStreamTypes[\"AUDIOVIDEO\"] = \"audiovideo\";\n})(ElementaryStreamTypes || (ElementaryStreamTypes = {}));\n\nvar BaseSegment = /*#__PURE__*/function () {\n // baseurl is the URL to the playlist\n // relurl is the portion of the URL that comes from inside the playlist.\n // Holds the types of data this fragment supports\n function BaseSegment(baseurl) {\n var _this$elementaryStrea;\n\n this._byteRange = null;\n this._url = null;\n this.baseurl = void 0;\n this.relurl = void 0;\n this.elementaryStreams = (_this$elementaryStrea = {}, _this$elementaryStrea[ElementaryStreamTypes.AUDIO] = null, _this$elementaryStrea[ElementaryStreamTypes.VIDEO] = null, _this$elementaryStrea[ElementaryStreamTypes.AUDIOVIDEO] = null, _this$elementaryStrea);\n this.baseurl = baseurl;\n } // setByteRange converts a EXT-X-BYTERANGE attribute into a two element array\n\n\n var _proto = BaseSegment.prototype;\n\n _proto.setByteRange = function setByteRange(value, previous) {\n var params = value.split('@', 2);\n var byteRange = [];\n\n if (params.length === 1) {\n byteRange[0] = previous ? previous.byteRangeEndOffset : 0;\n } else {\n byteRange[0] = parseInt(params[1]);\n }\n\n byteRange[1] = parseInt(params[0]) + byteRange[0];\n this._byteRange = byteRange;\n };\n\n _createClass(BaseSegment, [{\n key: \"byteRange\",\n get: function get() {\n if (!this._byteRange) {\n return [];\n }\n\n return this._byteRange;\n }\n }, {\n key: \"byteRangeStartOffset\",\n get: function get() {\n return this.byteRange[0];\n }\n }, {\n key: \"byteRangeEndOffset\",\n get: function get() {\n return this.byteRange[1];\n }\n }, {\n key: \"url\",\n get: function get() {\n if (!this._url && this.baseurl && this.relurl) {\n this._url = Object(url_toolkit__WEBPACK_IMPORTED_MODULE_1__[\"buildAbsoluteURL\"])(this.baseurl, this.relurl, {\n alwaysNormalize: true\n });\n }\n\n return this._url || '';\n },\n set: function set(value) {\n this._url = value;\n }\n }]);\n\n return BaseSegment;\n}();\nvar Fragment = /*#__PURE__*/function (_BaseSegment) {\n _inheritsLoose(Fragment, _BaseSegment);\n\n // EXTINF has to be present for a m3u8 to be considered valid\n // sn notates the sequence number for a segment, and if set to a string can be 'initSegment'\n // levelkey is the EXT-X-KEY that applies to this segment for decryption\n // core difference from the private field _decryptdata is the lack of the initialized IV\n // _decryptdata will set the IV for this segment based on the segment number in the fragment\n // A string representing the fragment type\n // A reference to the loader. Set while the fragment is loading, and removed afterwards. Used to abort fragment loading\n // The level/track index to which the fragment belongs\n // The continuity counter of the fragment\n // The starting Presentation Time Stamp (PTS) of the fragment. Set after transmux complete.\n // The ending Presentation Time Stamp (PTS) of the fragment. Set after transmux complete.\n // The latest Presentation Time Stamp (PTS) appended to the buffer.\n // The starting Decode Time Stamp (DTS) of the fragment. Set after transmux complete.\n // The ending Decode Time Stamp (DTS) of the fragment. Set after transmux complete.\n // The start time of the fragment, as listed in the manifest. Updated after transmux complete.\n // Set by `updateFragPTSDTS` in level-helper\n // The maximum starting Presentation Time Stamp (audio/video PTS) of the fragment. Set after transmux complete.\n // The minimum ending Presentation Time Stamp (audio/video PTS) of the fragment. Set after transmux complete.\n // Load/parse timing information\n // A flag indicating whether the segment was downloaded in order to test bitrate, and was not buffered\n // #EXTINF segment title\n // The Media Initialization Section for this segment\n function Fragment(type, baseurl) {\n var _this;\n\n _this = _BaseSegment.call(this, baseurl) || this;\n _this._decryptdata = null;\n _this.rawProgramDateTime = null;\n _this.programDateTime = null;\n _this.tagList = [];\n _this.duration = 0;\n _this.sn = 0;\n _this.levelkey = void 0;\n _this.type = void 0;\n _this.loader = null;\n _this.level = -1;\n _this.cc = 0;\n _this.startPTS = void 0;\n _this.endPTS = void 0;\n _this.appendedPTS = void 0;\n _this.startDTS = void 0;\n _this.endDTS = void 0;\n _this.start = 0;\n _this.deltaPTS = void 0;\n _this.maxStartPTS = void 0;\n _this.minEndPTS = void 0;\n _this.stats = new _load_stats__WEBPACK_IMPORTED_MODULE_4__[\"LoadStats\"]();\n _this.urlId = 0;\n _this.data = void 0;\n _this.bitrateTest = false;\n _this.title = null;\n _this.initSegment = null;\n _this.type = type;\n return _this;\n }\n\n var _proto2 = Fragment.prototype;\n\n /**\n * Utility method for parseLevelPlaylist to create an initialization vector for a given segment\n * @param {number} segmentNumber - segment number to generate IV with\n * @returns {Uint8Array}\n */\n _proto2.createInitializationVector = function createInitializationVector(segmentNumber) {\n var uint8View = new Uint8Array(16);\n\n for (var i = 12; i < 16; i++) {\n uint8View[i] = segmentNumber >> 8 * (15 - i) & 0xff;\n }\n\n return uint8View;\n }\n /**\n * Utility method for parseLevelPlaylist to get a fragment's decryption data from the currently parsed encryption key data\n * @param levelkey - a playlist's encryption info\n * @param segmentNumber - the fragment's segment number\n * @returns {LevelKey} - an object to be applied as a fragment's decryptdata\n */\n ;\n\n _proto2.setDecryptDataFromLevelKey = function setDecryptDataFromLevelKey(levelkey, segmentNumber) {\n var decryptdata = levelkey;\n\n if ((levelkey === null || levelkey === void 0 ? void 0 : levelkey.method) === 'AES-128' && levelkey.uri && !levelkey.iv) {\n decryptdata = _level_key__WEBPACK_IMPORTED_MODULE_3__[\"LevelKey\"].fromURI(levelkey.uri);\n decryptdata.method = levelkey.method;\n decryptdata.iv = this.createInitializationVector(segmentNumber);\n decryptdata.keyFormat = 'identity';\n }\n\n return decryptdata;\n };\n\n _proto2.setElementaryStreamInfo = function setElementaryStreamInfo(type, startPTS, endPTS, startDTS, endDTS, partial) {\n if (partial === void 0) {\n partial = false;\n }\n\n var elementaryStreams = this.elementaryStreams;\n var info = elementaryStreams[type];\n\n if (!info) {\n elementaryStreams[type] = {\n startPTS: startPTS,\n endPTS: endPTS,\n startDTS: startDTS,\n endDTS: endDTS,\n partial: partial\n };\n return;\n }\n\n info.startPTS = Math.min(info.startPTS, startPTS);\n info.endPTS = Math.max(info.endPTS, endPTS);\n info.startDTS = Math.min(info.startDTS, startDTS);\n info.endDTS = Math.max(info.endDTS, endDTS);\n };\n\n _proto2.clearElementaryStreamInfo = function clearElementaryStreamInfo() {\n var elementaryStreams = this.elementaryStreams;\n elementaryStreams[ElementaryStreamTypes.AUDIO] = null;\n elementaryStreams[ElementaryStreamTypes.VIDEO] = null;\n elementaryStreams[ElementaryStreamTypes.AUDIOVIDEO] = null;\n };\n\n _createClass(Fragment, [{\n key: \"decryptdata\",\n get: function get() {\n if (!this.levelkey && !this._decryptdata) {\n return null;\n }\n\n if (!this._decryptdata && this.levelkey) {\n var sn = this.sn;\n\n if (typeof sn !== 'number') {\n // We are fetching decryption data for a initialization segment\n // If the segment was encrypted with AES-128\n // It must have an IV defined. We cannot substitute the Segment Number in.\n if (this.levelkey && this.levelkey.method === 'AES-128' && !this.levelkey.iv) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"missing IV for initialization segment with method=\\\"\" + this.levelkey.method + \"\\\" - compliance issue\");\n }\n /*\n Be converted to a Number.\n 'initSegment' will become NaN.\n NaN, which when converted through ToInt32() -> +0.\n ---\n Explicitly set sn to resulting value from implicit conversions 'initSegment' values for IV generation.\n */\n\n\n sn = 0;\n }\n\n this._decryptdata = this.setDecryptDataFromLevelKey(this.levelkey, sn);\n }\n\n return this._decryptdata;\n }\n }, {\n key: \"end\",\n get: function get() {\n return this.start + this.duration;\n }\n }, {\n key: \"endProgramDateTime\",\n get: function get() {\n if (this.programDateTime === null) {\n return null;\n }\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.programDateTime)) {\n return null;\n }\n\n var duration = !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.duration) ? 0 : this.duration;\n return this.programDateTime + duration * 1000;\n }\n }, {\n key: \"encrypted\",\n get: function get() {\n var _this$decryptdata;\n\n // At the m3u8-parser level we need to add support for manifest signalled keyformats\n // when we want the fragment to start reporting that it is encrypted.\n // Currently, keyFormat will only be set for identity keys\n if ((_this$decryptdata = this.decryptdata) !== null && _this$decryptdata !== void 0 && _this$decryptdata.keyFormat && this.decryptdata.uri) {\n return true;\n }\n\n return false;\n }\n }]);\n\n return Fragment;\n}(BaseSegment);\nvar Part = /*#__PURE__*/function (_BaseSegment2) {\n _inheritsLoose(Part, _BaseSegment2);\n\n function Part(partAttrs, frag, baseurl, index, previous) {\n var _this2;\n\n _this2 = _BaseSegment2.call(this, baseurl) || this;\n _this2.fragOffset = 0;\n _this2.duration = 0;\n _this2.gap = false;\n _this2.independent = false;\n _this2.relurl = void 0;\n _this2.fragment = void 0;\n _this2.index = void 0;\n _this2.stats = new _load_stats__WEBPACK_IMPORTED_MODULE_4__[\"LoadStats\"]();\n _this2.duration = partAttrs.decimalFloatingPoint('DURATION');\n _this2.gap = partAttrs.bool('GAP');\n _this2.independent = partAttrs.bool('INDEPENDENT');\n _this2.relurl = partAttrs.enumeratedString('URI');\n _this2.fragment = frag;\n _this2.index = index;\n var byteRange = partAttrs.enumeratedString('BYTERANGE');\n\n if (byteRange) {\n _this2.setByteRange(byteRange, previous);\n }\n\n if (previous) {\n _this2.fragOffset = previous.fragOffset + previous.duration;\n }\n\n return _this2;\n }\n\n _createClass(Part, [{\n key: \"start\",\n get: function get() {\n return this.fragment.start + this.fragOffset;\n }\n }, {\n key: \"end\",\n get: function get() {\n return this.start + this.duration;\n }\n }, {\n key: \"loaded\",\n get: function get() {\n var elementaryStreams = this.elementaryStreams;\n return !!(elementaryStreams.audio || elementaryStreams.video || elementaryStreams.audiovideo);\n }\n }]);\n\n return Part;\n}(BaseSegment);\n\n/***/ }),\n\n/***/ \"./src/loader/key-loader.ts\":\n/*!**********************************!*\\\n !*** ./src/loader/key-loader.ts ***!\n \\**********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return KeyLoader; });\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/*\n * Decrypt key Loader\n */\n\n\n\n\nvar KeyLoader = /*#__PURE__*/function () {\n function KeyLoader(hls) {\n this.hls = void 0;\n this.loaders = {};\n this.decryptkey = null;\n this.decrypturl = null;\n this.hls = hls;\n this.registerListeners();\n }\n\n var _proto = KeyLoader.prototype;\n\n _proto.startLoad = function startLoad(startPosition) {};\n\n _proto.stopLoad = function stopLoad() {\n this.destroyInternalLoaders();\n };\n\n _proto.registerListeners = function registerListeners() {\n this.hls.on(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].KEY_LOADING, this.onKeyLoading, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n this.hls.off(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].KEY_LOADING, this.onKeyLoading);\n };\n\n _proto.destroyInternalLoaders = function destroyInternalLoaders() {\n for (var loaderName in this.loaders) {\n var loader = this.loaders[loaderName];\n\n if (loader) {\n loader.destroy();\n }\n }\n\n this.loaders = {};\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.destroyInternalLoaders();\n };\n\n _proto.onKeyLoading = function onKeyLoading(event, data) {\n var frag = data.frag;\n var type = frag.type;\n var loader = this.loaders[type];\n\n if (!frag.decryptdata) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('Missing decryption data on fragment in onKeyLoading');\n return;\n } // Load the key if the uri is different from previous one, or if the decrypt key has not yet been retrieved\n\n\n var uri = frag.decryptdata.uri;\n\n if (uri !== this.decrypturl || this.decryptkey === null) {\n var config = this.hls.config;\n\n if (loader) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn(\"abort previous key loader for type:\" + type);\n loader.abort();\n }\n\n if (!uri) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].warn('key uri is falsy');\n return;\n }\n\n var Loader = config.loader;\n var fragLoader = frag.loader = this.loaders[type] = new Loader(config);\n this.decrypturl = uri;\n this.decryptkey = null;\n var loaderContext = {\n url: uri,\n frag: frag,\n responseType: 'arraybuffer'\n }; // maxRetry is 0 so that instead of retrying the same key on the same variant multiple times,\n // key-loader will trigger an error and rely on stream-controller to handle retry logic.\n // this will also align retry logic with fragment-loader\n\n var loaderConfig = {\n timeout: config.fragLoadingTimeOut,\n maxRetry: 0,\n retryDelay: config.fragLoadingRetryDelay,\n maxRetryDelay: config.fragLoadingMaxRetryTimeout,\n highWaterMark: 0\n };\n var loaderCallbacks = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n };\n fragLoader.load(loaderContext, loaderConfig, loaderCallbacks);\n } else if (this.decryptkey) {\n // Return the key if it's already been loaded\n frag.decryptdata.key = this.decryptkey;\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].KEY_LOADED, {\n frag: frag\n });\n }\n };\n\n _proto.loadsuccess = function loadsuccess(response, stats, context) {\n var frag = context.frag;\n\n if (!frag.decryptdata) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_2__[\"logger\"].error('after key load, decryptdata unset');\n return;\n }\n\n this.decryptkey = frag.decryptdata.key = new Uint8Array(response.data); // detach fragment loader on load success\n\n frag.loader = null;\n delete this.loaders[frag.type];\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].KEY_LOADED, {\n frag: frag\n });\n };\n\n _proto.loaderror = function loaderror(response, context) {\n var frag = context.frag;\n var loader = frag.loader;\n\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_LOAD_ERROR,\n fatal: false,\n frag: frag,\n response: response\n });\n };\n\n _proto.loadtimeout = function loadtimeout(stats, context) {\n var frag = context.frag;\n var loader = frag.loader;\n\n if (loader) {\n loader.abort();\n }\n\n delete this.loaders[frag.type];\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_0__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_1__[\"ErrorDetails\"].KEY_LOAD_TIMEOUT,\n fatal: false,\n frag: frag\n });\n };\n\n return KeyLoader;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/loader/level-details.ts\":\n/*!*************************************!*\\\n !*** ./src/loader/level-details.ts ***!\n \\*************************************/\n/*! exports provided: LevelDetails */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"LevelDetails\", function() { return LevelDetails; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n\n\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nvar DEFAULT_TARGET_DURATION = 10;\nvar LevelDetails = /*#__PURE__*/function () {\n // Manifest reload synchronization\n function LevelDetails(baseUrl) {\n this.PTSKnown = false;\n this.alignedSliding = false;\n this.averagetargetduration = void 0;\n this.endCC = 0;\n this.endSN = 0;\n this.fragments = void 0;\n this.fragmentHint = void 0;\n this.partList = null;\n this.dateRanges = void 0;\n this.live = true;\n this.ageHeader = 0;\n this.advancedDateTime = void 0;\n this.updated = true;\n this.advanced = true;\n this.availabilityDelay = void 0;\n this.misses = 0;\n this.needSidxRanges = false;\n this.startCC = 0;\n this.startSN = 0;\n this.startTimeOffset = null;\n this.targetduration = 0;\n this.totalduration = 0;\n this.type = null;\n this.url = void 0;\n this.m3u8 = '';\n this.version = null;\n this.canBlockReload = false;\n this.canSkipUntil = 0;\n this.canSkipDateRanges = false;\n this.skippedSegments = 0;\n this.recentlyRemovedDateranges = void 0;\n this.partHoldBack = 0;\n this.holdBack = 0;\n this.partTarget = 0;\n this.preloadHint = void 0;\n this.renditionReports = void 0;\n this.tuneInGoal = 0;\n this.deltaUpdateFailed = void 0;\n this.driftStartTime = 0;\n this.driftEndTime = 0;\n this.driftStart = 0;\n this.driftEnd = 0;\n this.fragments = [];\n this.dateRanges = {};\n this.url = baseUrl;\n }\n\n var _proto = LevelDetails.prototype;\n\n _proto.reloaded = function reloaded(previous) {\n if (!previous) {\n this.advanced = true;\n this.updated = true;\n return;\n }\n\n var partSnDiff = this.lastPartSn - previous.lastPartSn;\n var partIndexDiff = this.lastPartIndex - previous.lastPartIndex;\n this.updated = this.endSN !== previous.endSN || !!partIndexDiff || !!partSnDiff;\n this.advanced = this.endSN > previous.endSN || partSnDiff > 0 || partSnDiff === 0 && partIndexDiff > 0;\n\n if (this.updated || this.advanced) {\n this.misses = Math.floor(previous.misses * 0.6);\n } else {\n this.misses = previous.misses + 1;\n }\n\n this.availabilityDelay = previous.availabilityDelay;\n };\n\n _createClass(LevelDetails, [{\n key: \"hasProgramDateTime\",\n get: function get() {\n if (this.fragments.length) {\n return Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this.fragments[this.fragments.length - 1].programDateTime);\n }\n\n return false;\n }\n }, {\n key: \"levelTargetDuration\",\n get: function get() {\n return this.averagetargetduration || this.targetduration || DEFAULT_TARGET_DURATION;\n }\n }, {\n key: \"drift\",\n get: function get() {\n var runTime = this.driftEndTime - this.driftStartTime;\n\n if (runTime > 0) {\n var runDuration = this.driftEnd - this.driftStart;\n return runDuration * 1000 / runTime;\n }\n\n return 1;\n }\n }, {\n key: \"edge\",\n get: function get() {\n return this.partEnd || this.fragmentEnd;\n }\n }, {\n key: \"partEnd\",\n get: function get() {\n var _this$partList;\n\n if ((_this$partList = this.partList) !== null && _this$partList !== void 0 && _this$partList.length) {\n return this.partList[this.partList.length - 1].end;\n }\n\n return this.fragmentEnd;\n }\n }, {\n key: \"fragmentEnd\",\n get: function get() {\n var _this$fragments;\n\n if ((_this$fragments = this.fragments) !== null && _this$fragments !== void 0 && _this$fragments.length) {\n return this.fragments[this.fragments.length - 1].end;\n }\n\n return 0;\n }\n }, {\n key: \"age\",\n get: function get() {\n if (this.advancedDateTime) {\n return Math.max(Date.now() - this.advancedDateTime, 0) / 1000;\n }\n\n return 0;\n }\n }, {\n key: \"lastPartIndex\",\n get: function get() {\n var _this$partList2;\n\n if ((_this$partList2 = this.partList) !== null && _this$partList2 !== void 0 && _this$partList2.length) {\n return this.partList[this.partList.length - 1].index;\n }\n\n return -1;\n }\n }, {\n key: \"lastPartSn\",\n get: function get() {\n var _this$partList3;\n\n if ((_this$partList3 = this.partList) !== null && _this$partList3 !== void 0 && _this$partList3.length) {\n return this.partList[this.partList.length - 1].fragment.sn;\n }\n\n return this.endSN;\n }\n }]);\n\n return LevelDetails;\n}();\n\n/***/ }),\n\n/***/ \"./src/loader/level-key.ts\":\n/*!*********************************!*\\\n !*** ./src/loader/level-key.ts ***!\n \\*********************************/\n/*! exports provided: LevelKey */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"LevelKey\", function() { return LevelKey; });\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! url-toolkit */ \"./node_modules/url-toolkit/src/url-toolkit.js\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(url_toolkit__WEBPACK_IMPORTED_MODULE_0__);\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\n\nvar LevelKey = /*#__PURE__*/function () {\n LevelKey.fromURL = function fromURL(baseUrl, relativeUrl) {\n return new LevelKey(baseUrl, relativeUrl);\n };\n\n LevelKey.fromURI = function fromURI(uri) {\n return new LevelKey(uri);\n };\n\n function LevelKey(absoluteOrBaseURI, relativeURL) {\n this._uri = null;\n this.method = null;\n this.keyFormat = null;\n this.keyFormatVersions = null;\n this.keyID = null;\n this.key = null;\n this.iv = null;\n\n if (relativeURL) {\n this._uri = Object(url_toolkit__WEBPACK_IMPORTED_MODULE_0__[\"buildAbsoluteURL\"])(absoluteOrBaseURI, relativeURL, {\n alwaysNormalize: true\n });\n } else {\n this._uri = absoluteOrBaseURI;\n }\n }\n\n _createClass(LevelKey, [{\n key: \"uri\",\n get: function get() {\n return this._uri;\n }\n }]);\n\n return LevelKey;\n}();\n\n/***/ }),\n\n/***/ \"./src/loader/load-stats.ts\":\n/*!**********************************!*\\\n !*** ./src/loader/load-stats.ts ***!\n \\**********************************/\n/*! exports provided: LoadStats */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"LoadStats\", function() { return LoadStats; });\nvar LoadStats = function LoadStats() {\n this.aborted = false;\n this.loaded = 0;\n this.retry = 0;\n this.total = 0;\n this.chunkCount = 0;\n this.bwEstimate = 0;\n this.loading = {\n start: 0,\n first: 0,\n end: 0\n };\n this.parsing = {\n start: 0,\n end: 0\n };\n this.buffering = {\n start: 0,\n first: 0,\n end: 0\n };\n};\n\n/***/ }),\n\n/***/ \"./src/loader/m3u8-parser.ts\":\n/*!***********************************!*\\\n !*** ./src/loader/m3u8-parser.ts ***!\n \\***********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return M3U8Parser; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! url-toolkit */ \"./node_modules/url-toolkit/src/url-toolkit.js\");\n/* harmony import */ var url_toolkit__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(url_toolkit__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _date_range__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./date-range */ \"./src/loader/date-range.ts\");\n/* harmony import */ var _fragment__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _level_details__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./level-details */ \"./src/loader/level-details.ts\");\n/* harmony import */ var _level_key__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./level-key */ \"./src/loader/level-key.ts\");\n/* harmony import */ var _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils/attr-list */ \"./src/utils/attr-list.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _utils_codecs__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../utils/codecs */ \"./src/utils/codecs.ts\");\n\n\n\n\n\n\n\n\n\n\n\n\n// https://regex101.com is your friend\nvar MASTER_PLAYLIST_REGEX = /#EXT-X-STREAM-INF:([^\\r\\n]*)(?:[\\r\\n](?:#[^\\r\\n]*)?)*([^\\r\\n]+)|#EXT-X-SESSION-DATA:([^\\r\\n]*)[\\r\\n]+/g;\nvar MASTER_PLAYLIST_MEDIA_REGEX = /#EXT-X-MEDIA:(.*)/g;\nvar LEVEL_PLAYLIST_REGEX_FAST = new RegExp([/#EXTINF:\\s*(\\d*(?:\\.\\d+)?)(?:,(.*)\\s+)?/.source, // duration (#EXTINF:,), group 1 => duration, group 2 => title\n/(?!#) *(\\S[\\S ]*)/.source, // segment URI, group 3 => the URI (note newline is not eaten)\n/#EXT-X-BYTERANGE:*(.+)/.source, // next segment's byterange, group 4 => range spec (x@y)\n/#EXT-X-PROGRAM-DATE-TIME:(.+)/.source, // next segment's program date/time group 5 => the datetime spec\n/#.*/.source // All other non-segment oriented tags will match with all groups empty\n].join('|'), 'g');\nvar LEVEL_PLAYLIST_REGEX_SLOW = new RegExp([/#(EXTM3U)/.source, /#EXT-X-(DATERANGE|KEY|MAP|PART|PART-INF|PLAYLIST-TYPE|PRELOAD-HINT|RENDITION-REPORT|SERVER-CONTROL|SKIP|START):(.+)/.source, /#EXT-X-(BITRATE|DISCONTINUITY-SEQUENCE|MEDIA-SEQUENCE|TARGETDURATION|VERSION): *(\\d+)/.source, /#EXT-X-(DISCONTINUITY|ENDLIST|GAP)/.source, /(#)([^:]*):(.*)/.source, /(#)(.*)(?:.*)\\r?\\n?/.source].join('|'));\nvar MP4_REGEX_SUFFIX = /\\.(mp4|m4s|m4v|m4a)$/i;\n\nfunction isMP4Url(url) {\n var _URLToolkit$parseURL$, _URLToolkit$parseURL;\n\n return MP4_REGEX_SUFFIX.test((_URLToolkit$parseURL$ = (_URLToolkit$parseURL = url_toolkit__WEBPACK_IMPORTED_MODULE_1__[\"parseURL\"](url)) === null || _URLToolkit$parseURL === void 0 ? void 0 : _URLToolkit$parseURL.path) != null ? _URLToolkit$parseURL$ : '');\n}\n\nvar M3U8Parser = /*#__PURE__*/function () {\n function M3U8Parser() {}\n\n M3U8Parser.findGroup = function findGroup(groups, mediaGroupId) {\n for (var i = 0; i < groups.length; i++) {\n var group = groups[i];\n\n if (group.id === mediaGroupId) {\n return group;\n }\n }\n };\n\n M3U8Parser.convertAVC1ToAVCOTI = function convertAVC1ToAVCOTI(codec) {\n // Convert avc1 codec string from RFC-4281 to RFC-6381 for MediaSource.isTypeSupported\n var avcdata = codec.split('.');\n\n if (avcdata.length > 2) {\n var result = avcdata.shift() + '.';\n result += parseInt(avcdata.shift()).toString(16);\n result += ('000' + parseInt(avcdata.shift()).toString(16)).slice(-4);\n return result;\n }\n\n return codec;\n };\n\n M3U8Parser.resolve = function resolve(url, baseUrl) {\n return url_toolkit__WEBPACK_IMPORTED_MODULE_1__[\"buildAbsoluteURL\"](baseUrl, url, {\n alwaysNormalize: true\n });\n };\n\n M3U8Parser.parseMasterPlaylist = function parseMasterPlaylist(string, baseurl) {\n var levels = [];\n var sessionData = {};\n var hasSessionData = false;\n MASTER_PLAYLIST_REGEX.lastIndex = 0;\n var result;\n\n while ((result = MASTER_PLAYLIST_REGEX.exec(string)) != null) {\n if (result[1]) {\n // '#EXT-X-STREAM-INF' is found, parse level tag in group 1\n var attrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](result[1]);\n var level = {\n attrs: attrs,\n bitrate: attrs.decimalInteger('AVERAGE-BANDWIDTH') || attrs.decimalInteger('BANDWIDTH'),\n name: attrs.NAME,\n url: M3U8Parser.resolve(result[2], baseurl)\n };\n var resolution = attrs.decimalResolution('RESOLUTION');\n\n if (resolution) {\n level.width = resolution.width;\n level.height = resolution.height;\n }\n\n setCodecs((attrs.CODECS || '').split(/[ ,]+/).filter(function (c) {\n return c;\n }), level);\n\n if (level.videoCodec && level.videoCodec.indexOf('avc1') !== -1) {\n level.videoCodec = M3U8Parser.convertAVC1ToAVCOTI(level.videoCodec);\n }\n\n levels.push(level);\n } else if (result[3]) {\n // '#EXT-X-SESSION-DATA' is found, parse session data in group 3\n var sessionAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](result[3]);\n\n if (sessionAttrs['DATA-ID']) {\n hasSessionData = true;\n sessionData[sessionAttrs['DATA-ID']] = sessionAttrs;\n }\n }\n }\n\n return {\n levels: levels,\n sessionData: hasSessionData ? sessionData : null\n };\n };\n\n M3U8Parser.parseMasterPlaylistMedia = function parseMasterPlaylistMedia(string, baseurl, type, groups) {\n if (groups === void 0) {\n groups = [];\n }\n\n var result;\n var medias = [];\n var id = 0;\n MASTER_PLAYLIST_MEDIA_REGEX.lastIndex = 0;\n\n while ((result = MASTER_PLAYLIST_MEDIA_REGEX.exec(string)) !== null) {\n var attrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](result[1]);\n\n if (attrs.TYPE === type) {\n var media = {\n attrs: attrs,\n bitrate: 0,\n id: id++,\n groupId: attrs['GROUP-ID'],\n instreamId: attrs['INSTREAM-ID'],\n name: attrs.NAME || attrs.LANGUAGE || '',\n type: type,\n default: attrs.bool('DEFAULT'),\n autoselect: attrs.bool('AUTOSELECT'),\n forced: attrs.bool('FORCED'),\n lang: attrs.LANGUAGE,\n url: attrs.URI ? M3U8Parser.resolve(attrs.URI, baseurl) : ''\n };\n\n if (groups.length) {\n // If there are audio or text groups signalled in the manifest, let's look for a matching codec string for this track\n // If we don't find the track signalled, lets use the first audio groups codec we have\n // Acting as a best guess\n var groupCodec = M3U8Parser.findGroup(groups, media.groupId) || groups[0];\n assignCodec(media, groupCodec, 'audioCodec');\n assignCodec(media, groupCodec, 'textCodec');\n }\n\n medias.push(media);\n }\n }\n\n return medias;\n };\n\n M3U8Parser.parseLevelPlaylist = function parseLevelPlaylist(string, baseurl, id, type, levelUrlId) {\n var level = new _level_details__WEBPACK_IMPORTED_MODULE_4__[\"LevelDetails\"](baseurl);\n var fragments = level.fragments; // The most recent init segment seen (applies to all subsequent segments)\n\n var currentInitSegment = null;\n var currentSN = 0;\n var currentPart = 0;\n var totalduration = 0;\n var discontinuityCounter = 0;\n var prevFrag = null;\n var frag = new _fragment__WEBPACK_IMPORTED_MODULE_3__[\"Fragment\"](type, baseurl);\n var result;\n var i;\n var levelkey;\n var firstPdtIndex = -1;\n var createNextFrag = false;\n LEVEL_PLAYLIST_REGEX_FAST.lastIndex = 0;\n level.m3u8 = string;\n\n while ((result = LEVEL_PLAYLIST_REGEX_FAST.exec(string)) !== null) {\n if (createNextFrag) {\n createNextFrag = false;\n frag = new _fragment__WEBPACK_IMPORTED_MODULE_3__[\"Fragment\"](type, baseurl); // setup the next fragment for part loading\n\n frag.start = totalduration;\n frag.sn = currentSN;\n frag.cc = discontinuityCounter;\n frag.level = id;\n\n if (currentInitSegment) {\n frag.initSegment = currentInitSegment;\n frag.rawProgramDateTime = currentInitSegment.rawProgramDateTime;\n currentInitSegment.rawProgramDateTime = null;\n }\n }\n\n var duration = result[1];\n\n if (duration) {\n // INF\n frag.duration = parseFloat(duration); // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n\n var title = (' ' + result[2]).slice(1);\n frag.title = title || null;\n frag.tagList.push(title ? ['INF', duration, title] : ['INF', duration]);\n } else if (result[3]) {\n // url\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.duration)) {\n frag.start = totalduration;\n\n if (levelkey) {\n frag.levelkey = levelkey;\n }\n\n frag.sn = currentSN;\n frag.level = id;\n frag.cc = discontinuityCounter;\n frag.urlId = levelUrlId;\n fragments.push(frag); // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n\n frag.relurl = (' ' + result[3]).slice(1);\n assignProgramDateTime(frag, prevFrag);\n prevFrag = frag;\n totalduration += frag.duration;\n currentSN++;\n currentPart = 0;\n createNextFrag = true;\n }\n } else if (result[4]) {\n // X-BYTERANGE\n var data = (' ' + result[4]).slice(1);\n\n if (prevFrag) {\n frag.setByteRange(data, prevFrag);\n } else {\n frag.setByteRange(data);\n }\n } else if (result[5]) {\n // PROGRAM-DATE-TIME\n // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n frag.rawProgramDateTime = (' ' + result[5]).slice(1);\n frag.tagList.push(['PROGRAM-DATE-TIME', frag.rawProgramDateTime]);\n\n if (firstPdtIndex === -1) {\n firstPdtIndex = fragments.length;\n }\n } else {\n result = result[0].match(LEVEL_PLAYLIST_REGEX_SLOW);\n\n if (!result) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_7__[\"logger\"].warn('No matches on slow regex match for level playlist!');\n continue;\n }\n\n for (i = 1; i < result.length; i++) {\n if (typeof result[i] !== 'undefined') {\n break;\n }\n } // avoid sliced strings https://github.com/video-dev/hls.js/issues/939\n\n\n var tag = (' ' + result[i]).slice(1);\n var value1 = (' ' + result[i + 1]).slice(1);\n var value2 = result[i + 2] ? (' ' + result[i + 2]).slice(1) : '';\n\n switch (tag) {\n case 'PLAYLIST-TYPE':\n level.type = value1.toUpperCase();\n break;\n\n case 'MEDIA-SEQUENCE':\n currentSN = level.startSN = parseInt(value1);\n break;\n\n case 'SKIP':\n {\n var skipAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n var skippedSegments = skipAttrs.decimalInteger('SKIPPED-SEGMENTS');\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(skippedSegments)) {\n level.skippedSegments = skippedSegments; // This will result in fragments[] containing undefined values, which we will fill in with `mergeDetails`\n\n for (var _i = skippedSegments; _i--;) {\n fragments.unshift(null);\n }\n\n currentSN += skippedSegments;\n }\n\n var recentlyRemovedDateranges = skipAttrs.enumeratedString('RECENTLY-REMOVED-DATERANGES');\n\n if (recentlyRemovedDateranges) {\n level.recentlyRemovedDateranges = recentlyRemovedDateranges.split('\\t');\n }\n\n break;\n }\n\n case 'TARGETDURATION':\n level.targetduration = parseFloat(value1);\n break;\n\n case 'VERSION':\n level.version = parseInt(value1);\n break;\n\n case 'EXTM3U':\n break;\n\n case 'ENDLIST':\n level.live = false;\n break;\n\n case '#':\n if (value1 || value2) {\n frag.tagList.push(value2 ? [value1, value2] : [value1]);\n }\n\n break;\n\n case 'DISCONTINUITY':\n discontinuityCounter++;\n frag.tagList.push(['DIS']);\n break;\n\n case 'GAP':\n frag.tagList.push([tag]);\n break;\n\n case 'BITRATE':\n frag.tagList.push([tag, value1]);\n break;\n\n case 'DATERANGE':\n {\n var dateRangeAttr = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n var dateRange = new _date_range__WEBPACK_IMPORTED_MODULE_2__[\"DateRange\"](dateRangeAttr, level.dateRanges[dateRangeAttr.ID]);\n\n if (dateRange.isValid || level.skippedSegments) {\n level.dateRanges[dateRange.id] = dateRange;\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_7__[\"logger\"].warn(\"Ignoring invalid DATERANGE tag: \\\"\" + value1 + \"\\\"\");\n } // Add to fragment tag list for backwards compatibility (< v1.2.0)\n\n\n frag.tagList.push(['EXT-X-DATERANGE', value1]);\n break;\n }\n\n case 'DISCONTINUITY-SEQUENCE':\n discontinuityCounter = parseInt(value1);\n break;\n\n case 'KEY':\n {\n var _keyAttrs$enumeratedS;\n\n // https://tools.ietf.org/html/rfc8216#section-4.3.2.4\n var keyAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n var decryptmethod = keyAttrs.enumeratedString('METHOD');\n var decrypturi = keyAttrs.URI;\n var decryptiv = keyAttrs.hexadecimalInteger('IV');\n var decryptkeyformatversions = keyAttrs.enumeratedString('KEYFORMATVERSIONS');\n var decryptkeyid = keyAttrs.enumeratedString('KEYID'); // From RFC: This attribute is OPTIONAL; its absence indicates an implicit value of \"identity\".\n\n var decryptkeyformat = (_keyAttrs$enumeratedS = keyAttrs.enumeratedString('KEYFORMAT')) != null ? _keyAttrs$enumeratedS : 'identity';\n var unsupportedKnownKeyformatsInManifest = ['com.apple.streamingkeydelivery', 'com.microsoft.playready', 'urn:uuid:edef8ba9-79d6-4ace-a3c8-27dcd51d21ed', // widevine (v2)\n 'com.widevine' // earlier widevine (v1)\n ];\n\n if (unsupportedKnownKeyformatsInManifest.indexOf(decryptkeyformat) > -1) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_7__[\"logger\"].warn(\"Keyformat \" + decryptkeyformat + \" is not supported from the manifest\");\n continue;\n } else if (decryptkeyformat !== 'identity') {\n // We are supposed to skip keys we don't understand.\n // As we currently only officially support identity keys\n // from the manifest we shouldn't save any other key.\n continue;\n } // TODO: multiple keys can be defined on a fragment, and we need to support this\n // for clients that support both playready and widevine\n\n\n if (decryptmethod) {\n // TODO: need to determine if the level key is actually a relative URL\n // if it isn't, then we should instead construct the LevelKey using fromURI.\n levelkey = _level_key__WEBPACK_IMPORTED_MODULE_5__[\"LevelKey\"].fromURL(baseurl, decrypturi);\n\n if (decrypturi && ['AES-128', 'SAMPLE-AES', 'SAMPLE-AES-CENC'].indexOf(decryptmethod) >= 0) {\n levelkey.method = decryptmethod;\n levelkey.keyFormat = decryptkeyformat;\n\n if (decryptkeyid) {\n levelkey.keyID = decryptkeyid;\n }\n\n if (decryptkeyformatversions) {\n levelkey.keyFormatVersions = decryptkeyformatversions;\n } // Initialization Vector (IV)\n\n\n levelkey.iv = decryptiv;\n }\n }\n\n break;\n }\n\n case 'START':\n {\n var startAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n var startTimeOffset = startAttrs.decimalFloatingPoint('TIME-OFFSET'); // TIME-OFFSET can be 0\n\n if (Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(startTimeOffset)) {\n level.startTimeOffset = startTimeOffset;\n }\n\n break;\n }\n\n case 'MAP':\n {\n var mapAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n\n if (frag.duration) {\n // Initial segment tag is after segment duration tag.\n // #EXTINF: 6.0\n // #EXT-X-MAP:URI=\"init.mp4\n var init = new _fragment__WEBPACK_IMPORTED_MODULE_3__[\"Fragment\"](type, baseurl);\n setInitSegment(init, mapAttrs, id, levelkey);\n currentInitSegment = init;\n frag.initSegment = currentInitSegment;\n\n if (currentInitSegment.rawProgramDateTime && !frag.rawProgramDateTime) {\n frag.rawProgramDateTime = currentInitSegment.rawProgramDateTime;\n }\n } else {\n // Initial segment tag is before segment duration tag\n setInitSegment(frag, mapAttrs, id, levelkey);\n currentInitSegment = frag;\n createNextFrag = true;\n }\n\n break;\n }\n\n case 'SERVER-CONTROL':\n {\n var serverControlAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n level.canBlockReload = serverControlAttrs.bool('CAN-BLOCK-RELOAD');\n level.canSkipUntil = serverControlAttrs.optionalFloat('CAN-SKIP-UNTIL', 0);\n level.canSkipDateRanges = level.canSkipUntil > 0 && serverControlAttrs.bool('CAN-SKIP-DATERANGES');\n level.partHoldBack = serverControlAttrs.optionalFloat('PART-HOLD-BACK', 0);\n level.holdBack = serverControlAttrs.optionalFloat('HOLD-BACK', 0);\n break;\n }\n\n case 'PART-INF':\n {\n var partInfAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n level.partTarget = partInfAttrs.decimalFloatingPoint('PART-TARGET');\n break;\n }\n\n case 'PART':\n {\n var partList = level.partList;\n\n if (!partList) {\n partList = level.partList = [];\n }\n\n var previousFragmentPart = currentPart > 0 ? partList[partList.length - 1] : undefined;\n var index = currentPart++;\n var part = new _fragment__WEBPACK_IMPORTED_MODULE_3__[\"Part\"](new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1), frag, baseurl, index, previousFragmentPart);\n partList.push(part);\n frag.duration += part.duration;\n break;\n }\n\n case 'PRELOAD-HINT':\n {\n var preloadHintAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n level.preloadHint = preloadHintAttrs;\n break;\n }\n\n case 'RENDITION-REPORT':\n {\n var renditionReportAttrs = new _utils_attr_list__WEBPACK_IMPORTED_MODULE_6__[\"AttrList\"](value1);\n level.renditionReports = level.renditionReports || [];\n level.renditionReports.push(renditionReportAttrs);\n break;\n }\n\n default:\n _utils_logger__WEBPACK_IMPORTED_MODULE_7__[\"logger\"].warn(\"line parsed but not handled: \" + result);\n break;\n }\n }\n }\n\n if (prevFrag && !prevFrag.relurl) {\n fragments.pop();\n totalduration -= prevFrag.duration;\n\n if (level.partList) {\n level.fragmentHint = prevFrag;\n }\n } else if (level.partList) {\n assignProgramDateTime(frag, prevFrag);\n frag.cc = discontinuityCounter;\n level.fragmentHint = frag;\n }\n\n var fragmentLength = fragments.length;\n var firstFragment = fragments[0];\n var lastFragment = fragments[fragmentLength - 1];\n totalduration += level.skippedSegments * level.targetduration;\n\n if (totalduration > 0 && fragmentLength && lastFragment) {\n level.averagetargetduration = totalduration / fragmentLength;\n var lastSn = lastFragment.sn;\n level.endSN = lastSn !== 'initSegment' ? lastSn : 0;\n\n if (firstFragment) {\n level.startCC = firstFragment.cc;\n\n if (!firstFragment.initSegment) {\n // this is a bit lurky but HLS really has no other way to tell us\n // if the fragments are TS or MP4, except if we download them :/\n // but this is to be able to handle SIDX.\n if (level.fragments.every(function (frag) {\n return frag.relurl && isMP4Url(frag.relurl);\n })) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_7__[\"logger\"].warn('MP4 fragments found but no init segment (probably no MAP, incomplete M3U8), trying to fetch SIDX');\n frag = new _fragment__WEBPACK_IMPORTED_MODULE_3__[\"Fragment\"](type, baseurl);\n frag.relurl = lastFragment.relurl;\n frag.level = id;\n frag.sn = 'initSegment';\n firstFragment.initSegment = frag;\n level.needSidxRanges = true;\n }\n }\n }\n } else {\n level.endSN = 0;\n level.startCC = 0;\n }\n\n if (level.fragmentHint) {\n totalduration += level.fragmentHint.duration;\n }\n\n level.totalduration = totalduration;\n level.endCC = discontinuityCounter;\n /**\n * Backfill any missing PDT values\n * \"If the first EXT-X-PROGRAM-DATE-TIME tag in a Playlist appears after\n * one or more Media Segment URIs, the client SHOULD extrapolate\n * backward from that tag (using EXTINF durations and/or media\n * timestamps) to associate dates with those segments.\"\n * We have already extrapolated forward, but all fragments up to the first instance of PDT do not have their PDTs\n * computed.\n */\n\n if (firstPdtIndex > 0) {\n backfillProgramDateTimes(fragments, firstPdtIndex);\n }\n\n return level;\n };\n\n return M3U8Parser;\n}();\n\n\n\nfunction setCodecs(codecs, level) {\n ['video', 'audio', 'text'].forEach(function (type) {\n var filtered = codecs.filter(function (codec) {\n return Object(_utils_codecs__WEBPACK_IMPORTED_MODULE_8__[\"isCodecType\"])(codec, type);\n });\n\n if (filtered.length) {\n var preferred = filtered.filter(function (codec) {\n return codec.lastIndexOf('avc1', 0) === 0 || codec.lastIndexOf('mp4a', 0) === 0;\n });\n level[type + \"Codec\"] = preferred.length > 0 ? preferred[0] : filtered[0]; // remove from list\n\n codecs = codecs.filter(function (codec) {\n return filtered.indexOf(codec) === -1;\n });\n }\n });\n level.unknownCodecs = codecs;\n}\n\nfunction assignCodec(media, groupItem, codecProperty) {\n var codecValue = groupItem[codecProperty];\n\n if (codecValue) {\n media[codecProperty] = codecValue;\n }\n}\n\nfunction backfillProgramDateTimes(fragments, firstPdtIndex) {\n var fragPrev = fragments[firstPdtIndex];\n\n for (var i = firstPdtIndex; i--;) {\n var frag = fragments[i]; // Exit on delta-playlist skipped segments\n\n if (!frag) {\n return;\n }\n\n frag.programDateTime = fragPrev.programDateTime - frag.duration * 1000;\n fragPrev = frag;\n }\n}\n\nfunction assignProgramDateTime(frag, prevFrag) {\n if (frag.rawProgramDateTime) {\n frag.programDateTime = Date.parse(frag.rawProgramDateTime);\n } else if (prevFrag !== null && prevFrag !== void 0 && prevFrag.programDateTime) {\n frag.programDateTime = prevFrag.endProgramDateTime;\n }\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(frag.programDateTime)) {\n frag.programDateTime = null;\n frag.rawProgramDateTime = null;\n }\n}\n\nfunction setInitSegment(frag, mapAttrs, id, levelkey) {\n frag.relurl = mapAttrs.URI;\n\n if (mapAttrs.BYTERANGE) {\n frag.setByteRange(mapAttrs.BYTERANGE);\n }\n\n frag.level = id;\n frag.sn = 'initSegment';\n\n if (levelkey) {\n frag.levelkey = levelkey;\n }\n\n frag.initSegment = null;\n}\n\n/***/ }),\n\n/***/ \"./src/loader/playlist-loader.ts\":\n/*!***************************************!*\\\n !*** ./src/loader/playlist-loader.ts ***!\n \\***************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./m3u8-parser */ \"./src/loader/m3u8-parser.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _utils_attr_list__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../utils/attr-list */ \"./src/utils/attr-list.ts\");\n\n\n\n/**\n * PlaylistLoader - delegate for media manifest/playlist loading tasks. Takes care of parsing media to internal data-models.\n *\n * Once loaded, dispatches events with parsed data-models of manifest/levels/audio/subtitle tracks.\n *\n * Uses loader(s) set in config to do actual internal loading of resource tasks.\n *\n * @module\n *\n */\n\n\n\n\n\n\n\n\nfunction mapContextToLevelType(context) {\n var type = context.type;\n\n switch (type) {\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK:\n return _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK:\n return _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].SUBTITLE;\n\n default:\n return _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].MAIN;\n }\n}\n\nfunction getResponseUrl(response, context) {\n var url = response.url; // responseURL not supported on some browsers (it is used to detect URL redirection)\n // data-uri mode also not supported (but no need to detect redirection)\n\n if (url === undefined || url.indexOf('data:') === 0) {\n // fallback to initial URL\n url = context.url;\n }\n\n return url;\n}\n\nvar PlaylistLoader = /*#__PURE__*/function () {\n function PlaylistLoader(hls) {\n this.hls = void 0;\n this.loaders = Object.create(null);\n this.hls = hls;\n this.registerListeners();\n }\n\n var _proto = PlaylistLoader.prototype;\n\n _proto.startLoad = function startLoad(startPosition) {};\n\n _proto.stopLoad = function stopLoad() {\n this.destroyInternalLoaders();\n };\n\n _proto.registerListeners = function registerListeners() {\n var hls = this.hls;\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].AUDIO_TRACK_LOADING, this.onAudioTrackLoading, this);\n hls.on(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACK_LOADING, this.onSubtitleTrackLoading, this);\n };\n\n _proto.unregisterListeners = function unregisterListeners() {\n var hls = this.hls;\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADING, this.onManifestLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADING, this.onLevelLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].AUDIO_TRACK_LOADING, this.onAudioTrackLoading, this);\n hls.off(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACK_LOADING, this.onSubtitleTrackLoading, this);\n }\n /**\n * Returns defaults or configured loader-type overloads (pLoader and loader config params)\n */\n ;\n\n _proto.createInternalLoader = function createInternalLoader(context) {\n var config = this.hls.config;\n var PLoader = config.pLoader;\n var Loader = config.loader;\n var InternalLoader = PLoader || Loader;\n var loader = new InternalLoader(config);\n context.loader = loader;\n this.loaders[context.type] = loader;\n return loader;\n };\n\n _proto.getInternalLoader = function getInternalLoader(context) {\n return this.loaders[context.type];\n };\n\n _proto.resetInternalLoader = function resetInternalLoader(contextType) {\n if (this.loaders[contextType]) {\n delete this.loaders[contextType];\n }\n }\n /**\n * Call `destroy` on all internal loader instances mapped (one per context type)\n */\n ;\n\n _proto.destroyInternalLoaders = function destroyInternalLoaders() {\n for (var contextType in this.loaders) {\n var loader = this.loaders[contextType];\n\n if (loader) {\n loader.destroy();\n }\n\n this.resetInternalLoader(contextType);\n }\n };\n\n _proto.destroy = function destroy() {\n this.unregisterListeners();\n this.destroyInternalLoaders();\n };\n\n _proto.onManifestLoading = function onManifestLoading(event, data) {\n var url = data.url;\n this.load({\n id: null,\n groupId: null,\n level: 0,\n responseType: 'text',\n type: _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST,\n url: url,\n deliveryDirectives: null\n });\n };\n\n _proto.onLevelLoading = function onLevelLoading(event, data) {\n var id = data.id,\n level = data.level,\n url = data.url,\n deliveryDirectives = data.deliveryDirectives;\n this.load({\n id: id,\n groupId: null,\n level: level,\n responseType: 'text',\n type: _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].LEVEL,\n url: url,\n deliveryDirectives: deliveryDirectives\n });\n };\n\n _proto.onAudioTrackLoading = function onAudioTrackLoading(event, data) {\n var id = data.id,\n groupId = data.groupId,\n url = data.url,\n deliveryDirectives = data.deliveryDirectives;\n this.load({\n id: id,\n groupId: groupId,\n level: null,\n responseType: 'text',\n type: _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK,\n url: url,\n deliveryDirectives: deliveryDirectives\n });\n };\n\n _proto.onSubtitleTrackLoading = function onSubtitleTrackLoading(event, data) {\n var id = data.id,\n groupId = data.groupId,\n url = data.url,\n deliveryDirectives = data.deliveryDirectives;\n this.load({\n id: id,\n groupId: groupId,\n level: null,\n responseType: 'text',\n type: _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK,\n url: url,\n deliveryDirectives: deliveryDirectives\n });\n };\n\n _proto.load = function load(context) {\n var _context$deliveryDire;\n\n var config = this.hls.config; // logger.debug(`[playlist-loader]: Loading playlist of type ${context.type}, level: ${context.level}, id: ${context.id}`);\n // Check if a loader for this context already exists\n\n var loader = this.getInternalLoader(context);\n\n if (loader) {\n var loaderContext = loader.context;\n\n if (loaderContext && loaderContext.url === context.url) {\n // same URL can't overlap\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].trace('[playlist-loader]: playlist request ongoing');\n return;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log(\"[playlist-loader]: aborting previous loader for type: \" + context.type);\n loader.abort();\n }\n\n var maxRetry;\n var timeout;\n var retryDelay;\n var maxRetryDelay; // apply different configs for retries depending on\n // context (manifest, level, audio/subs playlist)\n\n switch (context.type) {\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST:\n maxRetry = config.manifestLoadingMaxRetry;\n timeout = config.manifestLoadingTimeOut;\n retryDelay = config.manifestLoadingRetryDelay;\n maxRetryDelay = config.manifestLoadingMaxRetryTimeout;\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].LEVEL:\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK:\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK:\n // Manage retries in Level/Track Controller\n maxRetry = 0;\n timeout = config.levelLoadingTimeOut;\n break;\n\n default:\n maxRetry = config.levelLoadingMaxRetry;\n timeout = config.levelLoadingTimeOut;\n retryDelay = config.levelLoadingRetryDelay;\n maxRetryDelay = config.levelLoadingMaxRetryTimeout;\n break;\n }\n\n loader = this.createInternalLoader(context); // Override level/track timeout for LL-HLS requests\n // (the default of 10000ms is counter productive to blocking playlist reload requests)\n\n if ((_context$deliveryDire = context.deliveryDirectives) !== null && _context$deliveryDire !== void 0 && _context$deliveryDire.part) {\n var levelDetails;\n\n if (context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].LEVEL && context.level !== null) {\n levelDetails = this.hls.levels[context.level].details;\n } else if (context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK && context.id !== null) {\n levelDetails = this.hls.audioTracks[context.id].details;\n } else if (context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK && context.id !== null) {\n levelDetails = this.hls.subtitleTracks[context.id].details;\n }\n\n if (levelDetails) {\n var partTarget = levelDetails.partTarget;\n var targetDuration = levelDetails.targetduration;\n\n if (partTarget && targetDuration) {\n timeout = Math.min(Math.max(partTarget * 3, targetDuration * 0.8) * 1000, timeout);\n }\n }\n }\n\n var loaderConfig = {\n timeout: timeout,\n maxRetry: maxRetry,\n retryDelay: retryDelay,\n maxRetryDelay: maxRetryDelay,\n highWaterMark: 0\n };\n var loaderCallbacks = {\n onSuccess: this.loadsuccess.bind(this),\n onError: this.loaderror.bind(this),\n onTimeout: this.loadtimeout.bind(this)\n }; // logger.debug(`[playlist-loader]: Calling internal loader delegate for URL: ${context.url}`);\n\n loader.load(context, loaderConfig, loaderCallbacks);\n };\n\n _proto.loadsuccess = function loadsuccess(response, stats, context, networkDetails) {\n if (networkDetails === void 0) {\n networkDetails = null;\n }\n\n if (context.isSidxRequest) {\n this.handleSidxRequest(response, context);\n this.handlePlaylistLoaded(response, stats, context, networkDetails);\n return;\n }\n\n this.resetInternalLoader(context.type);\n var string = response.data; // Validate if it is an M3U8 at all\n\n if (string.indexOf('#EXTM3U') !== 0) {\n this.handleManifestParsingError(response, context, 'no EXTM3U delimiter', networkDetails);\n return;\n }\n\n stats.parsing.start = performance.now(); // Check if chunk-list or master. handle empty chunk list case (first EXTINF not signaled, but TARGETDURATION present)\n\n if (string.indexOf('#EXTINF:') > 0 || string.indexOf('#EXT-X-TARGETDURATION:') > 0) {\n this.handleTrackOrLevelPlaylist(response, stats, context, networkDetails);\n } else {\n this.handleMasterPlaylist(response, stats, context, networkDetails);\n }\n };\n\n _proto.loaderror = function loaderror(response, context, networkDetails) {\n if (networkDetails === void 0) {\n networkDetails = null;\n }\n\n this.handleNetworkError(context, networkDetails, false, response);\n };\n\n _proto.loadtimeout = function loadtimeout(stats, context, networkDetails) {\n if (networkDetails === void 0) {\n networkDetails = null;\n }\n\n this.handleNetworkError(context, networkDetails, true);\n };\n\n _proto.handleMasterPlaylist = function handleMasterPlaylist(response, stats, context, networkDetails) {\n var hls = this.hls;\n var string = response.data;\n var url = getResponseUrl(response, context);\n\n var _M3U8Parser$parseMast = _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__[\"default\"].parseMasterPlaylist(string, url),\n levels = _M3U8Parser$parseMast.levels,\n sessionData = _M3U8Parser$parseMast.sessionData;\n\n if (!levels.length) {\n this.handleManifestParsingError(response, context, 'no level found in manifest', networkDetails);\n return;\n } // multi level playlist, parse level info\n\n\n var audioGroups = levels.map(function (level) {\n return {\n id: level.attrs.AUDIO,\n audioCodec: level.audioCodec\n };\n });\n var subtitleGroups = levels.map(function (level) {\n return {\n id: level.attrs.SUBTITLES,\n textCodec: level.textCodec\n };\n });\n var audioTracks = _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__[\"default\"].parseMasterPlaylistMedia(string, url, 'AUDIO', audioGroups);\n var subtitles = _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__[\"default\"].parseMasterPlaylistMedia(string, url, 'SUBTITLES', subtitleGroups);\n var captions = _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__[\"default\"].parseMasterPlaylistMedia(string, url, 'CLOSED-CAPTIONS');\n\n if (audioTracks.length) {\n // check if we have found an audio track embedded in main playlist (audio track without URI attribute)\n var embeddedAudioFound = audioTracks.some(function (audioTrack) {\n return !audioTrack.url;\n }); // if no embedded audio track defined, but audio codec signaled in quality level,\n // we need to signal this main audio track this could happen with playlists with\n // alt audio rendition in which quality levels (main)\n // contains both audio+video. but with mixed audio track not signaled\n\n if (!embeddedAudioFound && levels[0].audioCodec && !levels[0].attrs.AUDIO) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].log('[playlist-loader]: audio codec signaled in quality level, but no embedded audio track signaled, create one');\n audioTracks.unshift({\n type: 'main',\n name: 'main',\n default: false,\n autoselect: false,\n forced: false,\n id: -1,\n attrs: new _utils_attr_list__WEBPACK_IMPORTED_MODULE_7__[\"AttrList\"]({}),\n bitrate: 0,\n url: ''\n });\n }\n }\n\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, {\n levels: levels,\n audioTracks: audioTracks,\n subtitles: subtitles,\n captions: captions,\n url: url,\n stats: stats,\n networkDetails: networkDetails,\n sessionData: sessionData\n });\n };\n\n _proto.handleTrackOrLevelPlaylist = function handleTrackOrLevelPlaylist(response, stats, context, networkDetails) {\n var hls = this.hls;\n var id = context.id,\n level = context.level,\n type = context.type;\n var url = getResponseUrl(response, context);\n var levelUrlId = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(id) ? id : 0;\n var levelId = Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(level) ? level : levelUrlId;\n var levelType = mapContextToLevelType(context);\n var levelDetails = _m3u8_parser__WEBPACK_IMPORTED_MODULE_5__[\"default\"].parseLevelPlaylist(response.data, url, levelId, levelType, levelUrlId);\n\n if (!levelDetails.fragments.length) {\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_EMPTY_ERROR,\n fatal: false,\n url: url,\n reason: 'no fragments found in level',\n level: typeof context.level === 'number' ? context.level : undefined\n });\n return;\n } // We have done our first request (Manifest-type) and receive\n // not a master playlist but a chunk-list (track/level)\n // We fire the manifest-loaded event anyway with the parsed level-details\n // by creating a single-level structure for it.\n\n\n if (type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST) {\n var singleLevel = {\n attrs: new _utils_attr_list__WEBPACK_IMPORTED_MODULE_7__[\"AttrList\"]({}),\n bitrate: 0,\n details: levelDetails,\n name: '',\n url: url\n };\n hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].MANIFEST_LOADED, {\n levels: [singleLevel],\n audioTracks: [],\n url: url,\n stats: stats,\n networkDetails: networkDetails,\n sessionData: null\n });\n } // save parsing time\n\n\n stats.parsing.end = performance.now(); // in case we need SIDX ranges\n // return early after calling load for\n // the SIDX box.\n\n if (levelDetails.needSidxRanges) {\n var _levelDetails$fragmen;\n\n var sidxUrl = (_levelDetails$fragmen = levelDetails.fragments[0].initSegment) === null || _levelDetails$fragmen === void 0 ? void 0 : _levelDetails$fragmen.url;\n this.load({\n url: sidxUrl,\n isSidxRequest: true,\n type: type,\n level: level,\n levelDetails: levelDetails,\n id: id,\n groupId: null,\n rangeStart: 0,\n rangeEnd: 2048,\n responseType: 'arraybuffer',\n deliveryDirectives: null\n });\n return;\n } // extend the context with the new levelDetails property\n\n\n context.levelDetails = levelDetails;\n this.handlePlaylistLoaded(response, stats, context, networkDetails);\n };\n\n _proto.handleSidxRequest = function handleSidxRequest(response, context) {\n var data = new Uint8Array(response.data);\n var sidxBox = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"findBox\"])(data, ['sidx'])[0]; // if provided fragment does not contain sidx, early return\n\n if (!sidxBox) {\n return;\n }\n\n var sidxInfo = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"parseSegmentIndex\"])(sidxBox);\n\n if (!sidxInfo) {\n return;\n }\n\n var sidxReferences = sidxInfo.references;\n var levelDetails = context.levelDetails;\n sidxReferences.forEach(function (segmentRef, index) {\n var segRefInfo = segmentRef.info;\n var frag = levelDetails.fragments[index];\n\n if (frag.byteRange.length === 0) {\n frag.setByteRange(String(1 + segRefInfo.end - segRefInfo.start) + '@' + String(segRefInfo.start));\n }\n\n if (frag.initSegment) {\n var moovBox = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__[\"findBox\"])(data, ['moov'])[0];\n var moovEndOffset = moovBox ? moovBox.length : null;\n frag.initSegment.setByteRange(String(moovEndOffset) + '@0');\n }\n });\n };\n\n _proto.handleManifestParsingError = function handleManifestParsingError(response, context, reason, networkDetails) {\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorTypes\"].NETWORK_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].MANIFEST_PARSING_ERROR,\n fatal: context.type === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST,\n url: response.url,\n reason: reason,\n response: response,\n context: context,\n networkDetails: networkDetails\n });\n };\n\n _proto.handleNetworkError = function handleNetworkError(context, networkDetails, timeout, response) {\n if (timeout === void 0) {\n timeout = false;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_3__[\"logger\"].warn(\"[playlist-loader]: A network \" + (timeout ? 'timeout' : 'error') + \" occurred while loading \" + context.type + \" level: \" + context.level + \" id: \" + context.id + \" group-id: \\\"\" + context.groupId + \"\\\"\");\n var details = _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].UNKNOWN;\n var fatal = false;\n var loader = this.getInternalLoader(context);\n\n switch (context.type) {\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST:\n details = timeout ? _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].MANIFEST_LOAD_TIMEOUT : _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].MANIFEST_LOAD_ERROR;\n fatal = true;\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].LEVEL:\n details = timeout ? _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_LOAD_TIMEOUT : _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].LEVEL_LOAD_ERROR;\n fatal = false;\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK:\n details = timeout ? _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].AUDIO_TRACK_LOAD_TIMEOUT : _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].AUDIO_TRACK_LOAD_ERROR;\n fatal = false;\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK:\n details = timeout ? _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].SUBTITLE_TRACK_LOAD_TIMEOUT : _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorDetails\"].SUBTITLE_LOAD_ERROR;\n fatal = false;\n break;\n }\n\n if (loader) {\n this.resetInternalLoader(context.type);\n }\n\n var errorData = {\n type: _errors__WEBPACK_IMPORTED_MODULE_2__[\"ErrorTypes\"].NETWORK_ERROR,\n details: details,\n fatal: fatal,\n url: context.url,\n loader: loader,\n context: context,\n networkDetails: networkDetails\n };\n\n if (response) {\n errorData.response = response;\n }\n\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].ERROR, errorData);\n };\n\n _proto.handlePlaylistLoaded = function handlePlaylistLoaded(response, stats, context, networkDetails) {\n var type = context.type,\n level = context.level,\n id = context.id,\n groupId = context.groupId,\n loader = context.loader,\n levelDetails = context.levelDetails,\n deliveryDirectives = context.deliveryDirectives;\n\n if (!(levelDetails !== null && levelDetails !== void 0 && levelDetails.targetduration)) {\n this.handleManifestParsingError(response, context, 'invalid target duration', networkDetails);\n return;\n }\n\n if (!loader) {\n return;\n }\n\n if (levelDetails.live) {\n if (loader.getCacheAge) {\n levelDetails.ageHeader = loader.getCacheAge() || 0;\n }\n\n if (!loader.getCacheAge || isNaN(levelDetails.ageHeader)) {\n levelDetails.ageHeader = 0;\n }\n }\n\n switch (type) {\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].MANIFEST:\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].LEVEL:\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].LEVEL_LOADED, {\n details: levelDetails,\n level: level || 0,\n id: id || 0,\n stats: stats,\n networkDetails: networkDetails,\n deliveryDirectives: deliveryDirectives\n });\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].AUDIO_TRACK:\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].AUDIO_TRACK_LOADED, {\n details: levelDetails,\n id: id || 0,\n groupId: groupId || '',\n stats: stats,\n networkDetails: networkDetails,\n deliveryDirectives: deliveryDirectives\n });\n break;\n\n case _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistContextType\"].SUBTITLE_TRACK:\n this.hls.trigger(_events__WEBPACK_IMPORTED_MODULE_1__[\"Events\"].SUBTITLE_TRACK_LOADED, {\n details: levelDetails,\n id: id || 0,\n groupId: groupId || '',\n stats: stats,\n networkDetails: networkDetails,\n deliveryDirectives: deliveryDirectives\n });\n break;\n }\n };\n\n return PlaylistLoader;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (PlaylistLoader);\n\n/***/ }),\n\n/***/ \"./src/polyfills/number.ts\":\n/*!*********************************!*\\\n !*** ./src/polyfills/number.ts ***!\n \\*********************************/\n/*! exports provided: isFiniteNumber, MAX_SAFE_INTEGER */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isFiniteNumber\", function() { return isFiniteNumber; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MAX_SAFE_INTEGER\", function() { return MAX_SAFE_INTEGER; });\nvar isFiniteNumber = Number.isFinite || function (value) {\n return typeof value === 'number' && isFinite(value);\n};\nvar MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER || 9007199254740991;\n\n/***/ }),\n\n/***/ \"./src/remux/aac-helper.ts\":\n/*!*********************************!*\\\n !*** ./src/remux/aac-helper.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/**\n * AAC helper\n */\nvar AAC = /*#__PURE__*/function () {\n function AAC() {}\n\n AAC.getSilentFrame = function getSilentFrame(codec, channelCount) {\n switch (codec) {\n case 'mp4a.40.2':\n if (channelCount === 1) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x23, 0x80]);\n } else if (channelCount === 2) {\n return new Uint8Array([0x21, 0x00, 0x49, 0x90, 0x02, 0x19, 0x00, 0x23, 0x80]);\n } else if (channelCount === 3) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x8e]);\n } else if (channelCount === 4) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x80, 0x2c, 0x80, 0x08, 0x02, 0x38]);\n } else if (channelCount === 5) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x38]);\n } else if (channelCount === 6) {\n return new Uint8Array([0x00, 0xc8, 0x00, 0x80, 0x20, 0x84, 0x01, 0x26, 0x40, 0x08, 0x64, 0x00, 0x82, 0x30, 0x04, 0x99, 0x00, 0x21, 0x90, 0x02, 0x00, 0xb2, 0x00, 0x20, 0x08, 0xe0]);\n }\n\n break;\n // handle HE-AAC below (mp4a.40.5 / mp4a.40.29)\n\n default:\n if (channelCount === 1) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0:d=0.05\" -c:a libfdk_aac -profile:a aac_he -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x4e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x1c, 0x6, 0xf1, 0xc1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 2) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n } else if (channelCount === 3) {\n // ffmpeg -y -f lavfi -i \"aevalsrc=0|0|0:d=0.05\" -c:a libfdk_aac -profile:a aac_he_v2 -b:a 4k output.aac && hexdump -v -e '16/1 \"0x%x,\" \"\\n\"' -v output.aac\n return new Uint8Array([0x1, 0x40, 0x22, 0x80, 0xa3, 0x5e, 0xe6, 0x80, 0xba, 0x8, 0x0, 0x0, 0x0, 0x0, 0x95, 0x0, 0x6, 0xf1, 0xa1, 0xa, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5a, 0x5e]);\n }\n\n break;\n }\n\n return undefined;\n };\n\n return AAC;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (AAC);\n\n/***/ }),\n\n/***/ \"./src/remux/mp4-generator.ts\":\n/*!************************************!*\\\n !*** ./src/remux/mp4-generator.ts ***!\n \\************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/**\n * Generate MP4 Box\n */\nvar UINT32_MAX = Math.pow(2, 32) - 1;\n\nvar MP4 = /*#__PURE__*/function () {\n function MP4() {}\n\n MP4.init = function init() {\n MP4.types = {\n avc1: [],\n // codingname\n avcC: [],\n btrt: [],\n dinf: [],\n dref: [],\n esds: [],\n ftyp: [],\n hdlr: [],\n mdat: [],\n mdhd: [],\n mdia: [],\n mfhd: [],\n minf: [],\n moof: [],\n moov: [],\n mp4a: [],\n '.mp3': [],\n mvex: [],\n mvhd: [],\n pasp: [],\n sdtp: [],\n stbl: [],\n stco: [],\n stsc: [],\n stsd: [],\n stsz: [],\n stts: [],\n tfdt: [],\n tfhd: [],\n traf: [],\n trak: [],\n trun: [],\n trex: [],\n tkhd: [],\n vmhd: [],\n smhd: []\n };\n var i;\n\n for (i in MP4.types) {\n if (MP4.types.hasOwnProperty(i)) {\n MP4.types[i] = [i.charCodeAt(0), i.charCodeAt(1), i.charCodeAt(2), i.charCodeAt(3)];\n }\n }\n\n var videoHdlr = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x76, 0x69, 0x64, 0x65, // handler_type: 'vide'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x56, 0x69, 0x64, 0x65, 0x6f, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'VideoHandler'\n ]);\n var audioHdlr = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0x73, 0x6f, 0x75, 0x6e, // handler_type: 'soun'\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x53, 0x6f, 0x75, 0x6e, 0x64, 0x48, 0x61, 0x6e, 0x64, 0x6c, 0x65, 0x72, 0x00 // name: 'SoundHandler'\n ]);\n MP4.HDLR_TYPES = {\n video: videoHdlr,\n audio: audioHdlr\n };\n var dref = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01, // entry_count\n 0x00, 0x00, 0x00, 0x0c, // entry_size\n 0x75, 0x72, 0x6c, 0x20, // 'url' type\n 0x00, // version 0\n 0x00, 0x00, 0x01 // entry_flags\n ]);\n var stco = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00 // entry_count\n ]);\n MP4.STTS = MP4.STSC = MP4.STCO = stco;\n MP4.STSZ = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, // sample_size\n 0x00, 0x00, 0x00, 0x00 // sample_count\n ]);\n MP4.VMHD = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x01, // flags\n 0x00, 0x00, // graphicsmode\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 // opcolor\n ]);\n MP4.SMHD = new Uint8Array([0x00, // version\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, // balance\n 0x00, 0x00 // reserved\n ]);\n MP4.STSD = new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x01]); // entry_count\n\n var majorBrand = new Uint8Array([105, 115, 111, 109]); // isom\n\n var avc1Brand = new Uint8Array([97, 118, 99, 49]); // avc1\n\n var minorVersion = new Uint8Array([0, 0, 0, 1]);\n MP4.FTYP = MP4.box(MP4.types.ftyp, majorBrand, minorVersion, majorBrand, avc1Brand);\n MP4.DINF = MP4.box(MP4.types.dinf, MP4.box(MP4.types.dref, dref));\n };\n\n MP4.box = function box(type) {\n var size = 8;\n\n for (var _len = arguments.length, payload = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n payload[_key - 1] = arguments[_key];\n }\n\n var i = payload.length;\n var len = i; // calculate the total size we need to allocate\n\n while (i--) {\n size += payload[i].byteLength;\n }\n\n var result = new Uint8Array(size);\n result[0] = size >> 24 & 0xff;\n result[1] = size >> 16 & 0xff;\n result[2] = size >> 8 & 0xff;\n result[3] = size & 0xff;\n result.set(type, 4); // copy the payload into the result\n\n for (i = 0, size = 8; i < len; i++) {\n // copy payload[i] array @ offset size\n result.set(payload[i], size);\n size += payload[i].byteLength;\n }\n\n return result;\n };\n\n MP4.hdlr = function hdlr(type) {\n return MP4.box(MP4.types.hdlr, MP4.HDLR_TYPES[type]);\n };\n\n MP4.mdat = function mdat(data) {\n return MP4.box(MP4.types.mdat, data);\n };\n\n MP4.mdhd = function mdhd(timescale, duration) {\n duration *= timescale;\n var upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n var lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.mdhd, new Uint8Array([0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n timescale >> 24 & 0xff, timescale >> 16 & 0xff, timescale >> 8 & 0xff, timescale & 0xff, // timescale\n upperWordDuration >> 24, upperWordDuration >> 16 & 0xff, upperWordDuration >> 8 & 0xff, upperWordDuration & 0xff, lowerWordDuration >> 24, lowerWordDuration >> 16 & 0xff, lowerWordDuration >> 8 & 0xff, lowerWordDuration & 0xff, 0x55, 0xc4, // 'und' language (undetermined)\n 0x00, 0x00]));\n };\n\n MP4.mdia = function mdia(track) {\n return MP4.box(MP4.types.mdia, MP4.mdhd(track.timescale, track.duration), MP4.hdlr(track.type), MP4.minf(track));\n };\n\n MP4.mfhd = function mfhd(sequenceNumber) {\n return MP4.box(MP4.types.mfhd, new Uint8Array([0x00, 0x00, 0x00, 0x00, // flags\n sequenceNumber >> 24, sequenceNumber >> 16 & 0xff, sequenceNumber >> 8 & 0xff, sequenceNumber & 0xff // sequence_number\n ]));\n };\n\n MP4.minf = function minf(track) {\n if (track.type === 'audio') {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.smhd, MP4.SMHD), MP4.DINF, MP4.stbl(track));\n } else {\n return MP4.box(MP4.types.minf, MP4.box(MP4.types.vmhd, MP4.VMHD), MP4.DINF, MP4.stbl(track));\n }\n };\n\n MP4.moof = function moof(sn, baseMediaDecodeTime, track) {\n return MP4.box(MP4.types.moof, MP4.mfhd(sn), MP4.traf(track, baseMediaDecodeTime));\n }\n /**\n * @param tracks... (optional) {array} the tracks associated with this movie\n */\n ;\n\n MP4.moov = function moov(tracks) {\n var i = tracks.length;\n var boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trak(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.moov, MP4.mvhd(tracks[0].timescale, tracks[0].duration)].concat(boxes).concat(MP4.mvex(tracks)));\n };\n\n MP4.mvex = function mvex(tracks) {\n var i = tracks.length;\n var boxes = [];\n\n while (i--) {\n boxes[i] = MP4.trex(tracks[i]);\n }\n\n return MP4.box.apply(null, [MP4.types.mvex].concat(boxes));\n };\n\n MP4.mvhd = function mvhd(timescale, duration) {\n duration *= timescale;\n var upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n var lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n var bytes = new Uint8Array([0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n timescale >> 24 & 0xff, timescale >> 16 & 0xff, timescale >> 8 & 0xff, timescale & 0xff, // timescale\n upperWordDuration >> 24, upperWordDuration >> 16 & 0xff, upperWordDuration >> 8 & 0xff, upperWordDuration & 0xff, lowerWordDuration >> 24, lowerWordDuration >> 16 & 0xff, lowerWordDuration >> 8 & 0xff, lowerWordDuration & 0xff, 0x00, 0x01, 0x00, 0x00, // 1.0 rate\n 0x01, 0x00, // 1.0 volume\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined\n 0xff, 0xff, 0xff, 0xff // next_track_ID\n ]);\n return MP4.box(MP4.types.mvhd, bytes);\n };\n\n MP4.sdtp = function sdtp(track) {\n var samples = track.samples || [];\n var bytes = new Uint8Array(4 + samples.length);\n var i;\n var flags; // leave the full box header (4 bytes) all zero\n // write the sample table\n\n for (i = 0; i < samples.length; i++) {\n flags = samples[i].flags;\n bytes[i + 4] = flags.dependsOn << 4 | flags.isDependedOn << 2 | flags.hasRedundancy;\n }\n\n return MP4.box(MP4.types.sdtp, bytes);\n };\n\n MP4.stbl = function stbl(track) {\n return MP4.box(MP4.types.stbl, MP4.stsd(track), MP4.box(MP4.types.stts, MP4.STTS), MP4.box(MP4.types.stsc, MP4.STSC), MP4.box(MP4.types.stsz, MP4.STSZ), MP4.box(MP4.types.stco, MP4.STCO));\n };\n\n MP4.avc1 = function avc1(track) {\n var sps = [];\n var pps = [];\n var i;\n var data;\n var len; // assemble the SPSs\n\n for (i = 0; i < track.sps.length; i++) {\n data = track.sps[i];\n len = data.byteLength;\n sps.push(len >>> 8 & 0xff);\n sps.push(len & 0xff); // SPS\n\n sps = sps.concat(Array.prototype.slice.call(data));\n } // assemble the PPSs\n\n\n for (i = 0; i < track.pps.length; i++) {\n data = track.pps[i];\n len = data.byteLength;\n pps.push(len >>> 8 & 0xff);\n pps.push(len & 0xff);\n pps = pps.concat(Array.prototype.slice.call(data));\n }\n\n var avcc = MP4.box(MP4.types.avcC, new Uint8Array([0x01, // version\n sps[3], // profile\n sps[4], // profile compat\n sps[5], // level\n 0xfc | 3, // lengthSizeMinusOne, hard-coded to 4 bytes\n 0xe0 | track.sps.length // 3bit reserved (111) + numOfSequenceParameterSets\n ].concat(sps).concat([track.pps.length // numOfPictureParameterSets\n ]).concat(pps))); // \"PPS\"\n\n var width = track.width;\n var height = track.height;\n var hSpacing = track.pixelRatio[0];\n var vSpacing = track.pixelRatio[1];\n return MP4.box(MP4.types.avc1, new Uint8Array([0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, // pre_defined\n 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // pre_defined\n width >> 8 & 0xff, width & 0xff, // width\n height >> 8 & 0xff, height & 0xff, // height\n 0x00, 0x48, 0x00, 0x00, // horizresolution\n 0x00, 0x48, 0x00, 0x00, // vertresolution\n 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // frame_count\n 0x12, 0x64, 0x61, 0x69, 0x6c, // dailymotion/hls.js\n 0x79, 0x6d, 0x6f, 0x74, 0x69, 0x6f, 0x6e, 0x2f, 0x68, 0x6c, 0x73, 0x2e, 0x6a, 0x73, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // compressorname\n 0x00, 0x18, // depth = 24\n 0x11, 0x11]), // pre_defined = -1\n avcc, MP4.box(MP4.types.btrt, new Uint8Array([0x00, 0x1c, 0x9c, 0x80, // bufferSizeDB\n 0x00, 0x2d, 0xc6, 0xc0, // maxBitrate\n 0x00, 0x2d, 0xc6, 0xc0])), // avgBitrate\n MP4.box(MP4.types.pasp, new Uint8Array([hSpacing >> 24, // hSpacing\n hSpacing >> 16 & 0xff, hSpacing >> 8 & 0xff, hSpacing & 0xff, vSpacing >> 24, // vSpacing\n vSpacing >> 16 & 0xff, vSpacing >> 8 & 0xff, vSpacing & 0xff])));\n };\n\n MP4.esds = function esds(track) {\n var configlen = track.config.length;\n return new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n 0x03, // descriptor_type\n 0x17 + configlen, // length\n 0x00, 0x01, // es_id\n 0x00, // stream_priority\n 0x04, // descriptor_type\n 0x0f + configlen, // length\n 0x40, // codec : mpeg4_audio\n 0x15, // stream_type\n 0x00, 0x00, 0x00, // buffer_size\n 0x00, 0x00, 0x00, 0x00, // maxBitrate\n 0x00, 0x00, 0x00, 0x00, // avgBitrate\n 0x05 // descriptor_type\n ].concat([configlen]).concat(track.config).concat([0x06, 0x01, 0x02])); // GASpecificConfig)); // length + audio config descriptor\n };\n\n MP4.mp4a = function mp4a(track) {\n var samplerate = track.samplerate;\n return MP4.box(MP4.types.mp4a, new Uint8Array([0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n samplerate >> 8 & 0xff, samplerate & 0xff, //\n 0x00, 0x00]), MP4.box(MP4.types.esds, MP4.esds(track)));\n };\n\n MP4.mp3 = function mp3(track) {\n var samplerate = track.samplerate;\n return MP4.box(MP4.types['.mp3'], new Uint8Array([0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, 0x00, // reserved\n 0x00, 0x01, // data_reference_index\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, track.channelCount, // channelcount\n 0x00, 0x10, // sampleSize:16bits\n 0x00, 0x00, 0x00, 0x00, // reserved2\n samplerate >> 8 & 0xff, samplerate & 0xff, //\n 0x00, 0x00]));\n };\n\n MP4.stsd = function stsd(track) {\n if (track.type === 'audio') {\n if (track.segmentCodec === 'mp3' && track.codec === 'mp3') {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp3(track));\n }\n\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.mp4a(track));\n } else {\n return MP4.box(MP4.types.stsd, MP4.STSD, MP4.avc1(track));\n }\n };\n\n MP4.tkhd = function tkhd(track) {\n var id = track.id;\n var duration = track.duration * track.timescale;\n var width = track.width;\n var height = track.height;\n var upperWordDuration = Math.floor(duration / (UINT32_MAX + 1));\n var lowerWordDuration = Math.floor(duration % (UINT32_MAX + 1));\n return MP4.box(MP4.types.tkhd, new Uint8Array([0x01, // version 1\n 0x00, 0x00, 0x07, // flags\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, // creation_time\n 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, // modification_time\n id >> 24 & 0xff, id >> 16 & 0xff, id >> 8 & 0xff, id & 0xff, // track_ID\n 0x00, 0x00, 0x00, 0x00, // reserved\n upperWordDuration >> 24, upperWordDuration >> 16 & 0xff, upperWordDuration >> 8 & 0xff, upperWordDuration & 0xff, lowerWordDuration >> 24, lowerWordDuration >> 16 & 0xff, lowerWordDuration >> 8 & 0xff, lowerWordDuration & 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, // reserved\n 0x00, 0x00, // layer\n 0x00, 0x00, // alternate_group\n 0x00, 0x00, // non-audio track volume\n 0x00, 0x00, // reserved\n 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x40, 0x00, 0x00, 0x00, // transformation: unity matrix\n width >> 8 & 0xff, width & 0xff, 0x00, 0x00, // width\n height >> 8 & 0xff, height & 0xff, 0x00, 0x00 // height\n ]));\n };\n\n MP4.traf = function traf(track, baseMediaDecodeTime) {\n var sampleDependencyTable = MP4.sdtp(track);\n var id = track.id;\n var upperWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1));\n var lowerWordBaseMediaDecodeTime = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n return MP4.box(MP4.types.traf, MP4.box(MP4.types.tfhd, new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n id >> 24, id >> 16 & 0xff, id >> 8 & 0xff, id & 0xff // track_ID\n ])), MP4.box(MP4.types.tfdt, new Uint8Array([0x01, // version 1\n 0x00, 0x00, 0x00, // flags\n upperWordBaseMediaDecodeTime >> 24, upperWordBaseMediaDecodeTime >> 16 & 0xff, upperWordBaseMediaDecodeTime >> 8 & 0xff, upperWordBaseMediaDecodeTime & 0xff, lowerWordBaseMediaDecodeTime >> 24, lowerWordBaseMediaDecodeTime >> 16 & 0xff, lowerWordBaseMediaDecodeTime >> 8 & 0xff, lowerWordBaseMediaDecodeTime & 0xff])), MP4.trun(track, sampleDependencyTable.length + 16 + // tfhd\n 20 + // tfdt\n 8 + // traf header\n 16 + // mfhd\n 8 + // moof header\n 8), // mdat header\n sampleDependencyTable);\n }\n /**\n * Generate a track box.\n * @param track {object} a track definition\n * @return {Uint8Array} the track box\n */\n ;\n\n MP4.trak = function trak(track) {\n track.duration = track.duration || 0xffffffff;\n return MP4.box(MP4.types.trak, MP4.tkhd(track), MP4.mdia(track));\n };\n\n MP4.trex = function trex(track) {\n var id = track.id;\n return MP4.box(MP4.types.trex, new Uint8Array([0x00, // version 0\n 0x00, 0x00, 0x00, // flags\n id >> 24, id >> 16 & 0xff, id >> 8 & 0xff, id & 0xff, // track_ID\n 0x00, 0x00, 0x00, 0x01, // default_sample_description_index\n 0x00, 0x00, 0x00, 0x00, // default_sample_duration\n 0x00, 0x00, 0x00, 0x00, // default_sample_size\n 0x00, 0x01, 0x00, 0x01 // default_sample_flags\n ]));\n };\n\n MP4.trun = function trun(track, offset) {\n var samples = track.samples || [];\n var len = samples.length;\n var arraylen = 12 + 16 * len;\n var array = new Uint8Array(arraylen);\n var i;\n var sample;\n var duration;\n var size;\n var flags;\n var cts;\n offset += 8 + arraylen;\n array.set([track.type === 'video' ? 0x01 : 0x00, // version 1 for video with signed-int sample_composition_time_offset\n 0x00, 0x0f, 0x01, // flags\n len >>> 24 & 0xff, len >>> 16 & 0xff, len >>> 8 & 0xff, len & 0xff, // sample_count\n offset >>> 24 & 0xff, offset >>> 16 & 0xff, offset >>> 8 & 0xff, offset & 0xff // data_offset\n ], 0);\n\n for (i = 0; i < len; i++) {\n sample = samples[i];\n duration = sample.duration;\n size = sample.size;\n flags = sample.flags;\n cts = sample.cts;\n array.set([duration >>> 24 & 0xff, duration >>> 16 & 0xff, duration >>> 8 & 0xff, duration & 0xff, // sample_duration\n size >>> 24 & 0xff, size >>> 16 & 0xff, size >>> 8 & 0xff, size & 0xff, // sample_size\n flags.isLeading << 2 | flags.dependsOn, flags.isDependedOn << 6 | flags.hasRedundancy << 4 | flags.paddingValue << 1 | flags.isNonSync, flags.degradPrio & 0xf0 << 8, flags.degradPrio & 0x0f, // sample_flags\n cts >>> 24 & 0xff, cts >>> 16 & 0xff, cts >>> 8 & 0xff, cts & 0xff // sample_composition_time_offset\n ], 12 + 16 * i);\n }\n\n return MP4.box(MP4.types.trun, array);\n };\n\n MP4.initSegment = function initSegment(tracks) {\n if (!MP4.types) {\n MP4.init();\n }\n\n var movie = MP4.moov(tracks);\n var result = new Uint8Array(MP4.FTYP.byteLength + movie.byteLength);\n result.set(MP4.FTYP);\n result.set(movie, MP4.FTYP.byteLength);\n return result;\n };\n\n return MP4;\n}();\n\nMP4.types = void 0;\nMP4.HDLR_TYPES = void 0;\nMP4.STTS = void 0;\nMP4.STSC = void 0;\nMP4.STCO = void 0;\nMP4.STSZ = void 0;\nMP4.VMHD = void 0;\nMP4.SMHD = void 0;\nMP4.STSD = void 0;\nMP4.FTYP = void 0;\nMP4.DINF = void 0;\n/* harmony default export */ __webpack_exports__[\"default\"] = (MP4);\n\n/***/ }),\n\n/***/ \"./src/remux/mp4-remuxer.ts\":\n/*!**********************************!*\\\n !*** ./src/remux/mp4-remuxer.ts ***!\n \\**********************************/\n/*! exports provided: default, normalizePts, flushTextTrackMetadataCueSamples, flushTextTrackUserdataCueSamples */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return MP4Remuxer; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"normalizePts\", function() { return normalizePts; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"flushTextTrackMetadataCueSamples\", function() { return flushTextTrackMetadataCueSamples; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"flushTextTrackUserdataCueSamples\", function() { return flushTextTrackUserdataCueSamples; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _aac_helper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./aac-helper */ \"./src/remux/aac-helper.ts\");\n/* harmony import */ var _mp4_generator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./mp4-generator */ \"./src/remux/mp4-generator.ts\");\n/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../events */ \"./src/events.ts\");\n/* harmony import */ var _errors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../errors */ \"./src/errors.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _types_loader__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../types/loader */ \"./src/types/loader.ts\");\n/* harmony import */ var _utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../utils/timescale-conversion */ \"./src/utils/timescale-conversion.ts\");\n\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n\n\n\nvar MAX_SILENT_FRAME_DURATION = 10 * 1000; // 10 seconds\n\nvar AAC_SAMPLES_PER_FRAME = 1024;\nvar MPEG_AUDIO_SAMPLE_PER_FRAME = 1152;\nvar chromeVersion = null;\nvar safariWebkitVersion = null;\n\nvar MP4Remuxer = /*#__PURE__*/function () {\n function MP4Remuxer(observer, config, typeSupported, vendor) {\n if (vendor === void 0) {\n vendor = '';\n }\n\n this.observer = void 0;\n this.config = void 0;\n this.typeSupported = void 0;\n this.ISGenerated = false;\n this._initPTS = void 0;\n this._initDTS = void 0;\n this.nextAvcDts = null;\n this.nextAudioPts = null;\n this.videoSampleDuration = null;\n this.isAudioContiguous = false;\n this.isVideoContiguous = false;\n this.observer = observer;\n this.config = config;\n this.typeSupported = typeSupported;\n this.ISGenerated = false;\n\n if (chromeVersion === null) {\n var userAgent = navigator.userAgent || '';\n var result = userAgent.match(/Chrome\\/(\\d+)/i);\n chromeVersion = result ? parseInt(result[1]) : 0;\n }\n\n if (safariWebkitVersion === null) {\n var _result = navigator.userAgent.match(/Safari\\/(\\d+)/i);\n\n safariWebkitVersion = _result ? parseInt(_result[1]) : 0;\n }\n }\n\n var _proto = MP4Remuxer.prototype;\n\n _proto.destroy = function destroy() {};\n\n _proto.resetTimeStamp = function resetTimeStamp(defaultTimeStamp) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log('[mp4-remuxer]: initPTS & initDTS reset');\n this._initPTS = this._initDTS = defaultTimeStamp;\n };\n\n _proto.resetNextTimestamp = function resetNextTimestamp() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log('[mp4-remuxer]: reset next timestamp');\n this.isVideoContiguous = false;\n this.isAudioContiguous = false;\n };\n\n _proto.resetInitSegment = function resetInitSegment() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log('[mp4-remuxer]: ISGenerated flag reset');\n this.ISGenerated = false;\n };\n\n _proto.getVideoStartPts = function getVideoStartPts(videoSamples) {\n var rolloverDetected = false;\n var startPTS = videoSamples.reduce(function (minPTS, sample) {\n var delta = sample.pts - minPTS;\n\n if (delta < -4294967296) {\n // 2^32, see PTSNormalize for reasoning, but we're hitting a rollover here, and we don't want that to impact the timeOffset calculation\n rolloverDetected = true;\n return normalizePts(minPTS, sample.pts);\n } else if (delta > 0) {\n return minPTS;\n } else {\n return sample.pts;\n }\n }, videoSamples[0].pts);\n\n if (rolloverDetected) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].debug('PTS rollover detected');\n }\n\n return startPTS;\n };\n\n _proto.remux = function remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset, accurateTimeOffset, flush, playlistType) {\n var video;\n var audio;\n var initSegment;\n var text;\n var id3;\n var independent;\n var audioTimeOffset = timeOffset;\n var videoTimeOffset = timeOffset; // If we're remuxing audio and video progressively, wait until we've received enough samples for each track before proceeding.\n // This is done to synchronize the audio and video streams. We know if the current segment will have samples if the \"pid\"\n // parameter is greater than -1. The pid is set when the PMT is parsed, which contains the tracks list.\n // However, if the initSegment has already been generated, or we've reached the end of a segment (flush),\n // then we can remux one track without waiting for the other.\n\n var hasAudio = audioTrack.pid > -1;\n var hasVideo = videoTrack.pid > -1;\n var length = videoTrack.samples.length;\n var enoughAudioSamples = audioTrack.samples.length > 0;\n var enoughVideoSamples = flush && length > 0 || length > 1;\n var canRemuxAvc = (!hasAudio || enoughAudioSamples) && (!hasVideo || enoughVideoSamples) || this.ISGenerated || flush;\n\n if (canRemuxAvc) {\n if (!this.ISGenerated) {\n initSegment = this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n\n var isVideoContiguous = this.isVideoContiguous;\n var firstKeyFrameIndex = -1;\n var firstKeyFramePTS;\n\n if (enoughVideoSamples) {\n firstKeyFrameIndex = findKeyframeIndex(videoTrack.samples);\n\n if (!isVideoContiguous && this.config.forceKeyFrameOnDiscontinuity) {\n independent = true;\n\n if (firstKeyFrameIndex > 0) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"[mp4-remuxer]: Dropped \" + firstKeyFrameIndex + \" out of \" + length + \" video samples due to a missing keyframe\");\n var startPTS = this.getVideoStartPts(videoTrack.samples);\n videoTrack.samples = videoTrack.samples.slice(firstKeyFrameIndex);\n videoTrack.dropped += firstKeyFrameIndex;\n videoTimeOffset += (videoTrack.samples[0].pts - startPTS) / videoTrack.inputTimeScale;\n firstKeyFramePTS = videoTimeOffset;\n } else if (firstKeyFrameIndex === -1) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"[mp4-remuxer]: No keyframe found out of \" + length + \" video samples\");\n independent = false;\n }\n }\n }\n\n if (this.ISGenerated) {\n if (enoughAudioSamples && enoughVideoSamples) {\n // timeOffset is expected to be the offset of the first timestamp of this fragment (first DTS)\n // if first audio DTS is not aligned with first video DTS then we need to take that into account\n // when providing timeOffset to remuxAudio / remuxVideo. if we don't do that, there might be a permanent / small\n // drift between audio and video streams\n var _startPTS = this.getVideoStartPts(videoTrack.samples);\n\n var tsDelta = normalizePts(audioTrack.samples[0].pts, _startPTS) - _startPTS;\n\n var audiovideoTimestampDelta = tsDelta / videoTrack.inputTimeScale;\n audioTimeOffset += Math.max(0, audiovideoTimestampDelta);\n videoTimeOffset += Math.max(0, -audiovideoTimestampDelta);\n } // Purposefully remuxing audio before video, so that remuxVideo can use nextAudioPts, which is calculated in remuxAudio.\n\n\n if (enoughAudioSamples) {\n // if initSegment was generated without audio samples, regenerate it again\n if (!audioTrack.samplerate) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn('[mp4-remuxer]: regenerate InitSegment as audio detected');\n initSegment = this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n\n audio = this.remuxAudio(audioTrack, audioTimeOffset, this.isAudioContiguous, accurateTimeOffset, hasVideo || enoughVideoSamples || playlistType === _types_loader__WEBPACK_IMPORTED_MODULE_6__[\"PlaylistLevelType\"].AUDIO ? videoTimeOffset : undefined);\n\n if (enoughVideoSamples) {\n var audioTrackLength = audio ? audio.endPTS - audio.startPTS : 0; // if initSegment was generated without video samples, regenerate it again\n\n if (!videoTrack.inputTimeScale) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn('[mp4-remuxer]: regenerate InitSegment as video detected');\n initSegment = this.generateIS(audioTrack, videoTrack, timeOffset);\n }\n\n video = this.remuxVideo(videoTrack, videoTimeOffset, isVideoContiguous, audioTrackLength);\n }\n } else if (enoughVideoSamples) {\n video = this.remuxVideo(videoTrack, videoTimeOffset, isVideoContiguous, 0);\n }\n\n if (video) {\n video.firstKeyFrame = firstKeyFrameIndex;\n video.independent = firstKeyFrameIndex !== -1;\n video.firstKeyFramePTS = firstKeyFramePTS;\n }\n }\n } // Allow ID3 and text to remux, even if more audio/video samples are required\n\n\n if (this.ISGenerated) {\n if (id3Track.samples.length) {\n id3 = flushTextTrackMetadataCueSamples(id3Track, timeOffset, this._initPTS, this._initDTS);\n }\n\n if (textTrack.samples.length) {\n text = flushTextTrackUserdataCueSamples(textTrack, timeOffset, this._initPTS);\n }\n }\n\n return {\n audio: audio,\n video: video,\n initSegment: initSegment,\n independent: independent,\n text: text,\n id3: id3\n };\n };\n\n _proto.generateIS = function generateIS(audioTrack, videoTrack, timeOffset) {\n var audioSamples = audioTrack.samples;\n var videoSamples = videoTrack.samples;\n var typeSupported = this.typeSupported;\n var tracks = {};\n var computePTSDTS = !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(this._initPTS);\n var container = 'audio/mp4';\n var initPTS;\n var initDTS;\n var timescale;\n\n if (computePTSDTS) {\n initPTS = initDTS = Infinity;\n }\n\n if (audioTrack.config && audioSamples.length) {\n // let's use audio sampling rate as MP4 time scale.\n // rationale is that there is a integer nb of audio frames per audio sample (1024 for AAC)\n // using audio sampling rate here helps having an integer MP4 frame duration\n // this avoids potential rounding issue and AV sync issue\n audioTrack.timescale = audioTrack.samplerate;\n\n switch (audioTrack.segmentCodec) {\n case 'mp3':\n if (typeSupported.mpeg) {\n // Chrome and Safari\n container = 'audio/mpeg';\n audioTrack.codec = '';\n } else if (typeSupported.mp3) {\n // Firefox\n audioTrack.codec = 'mp3';\n }\n\n break;\n }\n\n tracks.audio = {\n id: 'audio',\n container: container,\n codec: audioTrack.codec,\n initSegment: audioTrack.segmentCodec === 'mp3' && typeSupported.mpeg ? new Uint8Array(0) : _mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].initSegment([audioTrack]),\n metadata: {\n channelCount: audioTrack.channelCount\n }\n };\n\n if (computePTSDTS) {\n timescale = audioTrack.inputTimeScale; // remember first PTS of this demuxing context. for audio, PTS = DTS\n\n initPTS = initDTS = audioSamples[0].pts - Math.round(timescale * timeOffset);\n }\n }\n\n if (videoTrack.sps && videoTrack.pps && videoSamples.length) {\n // let's use input time scale as MP4 video timescale\n // we use input time scale straight away to avoid rounding issues on frame duration / cts computation\n videoTrack.timescale = videoTrack.inputTimeScale;\n tracks.video = {\n id: 'main',\n container: 'video/mp4',\n codec: videoTrack.codec,\n initSegment: _mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].initSegment([videoTrack]),\n metadata: {\n width: videoTrack.width,\n height: videoTrack.height\n }\n };\n\n if (computePTSDTS) {\n timescale = videoTrack.inputTimeScale;\n var startPTS = this.getVideoStartPts(videoSamples);\n var startOffset = Math.round(timescale * timeOffset);\n initDTS = Math.min(initDTS, normalizePts(videoSamples[0].dts, startPTS) - startOffset);\n initPTS = Math.min(initPTS, startPTS - startOffset);\n }\n }\n\n if (Object.keys(tracks).length) {\n this.ISGenerated = true;\n\n if (computePTSDTS) {\n this._initPTS = initPTS;\n this._initDTS = initDTS;\n }\n\n return {\n tracks: tracks,\n initPTS: initPTS,\n timescale: timescale\n };\n }\n };\n\n _proto.remuxVideo = function remuxVideo(track, timeOffset, contiguous, audioTrackLength) {\n var timeScale = track.inputTimeScale;\n var inputSamples = track.samples;\n var outputSamples = [];\n var nbSamples = inputSamples.length;\n var initPTS = this._initPTS;\n var nextAvcDts = this.nextAvcDts;\n var offset = 8;\n var mp4SampleDuration = this.videoSampleDuration;\n var firstDTS;\n var lastDTS;\n var minPTS = Number.POSITIVE_INFINITY;\n var maxPTS = Number.NEGATIVE_INFINITY;\n var sortSamples = false; // if parsed fragment is contiguous with last one, let's use last DTS value as reference\n\n if (!contiguous || nextAvcDts === null) {\n var pts = timeOffset * timeScale;\n var cts = inputSamples[0].pts - normalizePts(inputSamples[0].dts, inputSamples[0].pts); // if not contiguous, let's use target timeOffset\n\n nextAvcDts = pts - cts;\n } // PTS is coded on 33bits, and can loop from -2^32 to 2^32\n // PTSNormalize will make PTS/DTS value monotonic, we use last known DTS value as reference value\n\n\n for (var i = 0; i < nbSamples; i++) {\n var sample = inputSamples[i];\n sample.pts = normalizePts(sample.pts - initPTS, nextAvcDts);\n sample.dts = normalizePts(sample.dts - initPTS, nextAvcDts);\n\n if (sample.dts < inputSamples[i > 0 ? i - 1 : i].dts) {\n sortSamples = true;\n }\n } // sort video samples by DTS then PTS then demux id order\n\n\n if (sortSamples) {\n inputSamples.sort(function (a, b) {\n var deltadts = a.dts - b.dts;\n var deltapts = a.pts - b.pts;\n return deltadts || deltapts;\n });\n } // Get first/last DTS\n\n\n firstDTS = inputSamples[0].dts;\n lastDTS = inputSamples[inputSamples.length - 1].dts; // Sample duration (as expected by trun MP4 boxes), should be the delta between sample DTS\n // set this constant duration as being the avg delta between consecutive DTS.\n\n var inputDuration = lastDTS - firstDTS;\n var averageSampleDuration = inputDuration ? Math.round(inputDuration / (nbSamples - 1)) : mp4SampleDuration || track.inputTimeScale / 30; // if fragment are contiguous, detect hole/overlapping between fragments\n\n if (contiguous) {\n // check timestamp continuity across consecutive fragments (this is to remove inter-fragment gap/hole)\n var delta = firstDTS - nextAvcDts;\n var foundHole = delta > averageSampleDuration;\n var foundOverlap = delta < -1;\n\n if (foundHole || foundOverlap) {\n if (foundHole) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"AVC: \" + Object(_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__[\"toMsFromMpegTsClock\"])(delta, true) + \" ms (\" + delta + \"dts) hole between fragments detected, filling it\");\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"AVC: \" + Object(_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__[\"toMsFromMpegTsClock\"])(-delta, true) + \" ms (\" + delta + \"dts) overlapping between fragments detected\");\n }\n\n firstDTS = nextAvcDts;\n var firstPTS = inputSamples[0].pts - delta;\n inputSamples[0].dts = firstDTS;\n inputSamples[0].pts = firstPTS;\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log(\"Video: First PTS/DTS adjusted: \" + Object(_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__[\"toMsFromMpegTsClock\"])(firstPTS, true) + \"/\" + Object(_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__[\"toMsFromMpegTsClock\"])(firstDTS, true) + \", delta: \" + Object(_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__[\"toMsFromMpegTsClock\"])(delta, true) + \" ms\");\n }\n }\n\n firstDTS = Math.max(0, firstDTS);\n var nbNalu = 0;\n var naluLen = 0;\n\n for (var _i = 0; _i < nbSamples; _i++) {\n // compute total/avc sample length and nb of NAL units\n var _sample = inputSamples[_i];\n var units = _sample.units;\n var nbUnits = units.length;\n var sampleLen = 0;\n\n for (var j = 0; j < nbUnits; j++) {\n sampleLen += units[j].data.length;\n }\n\n naluLen += sampleLen;\n nbNalu += nbUnits;\n _sample.length = sampleLen; // ensure sample monotonic DTS\n\n _sample.dts = Math.max(_sample.dts, firstDTS);\n minPTS = Math.min(_sample.pts, minPTS);\n maxPTS = Math.max(_sample.pts, maxPTS);\n }\n\n lastDTS = inputSamples[nbSamples - 1].dts;\n /* concatenate the video data and construct the mdat in place\n (need 8 more bytes to fill length and mpdat type) */\n\n var mdatSize = naluLen + 4 * nbNalu + 8;\n var mdat;\n\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.emit(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, _events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorTypes\"].MUX_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorDetails\"].REMUX_ALLOC_ERROR,\n fatal: false,\n bytes: mdatSize,\n reason: \"fail allocating video mdat \" + mdatSize\n });\n return;\n }\n\n var view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(_mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].types.mdat, 4);\n var stretchedLastFrame = false;\n var minDtsDelta = Number.POSITIVE_INFINITY;\n var minPtsDelta = Number.POSITIVE_INFINITY;\n var maxDtsDelta = Number.NEGATIVE_INFINITY;\n var maxPtsDelta = Number.NEGATIVE_INFINITY;\n\n for (var _i2 = 0; _i2 < nbSamples; _i2++) {\n var avcSample = inputSamples[_i2];\n var avcSampleUnits = avcSample.units;\n var mp4SampleLength = 0; // convert NALU bitstream to MP4 format (prepend NALU with size field)\n\n for (var _j = 0, _nbUnits = avcSampleUnits.length; _j < _nbUnits; _j++) {\n var unit = avcSampleUnits[_j];\n var unitData = unit.data;\n var unitDataLen = unit.data.byteLength;\n view.setUint32(offset, unitDataLen);\n offset += 4;\n mdat.set(unitData, offset);\n offset += unitDataLen;\n mp4SampleLength += 4 + unitDataLen;\n } // expected sample duration is the Decoding Timestamp diff of consecutive samples\n\n\n var ptsDelta = void 0;\n\n if (_i2 < nbSamples - 1) {\n mp4SampleDuration = inputSamples[_i2 + 1].dts - avcSample.dts;\n ptsDelta = inputSamples[_i2 + 1].pts - avcSample.pts;\n } else {\n var config = this.config;\n var lastFrameDuration = _i2 > 0 ? avcSample.dts - inputSamples[_i2 - 1].dts : averageSampleDuration;\n ptsDelta = _i2 > 0 ? avcSample.pts - inputSamples[_i2 - 1].pts : averageSampleDuration;\n\n if (config.stretchShortVideoTrack && this.nextAudioPts !== null) {\n // In some cases, a segment's audio track duration may exceed the video track duration.\n // Since we've already remuxed audio, and we know how long the audio track is, we look to\n // see if the delta to the next segment is longer than maxBufferHole.\n // If so, playback would potentially get stuck, so we artificially inflate\n // the duration of the last frame to minimize any potential gap between segments.\n var gapTolerance = Math.floor(config.maxBufferHole * timeScale);\n var deltaToFrameEnd = (audioTrackLength ? minPTS + audioTrackLength * timeScale : this.nextAudioPts) - avcSample.pts;\n\n if (deltaToFrameEnd > gapTolerance) {\n // We subtract lastFrameDuration from deltaToFrameEnd to try to prevent any video\n // frame overlap. maxBufferHole should be >> lastFrameDuration anyway.\n mp4SampleDuration = deltaToFrameEnd - lastFrameDuration;\n\n if (mp4SampleDuration < 0) {\n mp4SampleDuration = lastFrameDuration;\n } else {\n stretchedLastFrame = true;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log(\"[mp4-remuxer]: It is approximately \" + deltaToFrameEnd / 90 + \" ms to the next segment; using duration \" + mp4SampleDuration / 90 + \" ms for the last video frame.\");\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n } else {\n mp4SampleDuration = lastFrameDuration;\n }\n }\n\n var compositionTimeOffset = Math.round(avcSample.pts - avcSample.dts);\n minDtsDelta = Math.min(minDtsDelta, mp4SampleDuration);\n maxDtsDelta = Math.max(maxDtsDelta, mp4SampleDuration);\n minPtsDelta = Math.min(minPtsDelta, ptsDelta);\n maxPtsDelta = Math.max(maxPtsDelta, ptsDelta);\n outputSamples.push(new Mp4Sample(avcSample.key, mp4SampleDuration, mp4SampleLength, compositionTimeOffset));\n }\n\n if (outputSamples.length) {\n if (chromeVersion) {\n if (chromeVersion < 70) {\n // Chrome workaround, mark first sample as being a Random Access Point (keyframe) to avoid sourcebuffer append issue\n // https://code.google.com/p/chromium/issues/detail?id=229412\n var flags = outputSamples[0].flags;\n flags.dependsOn = 2;\n flags.isNonSync = 0;\n }\n } else if (safariWebkitVersion) {\n // Fix for \"CNN special report, with CC\" in test-streams (Safari browser only)\n // Ignore DTS when frame durations are irregular. Safari MSE does not handle this leading to gaps.\n if (maxPtsDelta - minPtsDelta < maxDtsDelta - minDtsDelta && averageSampleDuration / maxDtsDelta < 0.025 && outputSamples[0].cts === 0) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn('Found irregular gaps in sample duration. Using PTS instead of DTS to determine MP4 sample duration.');\n var dts = firstDTS;\n\n for (var _i3 = 0, len = outputSamples.length; _i3 < len; _i3++) {\n var nextDts = dts + outputSamples[_i3].duration;\n\n var _pts = dts + outputSamples[_i3].cts;\n\n if (_i3 < len - 1) {\n var nextPts = nextDts + outputSamples[_i3 + 1].cts;\n outputSamples[_i3].duration = nextPts - _pts;\n } else {\n outputSamples[_i3].duration = _i3 ? outputSamples[_i3 - 1].duration : averageSampleDuration;\n }\n\n outputSamples[_i3].cts = 0;\n dts = nextDts;\n }\n }\n }\n }\n\n console.assert(mp4SampleDuration !== null, 'mp4SampleDuration must be computed'); // next AVC sample DTS should be equal to last sample DTS + last sample duration (in PES timescale)\n\n mp4SampleDuration = stretchedLastFrame || !mp4SampleDuration ? averageSampleDuration : mp4SampleDuration;\n this.nextAvcDts = nextAvcDts = lastDTS + mp4SampleDuration;\n this.videoSampleDuration = mp4SampleDuration;\n this.isVideoContiguous = true;\n var moof = _mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].moof(track.sequenceNumber++, firstDTS, _extends({}, track, {\n samples: outputSamples\n }));\n var type = 'video';\n var data = {\n data1: moof,\n data2: mdat,\n startPTS: minPTS / timeScale,\n endPTS: (maxPTS + mp4SampleDuration) / timeScale,\n startDTS: firstDTS / timeScale,\n endDTS: nextAvcDts / timeScale,\n type: type,\n hasAudio: false,\n hasVideo: true,\n nb: outputSamples.length,\n dropped: track.dropped\n };\n track.samples = [];\n track.dropped = 0;\n console.assert(mdat.length, 'MDAT length must not be zero');\n return data;\n };\n\n _proto.remuxAudio = function remuxAudio(track, timeOffset, contiguous, accurateTimeOffset, videoTimeOffset) {\n var inputTimeScale = track.inputTimeScale;\n var mp4timeScale = track.samplerate ? track.samplerate : inputTimeScale;\n var scaleFactor = inputTimeScale / mp4timeScale;\n var mp4SampleDuration = track.segmentCodec === 'aac' ? AAC_SAMPLES_PER_FRAME : MPEG_AUDIO_SAMPLE_PER_FRAME;\n var inputSampleDuration = mp4SampleDuration * scaleFactor;\n var initPTS = this._initPTS;\n var rawMPEG = track.segmentCodec === 'mp3' && this.typeSupported.mpeg;\n var outputSamples = [];\n var alignedWithVideo = videoTimeOffset !== undefined;\n var inputSamples = track.samples;\n var offset = rawMPEG ? 0 : 8;\n var nextAudioPts = this.nextAudioPts || -1; // window.audioSamples ? window.audioSamples.push(inputSamples.map(s => s.pts)) : (window.audioSamples = [inputSamples.map(s => s.pts)]);\n // for audio samples, also consider consecutive fragments as being contiguous (even if a level switch occurs),\n // for sake of clarity:\n // consecutive fragments are frags with\n // - less than 100ms gaps between new time offset (if accurate) and next expected PTS OR\n // - less than 20 audio frames distance\n // contiguous fragments are consecutive fragments from same quality level (same level, new SN = old SN + 1)\n // this helps ensuring audio continuity\n // and this also avoids audio glitches/cut when switching quality, or reporting wrong duration on first audio frame\n\n var timeOffsetMpegTS = timeOffset * inputTimeScale;\n this.isAudioContiguous = contiguous = contiguous || inputSamples.length && nextAudioPts > 0 && (accurateTimeOffset && Math.abs(timeOffsetMpegTS - nextAudioPts) < 9000 || Math.abs(normalizePts(inputSamples[0].pts - initPTS, timeOffsetMpegTS) - nextAudioPts) < 20 * inputSampleDuration); // compute normalized PTS\n\n inputSamples.forEach(function (sample) {\n sample.pts = normalizePts(sample.pts - initPTS, timeOffsetMpegTS);\n });\n\n if (!contiguous || nextAudioPts < 0) {\n // filter out sample with negative PTS that are not playable anyway\n // if we don't remove these negative samples, they will shift all audio samples forward.\n // leading to audio overlap between current / next fragment\n inputSamples = inputSamples.filter(function (sample) {\n return sample.pts >= 0;\n }); // in case all samples have negative PTS, and have been filtered out, return now\n\n if (!inputSamples.length) {\n return;\n }\n\n if (videoTimeOffset === 0) {\n // Set the start to 0 to match video so that start gaps larger than inputSampleDuration are filled with silence\n nextAudioPts = 0;\n } else if (accurateTimeOffset && !alignedWithVideo) {\n // When not seeking, not live, and LevelDetails.PTSKnown, use fragment start as predicted next audio PTS\n nextAudioPts = Math.max(0, timeOffsetMpegTS);\n } else {\n // if frags are not contiguous and if we cant trust time offset, let's use first sample PTS as next audio PTS\n nextAudioPts = inputSamples[0].pts;\n }\n } // If the audio track is missing samples, the frames seem to get \"left-shifted\" within the\n // resulting mp4 segment, causing sync issues and leaving gaps at the end of the audio segment.\n // In an effort to prevent this from happening, we inject frames here where there are gaps.\n // When possible, we inject a silent frame; when that's not possible, we duplicate the last\n // frame.\n\n\n if (track.segmentCodec === 'aac') {\n var maxAudioFramesDrift = this.config.maxAudioFramesDrift;\n\n for (var i = 0, nextPts = nextAudioPts; i < inputSamples.length; i++) {\n // First, let's see how far off this frame is from where we expect it to be\n var sample = inputSamples[i];\n var pts = sample.pts;\n var delta = pts - nextPts;\n var duration = Math.abs(1000 * delta / inputTimeScale); // When remuxing with video, if we're overlapping by more than a duration, drop this sample to stay in sync\n\n if (delta <= -maxAudioFramesDrift * inputSampleDuration && alignedWithVideo) {\n if (i === 0) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"Audio frame @ \" + (pts / inputTimeScale).toFixed(3) + \"s overlaps nextAudioPts by \" + Math.round(1000 * delta / inputTimeScale) + \" ms.\");\n this.nextAudioPts = nextAudioPts = nextPts = pts;\n }\n } // eslint-disable-line brace-style\n // Insert missing frames if:\n // 1: We're more than maxAudioFramesDrift frame away\n // 2: Not more than MAX_SILENT_FRAME_DURATION away\n // 3: currentTime (aka nextPtsNorm) is not 0\n // 4: remuxing with video (videoTimeOffset !== undefined)\n else if (delta >= maxAudioFramesDrift * inputSampleDuration && duration < MAX_SILENT_FRAME_DURATION && alignedWithVideo) {\n var missing = Math.round(delta / inputSampleDuration); // Adjust nextPts so that silent samples are aligned with media pts. This will prevent media samples from\n // later being shifted if nextPts is based on timeOffset and delta is not a multiple of inputSampleDuration.\n\n nextPts = pts - missing * inputSampleDuration;\n\n if (nextPts < 0) {\n missing--;\n nextPts += inputSampleDuration;\n }\n\n if (i === 0) {\n this.nextAudioPts = nextAudioPts = nextPts;\n }\n\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn(\"[mp4-remuxer]: Injecting \" + missing + \" audio frame @ \" + (nextPts / inputTimeScale).toFixed(3) + \"s due to \" + Math.round(1000 * delta / inputTimeScale) + \" ms gap.\");\n\n for (var j = 0; j < missing; j++) {\n var newStamp = Math.max(nextPts, 0);\n var fillFrame = _aac_helper__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n\n if (!fillFrame) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].log('[mp4-remuxer]: Unable to get silent frame for given audio codec; duplicating last frame instead.');\n fillFrame = sample.unit.subarray();\n }\n\n inputSamples.splice(i, 0, {\n unit: fillFrame,\n pts: newStamp\n });\n nextPts += inputSampleDuration;\n i++;\n }\n }\n\n sample.pts = nextPts;\n nextPts += inputSampleDuration;\n }\n }\n\n var firstPTS = null;\n var lastPTS = null;\n var mdat;\n var mdatSize = 0;\n var sampleLength = inputSamples.length;\n\n while (sampleLength--) {\n mdatSize += inputSamples[sampleLength].unit.byteLength;\n }\n\n for (var _j2 = 0, _nbSamples = inputSamples.length; _j2 < _nbSamples; _j2++) {\n var audioSample = inputSamples[_j2];\n var unit = audioSample.unit;\n var _pts2 = audioSample.pts;\n\n if (lastPTS !== null) {\n // If we have more than one sample, set the duration of the sample to the \"real\" duration; the PTS diff with\n // the previous sample\n var prevSample = outputSamples[_j2 - 1];\n prevSample.duration = Math.round((_pts2 - lastPTS) / scaleFactor);\n } else {\n if (contiguous && track.segmentCodec === 'aac') {\n // set PTS/DTS to expected PTS/DTS\n _pts2 = nextAudioPts;\n } // remember first PTS of our audioSamples\n\n\n firstPTS = _pts2;\n\n if (mdatSize > 0) {\n /* concatenate the audio data and construct the mdat in place\n (need 8 more bytes to fill length and mdat type) */\n mdatSize += offset;\n\n try {\n mdat = new Uint8Array(mdatSize);\n } catch (err) {\n this.observer.emit(_events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, _events__WEBPACK_IMPORTED_MODULE_3__[\"Events\"].ERROR, {\n type: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorTypes\"].MUX_ERROR,\n details: _errors__WEBPACK_IMPORTED_MODULE_4__[\"ErrorDetails\"].REMUX_ALLOC_ERROR,\n fatal: false,\n bytes: mdatSize,\n reason: \"fail allocating audio mdat \" + mdatSize\n });\n return;\n }\n\n if (!rawMPEG) {\n var view = new DataView(mdat.buffer);\n view.setUint32(0, mdatSize);\n mdat.set(_mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].types.mdat, 4);\n }\n } else {\n // no audio samples\n return;\n }\n }\n\n mdat.set(unit, offset);\n var unitLen = unit.byteLength;\n offset += unitLen; // Default the sample's duration to the computed mp4SampleDuration, which will either be 1024 for AAC or 1152 for MPEG\n // In the case that we have 1 sample, this will be the duration. If we have more than one sample, the duration\n // becomes the PTS diff with the previous sample\n\n outputSamples.push(new Mp4Sample(true, mp4SampleDuration, unitLen, 0));\n lastPTS = _pts2;\n } // We could end up with no audio samples if all input samples were overlapping with the previously remuxed ones\n\n\n var nbSamples = outputSamples.length;\n\n if (!nbSamples) {\n return;\n } // The next audio sample PTS should be equal to last sample PTS + duration\n\n\n var lastSample = outputSamples[outputSamples.length - 1];\n this.nextAudioPts = nextAudioPts = lastPTS + scaleFactor * lastSample.duration; // Set the track samples from inputSamples to outputSamples before remuxing\n\n var moof = rawMPEG ? new Uint8Array(0) : _mp4_generator__WEBPACK_IMPORTED_MODULE_2__[\"default\"].moof(track.sequenceNumber++, firstPTS / scaleFactor, _extends({}, track, {\n samples: outputSamples\n })); // Clear the track samples. This also clears the samples array in the demuxer, since the reference is shared\n\n track.samples = [];\n var start = firstPTS / inputTimeScale;\n var end = nextAudioPts / inputTimeScale;\n var type = 'audio';\n var audioData = {\n data1: moof,\n data2: mdat,\n startPTS: start,\n endPTS: end,\n startDTS: start,\n endDTS: end,\n type: type,\n hasAudio: true,\n hasVideo: false,\n nb: nbSamples\n };\n this.isAudioContiguous = true;\n console.assert(mdat.length, 'MDAT length must not be zero');\n return audioData;\n };\n\n _proto.remuxEmptyAudio = function remuxEmptyAudio(track, timeOffset, contiguous, videoData) {\n var inputTimeScale = track.inputTimeScale;\n var mp4timeScale = track.samplerate ? track.samplerate : inputTimeScale;\n var scaleFactor = inputTimeScale / mp4timeScale;\n var nextAudioPts = this.nextAudioPts; // sync with video's timestamp\n\n var startDTS = (nextAudioPts !== null ? nextAudioPts : videoData.startDTS * inputTimeScale) + this._initDTS;\n var endDTS = videoData.endDTS * inputTimeScale + this._initDTS; // one sample's duration value\n\n var frameDuration = scaleFactor * AAC_SAMPLES_PER_FRAME; // samples count of this segment's duration\n\n var nbSamples = Math.ceil((endDTS - startDTS) / frameDuration); // silent frame\n\n var silentFrame = _aac_helper__WEBPACK_IMPORTED_MODULE_1__[\"default\"].getSilentFrame(track.manifestCodec || track.codec, track.channelCount);\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].warn('[mp4-remuxer]: remux empty Audio'); // Can't remux if we can't generate a silent frame...\n\n if (!silentFrame) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_5__[\"logger\"].trace('[mp4-remuxer]: Unable to remuxEmptyAudio since we were unable to get a silent frame for given audio codec');\n return;\n }\n\n var samples = [];\n\n for (var i = 0; i < nbSamples; i++) {\n var stamp = startDTS + i * frameDuration;\n samples.push({\n unit: silentFrame,\n pts: stamp,\n dts: stamp\n });\n }\n\n track.samples = samples;\n return this.remuxAudio(track, timeOffset, contiguous, false);\n };\n\n return MP4Remuxer;\n}();\n\n\nfunction normalizePts(value, reference) {\n var offset;\n\n if (reference === null) {\n return value;\n }\n\n if (reference < value) {\n // - 2^33\n offset = -8589934592;\n } else {\n // + 2^33\n offset = 8589934592;\n }\n /* PTS is 33bit (from 0 to 2^33 -1)\n if diff between value and reference is bigger than half of the amplitude (2^32) then it means that\n PTS looping occured. fill the gap */\n\n\n while (Math.abs(value - reference) > 4294967296) {\n value += offset;\n }\n\n return value;\n}\n\nfunction findKeyframeIndex(samples) {\n for (var i = 0; i < samples.length; i++) {\n if (samples[i].key) {\n return i;\n }\n }\n\n return -1;\n}\n\nfunction flushTextTrackMetadataCueSamples(track, timeOffset, initPTS, initDTS) {\n var length = track.samples.length;\n\n if (!length) {\n return;\n }\n\n var inputTimeScale = track.inputTimeScale;\n\n for (var index = 0; index < length; index++) {\n var sample = track.samples[index]; // setting id3 pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n\n sample.pts = normalizePts(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n sample.dts = normalizePts(sample.dts - initDTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n\n var samples = track.samples;\n track.samples = [];\n return {\n samples: samples\n };\n}\nfunction flushTextTrackUserdataCueSamples(track, timeOffset, initPTS) {\n var length = track.samples.length;\n\n if (!length) {\n return;\n }\n\n var inputTimeScale = track.inputTimeScale;\n\n for (var index = 0; index < length; index++) {\n var sample = track.samples[index]; // setting text pts, dts to relative time\n // using this._initPTS and this._initDTS to calculate relative time\n\n sample.pts = normalizePts(sample.pts - initPTS, timeOffset * inputTimeScale) / inputTimeScale;\n }\n\n track.samples.sort(function (a, b) {\n return a.pts - b.pts;\n });\n var samples = track.samples;\n track.samples = [];\n return {\n samples: samples\n };\n}\n\nvar Mp4Sample = function Mp4Sample(isKeyframe, duration, size, cts) {\n this.size = void 0;\n this.duration = void 0;\n this.cts = void 0;\n this.flags = void 0;\n this.duration = duration;\n this.size = size;\n this.cts = cts;\n this.flags = new Mp4SampleFlags(isKeyframe);\n};\n\nvar Mp4SampleFlags = function Mp4SampleFlags(isKeyframe) {\n this.isLeading = 0;\n this.isDependedOn = 0;\n this.hasRedundancy = 0;\n this.degradPrio = 0;\n this.dependsOn = 1;\n this.isNonSync = 1;\n this.dependsOn = isKeyframe ? 2 : 1;\n this.isNonSync = isKeyframe ? 0 : 1;\n};\n\n/***/ }),\n\n/***/ \"./src/remux/passthrough-remuxer.ts\":\n/*!******************************************!*\\\n !*** ./src/remux/passthrough-remuxer.ts ***!\n \\******************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _mp4_remuxer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./mp4-remuxer */ \"./src/remux/mp4-remuxer.ts\");\n/* harmony import */ var _utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils/mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _loader_fragment__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../loader/fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n\n\n\n\n\n\nvar PassThroughRemuxer = /*#__PURE__*/function () {\n function PassThroughRemuxer() {\n this.emitInitSegment = false;\n this.audioCodec = void 0;\n this.videoCodec = void 0;\n this.initData = void 0;\n this.initPTS = void 0;\n this.initTracks = void 0;\n this.lastEndTime = null;\n }\n\n var _proto = PassThroughRemuxer.prototype;\n\n _proto.destroy = function destroy() {};\n\n _proto.resetTimeStamp = function resetTimeStamp(defaultInitPTS) {\n this.initPTS = defaultInitPTS;\n this.lastEndTime = null;\n };\n\n _proto.resetNextTimestamp = function resetNextTimestamp() {\n this.lastEndTime = null;\n };\n\n _proto.resetInitSegment = function resetInitSegment(initSegment, audioCodec, videoCodec) {\n this.audioCodec = audioCodec;\n this.videoCodec = videoCodec;\n this.generateInitSegment(initSegment);\n this.emitInitSegment = true;\n };\n\n _proto.generateInitSegment = function generateInitSegment(initSegment) {\n var audioCodec = this.audioCodec,\n videoCodec = this.videoCodec;\n\n if (!initSegment || !initSegment.byteLength) {\n this.initTracks = undefined;\n this.initData = undefined;\n return;\n }\n\n var initData = this.initData = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"parseInitSegment\"])(initSegment); // Get codec from initSegment or fallback to default\n\n if (!audioCodec) {\n audioCodec = getParsedTrackCodec(initData.audio, _loader_fragment__WEBPACK_IMPORTED_MODULE_3__[\"ElementaryStreamTypes\"].AUDIO);\n }\n\n if (!videoCodec) {\n videoCodec = getParsedTrackCodec(initData.video, _loader_fragment__WEBPACK_IMPORTED_MODULE_3__[\"ElementaryStreamTypes\"].VIDEO);\n }\n\n var tracks = {};\n\n if (initData.audio && initData.video) {\n tracks.audiovideo = {\n container: 'video/mp4',\n codec: audioCodec + ',' + videoCodec,\n initSegment: initSegment,\n id: 'main'\n };\n } else if (initData.audio) {\n tracks.audio = {\n container: 'audio/mp4',\n codec: audioCodec,\n initSegment: initSegment,\n id: 'audio'\n };\n } else if (initData.video) {\n tracks.video = {\n container: 'video/mp4',\n codec: videoCodec,\n initSegment: initSegment,\n id: 'main'\n };\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].warn('[passthrough-remuxer.ts]: initSegment does not contain moov or trak boxes.');\n }\n\n this.initTracks = tracks;\n };\n\n _proto.remux = function remux(audioTrack, videoTrack, id3Track, textTrack, timeOffset) {\n var _this$initPTS;\n\n var initPTS = this.initPTS,\n lastEndTime = this.lastEndTime;\n var result = {\n audio: undefined,\n video: undefined,\n text: textTrack,\n id3: id3Track,\n initSegment: undefined\n }; // If we haven't yet set a lastEndDTS, or it was reset, set it to the provided timeOffset. We want to use the\n // lastEndDTS over timeOffset whenever possible; during progressive playback, the media source will not update\n // the media duration (which is what timeOffset is provided as) before we need to process the next chunk.\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(lastEndTime)) {\n lastEndTime = this.lastEndTime = timeOffset || 0;\n } // The binary segment data is added to the videoTrack in the mp4demuxer. We don't check to see if the data is only\n // audio or video (or both); adding it to video was an arbitrary choice.\n\n\n var data = videoTrack.samples;\n\n if (!data || !data.length) {\n return result;\n }\n\n var initSegment = {\n initPTS: undefined,\n timescale: 1\n };\n var initData = this.initData;\n\n if (!initData || !initData.length) {\n this.generateInitSegment(data);\n initData = this.initData;\n }\n\n if (!initData || !initData.length) {\n // We can't remux if the initSegment could not be generated\n _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].warn('[passthrough-remuxer.ts]: Failed to generate initSegment.');\n return result;\n }\n\n if (this.emitInitSegment) {\n initSegment.tracks = this.initTracks;\n this.emitInitSegment = false;\n }\n\n var startDTS = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"getStartDTS\"])(initData, data);\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(initPTS)) {\n this.initPTS = initSegment.initPTS = initPTS = startDTS - timeOffset;\n }\n\n var duration = Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"getDuration\"])(data, initData);\n var startTime = audioTrack ? startDTS - initPTS : lastEndTime;\n var endTime = startTime + duration;\n Object(_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__[\"offsetStartDTS\"])(initData, data, initPTS);\n\n if (duration > 0) {\n this.lastEndTime = endTime;\n } else {\n _utils_logger__WEBPACK_IMPORTED_MODULE_4__[\"logger\"].warn('Duration parsed from mp4 should be greater than zero');\n this.resetNextTimestamp();\n }\n\n var hasAudio = !!initData.audio;\n var hasVideo = !!initData.video;\n var type = '';\n\n if (hasAudio) {\n type += 'audio';\n }\n\n if (hasVideo) {\n type += 'video';\n }\n\n var track = {\n data1: data,\n startPTS: startTime,\n startDTS: startTime,\n endPTS: endTime,\n endDTS: endTime,\n type: type,\n hasAudio: hasAudio,\n hasVideo: hasVideo,\n nb: 1,\n dropped: 0\n };\n result.audio = track.type === 'audio' ? track : undefined;\n result.video = track.type !== 'audio' ? track : undefined;\n result.initSegment = initSegment;\n var initPtsNum = (_this$initPTS = this.initPTS) != null ? _this$initPTS : 0;\n result.id3 = Object(_mp4_remuxer__WEBPACK_IMPORTED_MODULE_1__[\"flushTextTrackMetadataCueSamples\"])(id3Track, timeOffset, initPtsNum, initPtsNum);\n\n if (textTrack.samples.length) {\n result.text = Object(_mp4_remuxer__WEBPACK_IMPORTED_MODULE_1__[\"flushTextTrackUserdataCueSamples\"])(textTrack, timeOffset, initPtsNum);\n }\n\n return result;\n };\n\n return PassThroughRemuxer;\n}();\n\nfunction getParsedTrackCodec(track, type) {\n var parsedCodec = track === null || track === void 0 ? void 0 : track.codec;\n\n if (parsedCodec && parsedCodec.length > 4) {\n return parsedCodec;\n } // Since mp4-tools cannot parse full codec string (see 'TODO: Parse codec details'... in mp4-tools)\n // Provide defaults based on codec type\n // This allows for some playback of some fmp4 playlists without CODECS defined in manifest\n\n\n if (parsedCodec === 'hvc1' || parsedCodec === 'hev1') {\n return 'hvc1.1.c.L120.90';\n }\n\n if (parsedCodec === 'av01') {\n return 'av01.0.04M.08';\n }\n\n if (parsedCodec === 'avc1' || type === _loader_fragment__WEBPACK_IMPORTED_MODULE_3__[\"ElementaryStreamTypes\"].VIDEO) {\n return 'avc1.42e01e';\n }\n\n return 'mp4a.40.5';\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (PassThroughRemuxer);\n\n/***/ }),\n\n/***/ \"./src/task-loop.ts\":\n/*!**************************!*\\\n !*** ./src/task-loop.ts ***!\n \\**************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return TaskLoop; });\n/**\n * Sub-class specialization of EventHandler base class.\n *\n * TaskLoop allows to schedule a task function being called (optionnaly repeatedly) on the main loop,\n * scheduled asynchroneously, avoiding recursive calls in the same tick.\n *\n * The task itself is implemented in `doTick`. It can be requested and called for single execution\n * using the `tick` method.\n *\n * It will be assured that the task execution method (`tick`) only gets called once per main loop \"tick\",\n * no matter how often it gets requested for execution. Execution in further ticks will be scheduled accordingly.\n *\n * If further execution requests have already been scheduled on the next tick, it can be checked with `hasNextTick`,\n * and cancelled with `clearNextTick`.\n *\n * The task can be scheduled as an interval repeatedly with a period as parameter (see `setInterval`, `clearInterval`).\n *\n * Sub-classes need to implement the `doTick` method which will effectively have the task execution routine.\n *\n * Further explanations:\n *\n * The baseclass has a `tick` method that will schedule the doTick call. It may be called synchroneously\n * only for a stack-depth of one. On re-entrant calls, sub-sequent calls are scheduled for next main loop ticks.\n *\n * When the task execution (`tick` method) is called in re-entrant way this is detected and\n * we are limiting the task execution per call stack to exactly one, but scheduling/post-poning further\n * task processing on the next main loop iteration (also known as \"next tick\" in the Node/JS runtime lingo).\n */\nvar TaskLoop = /*#__PURE__*/function () {\n function TaskLoop() {\n this._boundTick = void 0;\n this._tickTimer = null;\n this._tickInterval = null;\n this._tickCallCount = 0;\n this._boundTick = this.tick.bind(this);\n }\n\n var _proto = TaskLoop.prototype;\n\n _proto.destroy = function destroy() {\n this.onHandlerDestroying();\n this.onHandlerDestroyed();\n };\n\n _proto.onHandlerDestroying = function onHandlerDestroying() {\n // clear all timers before unregistering from event bus\n this.clearNextTick();\n this.clearInterval();\n };\n\n _proto.onHandlerDestroyed = function onHandlerDestroyed() {}\n /**\n * @returns {boolean}\n */\n ;\n\n _proto.hasInterval = function hasInterval() {\n return !!this._tickInterval;\n }\n /**\n * @returns {boolean}\n */\n ;\n\n _proto.hasNextTick = function hasNextTick() {\n return !!this._tickTimer;\n }\n /**\n * @param {number} millis Interval time (ms)\n * @returns {boolean} True when interval has been scheduled, false when already scheduled (no effect)\n */\n ;\n\n _proto.setInterval = function setInterval(millis) {\n if (!this._tickInterval) {\n this._tickInterval = self.setInterval(this._boundTick, millis);\n return true;\n }\n\n return false;\n }\n /**\n * @returns {boolean} True when interval was cleared, false when none was set (no effect)\n */\n ;\n\n _proto.clearInterval = function clearInterval() {\n if (this._tickInterval) {\n self.clearInterval(this._tickInterval);\n this._tickInterval = null;\n return true;\n }\n\n return false;\n }\n /**\n * @returns {boolean} True when timeout was cleared, false when none was set (no effect)\n */\n ;\n\n _proto.clearNextTick = function clearNextTick() {\n if (this._tickTimer) {\n self.clearTimeout(this._tickTimer);\n this._tickTimer = null;\n return true;\n }\n\n return false;\n }\n /**\n * Will call the subclass doTick implementation in this main loop tick\n * or in the next one (via setTimeout(,0)) in case it has already been called\n * in this tick (in case this is a re-entrant call).\n */\n ;\n\n _proto.tick = function tick() {\n this._tickCallCount++;\n\n if (this._tickCallCount === 1) {\n this.doTick(); // re-entrant call to tick from previous doTick call stack\n // -> schedule a call on the next main loop iteration to process this task processing request\n\n if (this._tickCallCount > 1) {\n // make sure only one timer exists at any time at max\n this.tickImmediate();\n }\n\n this._tickCallCount = 0;\n }\n };\n\n _proto.tickImmediate = function tickImmediate() {\n this.clearNextTick();\n this._tickTimer = self.setTimeout(this._boundTick, 0);\n }\n /**\n * For subclass to implement task logic\n * @abstract\n */\n ;\n\n _proto.doTick = function doTick() {};\n\n return TaskLoop;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/types/cmcd.ts\":\n/*!***************************!*\\\n !*** ./src/types/cmcd.ts ***!\n \\***************************/\n/*! exports provided: CMCDVersion, CMCDObjectType, CMCDStreamingFormat, CMCDStreamType */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"CMCDVersion\", function() { return CMCDVersion; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"CMCDObjectType\", function() { return CMCDObjectType; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"CMCDStreamingFormat\", function() { return CMCDStreamingFormat; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"CMCDStreamType\", function() { return CMCDStreamType; });\n/**\n * CMCD spec version\n */\nvar CMCDVersion = 1;\n/**\n * CMCD Object Type\n */\n\nvar CMCDObjectType;\n/**\n * CMCD Streaming Format\n */\n\n(function (CMCDObjectType) {\n CMCDObjectType[\"MANIFEST\"] = \"m\";\n CMCDObjectType[\"AUDIO\"] = \"a\";\n CMCDObjectType[\"VIDEO\"] = \"v\";\n CMCDObjectType[\"MUXED\"] = \"av\";\n CMCDObjectType[\"INIT\"] = \"i\";\n CMCDObjectType[\"CAPTION\"] = \"c\";\n CMCDObjectType[\"TIMED_TEXT\"] = \"tt\";\n CMCDObjectType[\"KEY\"] = \"k\";\n CMCDObjectType[\"OTHER\"] = \"o\";\n})(CMCDObjectType || (CMCDObjectType = {}));\n\nvar CMCDStreamingFormat;\n/**\n * CMCD Streaming Type\n */\n\n(function (CMCDStreamingFormat) {\n CMCDStreamingFormat[\"DASH\"] = \"d\";\n CMCDStreamingFormat[\"HLS\"] = \"h\";\n CMCDStreamingFormat[\"SMOOTH\"] = \"s\";\n CMCDStreamingFormat[\"OTHER\"] = \"o\";\n})(CMCDStreamingFormat || (CMCDStreamingFormat = {}));\n\nvar CMCDStreamType;\n/**\n * CMCD Headers\n */\n\n(function (CMCDStreamType) {\n CMCDStreamType[\"VOD\"] = \"v\";\n CMCDStreamType[\"LIVE\"] = \"l\";\n})(CMCDStreamType || (CMCDStreamType = {}));\n\n/***/ }),\n\n/***/ \"./src/types/demuxer.ts\":\n/*!******************************!*\\\n !*** ./src/types/demuxer.ts ***!\n \\******************************/\n/*! exports provided: MetadataSchema */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MetadataSchema\", function() { return MetadataSchema; });\nvar MetadataSchema;\n\n(function (MetadataSchema) {\n MetadataSchema[\"audioId3\"] = \"org.id3\";\n MetadataSchema[\"dateRange\"] = \"com.apple.quicktime.HLS\";\n MetadataSchema[\"emsg\"] = \"https://aomedia.org/emsg/ID3\";\n})(MetadataSchema || (MetadataSchema = {}));\n\n/***/ }),\n\n/***/ \"./src/types/level.ts\":\n/*!****************************!*\\\n !*** ./src/types/level.ts ***!\n \\****************************/\n/*! exports provided: HlsSkip, getSkipValue, HlsUrlParameters, Level */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"HlsSkip\", function() { return HlsSkip; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getSkipValue\", function() { return getSkipValue; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"HlsUrlParameters\", function() { return HlsUrlParameters; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Level\", function() { return Level; });\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\n\nvar HlsSkip;\n\n(function (HlsSkip) {\n HlsSkip[\"No\"] = \"\";\n HlsSkip[\"Yes\"] = \"YES\";\n HlsSkip[\"v2\"] = \"v2\";\n})(HlsSkip || (HlsSkip = {}));\n\nfunction getSkipValue(details, msn) {\n var canSkipUntil = details.canSkipUntil,\n canSkipDateRanges = details.canSkipDateRanges,\n endSN = details.endSN;\n var snChangeGoal = msn !== undefined ? msn - endSN : 0;\n\n if (canSkipUntil && snChangeGoal < canSkipUntil) {\n if (canSkipDateRanges) {\n return HlsSkip.v2;\n }\n\n return HlsSkip.Yes;\n }\n\n return HlsSkip.No;\n}\nvar HlsUrlParameters = /*#__PURE__*/function () {\n function HlsUrlParameters(msn, part, skip) {\n this.msn = void 0;\n this.part = void 0;\n this.skip = void 0;\n this.msn = msn;\n this.part = part;\n this.skip = skip;\n }\n\n var _proto = HlsUrlParameters.prototype;\n\n _proto.addDirectives = function addDirectives(uri) {\n var url = new self.URL(uri);\n\n if (this.msn !== undefined) {\n url.searchParams.set('_HLS_msn', this.msn.toString());\n }\n\n if (this.part !== undefined) {\n url.searchParams.set('_HLS_part', this.part.toString());\n }\n\n if (this.skip) {\n url.searchParams.set('_HLS_skip', this.skip);\n }\n\n return url.toString();\n };\n\n return HlsUrlParameters;\n}();\nvar Level = /*#__PURE__*/function () {\n function Level(data) {\n this.attrs = void 0;\n this.audioCodec = void 0;\n this.bitrate = void 0;\n this.codecSet = void 0;\n this.height = void 0;\n this.id = void 0;\n this.name = void 0;\n this.videoCodec = void 0;\n this.width = void 0;\n this.unknownCodecs = void 0;\n this.audioGroupIds = void 0;\n this.details = void 0;\n this.fragmentError = 0;\n this.loadError = 0;\n this.loaded = void 0;\n this.realBitrate = 0;\n this.textGroupIds = void 0;\n this.url = void 0;\n this._urlId = 0;\n this.url = [data.url];\n this.attrs = data.attrs;\n this.bitrate = data.bitrate;\n\n if (data.details) {\n this.details = data.details;\n }\n\n this.id = data.id || 0;\n this.name = data.name;\n this.width = data.width || 0;\n this.height = data.height || 0;\n this.audioCodec = data.audioCodec;\n this.videoCodec = data.videoCodec;\n this.unknownCodecs = data.unknownCodecs;\n this.codecSet = [data.videoCodec, data.audioCodec].filter(function (c) {\n return c;\n }).join(',').replace(/\\.[^.,]+/g, '');\n }\n\n _createClass(Level, [{\n key: \"maxBitrate\",\n get: function get() {\n return Math.max(this.realBitrate, this.bitrate);\n }\n }, {\n key: \"uri\",\n get: function get() {\n return this.url[this._urlId] || '';\n }\n }, {\n key: \"urlId\",\n get: function get() {\n return this._urlId;\n },\n set: function set(value) {\n var newValue = value % this.url.length;\n\n if (this._urlId !== newValue) {\n this.details = undefined;\n this._urlId = newValue;\n }\n }\n }]);\n\n return Level;\n}();\n\n/***/ }),\n\n/***/ \"./src/types/loader.ts\":\n/*!*****************************!*\\\n !*** ./src/types/loader.ts ***!\n \\*****************************/\n/*! exports provided: PlaylistContextType, PlaylistLevelType */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"PlaylistContextType\", function() { return PlaylistContextType; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"PlaylistLevelType\", function() { return PlaylistLevelType; });\nvar PlaylistContextType;\n\n(function (PlaylistContextType) {\n PlaylistContextType[\"MANIFEST\"] = \"manifest\";\n PlaylistContextType[\"LEVEL\"] = \"level\";\n PlaylistContextType[\"AUDIO_TRACK\"] = \"audioTrack\";\n PlaylistContextType[\"SUBTITLE_TRACK\"] = \"subtitleTrack\";\n})(PlaylistContextType || (PlaylistContextType = {}));\n\nvar PlaylistLevelType;\n\n(function (PlaylistLevelType) {\n PlaylistLevelType[\"MAIN\"] = \"main\";\n PlaylistLevelType[\"AUDIO\"] = \"audio\";\n PlaylistLevelType[\"SUBTITLE\"] = \"subtitle\";\n})(PlaylistLevelType || (PlaylistLevelType = {}));\n\n/***/ }),\n\n/***/ \"./src/types/transmuxer.ts\":\n/*!*********************************!*\\\n !*** ./src/types/transmuxer.ts ***!\n \\*********************************/\n/*! exports provided: ChunkMetadata */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ChunkMetadata\", function() { return ChunkMetadata; });\nvar ChunkMetadata = function ChunkMetadata(level, sn, id, size, part, partial) {\n if (size === void 0) {\n size = 0;\n }\n\n if (part === void 0) {\n part = -1;\n }\n\n if (partial === void 0) {\n partial = false;\n }\n\n this.level = void 0;\n this.sn = void 0;\n this.part = void 0;\n this.id = void 0;\n this.size = void 0;\n this.partial = void 0;\n this.transmuxing = getNewPerformanceTiming();\n this.buffering = {\n audio: getNewPerformanceTiming(),\n video: getNewPerformanceTiming(),\n audiovideo: getNewPerformanceTiming()\n };\n this.level = level;\n this.sn = sn;\n this.id = id;\n this.size = size;\n this.part = part;\n this.partial = partial;\n};\n\nfunction getNewPerformanceTiming() {\n return {\n start: 0,\n executeStart: 0,\n executeEnd: 0,\n end: 0\n };\n}\n\n/***/ }),\n\n/***/ \"./src/utils/attr-list.ts\":\n/*!********************************!*\\\n !*** ./src/utils/attr-list.ts ***!\n \\********************************/\n/*! exports provided: AttrList */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"AttrList\", function() { return AttrList; });\nvar DECIMAL_RESOLUTION_REGEX = /^(\\d+)x(\\d+)$/; // eslint-disable-line no-useless-escape\n\nvar ATTR_LIST_REGEX = /\\s*(.+?)\\s*=((?:\\\".*?\\\")|.*?)(?:,|$)/g; // eslint-disable-line no-useless-escape\n// adapted from https://github.com/kanongil/node-m3u8parse/blob/master/attrlist.js\n\nvar AttrList = /*#__PURE__*/function () {\n function AttrList(attrs) {\n if (typeof attrs === 'string') {\n attrs = AttrList.parseAttrList(attrs);\n }\n\n for (var attr in attrs) {\n if (attrs.hasOwnProperty(attr)) {\n this[attr] = attrs[attr];\n }\n }\n }\n\n var _proto = AttrList.prototype;\n\n _proto.decimalInteger = function decimalInteger(attrName) {\n var intValue = parseInt(this[attrName], 10);\n\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n };\n\n _proto.hexadecimalInteger = function hexadecimalInteger(attrName) {\n if (this[attrName]) {\n var stringValue = (this[attrName] || '0x').slice(2);\n stringValue = (stringValue.length & 1 ? '0' : '') + stringValue;\n var value = new Uint8Array(stringValue.length / 2);\n\n for (var i = 0; i < stringValue.length / 2; i++) {\n value[i] = parseInt(stringValue.slice(i * 2, i * 2 + 2), 16);\n }\n\n return value;\n } else {\n return null;\n }\n };\n\n _proto.hexadecimalIntegerAsNumber = function hexadecimalIntegerAsNumber(attrName) {\n var intValue = parseInt(this[attrName], 16);\n\n if (intValue > Number.MAX_SAFE_INTEGER) {\n return Infinity;\n }\n\n return intValue;\n };\n\n _proto.decimalFloatingPoint = function decimalFloatingPoint(attrName) {\n return parseFloat(this[attrName]);\n };\n\n _proto.optionalFloat = function optionalFloat(attrName, defaultValue) {\n var value = this[attrName];\n return value ? parseFloat(value) : defaultValue;\n };\n\n _proto.enumeratedString = function enumeratedString(attrName) {\n return this[attrName];\n };\n\n _proto.bool = function bool(attrName) {\n return this[attrName] === 'YES';\n };\n\n _proto.decimalResolution = function decimalResolution(attrName) {\n var res = DECIMAL_RESOLUTION_REGEX.exec(this[attrName]);\n\n if (res === null) {\n return undefined;\n }\n\n return {\n width: parseInt(res[1], 10),\n height: parseInt(res[2], 10)\n };\n };\n\n AttrList.parseAttrList = function parseAttrList(input) {\n var match;\n var attrs = {};\n var quote = '\"';\n ATTR_LIST_REGEX.lastIndex = 0;\n\n while ((match = ATTR_LIST_REGEX.exec(input)) !== null) {\n var value = match[2];\n\n if (value.indexOf(quote) === 0 && value.lastIndexOf(quote) === value.length - 1) {\n value = value.slice(1, -1);\n }\n\n attrs[match[1]] = value;\n }\n\n return attrs;\n };\n\n return AttrList;\n}();\n\n/***/ }),\n\n/***/ \"./src/utils/binary-search.ts\":\n/*!************************************!*\\\n !*** ./src/utils/binary-search.ts ***!\n \\************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\nvar BinarySearch = {\n /**\n * Searches for an item in an array which matches a certain condition.\n * This requires the condition to only match one item in the array,\n * and for the array to be ordered.\n *\n * @param {Array<T>} list The array to search.\n * @param {BinarySearchComparison<T>} comparisonFn\n * Called and provided a candidate item as the first argument.\n * Should return:\n * > -1 if the item should be located at a lower index than the provided item.\n * > 1 if the item should be located at a higher index than the provided item.\n * > 0 if the item is the item you're looking for.\n *\n * @return {T | null} The object if it is found or null otherwise.\n */\n search: function search(list, comparisonFn) {\n var minIndex = 0;\n var maxIndex = list.length - 1;\n var currentIndex = null;\n var currentElement = null;\n\n while (minIndex <= maxIndex) {\n currentIndex = (minIndex + maxIndex) / 2 | 0;\n currentElement = list[currentIndex];\n var comparisonResult = comparisonFn(currentElement);\n\n if (comparisonResult > 0) {\n minIndex = currentIndex + 1;\n } else if (comparisonResult < 0) {\n maxIndex = currentIndex - 1;\n } else {\n return currentElement;\n }\n }\n\n return null;\n }\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (BinarySearch);\n\n/***/ }),\n\n/***/ \"./src/utils/buffer-helper.ts\":\n/*!************************************!*\\\n !*** ./src/utils/buffer-helper.ts ***!\n \\************************************/\n/*! exports provided: BufferHelper */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"BufferHelper\", function() { return BufferHelper; });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./logger */ \"./src/utils/logger.ts\");\n/**\n * @module BufferHelper\n *\n * Providing methods dealing with buffer length retrieval for example.\n *\n * In general, a helper around HTML5 MediaElement TimeRanges gathered from `buffered` property.\n *\n * Also @see https://developer.mozilla.org/en-US/docs/Web/API/HTMLMediaElement/buffered\n */\n\nvar noopBuffered = {\n length: 0,\n start: function start() {\n return 0;\n },\n end: function end() {\n return 0;\n }\n};\nvar BufferHelper = /*#__PURE__*/function () {\n function BufferHelper() {}\n\n /**\n * Return true if `media`'s buffered include `position`\n * @param {Bufferable} media\n * @param {number} position\n * @returns {boolean}\n */\n BufferHelper.isBuffered = function isBuffered(media, position) {\n try {\n if (media) {\n var buffered = BufferHelper.getBuffered(media);\n\n for (var i = 0; i < buffered.length; i++) {\n if (position >= buffered.start(i) && position <= buffered.end(i)) {\n return true;\n }\n }\n }\n } catch (error) {// this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n\n return false;\n };\n\n BufferHelper.bufferInfo = function bufferInfo(media, pos, maxHoleDuration) {\n try {\n if (media) {\n var vbuffered = BufferHelper.getBuffered(media);\n var buffered = [];\n var i;\n\n for (i = 0; i < vbuffered.length; i++) {\n buffered.push({\n start: vbuffered.start(i),\n end: vbuffered.end(i)\n });\n }\n\n return this.bufferedInfo(buffered, pos, maxHoleDuration);\n }\n } catch (error) {// this is to catch\n // InvalidStateError: Failed to read the 'buffered' property from 'SourceBuffer':\n // This SourceBuffer has been removed from the parent media source\n }\n\n return {\n len: 0,\n start: pos,\n end: pos,\n nextStart: undefined\n };\n };\n\n BufferHelper.bufferedInfo = function bufferedInfo(buffered, pos, maxHoleDuration) {\n pos = Math.max(0, pos); // sort on buffer.start/smaller end (IE does not always return sorted buffered range)\n\n buffered.sort(function (a, b) {\n var diff = a.start - b.start;\n\n if (diff) {\n return diff;\n } else {\n return b.end - a.end;\n }\n });\n var buffered2 = [];\n\n if (maxHoleDuration) {\n // there might be some small holes between buffer time range\n // consider that holes smaller than maxHoleDuration are irrelevant and build another\n // buffer time range representations that discards those holes\n for (var i = 0; i < buffered.length; i++) {\n var buf2len = buffered2.length;\n\n if (buf2len) {\n var buf2end = buffered2[buf2len - 1].end; // if small hole (value between 0 or maxHoleDuration ) or overlapping (negative)\n\n if (buffered[i].start - buf2end < maxHoleDuration) {\n // merge overlapping time ranges\n // update lastRange.end only if smaller than item.end\n // e.g. [ 1, 15] with [ 2,8] => [ 1,15] (no need to modify lastRange.end)\n // whereas [ 1, 8] with [ 2,15] => [ 1,15] ( lastRange should switch from [1,8] to [1,15])\n if (buffered[i].end > buf2end) {\n buffered2[buf2len - 1].end = buffered[i].end;\n }\n } else {\n // big hole\n buffered2.push(buffered[i]);\n }\n } else {\n // first value\n buffered2.push(buffered[i]);\n }\n }\n } else {\n buffered2 = buffered;\n }\n\n var bufferLen = 0; // bufferStartNext can possibly be undefined based on the conditional logic below\n\n var bufferStartNext; // bufferStart and bufferEnd are buffer boundaries around current video position\n\n var bufferStart = pos;\n var bufferEnd = pos;\n\n for (var _i = 0; _i < buffered2.length; _i++) {\n var start = buffered2[_i].start;\n var end = buffered2[_i].end; // logger.log('buf start/end:' + buffered.start(i) + '/' + buffered.end(i));\n\n if (pos + maxHoleDuration >= start && pos < end) {\n // play position is inside this buffer TimeRange, retrieve end of buffer position and buffer length\n bufferStart = start;\n bufferEnd = end;\n bufferLen = bufferEnd - pos;\n } else if (pos + maxHoleDuration < start) {\n bufferStartNext = start;\n break;\n }\n }\n\n return {\n len: bufferLen,\n start: bufferStart || 0,\n end: bufferEnd || 0,\n nextStart: bufferStartNext\n };\n }\n /**\n * Safe method to get buffered property.\n * SourceBuffer.buffered may throw if SourceBuffer is removed from it's MediaSource\n */\n ;\n\n BufferHelper.getBuffered = function getBuffered(media) {\n try {\n return media.buffered;\n } catch (e) {\n _logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].log('failed to get media.buffered', e);\n return noopBuffered;\n }\n };\n\n return BufferHelper;\n}();\n\n/***/ }),\n\n/***/ \"./src/utils/cea-608-parser.ts\":\n/*!*************************************!*\\\n !*** ./src/utils/cea-608-parser.ts ***!\n \\*************************************/\n/*! exports provided: Row, CaptionScreen, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Row\", function() { return Row; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"CaptionScreen\", function() { return CaptionScreen; });\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n\n/**\n *\n * This code was ported from the dash.js project at:\n * https://github.com/Dash-Industry-Forum/dash.js/blob/development/externals/cea608-parser.js\n * https://github.com/Dash-Industry-Forum/dash.js/commit/8269b26a761e0853bb21d78780ed945144ecdd4d#diff-71bc295a2d6b6b7093a1d3290d53a4b2\n *\n * The original copyright appears below:\n *\n * The copyright in this software is being made available under the BSD License,\n * included below. This software may be subject to other third party and contributor\n * rights, including patent rights, and no such rights are granted under this license.\n *\n * Copyright (c) 2015-2016, DASH Industry Forum.\n * All rights reserved.\n *\n * Redistribution and use in source and binary forms, with or without modification,\n * are permitted provided that the following conditions are met:\n * 1. Redistributions of source code must retain the above copyright notice, this\n * list of conditions and the following disclaimer.\n * * Redistributions in binary form must reproduce the above copyright notice,\n * this list of conditions and the following disclaimer in the documentation and/or\n * other materials provided with the distribution.\n * 2. Neither the name of Dash Industry Forum nor the names of its\n * contributors may be used to endorse or promote products derived from this software\n * without specific prior written permission.\n *\n * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS AS IS AND ANY\n * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED\n * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.\n * IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,\n * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT\n * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR\n * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,\n * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE\n * POSSIBILITY OF SUCH DAMAGE.\n */\n\n/**\n * Exceptions from regular ASCII. CodePoints are mapped to UTF-16 codes\n */\n\nvar specialCea608CharsCodes = {\n 0x2a: 0xe1,\n // lowercase a, acute accent\n 0x5c: 0xe9,\n // lowercase e, acute accent\n 0x5e: 0xed,\n // lowercase i, acute accent\n 0x5f: 0xf3,\n // lowercase o, acute accent\n 0x60: 0xfa,\n // lowercase u, acute accent\n 0x7b: 0xe7,\n // lowercase c with cedilla\n 0x7c: 0xf7,\n // division symbol\n 0x7d: 0xd1,\n // uppercase N tilde\n 0x7e: 0xf1,\n // lowercase n tilde\n 0x7f: 0x2588,\n // Full block\n // THIS BLOCK INCLUDES THE 16 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x11 AND LOW BETWEEN 0x30 AND 0x3F\n // THIS MEANS THAT \\x50 MUST BE ADDED TO THE VALUES\n 0x80: 0xae,\n // Registered symbol (R)\n 0x81: 0xb0,\n // degree sign\n 0x82: 0xbd,\n // 1/2 symbol\n 0x83: 0xbf,\n // Inverted (open) question mark\n 0x84: 0x2122,\n // Trademark symbol (TM)\n 0x85: 0xa2,\n // Cents symbol\n 0x86: 0xa3,\n // Pounds sterling\n 0x87: 0x266a,\n // Music 8'th note\n 0x88: 0xe0,\n // lowercase a, grave accent\n 0x89: 0x20,\n // transparent space (regular)\n 0x8a: 0xe8,\n // lowercase e, grave accent\n 0x8b: 0xe2,\n // lowercase a, circumflex accent\n 0x8c: 0xea,\n // lowercase e, circumflex accent\n 0x8d: 0xee,\n // lowercase i, circumflex accent\n 0x8e: 0xf4,\n // lowercase o, circumflex accent\n 0x8f: 0xfb,\n // lowercase u, circumflex accent\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x12 AND LOW BETWEEN 0x20 AND 0x3F\n 0x90: 0xc1,\n // capital letter A with acute\n 0x91: 0xc9,\n // capital letter E with acute\n 0x92: 0xd3,\n // capital letter O with acute\n 0x93: 0xda,\n // capital letter U with acute\n 0x94: 0xdc,\n // capital letter U with diaresis\n 0x95: 0xfc,\n // lowercase letter U with diaeresis\n 0x96: 0x2018,\n // opening single quote\n 0x97: 0xa1,\n // inverted exclamation mark\n 0x98: 0x2a,\n // asterisk\n 0x99: 0x2019,\n // closing single quote\n 0x9a: 0x2501,\n // box drawings heavy horizontal\n 0x9b: 0xa9,\n // copyright sign\n 0x9c: 0x2120,\n // Service mark\n 0x9d: 0x2022,\n // (round) bullet\n 0x9e: 0x201c,\n // Left double quotation mark\n 0x9f: 0x201d,\n // Right double quotation mark\n 0xa0: 0xc0,\n // uppercase A, grave accent\n 0xa1: 0xc2,\n // uppercase A, circumflex\n 0xa2: 0xc7,\n // uppercase C with cedilla\n 0xa3: 0xc8,\n // uppercase E, grave accent\n 0xa4: 0xca,\n // uppercase E, circumflex\n 0xa5: 0xcb,\n // capital letter E with diaresis\n 0xa6: 0xeb,\n // lowercase letter e with diaresis\n 0xa7: 0xce,\n // uppercase I, circumflex\n 0xa8: 0xcf,\n // uppercase I, with diaresis\n 0xa9: 0xef,\n // lowercase i, with diaresis\n 0xaa: 0xd4,\n // uppercase O, circumflex\n 0xab: 0xd9,\n // uppercase U, grave accent\n 0xac: 0xf9,\n // lowercase u, grave accent\n 0xad: 0xdb,\n // uppercase U, circumflex\n 0xae: 0xab,\n // left-pointing double angle quotation mark\n 0xaf: 0xbb,\n // right-pointing double angle quotation mark\n // THIS BLOCK INCLUDES THE 32 EXTENDED (TWO-BYTE) LINE 21 CHARACTERS\n // THAT COME FROM HI BYTE=0x13 AND LOW BETWEEN 0x20 AND 0x3F\n 0xb0: 0xc3,\n // Uppercase A, tilde\n 0xb1: 0xe3,\n // Lowercase a, tilde\n 0xb2: 0xcd,\n // Uppercase I, acute accent\n 0xb3: 0xcc,\n // Uppercase I, grave accent\n 0xb4: 0xec,\n // Lowercase i, grave accent\n 0xb5: 0xd2,\n // Uppercase O, grave accent\n 0xb6: 0xf2,\n // Lowercase o, grave accent\n 0xb7: 0xd5,\n // Uppercase O, tilde\n 0xb8: 0xf5,\n // Lowercase o, tilde\n 0xb9: 0x7b,\n // Open curly brace\n 0xba: 0x7d,\n // Closing curly brace\n 0xbb: 0x5c,\n // Backslash\n 0xbc: 0x5e,\n // Caret\n 0xbd: 0x5f,\n // Underscore\n 0xbe: 0x7c,\n // Pipe (vertical line)\n 0xbf: 0x223c,\n // Tilde operator\n 0xc0: 0xc4,\n // Uppercase A, umlaut\n 0xc1: 0xe4,\n // Lowercase A, umlaut\n 0xc2: 0xd6,\n // Uppercase O, umlaut\n 0xc3: 0xf6,\n // Lowercase o, umlaut\n 0xc4: 0xdf,\n // Esszett (sharp S)\n 0xc5: 0xa5,\n // Yen symbol\n 0xc6: 0xa4,\n // Generic currency sign\n 0xc7: 0x2503,\n // Box drawings heavy vertical\n 0xc8: 0xc5,\n // Uppercase A, ring\n 0xc9: 0xe5,\n // Lowercase A, ring\n 0xca: 0xd8,\n // Uppercase O, stroke\n 0xcb: 0xf8,\n // Lowercase o, strok\n 0xcc: 0x250f,\n // Box drawings heavy down and right\n 0xcd: 0x2513,\n // Box drawings heavy down and left\n 0xce: 0x2517,\n // Box drawings heavy up and right\n 0xcf: 0x251b // Box drawings heavy up and left\n\n};\n/**\n * Utils\n */\n\nvar getCharForByte = function getCharForByte(_byte) {\n var charCode = _byte;\n\n if (specialCea608CharsCodes.hasOwnProperty(_byte)) {\n charCode = specialCea608CharsCodes[_byte];\n }\n\n return String.fromCharCode(charCode);\n};\n\nvar NR_ROWS = 15;\nvar NR_COLS = 100; // Tables to look up row from PAC data\n\nvar rowsLowCh1 = {\n 0x11: 1,\n 0x12: 3,\n 0x15: 5,\n 0x16: 7,\n 0x17: 9,\n 0x10: 11,\n 0x13: 12,\n 0x14: 14\n};\nvar rowsHighCh1 = {\n 0x11: 2,\n 0x12: 4,\n 0x15: 6,\n 0x16: 8,\n 0x17: 10,\n 0x13: 13,\n 0x14: 15\n};\nvar rowsLowCh2 = {\n 0x19: 1,\n 0x1a: 3,\n 0x1d: 5,\n 0x1e: 7,\n 0x1f: 9,\n 0x18: 11,\n 0x1b: 12,\n 0x1c: 14\n};\nvar rowsHighCh2 = {\n 0x19: 2,\n 0x1a: 4,\n 0x1d: 6,\n 0x1e: 8,\n 0x1f: 10,\n 0x1b: 13,\n 0x1c: 15\n};\nvar backgroundColors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'black', 'transparent'];\nvar VerboseLevel;\n\n(function (VerboseLevel) {\n VerboseLevel[VerboseLevel[\"ERROR\"] = 0] = \"ERROR\";\n VerboseLevel[VerboseLevel[\"TEXT\"] = 1] = \"TEXT\";\n VerboseLevel[VerboseLevel[\"WARNING\"] = 2] = \"WARNING\";\n VerboseLevel[VerboseLevel[\"INFO\"] = 2] = \"INFO\";\n VerboseLevel[VerboseLevel[\"DEBUG\"] = 3] = \"DEBUG\";\n VerboseLevel[VerboseLevel[\"DATA\"] = 3] = \"DATA\";\n})(VerboseLevel || (VerboseLevel = {}));\n\nvar CaptionsLogger = /*#__PURE__*/function () {\n function CaptionsLogger() {\n this.time = null;\n this.verboseLevel = VerboseLevel.ERROR;\n }\n\n var _proto = CaptionsLogger.prototype;\n\n _proto.log = function log(severity, msg) {\n if (this.verboseLevel >= severity) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].log(this.time + \" [\" + severity + \"] \" + msg);\n }\n };\n\n return CaptionsLogger;\n}();\n\nvar numArrayToHexArray = function numArrayToHexArray(numArray) {\n var hexArray = [];\n\n for (var j = 0; j < numArray.length; j++) {\n hexArray.push(numArray[j].toString(16));\n }\n\n return hexArray;\n};\n\nvar PenState = /*#__PURE__*/function () {\n function PenState(foreground, underline, italics, background, flash) {\n this.foreground = void 0;\n this.underline = void 0;\n this.italics = void 0;\n this.background = void 0;\n this.flash = void 0;\n this.foreground = foreground || 'white';\n this.underline = underline || false;\n this.italics = italics || false;\n this.background = background || 'black';\n this.flash = flash || false;\n }\n\n var _proto2 = PenState.prototype;\n\n _proto2.reset = function reset() {\n this.foreground = 'white';\n this.underline = false;\n this.italics = false;\n this.background = 'black';\n this.flash = false;\n };\n\n _proto2.setStyles = function setStyles(styles) {\n var attribs = ['foreground', 'underline', 'italics', 'background', 'flash'];\n\n for (var i = 0; i < attribs.length; i++) {\n var style = attribs[i];\n\n if (styles.hasOwnProperty(style)) {\n this[style] = styles[style];\n }\n }\n };\n\n _proto2.isDefault = function isDefault() {\n return this.foreground === 'white' && !this.underline && !this.italics && this.background === 'black' && !this.flash;\n };\n\n _proto2.equals = function equals(other) {\n return this.foreground === other.foreground && this.underline === other.underline && this.italics === other.italics && this.background === other.background && this.flash === other.flash;\n };\n\n _proto2.copy = function copy(newPenState) {\n this.foreground = newPenState.foreground;\n this.underline = newPenState.underline;\n this.italics = newPenState.italics;\n this.background = newPenState.background;\n this.flash = newPenState.flash;\n };\n\n _proto2.toString = function toString() {\n return 'color=' + this.foreground + ', underline=' + this.underline + ', italics=' + this.italics + ', background=' + this.background + ', flash=' + this.flash;\n };\n\n return PenState;\n}();\n/**\n * Unicode character with styling and background.\n * @constructor\n */\n\n\nvar StyledUnicodeChar = /*#__PURE__*/function () {\n function StyledUnicodeChar(uchar, foreground, underline, italics, background, flash) {\n this.uchar = void 0;\n this.penState = void 0;\n this.uchar = uchar || ' '; // unicode character\n\n this.penState = new PenState(foreground, underline, italics, background, flash);\n }\n\n var _proto3 = StyledUnicodeChar.prototype;\n\n _proto3.reset = function reset() {\n this.uchar = ' ';\n this.penState.reset();\n };\n\n _proto3.setChar = function setChar(uchar, newPenState) {\n this.uchar = uchar;\n this.penState.copy(newPenState);\n };\n\n _proto3.setPenState = function setPenState(newPenState) {\n this.penState.copy(newPenState);\n };\n\n _proto3.equals = function equals(other) {\n return this.uchar === other.uchar && this.penState.equals(other.penState);\n };\n\n _proto3.copy = function copy(newChar) {\n this.uchar = newChar.uchar;\n this.penState.copy(newChar.penState);\n };\n\n _proto3.isEmpty = function isEmpty() {\n return this.uchar === ' ' && this.penState.isDefault();\n };\n\n return StyledUnicodeChar;\n}();\n/**\n * CEA-608 row consisting of NR_COLS instances of StyledUnicodeChar.\n * @constructor\n */\n\n\nvar Row = /*#__PURE__*/function () {\n function Row(logger) {\n this.chars = void 0;\n this.pos = void 0;\n this.currPenState = void 0;\n this.cueStartTime = void 0;\n this.logger = void 0;\n this.chars = [];\n\n for (var i = 0; i < NR_COLS; i++) {\n this.chars.push(new StyledUnicodeChar());\n }\n\n this.logger = logger;\n this.pos = 0;\n this.currPenState = new PenState();\n }\n\n var _proto4 = Row.prototype;\n\n _proto4.equals = function equals(other) {\n var equal = true;\n\n for (var i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].equals(other.chars[i])) {\n equal = false;\n break;\n }\n }\n\n return equal;\n };\n\n _proto4.copy = function copy(other) {\n for (var i = 0; i < NR_COLS; i++) {\n this.chars[i].copy(other.chars[i]);\n }\n };\n\n _proto4.isEmpty = function isEmpty() {\n var empty = true;\n\n for (var i = 0; i < NR_COLS; i++) {\n if (!this.chars[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n\n return empty;\n }\n /**\n * Set the cursor to a valid column.\n */\n ;\n\n _proto4.setCursor = function setCursor(absPos) {\n if (this.pos !== absPos) {\n this.pos = absPos;\n }\n\n if (this.pos < 0) {\n this.logger.log(VerboseLevel.DEBUG, 'Negative cursor position ' + this.pos);\n this.pos = 0;\n } else if (this.pos > NR_COLS) {\n this.logger.log(VerboseLevel.DEBUG, 'Too large cursor position ' + this.pos);\n this.pos = NR_COLS;\n }\n }\n /**\n * Move the cursor relative to current position.\n */\n ;\n\n _proto4.moveCursor = function moveCursor(relPos) {\n var newPos = this.pos + relPos;\n\n if (relPos > 1) {\n for (var i = this.pos + 1; i < newPos + 1; i++) {\n this.chars[i].setPenState(this.currPenState);\n }\n }\n\n this.setCursor(newPos);\n }\n /**\n * Backspace, move one step back and clear character.\n */\n ;\n\n _proto4.backSpace = function backSpace() {\n this.moveCursor(-1);\n this.chars[this.pos].setChar(' ', this.currPenState);\n };\n\n _proto4.insertChar = function insertChar(_byte2) {\n if (_byte2 >= 0x90) {\n // Extended char\n this.backSpace();\n }\n\n var _char = getCharForByte(_byte2);\n\n if (this.pos >= NR_COLS) {\n this.logger.log(VerboseLevel.ERROR, 'Cannot insert ' + _byte2.toString(16) + ' (' + _char + ') at position ' + this.pos + '. Skipping it!');\n return;\n }\n\n this.chars[this.pos].setChar(_char, this.currPenState);\n this.moveCursor(1);\n };\n\n _proto4.clearFromPos = function clearFromPos(startPos) {\n var i;\n\n for (i = startPos; i < NR_COLS; i++) {\n this.chars[i].reset();\n }\n };\n\n _proto4.clear = function clear() {\n this.clearFromPos(0);\n this.pos = 0;\n this.currPenState.reset();\n };\n\n _proto4.clearToEndOfRow = function clearToEndOfRow() {\n this.clearFromPos(this.pos);\n };\n\n _proto4.getTextString = function getTextString() {\n var chars = [];\n var empty = true;\n\n for (var i = 0; i < NR_COLS; i++) {\n var _char2 = this.chars[i].uchar;\n\n if (_char2 !== ' ') {\n empty = false;\n }\n\n chars.push(_char2);\n }\n\n if (empty) {\n return '';\n } else {\n return chars.join('');\n }\n };\n\n _proto4.setPenStyles = function setPenStyles(styles) {\n this.currPenState.setStyles(styles);\n var currChar = this.chars[this.pos];\n currChar.setPenState(this.currPenState);\n };\n\n return Row;\n}();\n/**\n * Keep a CEA-608 screen of 32x15 styled characters\n * @constructor\n */\n\nvar CaptionScreen = /*#__PURE__*/function () {\n function CaptionScreen(logger) {\n this.rows = void 0;\n this.currRow = void 0;\n this.nrRollUpRows = void 0;\n this.lastOutputScreen = void 0;\n this.logger = void 0;\n this.rows = [];\n\n for (var i = 0; i < NR_ROWS; i++) {\n this.rows.push(new Row(logger));\n } // Note that we use zero-based numbering (0-14)\n\n\n this.logger = logger;\n this.currRow = NR_ROWS - 1;\n this.nrRollUpRows = null;\n this.lastOutputScreen = null;\n this.reset();\n }\n\n var _proto5 = CaptionScreen.prototype;\n\n _proto5.reset = function reset() {\n for (var i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n }\n\n this.currRow = NR_ROWS - 1;\n };\n\n _proto5.equals = function equals(other) {\n var equal = true;\n\n for (var i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].equals(other.rows[i])) {\n equal = false;\n break;\n }\n }\n\n return equal;\n };\n\n _proto5.copy = function copy(other) {\n for (var i = 0; i < NR_ROWS; i++) {\n this.rows[i].copy(other.rows[i]);\n }\n };\n\n _proto5.isEmpty = function isEmpty() {\n var empty = true;\n\n for (var i = 0; i < NR_ROWS; i++) {\n if (!this.rows[i].isEmpty()) {\n empty = false;\n break;\n }\n }\n\n return empty;\n };\n\n _proto5.backSpace = function backSpace() {\n var row = this.rows[this.currRow];\n row.backSpace();\n };\n\n _proto5.clearToEndOfRow = function clearToEndOfRow() {\n var row = this.rows[this.currRow];\n row.clearToEndOfRow();\n }\n /**\n * Insert a character (without styling) in the current row.\n */\n ;\n\n _proto5.insertChar = function insertChar(_char3) {\n var row = this.rows[this.currRow];\n row.insertChar(_char3);\n };\n\n _proto5.setPen = function setPen(styles) {\n var row = this.rows[this.currRow];\n row.setPenStyles(styles);\n };\n\n _proto5.moveCursor = function moveCursor(relPos) {\n var row = this.rows[this.currRow];\n row.moveCursor(relPos);\n };\n\n _proto5.setCursor = function setCursor(absPos) {\n this.logger.log(VerboseLevel.INFO, 'setCursor: ' + absPos);\n var row = this.rows[this.currRow];\n row.setCursor(absPos);\n };\n\n _proto5.setPAC = function setPAC(pacData) {\n this.logger.log(VerboseLevel.INFO, 'pacData = ' + JSON.stringify(pacData));\n var newRow = pacData.row - 1;\n\n if (this.nrRollUpRows && newRow < this.nrRollUpRows - 1) {\n newRow = this.nrRollUpRows - 1;\n } // Make sure this only affects Roll-up Captions by checking this.nrRollUpRows\n\n\n if (this.nrRollUpRows && this.currRow !== newRow) {\n // clear all rows first\n for (var i = 0; i < NR_ROWS; i++) {\n this.rows[i].clear();\n } // Copy this.nrRollUpRows rows from lastOutputScreen and place it in the newRow location\n // topRowIndex - the start of rows to copy (inclusive index)\n\n\n var topRowIndex = this.currRow + 1 - this.nrRollUpRows; // We only copy if the last position was already shown.\n // We use the cueStartTime value to check this.\n\n var lastOutputScreen = this.lastOutputScreen;\n\n if (lastOutputScreen) {\n var prevLineTime = lastOutputScreen.rows[topRowIndex].cueStartTime;\n var time = this.logger.time;\n\n if (prevLineTime && time !== null && prevLineTime < time) {\n for (var _i = 0; _i < this.nrRollUpRows; _i++) {\n this.rows[newRow - this.nrRollUpRows + _i + 1].copy(lastOutputScreen.rows[topRowIndex + _i]);\n }\n }\n }\n }\n\n this.currRow = newRow;\n var row = this.rows[this.currRow];\n\n if (pacData.indent !== null) {\n var indent = pacData.indent;\n var prevPos = Math.max(indent - 1, 0);\n row.setCursor(pacData.indent);\n pacData.color = row.chars[prevPos].penState.foreground;\n }\n\n var styles = {\n foreground: pacData.color,\n underline: pacData.underline,\n italics: pacData.italics,\n background: 'black',\n flash: false\n };\n this.setPen(styles);\n }\n /**\n * Set background/extra foreground, but first do back_space, and then insert space (backwards compatibility).\n */\n ;\n\n _proto5.setBkgData = function setBkgData(bkgData) {\n this.logger.log(VerboseLevel.INFO, 'bkgData = ' + JSON.stringify(bkgData));\n this.backSpace();\n this.setPen(bkgData);\n this.insertChar(0x20); // Space\n };\n\n _proto5.setRollUpRows = function setRollUpRows(nrRows) {\n this.nrRollUpRows = nrRows;\n };\n\n _proto5.rollUp = function rollUp() {\n if (this.nrRollUpRows === null) {\n this.logger.log(VerboseLevel.DEBUG, 'roll_up but nrRollUpRows not set yet');\n return; // Not properly setup\n }\n\n this.logger.log(VerboseLevel.TEXT, this.getDisplayText());\n var topRowIndex = this.currRow + 1 - this.nrRollUpRows;\n var topRow = this.rows.splice(topRowIndex, 1)[0];\n topRow.clear();\n this.rows.splice(this.currRow, 0, topRow);\n this.logger.log(VerboseLevel.INFO, 'Rolling up'); // this.logger.log(VerboseLevel.TEXT, this.get_display_text())\n }\n /**\n * Get all non-empty rows with as unicode text.\n */\n ;\n\n _proto5.getDisplayText = function getDisplayText(asOneRow) {\n asOneRow = asOneRow || false;\n var displayText = [];\n var text = '';\n var rowNr = -1;\n\n for (var i = 0; i < NR_ROWS; i++) {\n var rowText = this.rows[i].getTextString();\n\n if (rowText) {\n rowNr = i + 1;\n\n if (asOneRow) {\n displayText.push('Row ' + rowNr + \": '\" + rowText + \"'\");\n } else {\n displayText.push(rowText.trim());\n }\n }\n }\n\n if (displayText.length > 0) {\n if (asOneRow) {\n text = '[' + displayText.join(' | ') + ']';\n } else {\n text = displayText.join('\\n');\n }\n }\n\n return text;\n };\n\n _proto5.getTextAndFormat = function getTextAndFormat() {\n return this.rows;\n };\n\n return CaptionScreen;\n}(); // var modes = ['MODE_ROLL-UP', 'MODE_POP-ON', 'MODE_PAINT-ON', 'MODE_TEXT'];\n\nvar Cea608Channel = /*#__PURE__*/function () {\n function Cea608Channel(channelNumber, outputFilter, logger) {\n this.chNr = void 0;\n this.outputFilter = void 0;\n this.mode = void 0;\n this.verbose = void 0;\n this.displayedMemory = void 0;\n this.nonDisplayedMemory = void 0;\n this.lastOutputScreen = void 0;\n this.currRollUpRow = void 0;\n this.writeScreen = void 0;\n this.cueStartTime = void 0;\n this.logger = void 0;\n this.chNr = channelNumber;\n this.outputFilter = outputFilter;\n this.mode = null;\n this.verbose = 0;\n this.displayedMemory = new CaptionScreen(logger);\n this.nonDisplayedMemory = new CaptionScreen(logger);\n this.lastOutputScreen = new CaptionScreen(logger);\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null; // Keeps track of where a cue started.\n\n this.logger = logger;\n }\n\n var _proto6 = Cea608Channel.prototype;\n\n _proto6.reset = function reset() {\n this.mode = null;\n this.displayedMemory.reset();\n this.nonDisplayedMemory.reset();\n this.lastOutputScreen.reset();\n this.outputFilter.reset();\n this.currRollUpRow = this.displayedMemory.rows[NR_ROWS - 1];\n this.writeScreen = this.displayedMemory;\n this.mode = null;\n this.cueStartTime = null;\n };\n\n _proto6.getHandler = function getHandler() {\n return this.outputFilter;\n };\n\n _proto6.setHandler = function setHandler(newHandler) {\n this.outputFilter = newHandler;\n };\n\n _proto6.setPAC = function setPAC(pacData) {\n this.writeScreen.setPAC(pacData);\n };\n\n _proto6.setBkgData = function setBkgData(bkgData) {\n this.writeScreen.setBkgData(bkgData);\n };\n\n _proto6.setMode = function setMode(newMode) {\n if (newMode === this.mode) {\n return;\n }\n\n this.mode = newMode;\n this.logger.log(VerboseLevel.INFO, 'MODE=' + newMode);\n\n if (this.mode === 'MODE_POP-ON') {\n this.writeScreen = this.nonDisplayedMemory;\n } else {\n this.writeScreen = this.displayedMemory;\n this.writeScreen.reset();\n }\n\n if (this.mode !== 'MODE_ROLL-UP') {\n this.displayedMemory.nrRollUpRows = null;\n this.nonDisplayedMemory.nrRollUpRows = null;\n }\n\n this.mode = newMode;\n };\n\n _proto6.insertChars = function insertChars(chars) {\n for (var i = 0; i < chars.length; i++) {\n this.writeScreen.insertChar(chars[i]);\n }\n\n var screen = this.writeScreen === this.displayedMemory ? 'DISP' : 'NON_DISP';\n this.logger.log(VerboseLevel.INFO, screen + ': ' + this.writeScreen.getDisplayText(true));\n\n if (this.mode === 'MODE_PAINT-ON' || this.mode === 'MODE_ROLL-UP') {\n this.logger.log(VerboseLevel.TEXT, 'DISPLAYED: ' + this.displayedMemory.getDisplayText(true));\n this.outputDataUpdate();\n }\n };\n\n _proto6.ccRCL = function ccRCL() {\n // Resume Caption Loading (switch mode to Pop On)\n this.logger.log(VerboseLevel.INFO, 'RCL - Resume Caption Loading');\n this.setMode('MODE_POP-ON');\n };\n\n _proto6.ccBS = function ccBS() {\n // BackSpace\n this.logger.log(VerboseLevel.INFO, 'BS - BackSpace');\n\n if (this.mode === 'MODE_TEXT') {\n return;\n }\n\n this.writeScreen.backSpace();\n\n if (this.writeScreen === this.displayedMemory) {\n this.outputDataUpdate();\n }\n };\n\n _proto6.ccAOF = function ccAOF() {// Reserved (formerly Alarm Off)\n };\n\n _proto6.ccAON = function ccAON() {// Reserved (formerly Alarm On)\n };\n\n _proto6.ccDER = function ccDER() {\n // Delete to End of Row\n this.logger.log(VerboseLevel.INFO, 'DER- Delete to End of Row');\n this.writeScreen.clearToEndOfRow();\n this.outputDataUpdate();\n };\n\n _proto6.ccRU = function ccRU(nrRows) {\n // Roll-Up Captions-2,3,or 4 Rows\n this.logger.log(VerboseLevel.INFO, 'RU(' + nrRows + ') - Roll Up');\n this.writeScreen = this.displayedMemory;\n this.setMode('MODE_ROLL-UP');\n this.writeScreen.setRollUpRows(nrRows);\n };\n\n _proto6.ccFON = function ccFON() {\n // Flash On\n this.logger.log(VerboseLevel.INFO, 'FON - Flash On');\n this.writeScreen.setPen({\n flash: true\n });\n };\n\n _proto6.ccRDC = function ccRDC() {\n // Resume Direct Captioning (switch mode to PaintOn)\n this.logger.log(VerboseLevel.INFO, 'RDC - Resume Direct Captioning');\n this.setMode('MODE_PAINT-ON');\n };\n\n _proto6.ccTR = function ccTR() {\n // Text Restart in text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'TR');\n this.setMode('MODE_TEXT');\n };\n\n _proto6.ccRTD = function ccRTD() {\n // Resume Text Display in Text mode (not supported, however)\n this.logger.log(VerboseLevel.INFO, 'RTD');\n this.setMode('MODE_TEXT');\n };\n\n _proto6.ccEDM = function ccEDM() {\n // Erase Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'EDM - Erase Displayed Memory');\n this.displayedMemory.reset();\n this.outputDataUpdate(true);\n };\n\n _proto6.ccCR = function ccCR() {\n // Carriage Return\n this.logger.log(VerboseLevel.INFO, 'CR - Carriage Return');\n this.writeScreen.rollUp();\n this.outputDataUpdate(true);\n };\n\n _proto6.ccENM = function ccENM() {\n // Erase Non-Displayed Memory\n this.logger.log(VerboseLevel.INFO, 'ENM - Erase Non-displayed Memory');\n this.nonDisplayedMemory.reset();\n };\n\n _proto6.ccEOC = function ccEOC() {\n // End of Caption (Flip Memories)\n this.logger.log(VerboseLevel.INFO, 'EOC - End Of Caption');\n\n if (this.mode === 'MODE_POP-ON') {\n var tmp = this.displayedMemory;\n this.displayedMemory = this.nonDisplayedMemory;\n this.nonDisplayedMemory = tmp;\n this.writeScreen = this.nonDisplayedMemory;\n this.logger.log(VerboseLevel.TEXT, 'DISP: ' + this.displayedMemory.getDisplayText());\n }\n\n this.outputDataUpdate(true);\n };\n\n _proto6.ccTO = function ccTO(nrCols) {\n // Tab Offset 1,2, or 3 columns\n this.logger.log(VerboseLevel.INFO, 'TO(' + nrCols + ') - Tab Offset');\n this.writeScreen.moveCursor(nrCols);\n };\n\n _proto6.ccMIDROW = function ccMIDROW(secondByte) {\n // Parse MIDROW command\n var styles = {\n flash: false\n };\n styles.underline = secondByte % 2 === 1;\n styles.italics = secondByte >= 0x2e;\n\n if (!styles.italics) {\n var colorIndex = Math.floor(secondByte / 2) - 0x10;\n var colors = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta'];\n styles.foreground = colors[colorIndex];\n } else {\n styles.foreground = 'white';\n }\n\n this.logger.log(VerboseLevel.INFO, 'MIDROW: ' + JSON.stringify(styles));\n this.writeScreen.setPen(styles);\n };\n\n _proto6.outputDataUpdate = function outputDataUpdate(dispatch) {\n if (dispatch === void 0) {\n dispatch = false;\n }\n\n var time = this.logger.time;\n\n if (time === null) {\n return;\n }\n\n if (this.outputFilter) {\n if (this.cueStartTime === null && !this.displayedMemory.isEmpty()) {\n // Start of a new cue\n this.cueStartTime = time;\n } else {\n if (!this.displayedMemory.equals(this.lastOutputScreen)) {\n this.outputFilter.newCue(this.cueStartTime, time, this.lastOutputScreen);\n\n if (dispatch && this.outputFilter.dispatchCue) {\n this.outputFilter.dispatchCue();\n }\n\n this.cueStartTime = this.displayedMemory.isEmpty() ? null : time;\n }\n }\n\n this.lastOutputScreen.copy(this.displayedMemory);\n }\n };\n\n _proto6.cueSplitAtTime = function cueSplitAtTime(t) {\n if (this.outputFilter) {\n if (!this.displayedMemory.isEmpty()) {\n if (this.outputFilter.newCue) {\n this.outputFilter.newCue(this.cueStartTime, t, this.displayedMemory);\n }\n\n this.cueStartTime = t;\n }\n }\n };\n\n return Cea608Channel;\n}();\n\nvar Cea608Parser = /*#__PURE__*/function () {\n function Cea608Parser(field, out1, out2) {\n this.channels = void 0;\n this.currentChannel = 0;\n this.cmdHistory = void 0;\n this.logger = void 0;\n var logger = new CaptionsLogger();\n this.channels = [null, new Cea608Channel(field, out1, logger), new Cea608Channel(field + 1, out2, logger)];\n this.cmdHistory = createCmdHistory();\n this.logger = logger;\n }\n\n var _proto7 = Cea608Parser.prototype;\n\n _proto7.getHandler = function getHandler(channel) {\n return this.channels[channel].getHandler();\n };\n\n _proto7.setHandler = function setHandler(channel, newHandler) {\n this.channels[channel].setHandler(newHandler);\n }\n /**\n * Add data for time t in forms of list of bytes (unsigned ints). The bytes are treated as pairs.\n */\n ;\n\n _proto7.addData = function addData(time, byteList) {\n var cmdFound;\n var a;\n var b;\n var charsFound = false;\n this.logger.time = time;\n\n for (var i = 0; i < byteList.length; i += 2) {\n a = byteList[i] & 0x7f;\n b = byteList[i + 1] & 0x7f;\n\n if (a === 0 && b === 0) {\n continue;\n } else {\n this.logger.log(VerboseLevel.DATA, '[' + numArrayToHexArray([byteList[i], byteList[i + 1]]) + '] -> (' + numArrayToHexArray([a, b]) + ')');\n }\n\n cmdFound = this.parseCmd(a, b);\n\n if (!cmdFound) {\n cmdFound = this.parseMidrow(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parsePAC(a, b);\n }\n\n if (!cmdFound) {\n cmdFound = this.parseBackgroundAttributes(a, b);\n }\n\n if (!cmdFound) {\n charsFound = this.parseChars(a, b);\n\n if (charsFound) {\n var currChNr = this.currentChannel;\n\n if (currChNr && currChNr > 0) {\n var channel = this.channels[currChNr];\n channel.insertChars(charsFound);\n } else {\n this.logger.log(VerboseLevel.WARNING, 'No channel found yet. TEXT-MODE?');\n }\n }\n }\n\n if (!cmdFound && !charsFound) {\n this.logger.log(VerboseLevel.WARNING, \"Couldn't parse cleaned data \" + numArrayToHexArray([a, b]) + ' orig: ' + numArrayToHexArray([byteList[i], byteList[i + 1]]));\n }\n }\n }\n /**\n * Parse Command.\n * @returns {Boolean} Tells if a command was found\n */\n ;\n\n _proto7.parseCmd = function parseCmd(a, b) {\n var cmdHistory = this.cmdHistory;\n var cond1 = (a === 0x14 || a === 0x1c || a === 0x15 || a === 0x1d) && b >= 0x20 && b <= 0x2f;\n var cond2 = (a === 0x17 || a === 0x1f) && b >= 0x21 && b <= 0x23;\n\n if (!(cond1 || cond2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n this.logger.log(VerboseLevel.DEBUG, 'Repeated command (' + numArrayToHexArray([a, b]) + ') is dropped');\n return true;\n }\n\n var chNr = a === 0x14 || a === 0x15 || a === 0x17 ? 1 : 2;\n var channel = this.channels[chNr];\n\n if (a === 0x14 || a === 0x15 || a === 0x1c || a === 0x1d) {\n if (b === 0x20) {\n channel.ccRCL();\n } else if (b === 0x21) {\n channel.ccBS();\n } else if (b === 0x22) {\n channel.ccAOF();\n } else if (b === 0x23) {\n channel.ccAON();\n } else if (b === 0x24) {\n channel.ccDER();\n } else if (b === 0x25) {\n channel.ccRU(2);\n } else if (b === 0x26) {\n channel.ccRU(3);\n } else if (b === 0x27) {\n channel.ccRU(4);\n } else if (b === 0x28) {\n channel.ccFON();\n } else if (b === 0x29) {\n channel.ccRDC();\n } else if (b === 0x2a) {\n channel.ccTR();\n } else if (b === 0x2b) {\n channel.ccRTD();\n } else if (b === 0x2c) {\n channel.ccEDM();\n } else if (b === 0x2d) {\n channel.ccCR();\n } else if (b === 0x2e) {\n channel.ccENM();\n } else if (b === 0x2f) {\n channel.ccEOC();\n }\n } else {\n // a == 0x17 || a == 0x1F\n channel.ccTO(b - 0x20);\n }\n\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n /**\n * Parse midrow styling command\n * @returns {Boolean}\n */\n ;\n\n _proto7.parseMidrow = function parseMidrow(a, b) {\n var chNr = 0;\n\n if ((a === 0x11 || a === 0x19) && b >= 0x20 && b <= 0x2f) {\n if (a === 0x11) {\n chNr = 1;\n } else {\n chNr = 2;\n }\n\n if (chNr !== this.currentChannel) {\n this.logger.log(VerboseLevel.ERROR, 'Mismatch channel in midrow parsing');\n return false;\n }\n\n var channel = this.channels[chNr];\n\n if (!channel) {\n return false;\n }\n\n channel.ccMIDROW(b);\n this.logger.log(VerboseLevel.DEBUG, 'MIDROW (' + numArrayToHexArray([a, b]) + ')');\n return true;\n }\n\n return false;\n }\n /**\n * Parse Preable Access Codes (Table 53).\n * @returns {Boolean} Tells if PAC found\n */\n ;\n\n _proto7.parsePAC = function parsePAC(a, b) {\n var row;\n var cmdHistory = this.cmdHistory;\n var case1 = (a >= 0x11 && a <= 0x17 || a >= 0x19 && a <= 0x1f) && b >= 0x40 && b <= 0x7f;\n var case2 = (a === 0x10 || a === 0x18) && b >= 0x40 && b <= 0x5f;\n\n if (!(case1 || case2)) {\n return false;\n }\n\n if (hasCmdRepeated(a, b, cmdHistory)) {\n setLastCmd(null, null, cmdHistory);\n return true; // Repeated commands are dropped (once)\n }\n\n var chNr = a <= 0x17 ? 1 : 2;\n\n if (b >= 0x40 && b <= 0x5f) {\n row = chNr === 1 ? rowsLowCh1[a] : rowsLowCh2[a];\n } else {\n // 0x60 <= b <= 0x7F\n row = chNr === 1 ? rowsHighCh1[a] : rowsHighCh2[a];\n }\n\n var channel = this.channels[chNr];\n\n if (!channel) {\n return false;\n }\n\n channel.setPAC(this.interpretPAC(row, b));\n setLastCmd(a, b, cmdHistory);\n this.currentChannel = chNr;\n return true;\n }\n /**\n * Interpret the second byte of the pac, and return the information.\n * @returns {Object} pacData with style parameters.\n */\n ;\n\n _proto7.interpretPAC = function interpretPAC(row, _byte3) {\n var pacIndex;\n var pacData = {\n color: null,\n italics: false,\n indent: null,\n underline: false,\n row: row\n };\n\n if (_byte3 > 0x5f) {\n pacIndex = _byte3 - 0x60;\n } else {\n pacIndex = _byte3 - 0x40;\n }\n\n pacData.underline = (pacIndex & 1) === 1;\n\n if (pacIndex <= 0xd) {\n pacData.color = ['white', 'green', 'blue', 'cyan', 'red', 'yellow', 'magenta', 'white'][Math.floor(pacIndex / 2)];\n } else if (pacIndex <= 0xf) {\n pacData.italics = true;\n pacData.color = 'white';\n } else {\n pacData.indent = Math.floor((pacIndex - 0x10) / 2) * 4;\n }\n\n return pacData; // Note that row has zero offset. The spec uses 1.\n }\n /**\n * Parse characters.\n * @returns An array with 1 to 2 codes corresponding to chars, if found. null otherwise.\n */\n ;\n\n _proto7.parseChars = function parseChars(a, b) {\n var channelNr;\n var charCodes = null;\n var charCode1 = null;\n\n if (a >= 0x19) {\n channelNr = 2;\n charCode1 = a - 8;\n } else {\n channelNr = 1;\n charCode1 = a;\n }\n\n if (charCode1 >= 0x11 && charCode1 <= 0x13) {\n // Special character\n var oneCode;\n\n if (charCode1 === 0x11) {\n oneCode = b + 0x50;\n } else if (charCode1 === 0x12) {\n oneCode = b + 0x70;\n } else {\n oneCode = b + 0x90;\n }\n\n this.logger.log(VerboseLevel.INFO, \"Special char '\" + getCharForByte(oneCode) + \"' in channel \" + channelNr);\n charCodes = [oneCode];\n } else if (a >= 0x20 && a <= 0x7f) {\n charCodes = b === 0 ? [a] : [a, b];\n }\n\n if (charCodes) {\n var hexCodes = numArrayToHexArray(charCodes);\n this.logger.log(VerboseLevel.DEBUG, 'Char codes = ' + hexCodes.join(','));\n setLastCmd(a, b, this.cmdHistory);\n }\n\n return charCodes;\n }\n /**\n * Parse extended background attributes as well as new foreground color black.\n * @returns {Boolean} Tells if background attributes are found\n */\n ;\n\n _proto7.parseBackgroundAttributes = function parseBackgroundAttributes(a, b) {\n var case1 = (a === 0x10 || a === 0x18) && b >= 0x20 && b <= 0x2f;\n var case2 = (a === 0x17 || a === 0x1f) && b >= 0x2d && b <= 0x2f;\n\n if (!(case1 || case2)) {\n return false;\n }\n\n var index;\n var bkgData = {};\n\n if (a === 0x10 || a === 0x18) {\n index = Math.floor((b - 0x20) / 2);\n bkgData.background = backgroundColors[index];\n\n if (b % 2 === 1) {\n bkgData.background = bkgData.background + '_semi';\n }\n } else if (b === 0x2d) {\n bkgData.background = 'transparent';\n } else {\n bkgData.foreground = 'black';\n\n if (b === 0x2f) {\n bkgData.underline = true;\n }\n }\n\n var chNr = a <= 0x17 ? 1 : 2;\n var channel = this.channels[chNr];\n channel.setBkgData(bkgData);\n setLastCmd(a, b, this.cmdHistory);\n return true;\n }\n /**\n * Reset state of parser and its channels.\n */\n ;\n\n _proto7.reset = function reset() {\n for (var i = 0; i < Object.keys(this.channels).length; i++) {\n var channel = this.channels[i];\n\n if (channel) {\n channel.reset();\n }\n }\n\n this.cmdHistory = createCmdHistory();\n }\n /**\n * Trigger the generation of a cue, and the start of a new one if displayScreens are not empty.\n */\n ;\n\n _proto7.cueSplitAtTime = function cueSplitAtTime(t) {\n for (var i = 0; i < this.channels.length; i++) {\n var channel = this.channels[i];\n\n if (channel) {\n channel.cueSplitAtTime(t);\n }\n }\n };\n\n return Cea608Parser;\n}();\n\nfunction setLastCmd(a, b, cmdHistory) {\n cmdHistory.a = a;\n cmdHistory.b = b;\n}\n\nfunction hasCmdRepeated(a, b, cmdHistory) {\n return cmdHistory.a === a && cmdHistory.b === b;\n}\n\nfunction createCmdHistory() {\n return {\n a: null,\n b: null\n };\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (Cea608Parser);\n\n/***/ }),\n\n/***/ \"./src/utils/codecs.ts\":\n/*!*****************************!*\\\n !*** ./src/utils/codecs.ts ***!\n \\*****************************/\n/*! exports provided: isCodecType, isCodecSupportedInMp4 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isCodecType\", function() { return isCodecType; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"isCodecSupportedInMp4\", function() { return isCodecSupportedInMp4; });\n// from http://mp4ra.org/codecs.html\nvar sampleEntryCodesISO = {\n audio: {\n a3ds: true,\n 'ac-3': true,\n 'ac-4': true,\n alac: true,\n alaw: true,\n dra1: true,\n 'dts+': true,\n 'dts-': true,\n dtsc: true,\n dtse: true,\n dtsh: true,\n 'ec-3': true,\n enca: true,\n g719: true,\n g726: true,\n m4ae: true,\n mha1: true,\n mha2: true,\n mhm1: true,\n mhm2: true,\n mlpa: true,\n mp4a: true,\n 'raw ': true,\n Opus: true,\n samr: true,\n sawb: true,\n sawp: true,\n sevc: true,\n sqcp: true,\n ssmv: true,\n twos: true,\n ulaw: true\n },\n video: {\n avc1: true,\n avc2: true,\n avc3: true,\n avc4: true,\n avcp: true,\n av01: true,\n drac: true,\n dvav: true,\n dvhe: true,\n encv: true,\n hev1: true,\n hvc1: true,\n mjp2: true,\n mp4v: true,\n mvc1: true,\n mvc2: true,\n mvc3: true,\n mvc4: true,\n resv: true,\n rv60: true,\n s263: true,\n svc1: true,\n svc2: true,\n 'vc-1': true,\n vp08: true,\n vp09: true\n },\n text: {\n stpp: true,\n wvtt: true\n }\n};\nfunction isCodecType(codec, type) {\n var typeCodes = sampleEntryCodesISO[type];\n return !!typeCodes && typeCodes[codec.slice(0, 4)] === true;\n}\nfunction isCodecSupportedInMp4(codec, type) {\n return MediaSource.isTypeSupported((type || 'video') + \"/mp4;codecs=\\\"\" + codec + \"\\\"\");\n}\n\n/***/ }),\n\n/***/ \"./src/utils/cues.ts\":\n/*!***************************!*\\\n !*** ./src/utils/cues.ts ***!\n \\***************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _vttparser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./vttparser */ \"./src/utils/vttparser.ts\");\n/* harmony import */ var _webvtt_parser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./webvtt-parser */ \"./src/utils/webvtt-parser.ts\");\n/* harmony import */ var _texttrack_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./texttrack-utils */ \"./src/utils/texttrack-utils.ts\");\n\n\n\nvar WHITESPACE_CHAR = /\\s/;\nvar Cues = {\n newCue: function newCue(track, startTime, endTime, captionScreen) {\n var result = [];\n var row; // the type data states this is VTTCue, but it can potentially be a TextTrackCue on old browsers\n\n var cue;\n var indenting;\n var indent;\n var text;\n var Cue = self.VTTCue || self.TextTrackCue;\n\n for (var r = 0; r < captionScreen.rows.length; r++) {\n row = captionScreen.rows[r];\n indenting = true;\n indent = 0;\n text = '';\n\n if (!row.isEmpty()) {\n for (var c = 0; c < row.chars.length; c++) {\n if (WHITESPACE_CHAR.test(row.chars[c].uchar) && indenting) {\n indent++;\n } else {\n text += row.chars[c].uchar;\n indenting = false;\n }\n } // To be used for cleaning-up orphaned roll-up captions\n\n\n row.cueStartTime = startTime; // Give a slight bump to the endTime if it's equal to startTime to avoid a SyntaxError in IE\n\n if (startTime === endTime) {\n endTime += 0.0001;\n }\n\n if (indent >= 16) {\n indent--;\n } else {\n indent++;\n }\n\n var cueText = Object(_vttparser__WEBPACK_IMPORTED_MODULE_0__[\"fixLineBreaks\"])(text.trim());\n var id = Object(_webvtt_parser__WEBPACK_IMPORTED_MODULE_1__[\"generateCueId\"])(startTime, endTime, cueText); // If this cue already exists in the track do not push it\n\n if (!track || !track.cues || !track.cues.getCueById(id)) {\n cue = new Cue(startTime, endTime, cueText);\n cue.id = id;\n cue.line = r + 1;\n cue.align = 'left'; // Clamp the position between 10 and 80 percent (CEA-608 PAC indent code)\n // https://dvcs.w3.org/hg/text-tracks/raw-file/default/608toVTT/608toVTT.html#positioning-in-cea-608\n // Firefox throws an exception and captions break with out of bounds 0-100 values\n\n cue.position = 10 + Math.min(80, Math.floor(indent * 8 / 32) * 10);\n result.push(cue);\n }\n }\n }\n\n if (track && result.length) {\n // Sort bottom cues in reverse order so that they render in line order when overlapping in Chrome\n result.sort(function (cueA, cueB) {\n if (cueA.line === 'auto' || cueB.line === 'auto') {\n return 0;\n }\n\n if (cueA.line > 8 && cueB.line > 8) {\n return cueB.line - cueA.line;\n }\n\n return cueA.line - cueB.line;\n });\n result.forEach(function (cue) {\n return Object(_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__[\"addCueToTrack\"])(track, cue);\n });\n }\n\n return result;\n }\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (Cues);\n\n/***/ }),\n\n/***/ \"./src/utils/discontinuities.ts\":\n/*!**************************************!*\\\n !*** ./src/utils/discontinuities.ts ***!\n \\**************************************/\n/*! exports provided: findFirstFragWithCC, shouldAlignOnDiscontinuities, findDiscontinuousReferenceFrag, adjustSlidingStart, alignStream, alignPDT, alignFragmentByPDTDelta, alignMediaPlaylistByPDT */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findFirstFragWithCC\", function() { return findFirstFragWithCC; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"shouldAlignOnDiscontinuities\", function() { return shouldAlignOnDiscontinuities; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findDiscontinuousReferenceFrag\", function() { return findDiscontinuousReferenceFrag; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"adjustSlidingStart\", function() { return adjustSlidingStart; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"alignStream\", function() { return alignStream; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"alignPDT\", function() { return alignPDT; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"alignFragmentByPDTDelta\", function() { return alignFragmentByPDTDelta; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"alignMediaPlaylistByPDT\", function() { return alignMediaPlaylistByPDT; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _controller_level_helper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../controller/level-helper */ \"./src/controller/level-helper.ts\");\n\n\n\n\nfunction findFirstFragWithCC(fragments, cc) {\n var firstFrag = null;\n\n for (var i = 0, len = fragments.length; i < len; i++) {\n var currentFrag = fragments[i];\n\n if (currentFrag && currentFrag.cc === cc) {\n firstFrag = currentFrag;\n break;\n }\n }\n\n return firstFrag;\n}\nfunction shouldAlignOnDiscontinuities(lastFrag, lastLevel, details) {\n if (lastLevel.details) {\n if (details.endCC > details.startCC || lastFrag && lastFrag.cc < details.startCC) {\n return true;\n }\n }\n\n return false;\n} // Find the first frag in the previous level which matches the CC of the first frag of the new level\n\nfunction findDiscontinuousReferenceFrag(prevDetails, curDetails) {\n var prevFrags = prevDetails.fragments;\n var curFrags = curDetails.fragments;\n\n if (!curFrags.length || !prevFrags.length) {\n _logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].log('No fragments to align');\n return;\n }\n\n var prevStartFrag = findFirstFragWithCC(prevFrags, curFrags[0].cc);\n\n if (!prevStartFrag || prevStartFrag && !prevStartFrag.startPTS) {\n _logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].log('No frag in previous level to align on');\n return;\n }\n\n return prevStartFrag;\n}\n\nfunction adjustFragmentStart(frag, sliding) {\n if (frag) {\n var start = frag.start + sliding;\n frag.start = frag.startPTS = start;\n frag.endPTS = start + frag.duration;\n }\n}\n\nfunction adjustSlidingStart(sliding, details) {\n // Update segments\n var fragments = details.fragments;\n\n for (var i = 0, len = fragments.length; i < len; i++) {\n adjustFragmentStart(fragments[i], sliding);\n } // Update LL-HLS parts at the end of the playlist\n\n\n if (details.fragmentHint) {\n adjustFragmentStart(details.fragmentHint, sliding);\n }\n\n details.alignedSliding = true;\n}\n/**\n * Using the parameters of the last level, this function computes PTS' of the new fragments so that they form a\n * contiguous stream with the last fragments.\n * The PTS of a fragment lets Hls.js know where it fits into a stream - by knowing every PTS, we know which fragment to\n * download at any given time. PTS is normally computed when the fragment is demuxed, so taking this step saves us time\n * and an extra download.\n * @param lastFrag\n * @param lastLevel\n * @param details\n */\n\nfunction alignStream(lastFrag, lastLevel, details) {\n if (!lastLevel) {\n return;\n }\n\n alignDiscontinuities(lastFrag, details, lastLevel);\n\n if (!details.alignedSliding && lastLevel.details) {\n // If the PTS wasn't figured out via discontinuity sequence that means there was no CC increase within the level.\n // Aligning via Program Date Time should therefore be reliable, since PDT should be the same within the same\n // discontinuity sequence.\n alignPDT(details, lastLevel.details);\n }\n\n if (!details.alignedSliding && lastLevel.details && !details.skippedSegments) {\n // Try to align on sn so that we pick a better start fragment.\n // Do not perform this on playlists with delta updates as this is only to align levels on switch\n // and adjustSliding only adjusts fragments after skippedSegments.\n Object(_controller_level_helper__WEBPACK_IMPORTED_MODULE_2__[\"adjustSliding\"])(lastLevel.details, details);\n }\n}\n/**\n * Computes the PTS if a new level's fragments using the PTS of a fragment in the last level which shares the same\n * discontinuity sequence.\n * @param lastFrag - The last Fragment which shares the same discontinuity sequence\n * @param lastLevel - The details of the last loaded level\n * @param details - The details of the new level\n */\n\nfunction alignDiscontinuities(lastFrag, details, lastLevel) {\n if (shouldAlignOnDiscontinuities(lastFrag, lastLevel, details)) {\n var referenceFrag = findDiscontinuousReferenceFrag(lastLevel.details, details);\n\n if (referenceFrag && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(referenceFrag.start)) {\n _logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].log(\"Adjusting PTS using last level due to CC increase within current level \" + details.url);\n adjustSlidingStart(referenceFrag.start, details);\n }\n }\n}\n/**\n * Computes the PTS of a new level's fragments using the difference in Program Date Time from the last level.\n * @param details - The details of the new level\n * @param lastDetails - The details of the last loaded level\n */\n\n\nfunction alignPDT(details, lastDetails) {\n // This check protects the unsafe \"!\" usage below for null program date time access.\n if (!lastDetails.fragments.length || !details.hasProgramDateTime || !lastDetails.hasProgramDateTime) {\n return;\n } // if last level sliding is 1000 and its first frag PROGRAM-DATE-TIME is 2017-08-20 1:10:00 AM\n // and if new details first frag PROGRAM DATE-TIME is 2017-08-20 1:10:08 AM\n // then we can deduce that playlist B sliding is 1000+8 = 1008s\n\n\n var lastPDT = lastDetails.fragments[0].programDateTime; // hasProgramDateTime check above makes this safe.\n\n var newPDT = details.fragments[0].programDateTime; // date diff is in ms. frag.start is in seconds\n\n var sliding = (newPDT - lastPDT) / 1000 + lastDetails.fragments[0].start;\n\n if (sliding && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(sliding)) {\n _logger__WEBPACK_IMPORTED_MODULE_1__[\"logger\"].log(\"Adjusting PTS using programDateTime delta \" + (newPDT - lastPDT) + \"ms, sliding:\" + sliding.toFixed(3) + \" \" + details.url + \" \");\n adjustSlidingStart(sliding, details);\n }\n}\nfunction alignFragmentByPDTDelta(frag, delta) {\n var programDateTime = frag.programDateTime;\n if (!programDateTime) return;\n var start = (programDateTime - delta) / 1000;\n frag.start = frag.startPTS = start;\n frag.endPTS = start + frag.duration;\n}\n/**\n * Ensures appropriate time-alignment between renditions based on PDT. Unlike `alignPDT`, which adjusts\n * the timeline based on the delta between PDTs of the 0th fragment of two playlists/`LevelDetails`,\n * this function assumes the timelines represented in `refDetails` are accurate, including the PDTs,\n * and uses the \"wallclock\"/PDT timeline as a cross-reference to `details`, adjusting the presentation\n * times/timelines of `details` accordingly.\n * Given the asynchronous nature of fetches and initial loads of live `main` and audio/subtitle tracks,\n * the primary purpose of this function is to ensure the \"local timelines\" of audio/subtitle tracks\n * are aligned to the main/video timeline, using PDT as the cross-reference/\"anchor\" that should\n * be consistent across playlists, per the HLS spec.\n * @param details - The details of the rendition you'd like to time-align (e.g. an audio rendition).\n * @param refDetails - The details of the reference rendition with start and PDT times for alignment.\n */\n\nfunction alignMediaPlaylistByPDT(details, refDetails) {\n // This check protects the unsafe \"!\" usage below for null program date time access.\n if (!refDetails.fragments.length || !details.hasProgramDateTime || !refDetails.hasProgramDateTime) {\n return;\n }\n\n var refPDT = refDetails.fragments[0].programDateTime; // hasProgramDateTime check above makes this safe.\n\n var refStart = refDetails.fragments[0].start; // Use the delta between the reference details' presentation timeline's start time and its PDT\n // to align the other rendition's timeline.\n\n var delta = refPDT - refStart * 1000; // Per spec: \"If any Media Playlist in a Master Playlist contains an EXT-X-PROGRAM-DATE-TIME tag, then all\n // Media Playlists in that Master Playlist MUST contain EXT-X-PROGRAM-DATE-TIME tags with consistent mappings\n // of date and time to media timestamps.\"\n // So we should be able to use each rendition's PDT as a reference time and use the delta to compute our relevant\n // start and end times.\n // NOTE: This code assumes each level/details timelines have already been made \"internally consistent\"\n\n details.fragments.forEach(function (frag) {\n alignFragmentByPDTDelta(frag, delta);\n });\n\n if (details.fragmentHint) {\n alignFragmentByPDTDelta(details.fragmentHint, delta);\n }\n\n details.alignedSliding = true;\n}\n\n/***/ }),\n\n/***/ \"./src/utils/ewma-bandwidth-estimator.ts\":\n/*!***********************************************!*\\\n !*** ./src/utils/ewma-bandwidth-estimator.ts ***!\n \\***********************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _utils_ewma__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/ewma */ \"./src/utils/ewma.ts\");\n/*\n * EWMA Bandwidth Estimator\n * - heavily inspired from shaka-player\n * Tracks bandwidth samples and estimates available bandwidth.\n * Based on the minimum of two exponentially-weighted moving averages with\n * different half-lives.\n */\n\n\nvar EwmaBandWidthEstimator = /*#__PURE__*/function () {\n function EwmaBandWidthEstimator(slow, fast, defaultEstimate) {\n this.defaultEstimate_ = void 0;\n this.minWeight_ = void 0;\n this.minDelayMs_ = void 0;\n this.slow_ = void 0;\n this.fast_ = void 0;\n this.defaultEstimate_ = defaultEstimate;\n this.minWeight_ = 0.001;\n this.minDelayMs_ = 50;\n this.slow_ = new _utils_ewma__WEBPACK_IMPORTED_MODULE_0__[\"default\"](slow);\n this.fast_ = new _utils_ewma__WEBPACK_IMPORTED_MODULE_0__[\"default\"](fast);\n }\n\n var _proto = EwmaBandWidthEstimator.prototype;\n\n _proto.update = function update(slow, fast) {\n var slow_ = this.slow_,\n fast_ = this.fast_;\n\n if (this.slow_.halfLife !== slow) {\n this.slow_ = new _utils_ewma__WEBPACK_IMPORTED_MODULE_0__[\"default\"](slow, slow_.getEstimate(), slow_.getTotalWeight());\n }\n\n if (this.fast_.halfLife !== fast) {\n this.fast_ = new _utils_ewma__WEBPACK_IMPORTED_MODULE_0__[\"default\"](fast, fast_.getEstimate(), fast_.getTotalWeight());\n }\n };\n\n _proto.sample = function sample(durationMs, numBytes) {\n durationMs = Math.max(durationMs, this.minDelayMs_);\n var numBits = 8 * numBytes; // weight is duration in seconds\n\n var durationS = durationMs / 1000; // value is bandwidth in bits/s\n\n var bandwidthInBps = numBits / durationS;\n this.fast_.sample(durationS, bandwidthInBps);\n this.slow_.sample(durationS, bandwidthInBps);\n };\n\n _proto.canEstimate = function canEstimate() {\n var fast = this.fast_;\n return fast && fast.getTotalWeight() >= this.minWeight_;\n };\n\n _proto.getEstimate = function getEstimate() {\n if (this.canEstimate()) {\n // console.log('slow estimate:'+ Math.round(this.slow_.getEstimate()));\n // console.log('fast estimate:'+ Math.round(this.fast_.getEstimate()));\n // Take the minimum of these two estimates. This should have the effect of\n // adapting down quickly, but up more slowly.\n return Math.min(this.fast_.getEstimate(), this.slow_.getEstimate());\n } else {\n return this.defaultEstimate_;\n }\n };\n\n _proto.destroy = function destroy() {};\n\n return EwmaBandWidthEstimator;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (EwmaBandWidthEstimator);\n\n/***/ }),\n\n/***/ \"./src/utils/ewma.ts\":\n/*!***************************!*\\\n !*** ./src/utils/ewma.ts ***!\n \\***************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/*\n * compute an Exponential Weighted moving average\n * - https://en.wikipedia.org/wiki/Moving_average#Exponential_moving_average\n * - heavily inspired from shaka-player\n */\nvar EWMA = /*#__PURE__*/function () {\n // About half of the estimated value will be from the last |halfLife| samples by weight.\n function EWMA(halfLife, estimate, weight) {\n if (estimate === void 0) {\n estimate = 0;\n }\n\n if (weight === void 0) {\n weight = 0;\n }\n\n this.halfLife = void 0;\n this.alpha_ = void 0;\n this.estimate_ = void 0;\n this.totalWeight_ = void 0;\n this.halfLife = halfLife; // Larger values of alpha expire historical data more slowly.\n\n this.alpha_ = halfLife ? Math.exp(Math.log(0.5) / halfLife) : 0;\n this.estimate_ = estimate;\n this.totalWeight_ = weight;\n }\n\n var _proto = EWMA.prototype;\n\n _proto.sample = function sample(weight, value) {\n var adjAlpha = Math.pow(this.alpha_, weight);\n this.estimate_ = value * (1 - adjAlpha) + adjAlpha * this.estimate_;\n this.totalWeight_ += weight;\n };\n\n _proto.getTotalWeight = function getTotalWeight() {\n return this.totalWeight_;\n };\n\n _proto.getEstimate = function getEstimate() {\n if (this.alpha_) {\n var zeroFactor = 1 - Math.pow(this.alpha_, this.totalWeight_);\n\n if (zeroFactor) {\n return this.estimate_ / zeroFactor;\n }\n }\n\n return this.estimate_;\n };\n\n return EWMA;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (EWMA);\n\n/***/ }),\n\n/***/ \"./src/utils/fetch-loader.ts\":\n/*!***********************************!*\\\n !*** ./src/utils/fetch-loader.ts ***!\n \\***********************************/\n/*! exports provided: fetchSupported, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"fetchSupported\", function() { return fetchSupported; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _loader_load_stats__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../loader/load-stats */ \"./src/loader/load-stats.ts\");\n/* harmony import */ var _demux_chunk_cache__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../demux/chunk-cache */ \"./src/demux/chunk-cache.ts\");\n\n\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; _setPrototypeOf(subClass, superClass); }\n\nfunction _wrapNativeSuper(Class) { var _cache = typeof Map === \"function\" ? new Map() : undefined; _wrapNativeSuper = function _wrapNativeSuper(Class) { if (Class === null || !_isNativeFunction(Class)) return Class; if (typeof Class !== \"function\") { throw new TypeError(\"Super expression must either be null or a function\"); } if (typeof _cache !== \"undefined\") { if (_cache.has(Class)) return _cache.get(Class); _cache.set(Class, Wrapper); } function Wrapper() { return _construct(Class, arguments, _getPrototypeOf(this).constructor); } Wrapper.prototype = Object.create(Class.prototype, { constructor: { value: Wrapper, enumerable: false, writable: true, configurable: true } }); return _setPrototypeOf(Wrapper, Class); }; return _wrapNativeSuper(Class); }\n\nfunction _construct(Parent, args, Class) { if (_isNativeReflectConstruct()) { _construct = Reflect.construct.bind(); } else { _construct = function _construct(Parent, args, Class) { var a = [null]; a.push.apply(a, args); var Constructor = Function.bind.apply(Parent, a); var instance = new Constructor(); if (Class) _setPrototypeOf(instance, Class.prototype); return instance; }; } return _construct.apply(null, arguments); }\n\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\n\nfunction _isNativeFunction(fn) { return Function.toString.call(fn).indexOf(\"[native code]\") !== -1; }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\nfunction fetchSupported() {\n if ( // @ts-ignore\n self.fetch && self.AbortController && self.ReadableStream && self.Request) {\n try {\n new self.ReadableStream({}); // eslint-disable-line no-new\n\n return true;\n } catch (e) {\n /* noop */\n }\n }\n\n return false;\n}\n\nvar FetchLoader = /*#__PURE__*/function () {\n function FetchLoader(config\n /* HlsConfig */\n ) {\n this.fetchSetup = void 0;\n this.requestTimeout = void 0;\n this.request = void 0;\n this.response = void 0;\n this.controller = void 0;\n this.context = void 0;\n this.config = null;\n this.callbacks = null;\n this.stats = void 0;\n this.loader = null;\n this.fetchSetup = config.fetchSetup || getRequest;\n this.controller = new self.AbortController();\n this.stats = new _loader_load_stats__WEBPACK_IMPORTED_MODULE_1__[\"LoadStats\"]();\n }\n\n var _proto = FetchLoader.prototype;\n\n _proto.destroy = function destroy() {\n this.loader = this.callbacks = null;\n this.abortInternal();\n };\n\n _proto.abortInternal = function abortInternal() {\n var response = this.response;\n\n if (!response || !response.ok) {\n this.stats.aborted = true;\n this.controller.abort();\n }\n };\n\n _proto.abort = function abort() {\n var _this$callbacks;\n\n this.abortInternal();\n\n if ((_this$callbacks = this.callbacks) !== null && _this$callbacks !== void 0 && _this$callbacks.onAbort) {\n this.callbacks.onAbort(this.stats, this.context, this.response);\n }\n };\n\n _proto.load = function load(context, config, callbacks) {\n var _this = this;\n\n var stats = this.stats;\n\n if (stats.loading.start) {\n throw new Error('Loader can only be used once.');\n }\n\n stats.loading.start = self.performance.now();\n var initParams = getRequestParameters(context, this.controller.signal);\n var onProgress = callbacks.onProgress;\n var isArrayBuffer = context.responseType === 'arraybuffer';\n var LENGTH = isArrayBuffer ? 'byteLength' : 'length';\n this.context = context;\n this.config = config;\n this.callbacks = callbacks;\n this.request = this.fetchSetup(context, initParams);\n self.clearTimeout(this.requestTimeout);\n this.requestTimeout = self.setTimeout(function () {\n _this.abortInternal();\n\n callbacks.onTimeout(stats, context, _this.response);\n }, config.timeout);\n self.fetch(this.request).then(function (response) {\n _this.response = _this.loader = response;\n\n if (!response.ok) {\n var status = response.status,\n statusText = response.statusText;\n throw new FetchError(statusText || 'fetch, bad network response', status, response);\n }\n\n stats.loading.first = Math.max(self.performance.now(), stats.loading.start);\n stats.total = parseInt(response.headers.get('Content-Length') || '0');\n\n if (onProgress && Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(config.highWaterMark)) {\n return _this.loadProgressively(response, stats, context, config.highWaterMark, onProgress);\n }\n\n if (isArrayBuffer) {\n return response.arrayBuffer();\n }\n\n return response.text();\n }).then(function (responseData) {\n var response = _this.response;\n self.clearTimeout(_this.requestTimeout);\n stats.loading.end = Math.max(self.performance.now(), stats.loading.first);\n stats.loaded = stats.total = responseData[LENGTH];\n var loaderResponse = {\n url: response.url,\n data: responseData\n };\n\n if (onProgress && !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(config.highWaterMark)) {\n onProgress(stats, context, responseData, response);\n }\n\n callbacks.onSuccess(loaderResponse, stats, context, response);\n }).catch(function (error) {\n self.clearTimeout(_this.requestTimeout);\n\n if (stats.aborted) {\n return;\n } // CORS errors result in an undefined code. Set it to 0 here to align with XHR's behavior\n // when destroying, 'error' itself can be undefined\n\n\n var code = !error ? 0 : error.code || 0;\n var text = !error ? null : error.message;\n callbacks.onError({\n code: code,\n text: text\n }, context, error ? error.details : null);\n });\n };\n\n _proto.getCacheAge = function getCacheAge() {\n var result = null;\n\n if (this.response) {\n var ageHeader = this.response.headers.get('age');\n result = ageHeader ? parseFloat(ageHeader) : null;\n }\n\n return result;\n };\n\n _proto.loadProgressively = function loadProgressively(response, stats, context, highWaterMark, onProgress) {\n if (highWaterMark === void 0) {\n highWaterMark = 0;\n }\n\n var chunkCache = new _demux_chunk_cache__WEBPACK_IMPORTED_MODULE_2__[\"default\"]();\n var reader = response.body.getReader();\n\n var pump = function pump() {\n return reader.read().then(function (data) {\n if (data.done) {\n if (chunkCache.dataLength) {\n onProgress(stats, context, chunkCache.flush(), response);\n }\n\n return Promise.resolve(new ArrayBuffer(0));\n }\n\n var chunk = data.value;\n var len = chunk.length;\n stats.loaded += len;\n\n if (len < highWaterMark || chunkCache.dataLength) {\n // The current chunk is too small to to be emitted or the cache already has data\n // Push it to the cache\n chunkCache.push(chunk);\n\n if (chunkCache.dataLength >= highWaterMark) {\n // flush in order to join the typed arrays\n onProgress(stats, context, chunkCache.flush(), response);\n }\n } else {\n // If there's nothing cached already, and the chache is large enough\n // just emit the progress event\n onProgress(stats, context, chunk, response);\n }\n\n return pump();\n }).catch(function () {\n /* aborted */\n return Promise.reject();\n });\n };\n\n return pump();\n };\n\n return FetchLoader;\n}();\n\nfunction getRequestParameters(context, signal) {\n var initParams = {\n method: 'GET',\n mode: 'cors',\n credentials: 'same-origin',\n signal: signal,\n headers: new self.Headers(_extends({}, context.headers))\n };\n\n if (context.rangeEnd) {\n initParams.headers.set('Range', 'bytes=' + context.rangeStart + '-' + String(context.rangeEnd - 1));\n }\n\n return initParams;\n}\n\nfunction getRequest(context, initParams) {\n return new self.Request(context.url, initParams);\n}\n\nvar FetchError = /*#__PURE__*/function (_Error) {\n _inheritsLoose(FetchError, _Error);\n\n function FetchError(message, code, details) {\n var _this2;\n\n _this2 = _Error.call(this, message) || this;\n _this2.code = void 0;\n _this2.details = void 0;\n _this2.code = code;\n _this2.details = details;\n return _this2;\n }\n\n return FetchError;\n}( /*#__PURE__*/_wrapNativeSuper(Error));\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (FetchLoader);\n\n/***/ }),\n\n/***/ \"./src/utils/imsc1-ttml-parser.ts\":\n/*!****************************************!*\\\n !*** ./src/utils/imsc1-ttml-parser.ts ***!\n \\****************************************/\n/*! exports provided: IMSC1_CODEC, parseIMSC1 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"IMSC1_CODEC\", function() { return IMSC1_CODEC; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseIMSC1\", function() { return parseIMSC1; });\n/* harmony import */ var _mp4_tools__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./mp4-tools */ \"./src/utils/mp4-tools.ts\");\n/* harmony import */ var _vttparser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./vttparser */ \"./src/utils/vttparser.ts\");\n/* harmony import */ var _vttcue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./vttcue */ \"./src/utils/vttcue.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n/* harmony import */ var _timescale_conversion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./timescale-conversion */ \"./src/utils/timescale-conversion.ts\");\n/* harmony import */ var _webvtt_parser__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./webvtt-parser */ \"./src/utils/webvtt-parser.ts\");\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\n\n\n\n\n\n\nvar IMSC1_CODEC = 'stpp.ttml.im1t'; // Time format: h:m:s:frames(.subframes)\n\nvar HMSF_REGEX = /^(\\d{2,}):(\\d{2}):(\\d{2}):(\\d{2})\\.?(\\d+)?$/; // Time format: hours, minutes, seconds, milliseconds, frames, ticks\n\nvar TIME_UNIT_REGEX = /^(\\d*(?:\\.\\d*)?)(h|m|s|ms|f|t)$/;\nvar textAlignToLineAlign = {\n left: 'start',\n center: 'center',\n right: 'end',\n start: 'start',\n end: 'end'\n};\nfunction parseIMSC1(payload, initPTS, timescale, callBack, errorCallBack) {\n var results = Object(_mp4_tools__WEBPACK_IMPORTED_MODULE_0__[\"findBox\"])(new Uint8Array(payload), ['mdat']);\n\n if (results.length === 0) {\n errorCallBack(new Error('Could not parse IMSC1 mdat'));\n return;\n }\n\n var ttmlList = results.map(function (mdat) {\n return Object(_demux_id3__WEBPACK_IMPORTED_MODULE_3__[\"utf8ArrayToStr\"])(mdat);\n });\n var syncTime = Object(_timescale_conversion__WEBPACK_IMPORTED_MODULE_4__[\"toTimescaleFromScale\"])(initPTS, 1, timescale);\n\n try {\n ttmlList.forEach(function (ttml) {\n return callBack(parseTTML(ttml, syncTime));\n });\n } catch (error) {\n errorCallBack(error);\n }\n}\n\nfunction parseTTML(ttml, syncTime) {\n var parser = new DOMParser();\n var xmlDoc = parser.parseFromString(ttml, 'text/xml');\n var tt = xmlDoc.getElementsByTagName('tt')[0];\n\n if (!tt) {\n throw new Error('Invalid ttml');\n }\n\n var defaultRateInfo = {\n frameRate: 30,\n subFrameRate: 1,\n frameRateMultiplier: 0,\n tickRate: 0\n };\n var rateInfo = Object.keys(defaultRateInfo).reduce(function (result, key) {\n result[key] = tt.getAttribute(\"ttp:\" + key) || defaultRateInfo[key];\n return result;\n }, {});\n var trim = tt.getAttribute('xml:space') !== 'preserve';\n var styleElements = collectionToDictionary(getElementCollection(tt, 'styling', 'style'));\n var regionElements = collectionToDictionary(getElementCollection(tt, 'layout', 'region'));\n var cueElements = getElementCollection(tt, 'body', '[begin]');\n return [].map.call(cueElements, function (cueElement) {\n var cueText = getTextContent(cueElement, trim);\n\n if (!cueText || !cueElement.hasAttribute('begin')) {\n return null;\n }\n\n var startTime = parseTtmlTime(cueElement.getAttribute('begin'), rateInfo);\n var duration = parseTtmlTime(cueElement.getAttribute('dur'), rateInfo);\n var endTime = parseTtmlTime(cueElement.getAttribute('end'), rateInfo);\n\n if (startTime === null) {\n throw timestampParsingError(cueElement);\n }\n\n if (endTime === null) {\n if (duration === null) {\n throw timestampParsingError(cueElement);\n }\n\n endTime = startTime + duration;\n }\n\n var cue = new _vttcue__WEBPACK_IMPORTED_MODULE_2__[\"default\"](startTime - syncTime, endTime - syncTime, cueText);\n cue.id = Object(_webvtt_parser__WEBPACK_IMPORTED_MODULE_5__[\"generateCueId\"])(cue.startTime, cue.endTime, cue.text);\n var region = regionElements[cueElement.getAttribute('region')];\n var style = styleElements[cueElement.getAttribute('style')]; // TODO: Add regions to track and cue (origin and extend)\n // These values are hard-coded (for now) to simulate region settings in the demo\n\n cue.position = 10;\n cue.size = 80; // Apply styles to cue\n\n var styles = getTtmlStyles(region, style, styleElements);\n var textAlign = styles.textAlign;\n\n if (textAlign) {\n // cue.positionAlign not settable in FF~2016\n var lineAlign = textAlignToLineAlign[textAlign];\n\n if (lineAlign) {\n cue.lineAlign = lineAlign;\n }\n\n cue.align = textAlign;\n }\n\n _extends(cue, styles);\n\n return cue;\n }).filter(function (cue) {\n return cue !== null;\n });\n}\n\nfunction getElementCollection(fromElement, parentName, childName) {\n var parent = fromElement.getElementsByTagName(parentName)[0];\n\n if (parent) {\n return [].slice.call(parent.querySelectorAll(childName));\n }\n\n return [];\n}\n\nfunction collectionToDictionary(elementsWithId) {\n return elementsWithId.reduce(function (dict, element) {\n var id = element.getAttribute('xml:id');\n\n if (id) {\n dict[id] = element;\n }\n\n return dict;\n }, {});\n}\n\nfunction getTextContent(element, trim) {\n return [].slice.call(element.childNodes).reduce(function (str, node, i) {\n var _node$childNodes;\n\n if (node.nodeName === 'br' && i) {\n return str + '\\n';\n }\n\n if ((_node$childNodes = node.childNodes) !== null && _node$childNodes !== void 0 && _node$childNodes.length) {\n return getTextContent(node, trim);\n } else if (trim) {\n return str + node.textContent.trim().replace(/\\s+/g, ' ');\n }\n\n return str + node.textContent;\n }, '');\n}\n\nfunction getTtmlStyles(region, style, styleElements) {\n var ttsNs = 'http://www.w3.org/ns/ttml#styling';\n var regionStyle = null;\n var styleAttributes = ['displayAlign', 'textAlign', 'color', 'backgroundColor', 'fontSize', 'fontFamily' // 'fontWeight',\n // 'lineHeight',\n // 'wrapOption',\n // 'fontStyle',\n // 'direction',\n // 'writingMode'\n ];\n var regionStyleName = region !== null && region !== void 0 && region.hasAttribute('style') ? region.getAttribute('style') : null;\n\n if (regionStyleName && styleElements.hasOwnProperty(regionStyleName)) {\n regionStyle = styleElements[regionStyleName];\n }\n\n return styleAttributes.reduce(function (styles, name) {\n var value = getAttributeNS(style, ttsNs, name) || getAttributeNS(region, ttsNs, name) || getAttributeNS(regionStyle, ttsNs, name);\n\n if (value) {\n styles[name] = value;\n }\n\n return styles;\n }, {});\n}\n\nfunction getAttributeNS(element, ns, name) {\n if (!element) {\n return null;\n }\n\n return element.hasAttributeNS(ns, name) ? element.getAttributeNS(ns, name) : null;\n}\n\nfunction timestampParsingError(node) {\n return new Error(\"Could not parse ttml timestamp \" + node);\n}\n\nfunction parseTtmlTime(timeAttributeValue, rateInfo) {\n if (!timeAttributeValue) {\n return null;\n }\n\n var seconds = Object(_vttparser__WEBPACK_IMPORTED_MODULE_1__[\"parseTimeStamp\"])(timeAttributeValue);\n\n if (seconds === null) {\n if (HMSF_REGEX.test(timeAttributeValue)) {\n seconds = parseHoursMinutesSecondsFrames(timeAttributeValue, rateInfo);\n } else if (TIME_UNIT_REGEX.test(timeAttributeValue)) {\n seconds = parseTimeUnits(timeAttributeValue, rateInfo);\n }\n }\n\n return seconds;\n}\n\nfunction parseHoursMinutesSecondsFrames(timeAttributeValue, rateInfo) {\n var m = HMSF_REGEX.exec(timeAttributeValue);\n var frames = (m[4] | 0) + (m[5] | 0) / rateInfo.subFrameRate;\n return (m[1] | 0) * 3600 + (m[2] | 0) * 60 + (m[3] | 0) + frames / rateInfo.frameRate;\n}\n\nfunction parseTimeUnits(timeAttributeValue, rateInfo) {\n var m = TIME_UNIT_REGEX.exec(timeAttributeValue);\n var value = Number(m[1]);\n var unit = m[2];\n\n switch (unit) {\n case 'h':\n return value * 3600;\n\n case 'm':\n return value * 60;\n\n case 'ms':\n return value * 1000;\n\n case 'f':\n return value / rateInfo.frameRate;\n\n case 't':\n return value / rateInfo.tickRate;\n }\n\n return value;\n}\n\n/***/ }),\n\n/***/ \"./src/utils/logger.ts\":\n/*!*****************************!*\\\n !*** ./src/utils/logger.ts ***!\n \\*****************************/\n/*! exports provided: enableLogs, logger */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"enableLogs\", function() { return enableLogs; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"logger\", function() { return logger; });\nvar noop = function noop() {};\n\nvar fakeLogger = {\n trace: noop,\n debug: noop,\n log: noop,\n warn: noop,\n info: noop,\n error: noop\n};\nvar exportedLogger = fakeLogger; // let lastCallTime;\n// function formatMsgWithTimeInfo(type, msg) {\n// const now = Date.now();\n// const diff = lastCallTime ? '+' + (now - lastCallTime) : '0';\n// lastCallTime = now;\n// msg = (new Date(now)).toISOString() + ' | [' + type + '] > ' + msg + ' ( ' + diff + ' ms )';\n// return msg;\n// }\n\nfunction consolePrintFn(type) {\n var func = self.console[type];\n\n if (func) {\n return func.bind(self.console, \"[\" + type + \"] >\");\n }\n\n return noop;\n}\n\nfunction exportLoggerFunctions(debugConfig) {\n for (var _len = arguments.length, functions = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n functions[_key - 1] = arguments[_key];\n }\n\n functions.forEach(function (type) {\n exportedLogger[type] = debugConfig[type] ? debugConfig[type].bind(debugConfig) : consolePrintFn(type);\n });\n}\n\nfunction enableLogs(debugConfig) {\n // check that console is available\n if (self.console && debugConfig === true || typeof debugConfig === 'object') {\n exportLoggerFunctions(debugConfig, // Remove out from list here to hard-disable a log-level\n // 'trace',\n 'debug', 'log', 'info', 'warn', 'error'); // Some browsers don't allow to use bind on console object anyway\n // fallback to default if needed\n\n try {\n exportedLogger.log();\n } catch (e) {\n exportedLogger = fakeLogger;\n }\n } else {\n exportedLogger = fakeLogger;\n }\n}\nvar logger = exportedLogger;\n\n/***/ }),\n\n/***/ \"./src/utils/mediakeys-helper.ts\":\n/*!***************************************!*\\\n !*** ./src/utils/mediakeys-helper.ts ***!\n \\***************************************/\n/*! exports provided: KeySystems, requestMediaKeySystemAccess */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"KeySystems\", function() { return KeySystems; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"requestMediaKeySystemAccess\", function() { return requestMediaKeySystemAccess; });\n/**\n * @see https://developer.mozilla.org/en-US/docs/Web/API/Navigator/requestMediaKeySystemAccess\n */\nvar KeySystems;\n\n(function (KeySystems) {\n KeySystems[\"WIDEVINE\"] = \"com.widevine.alpha\";\n KeySystems[\"PLAYREADY\"] = \"com.microsoft.playready\";\n})(KeySystems || (KeySystems = {}));\n\nvar requestMediaKeySystemAccess = function () {\n if (typeof self !== 'undefined' && self.navigator && self.navigator.requestMediaKeySystemAccess) {\n return self.navigator.requestMediaKeySystemAccess.bind(self.navigator);\n } else {\n return null;\n }\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/utils/mediasource-helper.ts\":\n/*!*****************************************!*\\\n !*** ./src/utils/mediasource-helper.ts ***!\n \\*****************************************/\n/*! exports provided: getMediaSource */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getMediaSource\", function() { return getMediaSource; });\n/**\n * MediaSource helper\n */\nfunction getMediaSource() {\n return self.MediaSource || self.WebKitMediaSource;\n}\n\n/***/ }),\n\n/***/ \"./src/utils/mp4-tools.ts\":\n/*!********************************!*\\\n !*** ./src/utils/mp4-tools.ts ***!\n \\********************************/\n/*! exports provided: RemuxerTrackIdConfig, bin2str, readUint16, readUint32, readSint32, writeUint32, findBox, parseSegmentIndex, parseInitSegment, getStartDTS, getDuration, computeRawDurationFromSamples, offsetStartDTS, segmentValidRange, appendUint8Array, parseSamples, parseSEIMessageFromNALu, parseEmsg */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"RemuxerTrackIdConfig\", function() { return RemuxerTrackIdConfig; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"bin2str\", function() { return bin2str; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"readUint16\", function() { return readUint16; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"readUint32\", function() { return readUint32; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"readSint32\", function() { return readSint32; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"writeUint32\", function() { return writeUint32; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"findBox\", function() { return findBox; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseSegmentIndex\", function() { return parseSegmentIndex; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseInitSegment\", function() { return parseInitSegment; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getStartDTS\", function() { return getStartDTS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getDuration\", function() { return getDuration; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"computeRawDurationFromSamples\", function() { return computeRawDurationFromSamples; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"offsetStartDTS\", function() { return offsetStartDTS; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"segmentValidRange\", function() { return segmentValidRange; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"appendUint8Array\", function() { return appendUint8Array; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseSamples\", function() { return parseSamples; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseSEIMessageFromNALu\", function() { return parseSEIMessageFromNALu; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseEmsg\", function() { return parseEmsg; });\n/* harmony import */ var _typed_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typed-array */ \"./src/utils/typed-array.ts\");\n/* harmony import */ var _loader_fragment__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../loader/fragment */ \"./src/loader/fragment.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n\n\n\nvar UINT32_MAX = Math.pow(2, 32) - 1;\nvar push = [].push; // We are using fixed track IDs for driving the MP4 remuxer\n// instead of following the TS PIDs.\n// There is no reason not to do this and some browsers/SourceBuffer-demuxers\n// may not like if there are TrackID \"switches\"\n// See https://github.com/video-dev/hls.js/issues/1331\n// Here we are mapping our internal track types to constant MP4 track IDs\n// With MSE currently one can only have one track of each, and we are muxing\n// whatever video/audio rendition in them.\n\nvar RemuxerTrackIdConfig = {\n video: 1,\n audio: 2,\n id3: 3,\n text: 4\n};\nfunction bin2str(data) {\n return String.fromCharCode.apply(null, data);\n}\nfunction readUint16(buffer, offset) {\n var val = buffer[offset] << 8 | buffer[offset + 1];\n return val < 0 ? 65536 + val : val;\n}\nfunction readUint32(buffer, offset) {\n var val = readSint32(buffer, offset);\n return val < 0 ? 4294967296 + val : val;\n}\nfunction readSint32(buffer, offset) {\n return buffer[offset] << 24 | buffer[offset + 1] << 16 | buffer[offset + 2] << 8 | buffer[offset + 3];\n}\nfunction writeUint32(buffer, offset, value) {\n buffer[offset] = value >> 24;\n buffer[offset + 1] = value >> 16 & 0xff;\n buffer[offset + 2] = value >> 8 & 0xff;\n buffer[offset + 3] = value & 0xff;\n} // Find the data for a box specified by its path\n\nfunction findBox(data, path) {\n var results = [];\n\n if (!path.length) {\n // short-circuit the search for empty paths\n return results;\n }\n\n var end = data.byteLength;\n\n for (var i = 0; i < end;) {\n var size = readUint32(data, i);\n var type = bin2str(data.subarray(i + 4, i + 8));\n var endbox = size > 1 ? i + size : end;\n\n if (type === path[0]) {\n if (path.length === 1) {\n // this is the end of the path and we've found the box we were\n // looking for\n results.push(data.subarray(i + 8, endbox));\n } else {\n // recursively search for the next box along the path\n var subresults = findBox(data.subarray(i + 8, endbox), path.slice(1));\n\n if (subresults.length) {\n push.apply(results, subresults);\n }\n }\n }\n\n i = endbox;\n } // we've finished searching all of data\n\n\n return results;\n}\nfunction parseSegmentIndex(sidx) {\n var references = [];\n var version = sidx[0]; // set initial offset, we skip the reference ID (not needed)\n\n var index = 8;\n var timescale = readUint32(sidx, index);\n index += 4; // TODO: parse earliestPresentationTime and firstOffset\n // usually zero in our case\n\n var earliestPresentationTime = 0;\n var firstOffset = 0;\n\n if (version === 0) {\n index += 8;\n } else {\n index += 16;\n } // skip reserved\n\n\n index += 2;\n var startByte = sidx.length + firstOffset;\n var referencesCount = readUint16(sidx, index);\n index += 2;\n\n for (var i = 0; i < referencesCount; i++) {\n var referenceIndex = index;\n var referenceInfo = readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n var referenceSize = referenceInfo & 0x7fffffff;\n var referenceType = (referenceInfo & 0x80000000) >>> 31;\n\n if (referenceType === 1) {\n // eslint-disable-next-line no-console\n console.warn('SIDX has hierarchical references (not supported)');\n return null;\n }\n\n var subsegmentDuration = readUint32(sidx, referenceIndex);\n referenceIndex += 4;\n references.push({\n referenceSize: referenceSize,\n subsegmentDuration: subsegmentDuration,\n // unscaled\n info: {\n duration: subsegmentDuration / timescale,\n start: startByte,\n end: startByte + referenceSize - 1\n }\n });\n startByte += referenceSize; // Skipping 1 bit for |startsWithSap|, 3 bits for |sapType|, and 28 bits\n // for |sapDelta|.\n\n referenceIndex += 4; // skip to next ref\n\n index = referenceIndex;\n }\n\n return {\n earliestPresentationTime: earliestPresentationTime,\n timescale: timescale,\n version: version,\n referencesCount: referencesCount,\n references: references\n };\n}\n/**\n * Parses an MP4 initialization segment and extracts stream type and\n * timescale values for any declared tracks. Timescale values indicate the\n * number of clock ticks per second to assume for time-based values\n * elsewhere in the MP4.\n *\n * To determine the start time of an MP4, you need two pieces of\n * information: the timescale unit and the earliest base media decode\n * time. Multiple timescales can be specified within an MP4 but the\n * base media decode time is always expressed in the timescale from\n * the media header box for the track:\n * ```\n * moov > trak > mdia > mdhd.timescale\n * moov > trak > mdia > hdlr\n * ```\n * @param initSegment {Uint8Array} the bytes of the init segment\n * @return {InitData} a hash of track type to timescale values or null if\n * the init segment is malformed.\n */\n\nfunction parseInitSegment(initSegment) {\n var result = [];\n var traks = findBox(initSegment, ['moov', 'trak']);\n\n for (var i = 0; i < traks.length; i++) {\n var trak = traks[i];\n var tkhd = findBox(trak, ['tkhd'])[0];\n\n if (tkhd) {\n var version = tkhd[0];\n\n var _index = version === 0 ? 12 : 20;\n\n var trackId = readUint32(tkhd, _index);\n var mdhd = findBox(trak, ['mdia', 'mdhd'])[0];\n\n if (mdhd) {\n version = mdhd[0];\n _index = version === 0 ? 12 : 20;\n var timescale = readUint32(mdhd, _index);\n var hdlr = findBox(trak, ['mdia', 'hdlr'])[0];\n\n if (hdlr) {\n var hdlrType = bin2str(hdlr.subarray(8, 12));\n var type = {\n soun: _loader_fragment__WEBPACK_IMPORTED_MODULE_1__[\"ElementaryStreamTypes\"].AUDIO,\n vide: _loader_fragment__WEBPACK_IMPORTED_MODULE_1__[\"ElementaryStreamTypes\"].VIDEO\n }[hdlrType];\n\n if (type) {\n // Parse codec details\n var stsd = findBox(trak, ['mdia', 'minf', 'stbl', 'stsd'])[0];\n var codec = void 0;\n\n if (stsd) {\n codec = bin2str(stsd.subarray(12, 16)); // TODO: Parse codec details to be able to build MIME type.\n // stsd.start += 8;\n // const codecBox = findBox(stsd, [codec])[0];\n // if (codecBox) {\n // TODO: Codec parsing support for avc1, mp4a, hevc, av01...\n // }\n }\n\n result[trackId] = {\n timescale: timescale,\n type: type\n };\n result[type] = {\n timescale: timescale,\n id: trackId,\n codec: codec\n };\n }\n }\n }\n }\n }\n\n var trex = findBox(initSegment, ['moov', 'mvex', 'trex']);\n trex.forEach(function (trex) {\n var trackId = readUint32(trex, 4);\n var track = result[trackId];\n\n if (track) {\n track.default = {\n duration: readUint32(trex, 12),\n flags: readUint32(trex, 20)\n };\n }\n });\n return result;\n}\n/**\n * Determine the base media decode start time, in seconds, for an MP4\n * fragment. If multiple fragments are specified, the earliest time is\n * returned.\n *\n * The base media decode time can be parsed from track fragment\n * metadata:\n * ```\n * moof > traf > tfdt.baseMediaDecodeTime\n * ```\n * It requires the timescale value from the mdhd to interpret.\n *\n * @param initData {InitData} a hash of track type to timescale values\n * @param fmp4 {Uint8Array} the bytes of the mp4 fragment\n * @return {number} the earliest base media decode start time for the\n * fragment, in seconds\n */\n\nfunction getStartDTS(initData, fmp4) {\n // we need info from two children of each track fragment box\n return findBox(fmp4, ['moof', 'traf']).reduce(function (result, traf) {\n var tfdt = findBox(traf, ['tfdt'])[0];\n var version = tfdt[0];\n var start = findBox(traf, ['tfhd']).reduce(function (result, tfhd) {\n // get the track id from the tfhd\n var id = readUint32(tfhd, 4);\n var track = initData[id];\n\n if (track) {\n var baseTime = readUint32(tfdt, 4);\n\n if (version === 1) {\n baseTime *= Math.pow(2, 32);\n baseTime += readUint32(tfdt, 8);\n } // assume a 90kHz clock if no timescale was specified\n\n\n var scale = track.timescale || 90e3; // convert base time to seconds\n\n var startTime = baseTime / scale;\n\n if (isFinite(startTime) && (result === null || startTime < result)) {\n return startTime;\n }\n }\n\n return result;\n }, null);\n\n if (start !== null && isFinite(start) && (result === null || start < result)) {\n return start;\n }\n\n return result;\n }, null) || 0;\n}\n/*\n For Reference:\n aligned(8) class TrackFragmentHeaderBox\n extends FullBox(‘tfhd’, 0, tf_flags){\n unsigned int(32) track_ID;\n // all the following are optional fields\n unsigned int(64) base_data_offset;\n unsigned int(32) sample_description_index;\n unsigned int(32) default_sample_duration;\n unsigned int(32) default_sample_size;\n unsigned int(32) default_sample_flags\n }\n */\n\nfunction getDuration(data, initData) {\n var sidxDuration = 0;\n var sidxs = findBox(data, ['sidx']);\n\n for (var i = 0; i < sidxs.length; i++) {\n var sidx = parseSegmentIndex(sidxs[i]);\n\n if (sidx !== null && sidx !== void 0 && sidx.references) {\n sidxDuration += sidx.references.reduce(function (dur, ref) {\n return dur + ref.info.duration || 0;\n }, 0);\n }\n }\n\n if (sidxDuration) {\n return sidxDuration;\n }\n\n var rawDuration = 0;\n var videoDuration = 0;\n var audioDuration = 0;\n var trafs = findBox(data, ['moof', 'traf']);\n\n for (var _i = 0; _i < trafs.length; _i++) {\n var traf = trafs[_i]; // There is only one tfhd & trun per traf\n // This is true for CMAF style content, and we should perhaps check the ftyp\n // and only look for a single trun then, but for ISOBMFF we should check\n // for multiple track runs.\n\n var tfhd = findBox(traf, ['tfhd'])[0]; // get the track id from the tfhd\n\n var id = readUint32(tfhd, 4);\n var track = initData[id];\n\n if (!track) {\n continue;\n }\n\n var trackDefault = track.default;\n var tfhdFlags = readUint32(tfhd, 0) | (trackDefault === null || trackDefault === void 0 ? void 0 : trackDefault.flags);\n var sampleDuration = trackDefault === null || trackDefault === void 0 ? void 0 : trackDefault.duration;\n\n if (tfhdFlags & 0x000008) {\n // 0x000008 indicates the presence of the default_sample_duration field\n if (tfhdFlags & 0x000002) {\n // 0x000002 indicates the presence of the sample_description_index field, which precedes default_sample_duration\n // If present, the default_sample_duration exists at byte offset 12\n sampleDuration = readUint32(tfhd, 12);\n } else {\n // Otherwise, the duration is at byte offset 8\n sampleDuration = readUint32(tfhd, 8);\n }\n } // assume a 90kHz clock if no timescale was specified\n\n\n var timescale = track.timescale || 90e3;\n var truns = findBox(traf, ['trun']);\n\n for (var j = 0; j < truns.length; j++) {\n rawDuration = computeRawDurationFromSamples(truns[j]);\n\n if (!rawDuration && sampleDuration) {\n var sampleCount = readUint32(truns[j], 4);\n rawDuration = sampleDuration * sampleCount;\n }\n\n if (track.type === _loader_fragment__WEBPACK_IMPORTED_MODULE_1__[\"ElementaryStreamTypes\"].VIDEO) {\n videoDuration += rawDuration / timescale;\n } else if (track.type === _loader_fragment__WEBPACK_IMPORTED_MODULE_1__[\"ElementaryStreamTypes\"].AUDIO) {\n audioDuration += rawDuration / timescale;\n }\n }\n }\n\n if (videoDuration) {\n return videoDuration;\n }\n\n return audioDuration;\n}\n/*\n For Reference:\n aligned(8) class TrackRunBox\n extends FullBox(‘trun’, version, tr_flags) {\n unsigned int(32) sample_count;\n // the following are optional fields\n signed int(32) data_offset;\n unsigned int(32) first_sample_flags;\n // all fields in the following array are optional\n {\n unsigned int(32) sample_duration;\n unsigned int(32) sample_size;\n unsigned int(32) sample_flags\n if (version == 0)\n { unsigned int(32)\n else\n { signed int(32)\n }[ sample_count ]\n }\n */\n\nfunction computeRawDurationFromSamples(trun) {\n var flags = readUint32(trun, 0); // Flags are at offset 0, non-optional sample_count is at offset 4. Therefore we start 8 bytes in.\n // Each field is an int32, which is 4 bytes\n\n var offset = 8; // data-offset-present flag\n\n if (flags & 0x000001) {\n offset += 4;\n } // first-sample-flags-present flag\n\n\n if (flags & 0x000004) {\n offset += 4;\n }\n\n var duration = 0;\n var sampleCount = readUint32(trun, 4);\n\n for (var i = 0; i < sampleCount; i++) {\n // sample-duration-present flag\n if (flags & 0x000100) {\n var sampleDuration = readUint32(trun, offset);\n duration += sampleDuration;\n offset += 4;\n } // sample-size-present flag\n\n\n if (flags & 0x000200) {\n offset += 4;\n } // sample-flags-present flag\n\n\n if (flags & 0x000400) {\n offset += 4;\n } // sample-composition-time-offsets-present flag\n\n\n if (flags & 0x000800) {\n offset += 4;\n }\n }\n\n return duration;\n}\nfunction offsetStartDTS(initData, fmp4, timeOffset) {\n findBox(fmp4, ['moof', 'traf']).forEach(function (traf) {\n findBox(traf, ['tfhd']).forEach(function (tfhd) {\n // get the track id from the tfhd\n var id = readUint32(tfhd, 4);\n var track = initData[id];\n\n if (!track) {\n return;\n } // assume a 90kHz clock if no timescale was specified\n\n\n var timescale = track.timescale || 90e3; // get the base media decode time from the tfdt\n\n findBox(traf, ['tfdt']).forEach(function (tfdt) {\n var version = tfdt[0];\n var baseMediaDecodeTime = readUint32(tfdt, 4);\n\n if (version === 0) {\n baseMediaDecodeTime -= timeOffset * timescale;\n baseMediaDecodeTime = Math.max(baseMediaDecodeTime, 0);\n writeUint32(tfdt, 4, baseMediaDecodeTime);\n } else {\n baseMediaDecodeTime *= Math.pow(2, 32);\n baseMediaDecodeTime += readUint32(tfdt, 8);\n baseMediaDecodeTime -= timeOffset * timescale;\n baseMediaDecodeTime = Math.max(baseMediaDecodeTime, 0);\n var upper = Math.floor(baseMediaDecodeTime / (UINT32_MAX + 1));\n var lower = Math.floor(baseMediaDecodeTime % (UINT32_MAX + 1));\n writeUint32(tfdt, 4, upper);\n writeUint32(tfdt, 8, lower);\n }\n });\n });\n });\n} // TODO: Check if the last moof+mdat pair is part of the valid range\n\nfunction segmentValidRange(data) {\n var segmentedRange = {\n valid: null,\n remainder: null\n };\n var moofs = findBox(data, ['moof']);\n\n if (!moofs) {\n return segmentedRange;\n } else if (moofs.length < 2) {\n segmentedRange.remainder = data;\n return segmentedRange;\n }\n\n var last = moofs[moofs.length - 1]; // Offset by 8 bytes; findBox offsets the start by as much\n\n segmentedRange.valid = Object(_typed_array__WEBPACK_IMPORTED_MODULE_0__[\"sliceUint8\"])(data, 0, last.byteOffset - 8);\n segmentedRange.remainder = Object(_typed_array__WEBPACK_IMPORTED_MODULE_0__[\"sliceUint8\"])(data, last.byteOffset - 8);\n return segmentedRange;\n}\nfunction appendUint8Array(data1, data2) {\n var temp = new Uint8Array(data1.length + data2.length);\n temp.set(data1);\n temp.set(data2, data1.length);\n return temp;\n}\nfunction parseSamples(timeOffset, track) {\n var seiSamples = [];\n var videoData = track.samples;\n var timescale = track.timescale;\n var trackId = track.id;\n var isHEVCFlavor = false;\n var moofs = findBox(videoData, ['moof']);\n moofs.map(function (moof) {\n var moofOffset = moof.byteOffset - 8;\n var trafs = findBox(moof, ['traf']);\n trafs.map(function (traf) {\n // get the base media decode time from the tfdt\n var baseTime = findBox(traf, ['tfdt']).map(function (tfdt) {\n var version = tfdt[0];\n var result = readUint32(tfdt, 4);\n\n if (version === 1) {\n result *= Math.pow(2, 32);\n result += readUint32(tfdt, 8);\n }\n\n return result / timescale;\n })[0];\n\n if (baseTime !== undefined) {\n timeOffset = baseTime;\n }\n\n return findBox(traf, ['tfhd']).map(function (tfhd) {\n var id = readUint32(tfhd, 4);\n var tfhdFlags = readUint32(tfhd, 0) & 0xffffff;\n var baseDataOffsetPresent = (tfhdFlags & 0x000001) !== 0;\n var sampleDescriptionIndexPresent = (tfhdFlags & 0x000002) !== 0;\n var defaultSampleDurationPresent = (tfhdFlags & 0x000008) !== 0;\n var defaultSampleDuration = 0;\n var defaultSampleSizePresent = (tfhdFlags & 0x000010) !== 0;\n var defaultSampleSize = 0;\n var defaultSampleFlagsPresent = (tfhdFlags & 0x000020) !== 0;\n var tfhdOffset = 8;\n\n if (id === trackId) {\n if (baseDataOffsetPresent) {\n tfhdOffset += 8;\n }\n\n if (sampleDescriptionIndexPresent) {\n tfhdOffset += 4;\n }\n\n if (defaultSampleDurationPresent) {\n defaultSampleDuration = readUint32(tfhd, tfhdOffset);\n tfhdOffset += 4;\n }\n\n if (defaultSampleSizePresent) {\n defaultSampleSize = readUint32(tfhd, tfhdOffset);\n tfhdOffset += 4;\n }\n\n if (defaultSampleFlagsPresent) {\n tfhdOffset += 4;\n }\n\n if (track.type === 'video') {\n isHEVCFlavor = isHEVC(track.codec);\n }\n\n findBox(traf, ['trun']).map(function (trun) {\n var version = trun[0];\n var flags = readUint32(trun, 0) & 0xffffff;\n var dataOffsetPresent = (flags & 0x000001) !== 0;\n var dataOffset = 0;\n var firstSampleFlagsPresent = (flags & 0x000004) !== 0;\n var sampleDurationPresent = (flags & 0x000100) !== 0;\n var sampleDuration = 0;\n var sampleSizePresent = (flags & 0x000200) !== 0;\n var sampleSize = 0;\n var sampleFlagsPresent = (flags & 0x000400) !== 0;\n var sampleCompositionOffsetsPresent = (flags & 0x000800) !== 0;\n var compositionOffset = 0;\n var sampleCount = readUint32(trun, 4);\n var trunOffset = 8; // past version, flags, and sample count\n\n if (dataOffsetPresent) {\n dataOffset = readUint32(trun, trunOffset);\n trunOffset += 4;\n }\n\n if (firstSampleFlagsPresent) {\n trunOffset += 4;\n }\n\n var sampleOffset = dataOffset + moofOffset;\n\n for (var ix = 0; ix < sampleCount; ix++) {\n if (sampleDurationPresent) {\n sampleDuration = readUint32(trun, trunOffset);\n trunOffset += 4;\n } else {\n sampleDuration = defaultSampleDuration;\n }\n\n if (sampleSizePresent) {\n sampleSize = readUint32(trun, trunOffset);\n trunOffset += 4;\n } else {\n sampleSize = defaultSampleSize;\n }\n\n if (sampleFlagsPresent) {\n trunOffset += 4;\n }\n\n if (sampleCompositionOffsetsPresent) {\n if (version === 0) {\n compositionOffset = readUint32(trun, trunOffset);\n } else {\n compositionOffset = readSint32(trun, trunOffset);\n }\n\n trunOffset += 4;\n }\n\n if (track.type === _loader_fragment__WEBPACK_IMPORTED_MODULE_1__[\"ElementaryStreamTypes\"].VIDEO) {\n var naluTotalSize = 0;\n\n while (naluTotalSize < sampleSize) {\n var naluSize = readUint32(videoData, sampleOffset);\n sampleOffset += 4;\n var naluType = videoData[sampleOffset] & 0x1f;\n\n if (isSEIMessage(isHEVCFlavor, naluType)) {\n var data = videoData.subarray(sampleOffset, sampleOffset + naluSize);\n parseSEIMessageFromNALu(data, timeOffset + compositionOffset / timescale, seiSamples);\n }\n\n sampleOffset += naluSize;\n naluTotalSize += naluSize + 4;\n }\n }\n\n timeOffset += sampleDuration / timescale;\n }\n });\n }\n });\n });\n });\n return seiSamples;\n}\n\nfunction isHEVC(codec) {\n if (!codec) {\n return false;\n }\n\n var delimit = codec.indexOf('.');\n var baseCodec = delimit < 0 ? codec : codec.substring(0, delimit);\n return baseCodec === 'hvc1' || baseCodec === 'hev1' || // Dolby Vision\n baseCodec === 'dvh1' || baseCodec === 'dvhe';\n}\n\nfunction isSEIMessage(isHEVCFlavor, naluType) {\n return isHEVCFlavor ? naluType === 39 || naluType === 40 : naluType === 6;\n}\n\nfunction parseSEIMessageFromNALu(unescapedData, pts, samples) {\n var data = discardEPB(unescapedData);\n var seiPtr = 0; // skip frameType\n\n seiPtr++;\n var payloadType = 0;\n var payloadSize = 0;\n var endOfCaptions = false;\n var b = 0;\n\n while (seiPtr < data.length) {\n payloadType = 0;\n\n do {\n if (seiPtr >= data.length) {\n break;\n }\n\n b = data[seiPtr++];\n payloadType += b;\n } while (b === 0xff); // Parse payload size.\n\n\n payloadSize = 0;\n\n do {\n if (seiPtr >= data.length) {\n break;\n }\n\n b = data[seiPtr++];\n payloadSize += b;\n } while (b === 0xff);\n\n var leftOver = data.length - seiPtr;\n\n if (!endOfCaptions && payloadType === 4 && seiPtr < data.length) {\n endOfCaptions = true;\n var countryCode = data[seiPtr++];\n\n if (countryCode === 181) {\n var providerCode = readUint16(data, seiPtr);\n seiPtr += 2;\n\n if (providerCode === 49) {\n var userStructure = readUint32(data, seiPtr);\n seiPtr += 4;\n\n if (userStructure === 0x47413934) {\n var userDataType = data[seiPtr++]; // Raw CEA-608 bytes wrapped in CEA-708 packet\n\n if (userDataType === 3) {\n var firstByte = data[seiPtr++];\n var totalCCs = 0x1f & firstByte;\n var enabled = 0x40 & firstByte;\n var totalBytes = enabled ? 2 + totalCCs * 3 : 0;\n var byteArray = new Uint8Array(totalBytes);\n\n if (enabled) {\n byteArray[0] = firstByte;\n\n for (var i = 1; i < totalBytes; i++) {\n byteArray[i] = data[seiPtr++];\n }\n }\n\n samples.push({\n type: userDataType,\n payloadType: payloadType,\n pts: pts,\n bytes: byteArray\n });\n }\n }\n }\n }\n } else if (payloadType === 5 && payloadSize < leftOver) {\n endOfCaptions = true;\n\n if (payloadSize > 16) {\n var uuidStrArray = [];\n\n for (var _i2 = 0; _i2 < 16; _i2++) {\n var _b = data[seiPtr++].toString(16);\n\n uuidStrArray.push(_b.length == 1 ? '0' + _b : _b);\n\n if (_i2 === 3 || _i2 === 5 || _i2 === 7 || _i2 === 9) {\n uuidStrArray.push('-');\n }\n }\n\n var length = payloadSize - 16;\n var userDataBytes = new Uint8Array(length);\n\n for (var _i3 = 0; _i3 < length; _i3++) {\n userDataBytes[_i3] = data[seiPtr++];\n }\n\n samples.push({\n payloadType: payloadType,\n pts: pts,\n uuid: uuidStrArray.join(''),\n userData: Object(_demux_id3__WEBPACK_IMPORTED_MODULE_2__[\"utf8ArrayToStr\"])(userDataBytes),\n userDataBytes: userDataBytes\n });\n }\n } else if (payloadSize < leftOver) {\n seiPtr += payloadSize;\n } else if (payloadSize > leftOver) {\n break;\n }\n }\n}\n/**\n * remove Emulation Prevention bytes from a RBSP\n */\n\nfunction discardEPB(data) {\n var length = data.byteLength;\n var EPBPositions = [];\n var i = 1; // Find all `Emulation Prevention Bytes`\n\n while (i < length - 2) {\n if (data[i] === 0 && data[i + 1] === 0 && data[i + 2] === 0x03) {\n EPBPositions.push(i + 2);\n i += 2;\n } else {\n i++;\n }\n } // If no Emulation Prevention Bytes were found just return the original\n // array\n\n\n if (EPBPositions.length === 0) {\n return data;\n } // Create a new array to hold the NAL unit data\n\n\n var newLength = length - EPBPositions.length;\n var newData = new Uint8Array(newLength);\n var sourceIndex = 0;\n\n for (i = 0; i < newLength; sourceIndex++, i++) {\n if (sourceIndex === EPBPositions[0]) {\n // Skip this byte\n sourceIndex++; // Remove this position index\n\n EPBPositions.shift();\n }\n\n newData[i] = data[sourceIndex];\n }\n\n return newData;\n}\n\nfunction parseEmsg(data) {\n var version = data[0];\n var schemeIdUri = '';\n var value = '';\n var timeScale = 0;\n var presentationTimeDelta = 0;\n var presentationTime = 0;\n var eventDuration = 0;\n var id = 0;\n var offset = 0;\n\n if (version === 0) {\n while (bin2str(data.subarray(offset, offset + 1)) !== '\\0') {\n schemeIdUri += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n }\n\n schemeIdUri += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n\n while (bin2str(data.subarray(offset, offset + 1)) !== '\\0') {\n value += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n }\n\n value += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n timeScale = readUint32(data, 12);\n presentationTimeDelta = readUint32(data, 16);\n eventDuration = readUint32(data, 20);\n id = readUint32(data, 24);\n offset = 28;\n } else if (version === 1) {\n offset += 4;\n timeScale = readUint32(data, offset);\n offset += 4;\n var leftPresentationTime = readUint32(data, offset);\n offset += 4;\n var rightPresentationTime = readUint32(data, offset);\n offset += 4;\n presentationTime = Math.pow(2, 32) * leftPresentationTime + rightPresentationTime;\n\n if (!Number.isSafeInteger(presentationTime)) {\n presentationTime = Number.MAX_SAFE_INTEGER; // eslint-disable-next-line no-console\n\n console.warn('Presentation time exceeds safe integer limit and wrapped to max safe integer in parsing emsg box');\n }\n\n eventDuration = readUint32(data, offset);\n offset += 4;\n id = readUint32(data, offset);\n offset += 4;\n\n while (bin2str(data.subarray(offset, offset + 1)) !== '\\0') {\n schemeIdUri += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n }\n\n schemeIdUri += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n\n while (bin2str(data.subarray(offset, offset + 1)) !== '\\0') {\n value += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n }\n\n value += bin2str(data.subarray(offset, offset + 1));\n offset += 1;\n }\n\n var payload = data.subarray(offset, data.byteLength);\n return {\n schemeIdUri: schemeIdUri,\n value: value,\n timeScale: timeScale,\n presentationTime: presentationTime,\n presentationTimeDelta: presentationTimeDelta,\n eventDuration: eventDuration,\n id: id,\n payload: payload\n };\n}\n\n/***/ }),\n\n/***/ \"./src/utils/output-filter.ts\":\n/*!************************************!*\\\n !*** ./src/utils/output-filter.ts ***!\n \\************************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"default\", function() { return OutputFilter; });\nvar OutputFilter = /*#__PURE__*/function () {\n function OutputFilter(timelineController, trackName) {\n this.timelineController = void 0;\n this.cueRanges = [];\n this.trackName = void 0;\n this.startTime = null;\n this.endTime = null;\n this.screen = null;\n this.timelineController = timelineController;\n this.trackName = trackName;\n }\n\n var _proto = OutputFilter.prototype;\n\n _proto.dispatchCue = function dispatchCue() {\n if (this.startTime === null) {\n return;\n }\n\n this.timelineController.addCues(this.trackName, this.startTime, this.endTime, this.screen, this.cueRanges);\n this.startTime = null;\n };\n\n _proto.newCue = function newCue(startTime, endTime, screen) {\n if (this.startTime === null || this.startTime > startTime) {\n this.startTime = startTime;\n }\n\n this.endTime = endTime;\n this.screen = screen;\n this.timelineController.createCaptionsTrack(this.trackName);\n };\n\n _proto.reset = function reset() {\n this.cueRanges = [];\n this.startTime = null;\n };\n\n return OutputFilter;\n}();\n\n\n\n/***/ }),\n\n/***/ \"./src/utils/texttrack-utils.ts\":\n/*!**************************************!*\\\n !*** ./src/utils/texttrack-utils.ts ***!\n \\**************************************/\n/*! exports provided: sendAddTrackEvent, addCueToTrack, clearCurrentCues, removeCuesInRange, getCuesInRange */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"sendAddTrackEvent\", function() { return sendAddTrackEvent; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"addCueToTrack\", function() { return addCueToTrack; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"clearCurrentCues\", function() { return clearCurrentCues; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"removeCuesInRange\", function() { return removeCuesInRange; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"getCuesInRange\", function() { return getCuesInRange; });\n/* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./logger */ \"./src/utils/logger.ts\");\n\nfunction sendAddTrackEvent(track, videoEl) {\n var event;\n\n try {\n event = new Event('addtrack');\n } catch (err) {\n // for IE11\n event = document.createEvent('Event');\n event.initEvent('addtrack', false, false);\n }\n\n event.track = track;\n videoEl.dispatchEvent(event);\n}\nfunction addCueToTrack(track, cue) {\n // Sometimes there are cue overlaps on segmented vtts so the same\n // cue can appear more than once in different vtt files.\n // This avoid showing duplicated cues with same timecode and text.\n var mode = track.mode;\n\n if (mode === 'disabled') {\n track.mode = 'hidden';\n }\n\n if (track.cues && !track.cues.getCueById(cue.id)) {\n try {\n track.addCue(cue);\n\n if (!track.cues.getCueById(cue.id)) {\n throw new Error(\"addCue is failed for: \" + cue);\n }\n } catch (err) {\n _logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].debug(\"[texttrack-utils]: \" + err);\n var textTrackCue = new self.TextTrackCue(cue.startTime, cue.endTime, cue.text);\n textTrackCue.id = cue.id;\n track.addCue(textTrackCue);\n }\n }\n\n if (mode === 'disabled') {\n track.mode = mode;\n }\n}\nfunction clearCurrentCues(track) {\n // When track.mode is disabled, track.cues will be null.\n // To guarantee the removal of cues, we need to temporarily\n // change the mode to hidden\n var mode = track.mode;\n\n if (mode === 'disabled') {\n track.mode = 'hidden';\n }\n\n if (track.cues) {\n for (var i = track.cues.length; i--;) {\n track.removeCue(track.cues[i]);\n }\n }\n\n if (mode === 'disabled') {\n track.mode = mode;\n }\n}\nfunction removeCuesInRange(track, start, end, predicate) {\n var mode = track.mode;\n\n if (mode === 'disabled') {\n track.mode = 'hidden';\n }\n\n if (track.cues && track.cues.length > 0) {\n var cues = getCuesInRange(track.cues, start, end);\n\n for (var i = 0; i < cues.length; i++) {\n if (!predicate || predicate(cues[i])) {\n track.removeCue(cues[i]);\n }\n }\n }\n\n if (mode === 'disabled') {\n track.mode = mode;\n }\n} // Find first cue starting after given time.\n// Modified version of binary search O(log(n)).\n\nfunction getFirstCueIndexAfterTime(cues, time) {\n // If first cue starts after time, start there\n if (time < cues[0].startTime) {\n return 0;\n } // If the last cue ends before time there is no overlap\n\n\n var len = cues.length - 1;\n\n if (time > cues[len].endTime) {\n return -1;\n }\n\n var left = 0;\n var right = len;\n\n while (left <= right) {\n var mid = Math.floor((right + left) / 2);\n\n if (time < cues[mid].startTime) {\n right = mid - 1;\n } else if (time > cues[mid].startTime && left < len) {\n left = mid + 1;\n } else {\n // If it's not lower or higher, it must be equal.\n return mid;\n }\n } // At this point, left and right have swapped.\n // No direct match was found, left or right element must be the closest. Check which one has the smallest diff.\n\n\n return cues[left].startTime - time < time - cues[right].startTime ? left : right;\n}\n\nfunction getCuesInRange(cues, start, end) {\n var cuesFound = [];\n var firstCueInRange = getFirstCueIndexAfterTime(cues, start);\n\n if (firstCueInRange > -1) {\n for (var i = firstCueInRange, len = cues.length; i < len; i++) {\n var _cue = cues[i];\n\n if (_cue.startTime >= start && _cue.endTime <= end) {\n cuesFound.push(_cue);\n } else if (_cue.startTime > end) {\n return cuesFound;\n }\n }\n }\n\n return cuesFound;\n}\n\n/***/ }),\n\n/***/ \"./src/utils/time-ranges.ts\":\n/*!**********************************!*\\\n !*** ./src/utils/time-ranges.ts ***!\n \\**********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/**\n * TimeRanges to string helper\n */\nvar TimeRanges = {\n toString: function toString(r) {\n var log = '';\n var len = r.length;\n\n for (var i = 0; i < len; i++) {\n log += '[' + r.start(i).toFixed(3) + ',' + r.end(i).toFixed(3) + ']';\n }\n\n return log;\n }\n};\n/* harmony default export */ __webpack_exports__[\"default\"] = (TimeRanges);\n\n/***/ }),\n\n/***/ \"./src/utils/timescale-conversion.ts\":\n/*!*******************************************!*\\\n !*** ./src/utils/timescale-conversion.ts ***!\n \\*******************************************/\n/*! exports provided: toTimescaleFromBase, toTimescaleFromScale, toMsFromMpegTsClock, toMpegTsClockFromTimescale */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"toTimescaleFromBase\", function() { return toTimescaleFromBase; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"toTimescaleFromScale\", function() { return toTimescaleFromScale; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"toMsFromMpegTsClock\", function() { return toMsFromMpegTsClock; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"toMpegTsClockFromTimescale\", function() { return toMpegTsClockFromTimescale; });\nvar MPEG_TS_CLOCK_FREQ_HZ = 90000;\nfunction toTimescaleFromBase(value, destScale, srcBase, round) {\n if (srcBase === void 0) {\n srcBase = 1;\n }\n\n if (round === void 0) {\n round = false;\n }\n\n var result = value * destScale * srcBase; // equivalent to `(value * scale) / (1 / base)`\n\n return round ? Math.round(result) : result;\n}\nfunction toTimescaleFromScale(value, destScale, srcScale, round) {\n if (srcScale === void 0) {\n srcScale = 1;\n }\n\n if (round === void 0) {\n round = false;\n }\n\n return toTimescaleFromBase(value, destScale, 1 / srcScale, round);\n}\nfunction toMsFromMpegTsClock(value, round) {\n if (round === void 0) {\n round = false;\n }\n\n return toTimescaleFromBase(value, 1000, 1 / MPEG_TS_CLOCK_FREQ_HZ, round);\n}\nfunction toMpegTsClockFromTimescale(value, srcScale) {\n if (srcScale === void 0) {\n srcScale = 1;\n }\n\n return toTimescaleFromBase(value, MPEG_TS_CLOCK_FREQ_HZ, 1 / srcScale);\n}\n\n/***/ }),\n\n/***/ \"./src/utils/typed-array.ts\":\n/*!**********************************!*\\\n !*** ./src/utils/typed-array.ts ***!\n \\**********************************/\n/*! exports provided: sliceUint8 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"sliceUint8\", function() { return sliceUint8; });\nfunction sliceUint8(array, start, end) {\n // @ts-expect-error This polyfills IE11 usage of Uint8Array slice.\n // It always exists in the TypeScript definition so fails, but it fails at runtime on IE11.\n return Uint8Array.prototype.slice ? array.slice(start, end) : new Uint8Array(Array.prototype.slice.call(array, start, end));\n}\n\n/***/ }),\n\n/***/ \"./src/utils/vttcue.ts\":\n/*!*****************************!*\\\n !*** ./src/utils/vttcue.ts ***!\n \\*****************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the 'License');\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an 'AS IS' BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n/* harmony default export */ __webpack_exports__[\"default\"] = ((function () {\n if (typeof self !== 'undefined' && self.VTTCue) {\n return self.VTTCue;\n }\n\n var AllowedDirections = ['', 'lr', 'rl'];\n var AllowedAlignments = ['start', 'middle', 'end', 'left', 'right'];\n\n function isAllowedValue(allowed, value) {\n if (typeof value !== 'string') {\n return false;\n } // necessary for assuring the generic conforms to the Array interface\n\n\n if (!Array.isArray(allowed)) {\n return false;\n } // reset the type so that the next narrowing works well\n\n\n var lcValue = value.toLowerCase(); // use the allow list to narrow the type to a specific subset of strings\n\n if (~allowed.indexOf(lcValue)) {\n return lcValue;\n }\n\n return false;\n }\n\n function findDirectionSetting(value) {\n return isAllowedValue(AllowedDirections, value);\n }\n\n function findAlignSetting(value) {\n return isAllowedValue(AllowedAlignments, value);\n }\n\n function extend(obj) {\n for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n rest[_key - 1] = arguments[_key];\n }\n\n var i = 1;\n\n for (; i < arguments.length; i++) {\n var cobj = arguments[i];\n\n for (var p in cobj) {\n obj[p] = cobj[p];\n }\n }\n\n return obj;\n }\n\n function VTTCue(startTime, endTime, text) {\n var cue = this;\n var baseObj = {\n enumerable: true\n };\n /**\n * Shim implementation specific properties. These properties are not in\n * the spec.\n */\n // Lets us know when the VTTCue's data has changed in such a way that we need\n // to recompute its display state. This lets us compute its display state\n // lazily.\n\n cue.hasBeenReset = false;\n /**\n * VTTCue and TextTrackCue properties\n * http://dev.w3.org/html5/webvtt/#vttcue-interface\n */\n\n var _id = '';\n var _pauseOnExit = false;\n var _startTime = startTime;\n var _endTime = endTime;\n var _text = text;\n var _region = null;\n var _vertical = '';\n var _snapToLines = true;\n var _line = 'auto';\n var _lineAlign = 'start';\n var _position = 50;\n var _positionAlign = 'middle';\n var _size = 50;\n var _align = 'middle';\n Object.defineProperty(cue, 'id', extend({}, baseObj, {\n get: function get() {\n return _id;\n },\n set: function set(value) {\n _id = '' + value;\n }\n }));\n Object.defineProperty(cue, 'pauseOnExit', extend({}, baseObj, {\n get: function get() {\n return _pauseOnExit;\n },\n set: function set(value) {\n _pauseOnExit = !!value;\n }\n }));\n Object.defineProperty(cue, 'startTime', extend({}, baseObj, {\n get: function get() {\n return _startTime;\n },\n set: function set(value) {\n if (typeof value !== 'number') {\n throw new TypeError('Start time must be set to a number.');\n }\n\n _startTime = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'endTime', extend({}, baseObj, {\n get: function get() {\n return _endTime;\n },\n set: function set(value) {\n if (typeof value !== 'number') {\n throw new TypeError('End time must be set to a number.');\n }\n\n _endTime = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'text', extend({}, baseObj, {\n get: function get() {\n return _text;\n },\n set: function set(value) {\n _text = '' + value;\n this.hasBeenReset = true;\n }\n })); // todo: implement VTTRegion polyfill?\n\n Object.defineProperty(cue, 'region', extend({}, baseObj, {\n get: function get() {\n return _region;\n },\n set: function set(value) {\n _region = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'vertical', extend({}, baseObj, {\n get: function get() {\n return _vertical;\n },\n set: function set(value) {\n var setting = findDirectionSetting(value); // Have to check for false because the setting an be an empty string.\n\n if (setting === false) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _vertical = setting;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'snapToLines', extend({}, baseObj, {\n get: function get() {\n return _snapToLines;\n },\n set: function set(value) {\n _snapToLines = !!value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'line', extend({}, baseObj, {\n get: function get() {\n return _line;\n },\n set: function set(value) {\n if (typeof value !== 'number' && value !== 'auto') {\n throw new SyntaxError('An invalid number or illegal string was specified.');\n }\n\n _line = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'lineAlign', extend({}, baseObj, {\n get: function get() {\n return _lineAlign;\n },\n set: function set(value) {\n var setting = findAlignSetting(value);\n\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _lineAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'position', extend({}, baseObj, {\n get: function get() {\n return _position;\n },\n set: function set(value) {\n if (value < 0 || value > 100) {\n throw new Error('Position must be between 0 and 100.');\n }\n\n _position = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'positionAlign', extend({}, baseObj, {\n get: function get() {\n return _positionAlign;\n },\n set: function set(value) {\n var setting = findAlignSetting(value);\n\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _positionAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'size', extend({}, baseObj, {\n get: function get() {\n return _size;\n },\n set: function set(value) {\n if (value < 0 || value > 100) {\n throw new Error('Size must be between 0 and 100.');\n }\n\n _size = value;\n this.hasBeenReset = true;\n }\n }));\n Object.defineProperty(cue, 'align', extend({}, baseObj, {\n get: function get() {\n return _align;\n },\n set: function set(value) {\n var setting = findAlignSetting(value);\n\n if (!setting) {\n throw new SyntaxError('An invalid or illegal string was specified.');\n }\n\n _align = setting;\n this.hasBeenReset = true;\n }\n }));\n /**\n * Other <track> spec defined properties\n */\n // http://www.whatwg.org/specs/web-apps/current-work/multipage/the-video-element.html#text-track-cue-display-state\n\n cue.displayState = undefined;\n }\n /**\n * VTTCue methods\n */\n\n\n VTTCue.prototype.getCueAsHTML = function () {\n // Assume WebVTT.convertCueToDOMTree is on the global.\n var WebVTT = self.WebVTT;\n return WebVTT.convertCueToDOMTree(self, this.text);\n }; // this is a polyfill hack\n\n\n return VTTCue;\n})());\n\n/***/ }),\n\n/***/ \"./src/utils/vttparser.ts\":\n/*!********************************!*\\\n !*** ./src/utils/vttparser.ts ***!\n \\********************************/\n/*! exports provided: parseTimeStamp, fixLineBreaks, VTTParser */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseTimeStamp\", function() { return parseTimeStamp; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"fixLineBreaks\", function() { return fixLineBreaks; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"VTTParser\", function() { return VTTParser; });\n/* harmony import */ var _vttcue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./vttcue */ \"./src/utils/vttcue.ts\");\n/*\n * Source: https://github.com/mozilla/vtt.js/blob/master/dist/vtt.js\n */\n\n\nvar StringDecoder = /*#__PURE__*/function () {\n function StringDecoder() {}\n\n var _proto = StringDecoder.prototype;\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n _proto.decode = function decode(data, options) {\n if (!data) {\n return '';\n }\n\n if (typeof data !== 'string') {\n throw new Error('Error - expected string data.');\n }\n\n return decodeURIComponent(encodeURIComponent(data));\n };\n\n return StringDecoder;\n}(); // Try to parse input as a time stamp.\n\n\nfunction parseTimeStamp(input) {\n function computeSeconds(h, m, s, f) {\n return (h | 0) * 3600 + (m | 0) * 60 + (s | 0) + parseFloat(f || 0);\n }\n\n var m = input.match(/^(?:(\\d+):)?(\\d{2}):(\\d{2})(\\.\\d+)?/);\n\n if (!m) {\n return null;\n }\n\n if (parseFloat(m[2]) > 59) {\n // Timestamp takes the form of [hours]:[minutes].[milliseconds]\n // First position is hours as it's over 59.\n return computeSeconds(m[2], m[3], 0, m[4]);\n } // Timestamp takes the form of [hours (optional)]:[minutes]:[seconds].[milliseconds]\n\n\n return computeSeconds(m[1], m[2], m[3], m[4]);\n} // A settings object holds key/value pairs and will ignore anything but the first\n// assignment to a specific key.\n\nvar Settings = /*#__PURE__*/function () {\n function Settings() {\n this.values = Object.create(null);\n }\n\n var _proto2 = Settings.prototype;\n\n // Only accept the first assignment to any key.\n _proto2.set = function set(k, v) {\n if (!this.get(k) && v !== '') {\n this.values[k] = v;\n }\n } // Return the value for a key, or a default value.\n // If 'defaultKey' is passed then 'dflt' is assumed to be an object with\n // a number of possible default values as properties where 'defaultKey' is\n // the key of the property that will be chosen; otherwise it's assumed to be\n // a single value.\n ;\n\n _proto2.get = function get(k, dflt, defaultKey) {\n if (defaultKey) {\n return this.has(k) ? this.values[k] : dflt[defaultKey];\n }\n\n return this.has(k) ? this.values[k] : dflt;\n } // Check whether we have a value for a key.\n ;\n\n _proto2.has = function has(k) {\n return k in this.values;\n } // Accept a setting if its one of the given alternatives.\n ;\n\n _proto2.alt = function alt(k, v, a) {\n for (var n = 0; n < a.length; ++n) {\n if (v === a[n]) {\n this.set(k, v);\n break;\n }\n }\n } // Accept a setting if its a valid (signed) integer.\n ;\n\n _proto2.integer = function integer(k, v) {\n if (/^-?\\d+$/.test(v)) {\n // integer\n this.set(k, parseInt(v, 10));\n }\n } // Accept a setting if its a valid percentage.\n ;\n\n _proto2.percent = function percent(k, v) {\n if (/^([\\d]{1,3})(\\.[\\d]*)?%$/.test(v)) {\n var percent = parseFloat(v);\n\n if (percent >= 0 && percent <= 100) {\n this.set(k, percent);\n return true;\n }\n }\n\n return false;\n };\n\n return Settings;\n}(); // Helper function to parse input into groups separated by 'groupDelim', and\n// interpret each group as a key/value pair separated by 'keyValueDelim'.\n\n\nfunction parseOptions(input, callback, keyValueDelim, groupDelim) {\n var groups = groupDelim ? input.split(groupDelim) : [input];\n\n for (var i in groups) {\n if (typeof groups[i] !== 'string') {\n continue;\n }\n\n var kv = groups[i].split(keyValueDelim);\n\n if (kv.length !== 2) {\n continue;\n }\n\n var _k = kv[0];\n var _v = kv[1];\n callback(_k, _v);\n }\n}\n\nvar defaults = new _vttcue__WEBPACK_IMPORTED_MODULE_0__[\"default\"](0, 0, ''); // 'middle' was changed to 'center' in the spec: https://github.com/w3c/webvtt/pull/244\n// Safari doesn't yet support this change, but FF and Chrome do.\n\nvar center = defaults.align === 'middle' ? 'middle' : 'center';\n\nfunction parseCue(input, cue, regionList) {\n // Remember the original input if we need to throw an error.\n var oInput = input; // 4.1 WebVTT timestamp\n\n function consumeTimeStamp() {\n var ts = parseTimeStamp(input);\n\n if (ts === null) {\n throw new Error('Malformed timestamp: ' + oInput);\n } // Remove time stamp from input.\n\n\n input = input.replace(/^[^\\sa-zA-Z-]+/, '');\n return ts;\n } // 4.4.2 WebVTT cue settings\n\n\n function consumeCueSettings(input, cue) {\n var settings = new Settings();\n parseOptions(input, function (k, v) {\n var vals;\n\n switch (k) {\n case 'region':\n // Find the last region we parsed with the same region id.\n for (var i = regionList.length - 1; i >= 0; i--) {\n if (regionList[i].id === v) {\n settings.set(k, regionList[i].region);\n break;\n }\n }\n\n break;\n\n case 'vertical':\n settings.alt(k, v, ['rl', 'lr']);\n break;\n\n case 'line':\n vals = v.split(',');\n settings.integer(k, vals[0]);\n\n if (settings.percent(k, vals[0])) {\n settings.set('snapToLines', false);\n }\n\n settings.alt(k, vals[0], ['auto']);\n\n if (vals.length === 2) {\n settings.alt('lineAlign', vals[1], ['start', center, 'end']);\n }\n\n break;\n\n case 'position':\n vals = v.split(',');\n settings.percent(k, vals[0]);\n\n if (vals.length === 2) {\n settings.alt('positionAlign', vals[1], ['start', center, 'end', 'line-left', 'line-right', 'auto']);\n }\n\n break;\n\n case 'size':\n settings.percent(k, v);\n break;\n\n case 'align':\n settings.alt(k, v, ['start', center, 'end', 'left', 'right']);\n break;\n }\n }, /:/, /\\s/); // Apply default values for any missing fields.\n\n cue.region = settings.get('region', null);\n cue.vertical = settings.get('vertical', '');\n var line = settings.get('line', 'auto');\n\n if (line === 'auto' && defaults.line === -1) {\n // set numeric line number for Safari\n line = -1;\n }\n\n cue.line = line;\n cue.lineAlign = settings.get('lineAlign', 'start');\n cue.snapToLines = settings.get('snapToLines', true);\n cue.size = settings.get('size', 100);\n cue.align = settings.get('align', center);\n var position = settings.get('position', 'auto');\n\n if (position === 'auto' && defaults.position === 50) {\n // set numeric position for Safari\n position = cue.align === 'start' || cue.align === 'left' ? 0 : cue.align === 'end' || cue.align === 'right' ? 100 : 50;\n }\n\n cue.position = position;\n }\n\n function skipWhitespace() {\n input = input.replace(/^\\s+/, '');\n } // 4.1 WebVTT cue timings.\n\n\n skipWhitespace();\n cue.startTime = consumeTimeStamp(); // (1) collect cue start time\n\n skipWhitespace();\n\n if (input.slice(0, 3) !== '-->') {\n // (3) next characters must match '-->'\n throw new Error(\"Malformed time stamp (time stamps must be separated by '-->'): \" + oInput);\n }\n\n input = input.slice(3);\n skipWhitespace();\n cue.endTime = consumeTimeStamp(); // (5) collect cue end time\n // 4.1 WebVTT cue settings list.\n\n skipWhitespace();\n consumeCueSettings(input, cue);\n}\n\nfunction fixLineBreaks(input) {\n return input.replace(/<br(?: \\/)?>/gi, '\\n');\n}\nvar VTTParser = /*#__PURE__*/function () {\n function VTTParser() {\n this.state = 'INITIAL';\n this.buffer = '';\n this.decoder = new StringDecoder();\n this.regionList = [];\n this.cue = null;\n this.oncue = void 0;\n this.onparsingerror = void 0;\n this.onflush = void 0;\n }\n\n var _proto3 = VTTParser.prototype;\n\n _proto3.parse = function parse(data) {\n var _this = this; // If there is no data then we won't decode it, but will just try to parse\n // whatever is in buffer already. This may occur in circumstances, for\n // example when flush() is called.\n\n\n if (data) {\n // Try to decode the data that we received.\n _this.buffer += _this.decoder.decode(data, {\n stream: true\n });\n }\n\n function collectNextLine() {\n var buffer = _this.buffer;\n var pos = 0;\n buffer = fixLineBreaks(buffer);\n\n while (pos < buffer.length && buffer[pos] !== '\\r' && buffer[pos] !== '\\n') {\n ++pos;\n }\n\n var line = buffer.slice(0, pos); // Advance the buffer early in case we fail below.\n\n if (buffer[pos] === '\\r') {\n ++pos;\n }\n\n if (buffer[pos] === '\\n') {\n ++pos;\n }\n\n _this.buffer = buffer.slice(pos);\n return line;\n } // 3.2 WebVTT metadata header syntax\n\n\n function parseHeader(input) {\n parseOptions(input, function (k, v) {// switch (k) {\n // case 'region':\n // 3.3 WebVTT region metadata header syntax\n // console.log('parse region', v);\n // parseRegion(v);\n // break;\n // }\n }, /:/);\n } // 5.1 WebVTT file parsing.\n\n\n try {\n var line = '';\n\n if (_this.state === 'INITIAL') {\n // We can't start parsing until we have the first line.\n if (!/\\r\\n|\\n/.test(_this.buffer)) {\n return this;\n }\n\n line = collectNextLine(); // strip of UTF-8 BOM if any\n // https://en.wikipedia.org/wiki/Byte_order_mark#UTF-8\n\n var m = line.match(/^()?WEBVTT([ \\t].*)?$/);\n\n if (!m || !m[0]) {\n throw new Error('Malformed WebVTT signature.');\n }\n\n _this.state = 'HEADER';\n }\n\n var alreadyCollectedLine = false;\n\n while (_this.buffer) {\n // We can't parse a line until we have the full line.\n if (!/\\r\\n|\\n/.test(_this.buffer)) {\n return this;\n }\n\n if (!alreadyCollectedLine) {\n line = collectNextLine();\n } else {\n alreadyCollectedLine = false;\n }\n\n switch (_this.state) {\n case 'HEADER':\n // 13-18 - Allow a header (metadata) under the WEBVTT line.\n if (/:/.test(line)) {\n parseHeader(line);\n } else if (!line) {\n // An empty line terminates the header and starts the body (cues).\n _this.state = 'ID';\n }\n\n continue;\n\n case 'NOTE':\n // Ignore NOTE blocks.\n if (!line) {\n _this.state = 'ID';\n }\n\n continue;\n\n case 'ID':\n // Check for the start of NOTE blocks.\n if (/^NOTE($|[ \\t])/.test(line)) {\n _this.state = 'NOTE';\n break;\n } // 19-29 - Allow any number of line terminators, then initialize new cue values.\n\n\n if (!line) {\n continue;\n }\n\n _this.cue = new _vttcue__WEBPACK_IMPORTED_MODULE_0__[\"default\"](0, 0, '');\n _this.state = 'CUE'; // 30-39 - Check if self line contains an optional identifier or timing data.\n\n if (line.indexOf('-->') === -1) {\n _this.cue.id = line;\n continue;\n }\n\n // Process line as start of a cue.\n\n /* falls through */\n\n case 'CUE':\n // 40 - Collect cue timings and settings.\n if (!_this.cue) {\n _this.state = 'BADCUE';\n continue;\n }\n\n try {\n parseCue(line, _this.cue, _this.regionList);\n } catch (e) {\n // In case of an error ignore rest of the cue.\n _this.cue = null;\n _this.state = 'BADCUE';\n continue;\n }\n\n _this.state = 'CUETEXT';\n continue;\n\n case 'CUETEXT':\n {\n var hasSubstring = line.indexOf('-->') !== -1; // 34 - If we have an empty line then report the cue.\n // 35 - If we have the special substring '-->' then report the cue,\n // but do not collect the line as we need to process the current\n // one as a new cue.\n\n if (!line || hasSubstring && (alreadyCollectedLine = true)) {\n // We are done parsing self cue.\n if (_this.oncue && _this.cue) {\n _this.oncue(_this.cue);\n }\n\n _this.cue = null;\n _this.state = 'ID';\n continue;\n }\n\n if (_this.cue === null) {\n continue;\n }\n\n if (_this.cue.text) {\n _this.cue.text += '\\n';\n }\n\n _this.cue.text += line;\n }\n continue;\n\n case 'BADCUE':\n // 54-62 - Collect and discard the remaining cue.\n if (!line) {\n _this.state = 'ID';\n }\n\n }\n }\n } catch (e) {\n // If we are currently parsing a cue, report what we have.\n if (_this.state === 'CUETEXT' && _this.cue && _this.oncue) {\n _this.oncue(_this.cue);\n }\n\n _this.cue = null; // Enter BADWEBVTT state if header was not parsed correctly otherwise\n // another exception occurred so enter BADCUE state.\n\n _this.state = _this.state === 'INITIAL' ? 'BADWEBVTT' : 'BADCUE';\n }\n\n return this;\n };\n\n _proto3.flush = function flush() {\n var _this = this;\n\n try {\n // Finish decoding the stream.\n // _this.buffer += _this.decoder.decode();\n // Synthesize the end of the current cue or region.\n if (_this.cue || _this.state === 'HEADER') {\n _this.buffer += '\\n\\n';\n\n _this.parse();\n } // If we've flushed, parsed, and we're still on the INITIAL state then\n // that means we don't have enough of the stream to parse the first\n // line.\n\n\n if (_this.state === 'INITIAL' || _this.state === 'BADWEBVTT') {\n throw new Error('Malformed WebVTT signature.');\n }\n } catch (e) {\n if (_this.onparsingerror) {\n _this.onparsingerror(e);\n }\n }\n\n if (_this.onflush) {\n _this.onflush();\n }\n\n return this;\n };\n\n return VTTParser;\n}();\n\n/***/ }),\n\n/***/ \"./src/utils/webvtt-parser.ts\":\n/*!************************************!*\\\n !*** ./src/utils/webvtt-parser.ts ***!\n \\************************************/\n/*! exports provided: generateCueId, parseWebVTT */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"generateCueId\", function() { return generateCueId; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"parseWebVTT\", function() { return parseWebVTT; });\n/* harmony import */ var _home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./src/polyfills/number */ \"./src/polyfills/number.ts\");\n/* harmony import */ var _vttparser__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./vttparser */ \"./src/utils/vttparser.ts\");\n/* harmony import */ var _demux_id3__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../demux/id3 */ \"./src/demux/id3.ts\");\n/* harmony import */ var _timescale_conversion__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./timescale-conversion */ \"./src/utils/timescale-conversion.ts\");\n/* harmony import */ var _remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../remux/mp4-remuxer */ \"./src/remux/mp4-remuxer.ts\");\n\n\n\n\n\n\n\n\nvar LINEBREAKS = /\\r\\n|\\n\\r|\\n|\\r/g; // String.prototype.startsWith is not supported in IE11\n\nvar startsWith = function startsWith(inputString, searchString, position) {\n if (position === void 0) {\n position = 0;\n }\n\n return inputString.slice(position, position + searchString.length) === searchString;\n};\n\nvar cueString2millis = function cueString2millis(timeString) {\n var ts = parseInt(timeString.slice(-3));\n var secs = parseInt(timeString.slice(-6, -4));\n var mins = parseInt(timeString.slice(-9, -7));\n var hours = timeString.length > 9 ? parseInt(timeString.substring(0, timeString.indexOf(':'))) : 0;\n\n if (!Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(ts) || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(secs) || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(mins) || !Object(_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__[\"isFiniteNumber\"])(hours)) {\n throw Error(\"Malformed X-TIMESTAMP-MAP: Local:\" + timeString);\n }\n\n ts += 1000 * secs;\n ts += 60 * 1000 * mins;\n ts += 60 * 60 * 1000 * hours;\n return ts;\n}; // From https://github.com/darkskyapp/string-hash\n\n\nvar hash = function hash(text) {\n var hash = 5381;\n var i = text.length;\n\n while (i) {\n hash = hash * 33 ^ text.charCodeAt(--i);\n }\n\n return (hash >>> 0).toString();\n}; // Create a unique hash id for a cue based on start/end times and text.\n// This helps timeline-controller to avoid showing repeated captions.\n\n\nfunction generateCueId(startTime, endTime, text) {\n return hash(startTime.toString()) + hash(endTime.toString()) + hash(text);\n}\n\nvar calculateOffset = function calculateOffset(vttCCs, cc, presentationTime) {\n var currCC = vttCCs[cc];\n var prevCC = vttCCs[currCC.prevCC]; // This is the first discontinuity or cues have been processed since the last discontinuity\n // Offset = current discontinuity time\n\n if (!prevCC || !prevCC.new && currCC.new) {\n vttCCs.ccOffset = vttCCs.presentationOffset = currCC.start;\n currCC.new = false;\n return;\n } // There have been discontinuities since cues were last parsed.\n // Offset = time elapsed\n\n\n while ((_prevCC = prevCC) !== null && _prevCC !== void 0 && _prevCC.new) {\n var _prevCC;\n\n vttCCs.ccOffset += currCC.start - prevCC.start;\n currCC.new = false;\n currCC = prevCC;\n prevCC = vttCCs[currCC.prevCC];\n }\n\n vttCCs.presentationOffset = presentationTime;\n};\n\nfunction parseWebVTT(vttByteArray, initPTS, timescale, vttCCs, cc, timeOffset, callBack, errorCallBack) {\n var parser = new _vttparser__WEBPACK_IMPORTED_MODULE_1__[\"VTTParser\"](); // Convert byteArray into string, replacing any somewhat exotic linefeeds with \"\\n\", then split on that character.\n // Uint8Array.prototype.reduce is not implemented in IE11\n\n var vttLines = Object(_demux_id3__WEBPACK_IMPORTED_MODULE_2__[\"utf8ArrayToStr\"])(new Uint8Array(vttByteArray)).trim().replace(LINEBREAKS, '\\n').split('\\n');\n var cues = [];\n var initPTS90Hz = Object(_timescale_conversion__WEBPACK_IMPORTED_MODULE_3__[\"toMpegTsClockFromTimescale\"])(initPTS, timescale);\n var cueTime = '00:00.000';\n var timestampMapMPEGTS = 0;\n var timestampMapLOCAL = 0;\n var parsingError;\n var inHeader = true;\n\n parser.oncue = function (cue) {\n // Adjust cue timing; clamp cues to start no earlier than - and drop cues that don't end after - 0 on timeline.\n var currCC = vttCCs[cc];\n var cueOffset = vttCCs.ccOffset; // Calculate subtitle PTS offset\n\n var webVttMpegTsMapOffset = (timestampMapMPEGTS - initPTS90Hz) / 90000; // Update offsets for new discontinuities\n\n if (currCC !== null && currCC !== void 0 && currCC.new) {\n if (timestampMapLOCAL !== undefined) {\n // When local time is provided, offset = discontinuity start time - local time\n cueOffset = vttCCs.ccOffset = currCC.start;\n } else {\n calculateOffset(vttCCs, cc, webVttMpegTsMapOffset);\n }\n }\n\n if (webVttMpegTsMapOffset) {\n // If we have MPEGTS, offset = presentation time + discontinuity offset\n cueOffset = webVttMpegTsMapOffset - vttCCs.presentationOffset;\n }\n\n var duration = cue.endTime - cue.startTime;\n var startTime = Object(_remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_4__[\"normalizePts\"])((cue.startTime + cueOffset - timestampMapLOCAL) * 90000, timeOffset * 90000) / 90000;\n cue.startTime = Math.max(startTime, 0);\n cue.endTime = Math.max(startTime + duration, 0); //trim trailing webvtt block whitespaces\n\n var text = cue.text.trim(); // Fix encoding of special characters\n\n cue.text = decodeURIComponent(encodeURIComponent(text)); // If the cue was not assigned an id from the VTT file (line above the content), create one.\n\n if (!cue.id) {\n cue.id = generateCueId(cue.startTime, cue.endTime, text);\n }\n\n if (cue.endTime > 0) {\n cues.push(cue);\n }\n };\n\n parser.onparsingerror = function (error) {\n parsingError = error;\n };\n\n parser.onflush = function () {\n if (parsingError) {\n errorCallBack(parsingError);\n return;\n }\n\n callBack(cues);\n }; // Go through contents line by line.\n\n\n vttLines.forEach(function (line) {\n if (inHeader) {\n // Look for X-TIMESTAMP-MAP in header.\n if (startsWith(line, 'X-TIMESTAMP-MAP=')) {\n // Once found, no more are allowed anyway, so stop searching.\n inHeader = false; // Extract LOCAL and MPEGTS.\n\n line.slice(16).split(',').forEach(function (timestamp) {\n if (startsWith(timestamp, 'LOCAL:')) {\n cueTime = timestamp.slice(6);\n } else if (startsWith(timestamp, 'MPEGTS:')) {\n timestampMapMPEGTS = parseInt(timestamp.slice(7));\n }\n });\n\n try {\n // Convert cue time to seconds\n timestampMapLOCAL = cueString2millis(cueTime) / 1000;\n } catch (error) {\n parsingError = error;\n } // Return without parsing X-TIMESTAMP-MAP line.\n\n\n return;\n } else if (line === '') {\n inHeader = false;\n }\n } // Parse line by default.\n\n\n parser.parse(line + '\\n');\n });\n parser.flush();\n}\n\n/***/ }),\n\n/***/ \"./src/utils/xhr-loader.ts\":\n/*!*********************************!*\\\n !*** ./src/utils/xhr-loader.ts ***!\n \\*********************************/\n/*! exports provided: default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _utils_logger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../utils/logger */ \"./src/utils/logger.ts\");\n/* harmony import */ var _loader_load_stats__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../loader/load-stats */ \"./src/loader/load-stats.ts\");\n\n\nvar AGE_HEADER_LINE_REGEX = /^age:\\s*[\\d.]+\\s*$/m;\n\nvar XhrLoader = /*#__PURE__*/function () {\n function XhrLoader(config\n /* HlsConfig */\n ) {\n this.xhrSetup = void 0;\n this.requestTimeout = void 0;\n this.retryTimeout = void 0;\n this.retryDelay = void 0;\n this.config = null;\n this.callbacks = null;\n this.context = void 0;\n this.loader = null;\n this.stats = void 0;\n this.xhrSetup = config ? config.xhrSetup : null;\n this.stats = new _loader_load_stats__WEBPACK_IMPORTED_MODULE_1__[\"LoadStats\"]();\n this.retryDelay = 0;\n }\n\n var _proto = XhrLoader.prototype;\n\n _proto.destroy = function destroy() {\n this.callbacks = null;\n this.abortInternal();\n this.loader = null;\n this.config = null;\n };\n\n _proto.abortInternal = function abortInternal() {\n var loader = this.loader;\n self.clearTimeout(this.requestTimeout);\n self.clearTimeout(this.retryTimeout);\n\n if (loader) {\n loader.onreadystatechange = null;\n loader.onprogress = null;\n\n if (loader.readyState !== 4) {\n this.stats.aborted = true;\n loader.abort();\n }\n }\n };\n\n _proto.abort = function abort() {\n var _this$callbacks;\n\n this.abortInternal();\n\n if ((_this$callbacks = this.callbacks) !== null && _this$callbacks !== void 0 && _this$callbacks.onAbort) {\n this.callbacks.onAbort(this.stats, this.context, this.loader);\n }\n };\n\n _proto.load = function load(context, config, callbacks) {\n if (this.stats.loading.start) {\n throw new Error('Loader can only be used once.');\n }\n\n this.stats.loading.start = self.performance.now();\n this.context = context;\n this.config = config;\n this.callbacks = callbacks;\n this.retryDelay = config.retryDelay;\n this.loadInternal();\n };\n\n _proto.loadInternal = function loadInternal() {\n var config = this.config,\n context = this.context;\n\n if (!config) {\n return;\n }\n\n var xhr = this.loader = new self.XMLHttpRequest();\n var stats = this.stats;\n stats.loading.first = 0;\n stats.loaded = 0;\n var xhrSetup = this.xhrSetup;\n\n try {\n if (xhrSetup) {\n try {\n xhrSetup(xhr, context.url);\n } catch (e) {\n // fix xhrSetup: (xhr, url) => {xhr.setRequestHeader(\"Content-Language\", \"test\");}\n // not working, as xhr.setRequestHeader expects xhr.readyState === OPEN\n xhr.open('GET', context.url, true);\n xhrSetup(xhr, context.url);\n }\n }\n\n if (!xhr.readyState) {\n xhr.open('GET', context.url, true);\n }\n\n var headers = this.context.headers;\n\n if (headers) {\n for (var header in headers) {\n xhr.setRequestHeader(header, headers[header]);\n }\n }\n } catch (e) {\n // IE11 throws an exception on xhr.open if attempting to access an HTTP resource over HTTPS\n this.callbacks.onError({\n code: xhr.status,\n text: e.message\n }, context, xhr);\n return;\n }\n\n if (context.rangeEnd) {\n xhr.setRequestHeader('Range', 'bytes=' + context.rangeStart + '-' + (context.rangeEnd - 1));\n }\n\n xhr.onreadystatechange = this.readystatechange.bind(this);\n xhr.onprogress = this.loadprogress.bind(this);\n xhr.responseType = context.responseType; // setup timeout before we perform request\n\n self.clearTimeout(this.requestTimeout);\n this.requestTimeout = self.setTimeout(this.loadtimeout.bind(this), config.timeout);\n xhr.send();\n };\n\n _proto.readystatechange = function readystatechange() {\n var context = this.context,\n xhr = this.loader,\n stats = this.stats;\n\n if (!context || !xhr) {\n return;\n }\n\n var readyState = xhr.readyState;\n var config = this.config; // don't proceed if xhr has been aborted\n\n if (stats.aborted) {\n return;\n } // >= HEADERS_RECEIVED\n\n\n if (readyState >= 2) {\n // clear xhr timeout and rearm it if readyState less than 4\n self.clearTimeout(this.requestTimeout);\n\n if (stats.loading.first === 0) {\n stats.loading.first = Math.max(self.performance.now(), stats.loading.start);\n }\n\n if (readyState === 4) {\n xhr.onreadystatechange = null;\n xhr.onprogress = null;\n var status = xhr.status; // http status between 200 to 299 are all successful\n\n if (status >= 200 && status < 300) {\n stats.loading.end = Math.max(self.performance.now(), stats.loading.first);\n var data;\n var len;\n\n if (context.responseType === 'arraybuffer') {\n data = xhr.response;\n len = data.byteLength;\n } else {\n data = xhr.responseText;\n len = data.length;\n }\n\n stats.loaded = stats.total = len;\n\n if (!this.callbacks) {\n return;\n }\n\n var onProgress = this.callbacks.onProgress;\n\n if (onProgress) {\n onProgress(stats, context, data, xhr);\n }\n\n if (!this.callbacks) {\n return;\n }\n\n var response = {\n url: xhr.responseURL,\n data: data\n };\n this.callbacks.onSuccess(response, stats, context, xhr);\n } else {\n // if max nb of retries reached or if http status between 400 and 499 (such error cannot be recovered, retrying is useless), return error\n if (stats.retry >= config.maxRetry || status >= 400 && status < 499) {\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].error(status + \" while loading \" + context.url);\n this.callbacks.onError({\n code: status,\n text: xhr.statusText\n }, context, xhr);\n } else {\n // retry\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].warn(status + \" while loading \" + context.url + \", retrying in \" + this.retryDelay + \"...\"); // abort and reset internal state\n\n this.abortInternal();\n this.loader = null; // schedule retry\n\n self.clearTimeout(this.retryTimeout);\n this.retryTimeout = self.setTimeout(this.loadInternal.bind(this), this.retryDelay); // set exponential backoff\n\n this.retryDelay = Math.min(2 * this.retryDelay, config.maxRetryDelay);\n stats.retry++;\n }\n }\n } else {\n // readyState >= 2 AND readyState !==4 (readyState = HEADERS_RECEIVED || LOADING) rearm timeout as xhr not finished yet\n self.clearTimeout(this.requestTimeout);\n this.requestTimeout = self.setTimeout(this.loadtimeout.bind(this), config.timeout);\n }\n }\n };\n\n _proto.loadtimeout = function loadtimeout() {\n _utils_logger__WEBPACK_IMPORTED_MODULE_0__[\"logger\"].warn(\"timeout while loading \" + this.context.url);\n var callbacks = this.callbacks;\n\n if (callbacks) {\n this.abortInternal();\n callbacks.onTimeout(this.stats, this.context, this.loader);\n }\n };\n\n _proto.loadprogress = function loadprogress(event) {\n var stats = this.stats;\n stats.loaded = event.loaded;\n\n if (event.lengthComputable) {\n stats.total = event.total;\n }\n };\n\n _proto.getCacheAge = function getCacheAge() {\n var result = null;\n\n if (this.loader && AGE_HEADER_LINE_REGEX.test(this.loader.getAllResponseHeaders())) {\n var ageHeader = this.loader.getResponseHeader('age');\n result = ageHeader ? parseFloat(ageHeader) : null;\n }\n\n return result;\n };\n\n return XhrLoader;\n}();\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (XhrLoader);\n\n/***/ })\n\n/******/ })[\"default\"];\n});\n//# sourceMappingURL=hls.js.map","/*!\n * html-attributes\n * https://github.com/alexmingoia/html-attributes\n */\n\n'use strict';\n\n/**\n * @module html-attributes\n */\n\nmodule.exports = {\n \"abbr\": \"abbr\",\n \"accept\": \"accept\",\n \"acceptCharset\": \"accept-charset\",\n \"accessKey\": \"accesskey\",\n \"action\": \"action\",\n \"allowFullScreen\": \"allowfullscreen\",\n \"allowTransparency\": \"allowtransparency\",\n \"alt\": \"alt\",\n \"async\": \"async\",\n \"autoComplete\": \"autocomplete\",\n \"autoFocus\": \"autofocus\",\n \"autoPlay\": \"autoplay\",\n \"cellPadding\": \"cellpadding\",\n \"cellSpacing\": \"cellspacing\",\n \"challenge\": \"challenge\",\n \"charset\": \"charset\",\n \"checked\": \"checked\",\n \"cite\": \"cite\",\n \"class\": \"class\",\n \"className\": \"class\",\n \"cols\": \"cols\",\n \"colSpan\": \"colspan\",\n \"command\": \"command\",\n \"content\": \"content\",\n \"contentEditable\": \"contenteditable\",\n \"contextMenu\": \"contextmenu\",\n \"controls\": \"controls\",\n \"coords\": \"coords\",\n \"crossOrigin\": \"crossorigin\",\n \"data\": \"data\",\n \"dateTime\": \"datetime\",\n \"default\": \"default\",\n \"defer\": \"defer\",\n \"dir\": \"dir\",\n \"disabled\": \"disabled\",\n \"download\": \"download\",\n \"draggable\": \"draggable\",\n \"dropzone\": \"dropzone\",\n \"encType\": \"enctype\",\n \"for\": \"for\",\n \"form\": \"form\",\n \"formAction\": \"formaction\",\n \"formEncType\": \"formenctype\",\n \"formMethod\": \"formmethod\",\n \"formNoValidate\": \"formnovalidate\",\n \"formTarget\": \"formtarget\",\n \"frameBorder\": \"frameBorder\",\n \"headers\": \"headers\",\n \"height\": \"height\",\n \"hidden\": \"hidden\",\n \"high\": \"high\",\n \"href\": \"href\",\n \"hrefLang\": \"hreflang\",\n \"htmlFor\": \"for\",\n \"httpEquiv\": \"http-equiv\",\n \"icon\": \"icon\",\n \"id\": \"id\",\n \"inputMode\": \"inputmode\",\n \"isMap\": \"ismap\",\n \"itemId\": \"itemid\",\n \"itemProp\": \"itemprop\",\n \"itemRef\": \"itemref\",\n \"itemScope\": \"itemscope\",\n \"itemType\": \"itemtype\",\n \"kind\": \"kind\",\n \"label\": \"label\",\n \"lang\": \"lang\",\n \"list\": \"list\",\n \"loop\": \"loop\",\n \"manifest\": \"manifest\",\n \"max\": \"max\",\n \"maxLength\": \"maxlength\",\n \"media\": \"media\",\n \"mediaGroup\": \"mediagroup\",\n \"method\": \"method\",\n \"min\": \"min\",\n \"minLength\": \"minlength\",\n \"multiple\": \"multiple\",\n \"muted\": \"muted\",\n \"name\": \"name\",\n \"noValidate\": \"novalidate\",\n \"open\": \"open\",\n \"optimum\": \"optimum\",\n \"pattern\": \"pattern\",\n \"ping\": \"ping\",\n \"placeholder\": \"placeholder\",\n \"poster\": \"poster\",\n \"preload\": \"preload\",\n \"radioGroup\": \"radiogroup\",\n \"readOnly\": \"readonly\",\n \"rel\": \"rel\",\n \"required\": \"required\",\n \"role\": \"role\",\n \"rows\": \"rows\",\n \"rowSpan\": \"rowspan\",\n \"sandbox\": \"sandbox\",\n \"scope\": \"scope\",\n \"scoped\": \"scoped\",\n \"scrolling\": \"scrolling\",\n \"seamless\": \"seamless\",\n \"selected\": \"selected\",\n \"shape\": \"shape\",\n \"size\": \"size\",\n \"sizes\": \"sizes\",\n \"sortable\": \"sortable\",\n \"span\": \"span\",\n \"spellCheck\": \"spellcheck\",\n \"src\": \"src\",\n \"srcDoc\": \"srcdoc\",\n \"srcSet\": \"srcset\",\n \"start\": \"start\",\n \"step\": \"step\",\n \"style\": \"style\",\n \"tabIndex\": \"tabindex\",\n \"target\": \"target\",\n \"title\": \"title\",\n \"translate\": \"translate\",\n \"type\": \"type\",\n \"typeMustMatch\": \"typemustmatch\",\n \"useMap\": \"usemap\",\n \"value\": \"value\",\n \"width\": \"width\",\n \"wmode\": \"wmode\",\n \"wrap\": \"wrap\"\n};\n","import e from\"void-elements\";var t=/\\s([^'\"/\\s><]+?)[\\s/>]|([^\\s=]+)=\\s?(\".*?\"|'.*?')/g;function n(n){var r={type:\"tag\",name:\"\",voidElement:!1,attrs:{},children:[]},i=n.match(/<\\/?([^\\s]+?)[/\\s>]/);if(i&&(r.name=i[1],(e[i[1]]||\"/\"===n.charAt(n.length-2))&&(r.voidElement=!0),r.name.startsWith(\"!--\"))){var s=n.indexOf(\"--\\x3e\");return{type:\"comment\",comment:-1!==s?n.slice(4,s):\"\"}}for(var a=new RegExp(t),c=null;null!==(c=a.exec(n));)if(c[0].trim())if(c[1]){var o=c[1].trim(),l=[o,\"\"];o.indexOf(\"=\")>-1&&(l=o.split(\"=\")),r.attrs[l[0]]=l[1],a.lastIndex--}else c[2]&&(r.attrs[c[2]]=c[3].trim().substring(1,c[3].length-1));return r}var r=/<[a-zA-Z0-9\\-\\!\\/](?:\"[^\"]*\"|'[^']*'|[^'\">])*>/g,i=/^\\s*$/,s=Object.create(null);function a(e,t){switch(t.type){case\"text\":return e+t.content;case\"tag\":return e+=\"<\"+t.name+(t.attrs?function(e){var t=[];for(var n in e)t.push(n+'=\"'+e[n]+'\"');return t.length?\" \"+t.join(\" \"):\"\"}(t.attrs):\"\")+(t.voidElement?\"/>\":\">\"),t.voidElement?e:e+t.children.reduce(a,\"\")+\"</\"+t.name+\">\";case\"comment\":return e+\"\\x3c!--\"+t.comment+\"--\\x3e\"}}var c={parse:function(e,t){t||(t={}),t.components||(t.components=s);var a,c=[],o=[],l=-1,m=!1;if(0!==e.indexOf(\"<\")){var u=e.indexOf(\"<\");c.push({type:\"text\",content:-1===u?e:e.substring(0,u)})}return e.replace(r,function(r,s){if(m){if(r!==\"</\"+a.name+\">\")return;m=!1}var u,f=\"/\"!==r.charAt(1),h=r.startsWith(\"\\x3c!--\"),p=s+r.length,d=e.charAt(p);if(h){var v=n(r);return l<0?(c.push(v),c):((u=o[l]).children.push(v),c)}if(f&&(l++,\"tag\"===(a=n(r)).type&&t.components[a.name]&&(a.type=\"component\",m=!0),a.voidElement||m||!d||\"<\"===d||a.children.push({type:\"text\",content:e.slice(p,e.indexOf(\"<\",p))}),0===l&&c.push(a),(u=o[l-1])&&u.children.push(a),o[l]=a),(!f||a.voidElement)&&(l>-1&&(a.voidElement||a.name===r.slice(2,-1))&&(l--,a=-1===l?c:o[l]),!m&&\"<\"!==d&&d)){u=-1===l?c:o[l].children;var x=e.indexOf(\"<\",p),g=e.slice(p,-1===x?void 0:x);i.test(g)&&(g=\" \"),(x>-1&&l+u.length>=0||\" \"!==g)&&u.push({type:\"text\",content:g})}}),c},stringify:function(e){return e.reduce(function(e,t){return e+a(\"\",t)},\"\")}};export default c;\n//# sourceMappingURL=html-parse-stringify.module.js.map\n","'use strict';\n\nvar _typeof = require('@babel/runtime/helpers/typeof');\nvar _classCallCheck = require('@babel/runtime/helpers/classCallCheck');\nvar _createClass = require('@babel/runtime/helpers/createClass');\nvar _assertThisInitialized = require('@babel/runtime/helpers/assertThisInitialized');\nvar _inherits = require('@babel/runtime/helpers/inherits');\nvar _possibleConstructorReturn = require('@babel/runtime/helpers/possibleConstructorReturn');\nvar _getPrototypeOf = require('@babel/runtime/helpers/getPrototypeOf');\nvar _defineProperty = require('@babel/runtime/helpers/defineProperty');\nvar _toArray = require('@babel/runtime/helpers/toArray');\n\nfunction _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }\n\nvar _typeof__default = /*#__PURE__*/_interopDefaultLegacy(_typeof);\nvar _classCallCheck__default = /*#__PURE__*/_interopDefaultLegacy(_classCallCheck);\nvar _createClass__default = /*#__PURE__*/_interopDefaultLegacy(_createClass);\nvar _assertThisInitialized__default = /*#__PURE__*/_interopDefaultLegacy(_assertThisInitialized);\nvar _inherits__default = /*#__PURE__*/_interopDefaultLegacy(_inherits);\nvar _possibleConstructorReturn__default = /*#__PURE__*/_interopDefaultLegacy(_possibleConstructorReturn);\nvar _getPrototypeOf__default = /*#__PURE__*/_interopDefaultLegacy(_getPrototypeOf);\nvar _defineProperty__default = /*#__PURE__*/_interopDefaultLegacy(_defineProperty);\nvar _toArray__default = /*#__PURE__*/_interopDefaultLegacy(_toArray);\n\nfunction ownKeys$6(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$6(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$6(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$6(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar consoleLogger = {\n type: 'logger',\n log: function log(args) {\n this.output('log', args);\n },\n warn: function warn(args) {\n this.output('warn', args);\n },\n error: function error(args) {\n this.output('error', args);\n },\n output: function output(type, args) {\n if (console && console[type]) console[type].apply(console, args);\n }\n};\nvar Logger = function () {\n function Logger(concreteLogger) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n _classCallCheck__default[\"default\"](this, Logger);\n this.init(concreteLogger, options);\n }\n _createClass__default[\"default\"](Logger, [{\n key: \"init\",\n value: function init(concreteLogger) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n this.prefix = options.prefix || 'i18next:';\n this.logger = concreteLogger || consoleLogger;\n this.options = options;\n this.debug = options.debug;\n }\n }, {\n key: \"setDebug\",\n value: function setDebug(bool) {\n this.debug = bool;\n }\n }, {\n key: \"log\",\n value: function log() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n return this.forward(args, 'log', '', true);\n }\n }, {\n key: \"warn\",\n value: function warn() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n return this.forward(args, 'warn', '', true);\n }\n }, {\n key: \"error\",\n value: function error() {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n return this.forward(args, 'error', '');\n }\n }, {\n key: \"deprecate\",\n value: function deprecate() {\n for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n args[_key4] = arguments[_key4];\n }\n return this.forward(args, 'warn', 'WARNING DEPRECATED: ', true);\n }\n }, {\n key: \"forward\",\n value: function forward(args, lvl, prefix, debugOnly) {\n if (debugOnly && !this.debug) return null;\n if (typeof args[0] === 'string') args[0] = \"\".concat(prefix).concat(this.prefix, \" \").concat(args[0]);\n return this.logger[lvl](args);\n }\n }, {\n key: \"create\",\n value: function create(moduleName) {\n return new Logger(this.logger, _objectSpread$6(_objectSpread$6({}, {\n prefix: \"\".concat(this.prefix, \":\").concat(moduleName, \":\")\n }), this.options));\n }\n }, {\n key: \"clone\",\n value: function clone(options) {\n options = options || this.options;\n options.prefix = options.prefix || this.prefix;\n return new Logger(this.logger, options);\n }\n }]);\n return Logger;\n}();\nvar baseLogger = new Logger();\n\nvar EventEmitter = function () {\n function EventEmitter() {\n _classCallCheck__default[\"default\"](this, EventEmitter);\n this.observers = {};\n }\n _createClass__default[\"default\"](EventEmitter, [{\n key: \"on\",\n value: function on(events, listener) {\n var _this = this;\n events.split(' ').forEach(function (event) {\n _this.observers[event] = _this.observers[event] || [];\n _this.observers[event].push(listener);\n });\n return this;\n }\n }, {\n key: \"off\",\n value: function off(event, listener) {\n if (!this.observers[event]) return;\n if (!listener) {\n delete this.observers[event];\n return;\n }\n this.observers[event] = this.observers[event].filter(function (l) {\n return l !== listener;\n });\n }\n }, {\n key: \"emit\",\n value: function emit(event) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n if (this.observers[event]) {\n var cloned = [].concat(this.observers[event]);\n cloned.forEach(function (observer) {\n observer.apply(void 0, args);\n });\n }\n if (this.observers['*']) {\n var _cloned = [].concat(this.observers['*']);\n _cloned.forEach(function (observer) {\n observer.apply(observer, [event].concat(args));\n });\n }\n }\n }]);\n return EventEmitter;\n}();\n\nfunction defer() {\n var res;\n var rej;\n var promise = new Promise(function (resolve, reject) {\n res = resolve;\n rej = reject;\n });\n promise.resolve = res;\n promise.reject = rej;\n return promise;\n}\nfunction makeString(object) {\n if (object == null) return '';\n return '' + object;\n}\nfunction copy(a, s, t) {\n a.forEach(function (m) {\n if (s[m]) t[m] = s[m];\n });\n}\nfunction getLastOfPath(object, path, Empty) {\n function cleanKey(key) {\n return key && key.indexOf('###') > -1 ? key.replace(/###/g, '.') : key;\n }\n function canNotTraverseDeeper() {\n return !object || typeof object === 'string';\n }\n var stack = typeof path !== 'string' ? [].concat(path) : path.split('.');\n while (stack.length > 1) {\n if (canNotTraverseDeeper()) return {};\n var key = cleanKey(stack.shift());\n if (!object[key] && Empty) object[key] = new Empty();\n if (Object.prototype.hasOwnProperty.call(object, key)) {\n object = object[key];\n } else {\n object = {};\n }\n }\n if (canNotTraverseDeeper()) return {};\n return {\n obj: object,\n k: cleanKey(stack.shift())\n };\n}\nfunction setPath(object, path, newValue) {\n var _getLastOfPath = getLastOfPath(object, path, Object),\n obj = _getLastOfPath.obj,\n k = _getLastOfPath.k;\n obj[k] = newValue;\n}\nfunction pushPath(object, path, newValue, concat) {\n var _getLastOfPath2 = getLastOfPath(object, path, Object),\n obj = _getLastOfPath2.obj,\n k = _getLastOfPath2.k;\n obj[k] = obj[k] || [];\n if (concat) obj[k] = obj[k].concat(newValue);\n if (!concat) obj[k].push(newValue);\n}\nfunction getPath(object, path) {\n var _getLastOfPath3 = getLastOfPath(object, path),\n obj = _getLastOfPath3.obj,\n k = _getLastOfPath3.k;\n if (!obj) return undefined;\n return obj[k];\n}\nfunction getPathWithDefaults(data, defaultData, key) {\n var value = getPath(data, key);\n if (value !== undefined) {\n return value;\n }\n return getPath(defaultData, key);\n}\nfunction deepExtend(target, source, overwrite) {\n for (var prop in source) {\n if (prop !== '__proto__' && prop !== 'constructor') {\n if (prop in target) {\n if (typeof target[prop] === 'string' || target[prop] instanceof String || typeof source[prop] === 'string' || source[prop] instanceof String) {\n if (overwrite) target[prop] = source[prop];\n } else {\n deepExtend(target[prop], source[prop], overwrite);\n }\n } else {\n target[prop] = source[prop];\n }\n }\n }\n return target;\n}\nfunction regexEscape(str) {\n return str.replace(/[\\-\\[\\]\\/\\{\\}\\(\\)\\*\\+\\?\\.\\\\\\^\\$\\|]/g, '\\\\$&');\n}\nvar _entityMap = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": ''',\n '/': '/'\n};\nfunction escape(data) {\n if (typeof data === 'string') {\n return data.replace(/[&<>\"'\\/]/g, function (s) {\n return _entityMap[s];\n });\n }\n return data;\n}\nvar isIE10 = typeof window !== 'undefined' && window.navigator && typeof window.navigator.userAgentData === 'undefined' && window.navigator.userAgent && window.navigator.userAgent.indexOf('MSIE') > -1;\nvar chars = [' ', ',', '?', '!', ';'];\nfunction looksLikeObjectPath(key, nsSeparator, keySeparator) {\n nsSeparator = nsSeparator || '';\n keySeparator = keySeparator || '';\n var possibleChars = chars.filter(function (c) {\n return nsSeparator.indexOf(c) < 0 && keySeparator.indexOf(c) < 0;\n });\n if (possibleChars.length === 0) return true;\n var r = new RegExp(\"(\".concat(possibleChars.map(function (c) {\n return c === '?' ? '\\\\?' : c;\n }).join('|'), \")\"));\n var matched = !r.test(key);\n if (!matched) {\n var ki = key.indexOf(keySeparator);\n if (ki > 0 && !r.test(key.substring(0, ki))) {\n matched = true;\n }\n }\n return matched;\n}\n\nfunction ownKeys$5(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$5(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$5(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$5(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _createSuper$3(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$3(); return function _createSuperInternal() { var Super = _getPrototypeOf__default[\"default\"](Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf__default[\"default\"](this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn__default[\"default\"](this, result); }; }\nfunction _isNativeReflectConstruct$3() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction deepFind(obj, path) {\n var keySeparator = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : '.';\n if (!obj) return undefined;\n if (obj[path]) return obj[path];\n var paths = path.split(keySeparator);\n var current = obj;\n for (var i = 0; i < paths.length; ++i) {\n if (!current) return undefined;\n if (typeof current[paths[i]] === 'string' && i + 1 < paths.length) {\n return undefined;\n }\n if (current[paths[i]] === undefined) {\n var j = 2;\n var p = paths.slice(i, i + j).join(keySeparator);\n var mix = current[p];\n while (mix === undefined && paths.length > i + j) {\n j++;\n p = paths.slice(i, i + j).join(keySeparator);\n mix = current[p];\n }\n if (mix === undefined) return undefined;\n if (mix === null) return null;\n if (path.endsWith(p)) {\n if (typeof mix === 'string') return mix;\n if (p && typeof mix[p] === 'string') return mix[p];\n }\n var joinedPath = paths.slice(i + j).join(keySeparator);\n if (joinedPath) return deepFind(mix, joinedPath, keySeparator);\n return undefined;\n }\n current = current[paths[i]];\n }\n return current;\n}\nvar ResourceStore = function (_EventEmitter) {\n _inherits__default[\"default\"](ResourceStore, _EventEmitter);\n var _super = _createSuper$3(ResourceStore);\n function ResourceStore(data) {\n var _this;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n ns: ['translation'],\n defaultNS: 'translation'\n };\n _classCallCheck__default[\"default\"](this, ResourceStore);\n _this = _super.call(this);\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized__default[\"default\"](_this));\n }\n _this.data = data || {};\n _this.options = options;\n if (_this.options.keySeparator === undefined) {\n _this.options.keySeparator = '.';\n }\n if (_this.options.ignoreJSONStructure === undefined) {\n _this.options.ignoreJSONStructure = true;\n }\n return _this;\n }\n _createClass__default[\"default\"](ResourceStore, [{\n key: \"addNamespaces\",\n value: function addNamespaces(ns) {\n if (this.options.ns.indexOf(ns) < 0) {\n this.options.ns.push(ns);\n }\n }\n }, {\n key: \"removeNamespaces\",\n value: function removeNamespaces(ns) {\n var index = this.options.ns.indexOf(ns);\n if (index > -1) {\n this.options.ns.splice(index, 1);\n }\n }\n }, {\n key: \"getResource\",\n value: function getResource(lng, ns, key) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n var ignoreJSONStructure = options.ignoreJSONStructure !== undefined ? options.ignoreJSONStructure : this.options.ignoreJSONStructure;\n var path = [lng, ns];\n if (key && typeof key !== 'string') path = path.concat(key);\n if (key && typeof key === 'string') path = path.concat(keySeparator ? key.split(keySeparator) : key);\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n }\n var result = getPath(this.data, path);\n if (result || !ignoreJSONStructure || typeof key !== 'string') return result;\n return deepFind(this.data && this.data[lng] && this.data[lng][ns], key, keySeparator);\n }\n }, {\n key: \"addResource\",\n value: function addResource(lng, ns, key, value) {\n var options = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {\n silent: false\n };\n var keySeparator = this.options.keySeparator;\n if (keySeparator === undefined) keySeparator = '.';\n var path = [lng, ns];\n if (key) path = path.concat(keySeparator ? key.split(keySeparator) : key);\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n value = ns;\n ns = path[1];\n }\n this.addNamespaces(ns);\n setPath(this.data, path, value);\n if (!options.silent) this.emit('added', lng, ns, key, value);\n }\n }, {\n key: \"addResources\",\n value: function addResources(lng, ns, resources) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {\n silent: false\n };\n for (var m in resources) {\n if (typeof resources[m] === 'string' || Object.prototype.toString.apply(resources[m]) === '[object Array]') this.addResource(lng, ns, m, resources[m], {\n silent: true\n });\n }\n if (!options.silent) this.emit('added', lng, ns, resources);\n }\n }, {\n key: \"addResourceBundle\",\n value: function addResourceBundle(lng, ns, resources, deep, overwrite) {\n var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {\n silent: false\n };\n var path = [lng, ns];\n if (lng.indexOf('.') > -1) {\n path = lng.split('.');\n deep = resources;\n resources = ns;\n ns = path[1];\n }\n this.addNamespaces(ns);\n var pack = getPath(this.data, path) || {};\n if (deep) {\n deepExtend(pack, resources, overwrite);\n } else {\n pack = _objectSpread$5(_objectSpread$5({}, pack), resources);\n }\n setPath(this.data, path, pack);\n if (!options.silent) this.emit('added', lng, ns, resources);\n }\n }, {\n key: \"removeResourceBundle\",\n value: function removeResourceBundle(lng, ns) {\n if (this.hasResourceBundle(lng, ns)) {\n delete this.data[lng][ns];\n }\n this.removeNamespaces(ns);\n this.emit('removed', lng, ns);\n }\n }, {\n key: \"hasResourceBundle\",\n value: function hasResourceBundle(lng, ns) {\n return this.getResource(lng, ns) !== undefined;\n }\n }, {\n key: \"getResourceBundle\",\n value: function getResourceBundle(lng, ns) {\n if (!ns) ns = this.options.defaultNS;\n if (this.options.compatibilityAPI === 'v1') return _objectSpread$5(_objectSpread$5({}, {}), this.getResource(lng, ns));\n return this.getResource(lng, ns);\n }\n }, {\n key: \"getDataByLanguage\",\n value: function getDataByLanguage(lng) {\n return this.data[lng];\n }\n }, {\n key: \"hasLanguageSomeTranslations\",\n value: function hasLanguageSomeTranslations(lng) {\n var data = this.getDataByLanguage(lng);\n var n = data && Object.keys(data) || [];\n return !!n.find(function (v) {\n return data[v] && Object.keys(data[v]).length > 0;\n });\n }\n }, {\n key: \"toJSON\",\n value: function toJSON() {\n return this.data;\n }\n }]);\n return ResourceStore;\n}(EventEmitter);\n\nvar postProcessor = {\n processors: {},\n addPostProcessor: function addPostProcessor(module) {\n this.processors[module.name] = module;\n },\n handle: function handle(processors, value, key, options, translator) {\n var _this = this;\n processors.forEach(function (processor) {\n if (_this.processors[processor]) value = _this.processors[processor].process(value, key, options, translator);\n });\n return value;\n }\n};\n\nfunction ownKeys$4(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$4(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$4(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$4(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _createSuper$2(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$2(); return function _createSuperInternal() { var Super = _getPrototypeOf__default[\"default\"](Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf__default[\"default\"](this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn__default[\"default\"](this, result); }; }\nfunction _isNativeReflectConstruct$2() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nvar checkedLoadedFor = {};\nvar Translator = function (_EventEmitter) {\n _inherits__default[\"default\"](Translator, _EventEmitter);\n var _super = _createSuper$2(Translator);\n function Translator(services) {\n var _this;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n _classCallCheck__default[\"default\"](this, Translator);\n _this = _super.call(this);\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized__default[\"default\"](_this));\n }\n copy(['resourceStore', 'languageUtils', 'pluralResolver', 'interpolator', 'backendConnector', 'i18nFormat', 'utils'], services, _assertThisInitialized__default[\"default\"](_this));\n _this.options = options;\n if (_this.options.keySeparator === undefined) {\n _this.options.keySeparator = '.';\n }\n _this.logger = baseLogger.create('translator');\n return _this;\n }\n _createClass__default[\"default\"](Translator, [{\n key: \"changeLanguage\",\n value: function changeLanguage(lng) {\n if (lng) this.language = lng;\n }\n }, {\n key: \"exists\",\n value: function exists(key) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n interpolation: {}\n };\n if (key === undefined || key === null) {\n return false;\n }\n var resolved = this.resolve(key, options);\n return resolved && resolved.res !== undefined;\n }\n }, {\n key: \"extractFromKey\",\n value: function extractFromKey(key, options) {\n var nsSeparator = options.nsSeparator !== undefined ? options.nsSeparator : this.options.nsSeparator;\n if (nsSeparator === undefined) nsSeparator = ':';\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n var namespaces = options.ns || this.options.defaultNS || [];\n var wouldCheckForNsInKey = nsSeparator && key.indexOf(nsSeparator) > -1;\n var seemsNaturalLanguage = !this.options.userDefinedKeySeparator && !options.keySeparator && !this.options.userDefinedNsSeparator && !options.nsSeparator && !looksLikeObjectPath(key, nsSeparator, keySeparator);\n if (wouldCheckForNsInKey && !seemsNaturalLanguage) {\n var m = key.match(this.interpolator.nestingRegexp);\n if (m && m.length > 0) {\n return {\n key: key,\n namespaces: namespaces\n };\n }\n var parts = key.split(nsSeparator);\n if (nsSeparator !== keySeparator || nsSeparator === keySeparator && this.options.ns.indexOf(parts[0]) > -1) namespaces = parts.shift();\n key = parts.join(keySeparator);\n }\n if (typeof namespaces === 'string') namespaces = [namespaces];\n return {\n key: key,\n namespaces: namespaces\n };\n }\n }, {\n key: \"translate\",\n value: function translate(keys, options, lastKey) {\n var _this2 = this;\n if (_typeof__default[\"default\"](options) !== 'object' && this.options.overloadTranslationOptionHandler) {\n options = this.options.overloadTranslationOptionHandler(arguments);\n }\n if (!options) options = {};\n if (keys === undefined || keys === null) return '';\n if (!Array.isArray(keys)) keys = [String(keys)];\n var returnDetails = options.returnDetails !== undefined ? options.returnDetails : this.options.returnDetails;\n var keySeparator = options.keySeparator !== undefined ? options.keySeparator : this.options.keySeparator;\n var _this$extractFromKey = this.extractFromKey(keys[keys.length - 1], options),\n key = _this$extractFromKey.key,\n namespaces = _this$extractFromKey.namespaces;\n var namespace = namespaces[namespaces.length - 1];\n var lng = options.lng || this.language;\n var appendNamespaceToCIMode = options.appendNamespaceToCIMode || this.options.appendNamespaceToCIMode;\n if (lng && lng.toLowerCase() === 'cimode') {\n if (appendNamespaceToCIMode) {\n var nsSeparator = options.nsSeparator || this.options.nsSeparator;\n if (returnDetails) {\n resolved.res = \"\".concat(namespace).concat(nsSeparator).concat(key);\n return resolved;\n }\n return \"\".concat(namespace).concat(nsSeparator).concat(key);\n }\n if (returnDetails) {\n resolved.res = key;\n return resolved;\n }\n return key;\n }\n var resolved = this.resolve(keys, options);\n var res = resolved && resolved.res;\n var resUsedKey = resolved && resolved.usedKey || key;\n var resExactUsedKey = resolved && resolved.exactUsedKey || key;\n var resType = Object.prototype.toString.apply(res);\n var noObject = ['[object Number]', '[object Function]', '[object RegExp]'];\n var joinArrays = options.joinArrays !== undefined ? options.joinArrays : this.options.joinArrays;\n var handleAsObjectInI18nFormat = !this.i18nFormat || this.i18nFormat.handleAsObject;\n var handleAsObject = typeof res !== 'string' && typeof res !== 'boolean' && typeof res !== 'number';\n if (handleAsObjectInI18nFormat && res && handleAsObject && noObject.indexOf(resType) < 0 && !(typeof joinArrays === 'string' && resType === '[object Array]')) {\n if (!options.returnObjects && !this.options.returnObjects) {\n if (!this.options.returnedObjectHandler) {\n this.logger.warn('accessing an object - but returnObjects options is not enabled!');\n }\n var r = this.options.returnedObjectHandler ? this.options.returnedObjectHandler(resUsedKey, res, _objectSpread$4(_objectSpread$4({}, options), {}, {\n ns: namespaces\n })) : \"key '\".concat(key, \" (\").concat(this.language, \")' returned an object instead of string.\");\n if (returnDetails) {\n resolved.res = r;\n return resolved;\n }\n return r;\n }\n if (keySeparator) {\n var resTypeIsArray = resType === '[object Array]';\n var copy = resTypeIsArray ? [] : {};\n var newKeyToUse = resTypeIsArray ? resExactUsedKey : resUsedKey;\n for (var m in res) {\n if (Object.prototype.hasOwnProperty.call(res, m)) {\n var deepKey = \"\".concat(newKeyToUse).concat(keySeparator).concat(m);\n copy[m] = this.translate(deepKey, _objectSpread$4(_objectSpread$4({}, options), {\n joinArrays: false,\n ns: namespaces\n }));\n if (copy[m] === deepKey) copy[m] = res[m];\n }\n }\n res = copy;\n }\n } else if (handleAsObjectInI18nFormat && typeof joinArrays === 'string' && resType === '[object Array]') {\n res = res.join(joinArrays);\n if (res) res = this.extendTranslation(res, keys, options, lastKey);\n } else {\n var usedDefault = false;\n var usedKey = false;\n var needsPluralHandling = options.count !== undefined && typeof options.count !== 'string';\n var hasDefaultValue = Translator.hasDefaultValue(options);\n var defaultValueSuffix = needsPluralHandling ? this.pluralResolver.getSuffix(lng, options.count, options) : '';\n var defaultValue = options[\"defaultValue\".concat(defaultValueSuffix)] || options.defaultValue;\n if (!this.isValidLookup(res) && hasDefaultValue) {\n usedDefault = true;\n res = defaultValue;\n }\n if (!this.isValidLookup(res)) {\n usedKey = true;\n res = key;\n }\n var missingKeyNoValueFallbackToKey = options.missingKeyNoValueFallbackToKey || this.options.missingKeyNoValueFallbackToKey;\n var resForMissing = missingKeyNoValueFallbackToKey && usedKey ? undefined : res;\n var updateMissing = hasDefaultValue && defaultValue !== res && this.options.updateMissing;\n if (usedKey || usedDefault || updateMissing) {\n this.logger.log(updateMissing ? 'updateKey' : 'missingKey', lng, namespace, key, updateMissing ? defaultValue : res);\n if (keySeparator) {\n var fk = this.resolve(key, _objectSpread$4(_objectSpread$4({}, options), {}, {\n keySeparator: false\n }));\n if (fk && fk.res) this.logger.warn('Seems the loaded translations were in flat JSON format instead of nested. Either set keySeparator: false on init or make sure your translations are published in nested format.');\n }\n var lngs = [];\n var fallbackLngs = this.languageUtils.getFallbackCodes(this.options.fallbackLng, options.lng || this.language);\n if (this.options.saveMissingTo === 'fallback' && fallbackLngs && fallbackLngs[0]) {\n for (var i = 0; i < fallbackLngs.length; i++) {\n lngs.push(fallbackLngs[i]);\n }\n } else if (this.options.saveMissingTo === 'all') {\n lngs = this.languageUtils.toResolveHierarchy(options.lng || this.language);\n } else {\n lngs.push(options.lng || this.language);\n }\n var send = function send(l, k, specificDefaultValue) {\n var defaultForMissing = hasDefaultValue && specificDefaultValue !== res ? specificDefaultValue : resForMissing;\n if (_this2.options.missingKeyHandler) {\n _this2.options.missingKeyHandler(l, namespace, k, defaultForMissing, updateMissing, options);\n } else if (_this2.backendConnector && _this2.backendConnector.saveMissing) {\n _this2.backendConnector.saveMissing(l, namespace, k, defaultForMissing, updateMissing, options);\n }\n _this2.emit('missingKey', l, namespace, k, res);\n };\n if (this.options.saveMissing) {\n if (this.options.saveMissingPlurals && needsPluralHandling) {\n lngs.forEach(function (language) {\n _this2.pluralResolver.getSuffixes(language, options).forEach(function (suffix) {\n send([language], key + suffix, options[\"defaultValue\".concat(suffix)] || defaultValue);\n });\n });\n } else {\n send(lngs, key, defaultValue);\n }\n }\n }\n res = this.extendTranslation(res, keys, options, resolved, lastKey);\n if (usedKey && res === key && this.options.appendNamespaceToMissingKey) res = \"\".concat(namespace, \":\").concat(key);\n if ((usedKey || usedDefault) && this.options.parseMissingKeyHandler) {\n if (this.options.compatibilityAPI !== 'v1') {\n res = this.options.parseMissingKeyHandler(this.options.appendNamespaceToMissingKey ? \"\".concat(namespace, \":\").concat(key) : key, usedDefault ? res : undefined);\n } else {\n res = this.options.parseMissingKeyHandler(res);\n }\n }\n }\n if (returnDetails) {\n resolved.res = res;\n return resolved;\n }\n return res;\n }\n }, {\n key: \"extendTranslation\",\n value: function extendTranslation(res, key, options, resolved, lastKey) {\n var _this3 = this;\n if (this.i18nFormat && this.i18nFormat.parse) {\n res = this.i18nFormat.parse(res, _objectSpread$4(_objectSpread$4({}, this.options.interpolation.defaultVariables), options), resolved.usedLng, resolved.usedNS, resolved.usedKey, {\n resolved: resolved\n });\n } else if (!options.skipInterpolation) {\n if (options.interpolation) this.interpolator.init(_objectSpread$4(_objectSpread$4({}, options), {\n interpolation: _objectSpread$4(_objectSpread$4({}, this.options.interpolation), options.interpolation)\n }));\n var skipOnVariables = typeof res === 'string' && (options && options.interpolation && options.interpolation.skipOnVariables !== undefined ? options.interpolation.skipOnVariables : this.options.interpolation.skipOnVariables);\n var nestBef;\n if (skipOnVariables) {\n var nb = res.match(this.interpolator.nestingRegexp);\n nestBef = nb && nb.length;\n }\n var data = options.replace && typeof options.replace !== 'string' ? options.replace : options;\n if (this.options.interpolation.defaultVariables) data = _objectSpread$4(_objectSpread$4({}, this.options.interpolation.defaultVariables), data);\n res = this.interpolator.interpolate(res, data, options.lng || this.language, options);\n if (skipOnVariables) {\n var na = res.match(this.interpolator.nestingRegexp);\n var nestAft = na && na.length;\n if (nestBef < nestAft) options.nest = false;\n }\n if (options.nest !== false) res = this.interpolator.nest(res, function () {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n if (lastKey && lastKey[0] === args[0] && !options.context) {\n _this3.logger.warn(\"It seems you are nesting recursively key: \".concat(args[0], \" in key: \").concat(key[0]));\n return null;\n }\n return _this3.translate.apply(_this3, args.concat([key]));\n }, options);\n if (options.interpolation) this.interpolator.reset();\n }\n var postProcess = options.postProcess || this.options.postProcess;\n var postProcessorNames = typeof postProcess === 'string' ? [postProcess] : postProcess;\n if (res !== undefined && res !== null && postProcessorNames && postProcessorNames.length && options.applyPostProcessor !== false) {\n res = postProcessor.handle(postProcessorNames, res, key, this.options && this.options.postProcessPassResolved ? _objectSpread$4({\n i18nResolved: resolved\n }, options) : options, this);\n }\n return res;\n }\n }, {\n key: \"resolve\",\n value: function resolve(keys) {\n var _this4 = this;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var found;\n var usedKey;\n var exactUsedKey;\n var usedLng;\n var usedNS;\n if (typeof keys === 'string') keys = [keys];\n keys.forEach(function (k) {\n if (_this4.isValidLookup(found)) return;\n var extracted = _this4.extractFromKey(k, options);\n var key = extracted.key;\n usedKey = key;\n var namespaces = extracted.namespaces;\n if (_this4.options.fallbackNS) namespaces = namespaces.concat(_this4.options.fallbackNS);\n var needsPluralHandling = options.count !== undefined && typeof options.count !== 'string';\n var needsZeroSuffixLookup = needsPluralHandling && !options.ordinal && options.count === 0 && _this4.pluralResolver.shouldUseIntlApi();\n var needsContextHandling = options.context !== undefined && (typeof options.context === 'string' || typeof options.context === 'number') && options.context !== '';\n var codes = options.lngs ? options.lngs : _this4.languageUtils.toResolveHierarchy(options.lng || _this4.language, options.fallbackLng);\n namespaces.forEach(function (ns) {\n if (_this4.isValidLookup(found)) return;\n usedNS = ns;\n if (!checkedLoadedFor[\"\".concat(codes[0], \"-\").concat(ns)] && _this4.utils && _this4.utils.hasLoadedNamespace && !_this4.utils.hasLoadedNamespace(usedNS)) {\n checkedLoadedFor[\"\".concat(codes[0], \"-\").concat(ns)] = true;\n _this4.logger.warn(\"key \\\"\".concat(usedKey, \"\\\" for languages \\\"\").concat(codes.join(', '), \"\\\" won't get resolved as namespace \\\"\").concat(usedNS, \"\\\" was not yet loaded\"), 'This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!');\n }\n codes.forEach(function (code) {\n if (_this4.isValidLookup(found)) return;\n usedLng = code;\n var finalKeys = [key];\n if (_this4.i18nFormat && _this4.i18nFormat.addLookupKeys) {\n _this4.i18nFormat.addLookupKeys(finalKeys, key, code, ns, options);\n } else {\n var pluralSuffix;\n if (needsPluralHandling) pluralSuffix = _this4.pluralResolver.getSuffix(code, options.count, options);\n var zeroSuffix = \"\".concat(_this4.options.pluralSeparator, \"zero\");\n if (needsPluralHandling) {\n finalKeys.push(key + pluralSuffix);\n if (needsZeroSuffixLookup) {\n finalKeys.push(key + zeroSuffix);\n }\n }\n if (needsContextHandling) {\n var contextKey = \"\".concat(key).concat(_this4.options.contextSeparator).concat(options.context);\n finalKeys.push(contextKey);\n if (needsPluralHandling) {\n finalKeys.push(contextKey + pluralSuffix);\n if (needsZeroSuffixLookup) {\n finalKeys.push(contextKey + zeroSuffix);\n }\n }\n }\n }\n var possibleKey;\n while (possibleKey = finalKeys.pop()) {\n if (!_this4.isValidLookup(found)) {\n exactUsedKey = possibleKey;\n found = _this4.getResource(code, ns, possibleKey, options);\n }\n }\n });\n });\n });\n return {\n res: found,\n usedKey: usedKey,\n exactUsedKey: exactUsedKey,\n usedLng: usedLng,\n usedNS: usedNS\n };\n }\n }, {\n key: \"isValidLookup\",\n value: function isValidLookup(res) {\n return res !== undefined && !(!this.options.returnNull && res === null) && !(!this.options.returnEmptyString && res === '');\n }\n }, {\n key: \"getResource\",\n value: function getResource(code, ns, key) {\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n if (this.i18nFormat && this.i18nFormat.getResource) return this.i18nFormat.getResource(code, ns, key, options);\n return this.resourceStore.getResource(code, ns, key, options);\n }\n }], [{\n key: \"hasDefaultValue\",\n value: function hasDefaultValue(options) {\n var prefix = 'defaultValue';\n for (var option in options) {\n if (Object.prototype.hasOwnProperty.call(options, option) && prefix === option.substring(0, prefix.length) && undefined !== options[option]) {\n return true;\n }\n }\n return false;\n }\n }]);\n return Translator;\n}(EventEmitter);\n\nfunction capitalize(string) {\n return string.charAt(0).toUpperCase() + string.slice(1);\n}\nvar LanguageUtil = function () {\n function LanguageUtil(options) {\n _classCallCheck__default[\"default\"](this, LanguageUtil);\n this.options = options;\n this.supportedLngs = this.options.supportedLngs || false;\n this.logger = baseLogger.create('languageUtils');\n }\n _createClass__default[\"default\"](LanguageUtil, [{\n key: \"getScriptPartFromCode\",\n value: function getScriptPartFromCode(code) {\n if (!code || code.indexOf('-') < 0) return null;\n var p = code.split('-');\n if (p.length === 2) return null;\n p.pop();\n if (p[p.length - 1].toLowerCase() === 'x') return null;\n return this.formatLanguageCode(p.join('-'));\n }\n }, {\n key: \"getLanguagePartFromCode\",\n value: function getLanguagePartFromCode(code) {\n if (!code || code.indexOf('-') < 0) return code;\n var p = code.split('-');\n return this.formatLanguageCode(p[0]);\n }\n }, {\n key: \"formatLanguageCode\",\n value: function formatLanguageCode(code) {\n if (typeof code === 'string' && code.indexOf('-') > -1) {\n var specialCases = ['hans', 'hant', 'latn', 'cyrl', 'cans', 'mong', 'arab'];\n var p = code.split('-');\n if (this.options.lowerCaseLng) {\n p = p.map(function (part) {\n return part.toLowerCase();\n });\n } else if (p.length === 2) {\n p[0] = p[0].toLowerCase();\n p[1] = p[1].toUpperCase();\n if (specialCases.indexOf(p[1].toLowerCase()) > -1) p[1] = capitalize(p[1].toLowerCase());\n } else if (p.length === 3) {\n p[0] = p[0].toLowerCase();\n if (p[1].length === 2) p[1] = p[1].toUpperCase();\n if (p[0] !== 'sgn' && p[2].length === 2) p[2] = p[2].toUpperCase();\n if (specialCases.indexOf(p[1].toLowerCase()) > -1) p[1] = capitalize(p[1].toLowerCase());\n if (specialCases.indexOf(p[2].toLowerCase()) > -1) p[2] = capitalize(p[2].toLowerCase());\n }\n return p.join('-');\n }\n return this.options.cleanCode || this.options.lowerCaseLng ? code.toLowerCase() : code;\n }\n }, {\n key: \"isSupportedCode\",\n value: function isSupportedCode(code) {\n if (this.options.load === 'languageOnly' || this.options.nonExplicitSupportedLngs) {\n code = this.getLanguagePartFromCode(code);\n }\n return !this.supportedLngs || !this.supportedLngs.length || this.supportedLngs.indexOf(code) > -1;\n }\n }, {\n key: \"getBestMatchFromCodes\",\n value: function getBestMatchFromCodes(codes) {\n var _this = this;\n if (!codes) return null;\n var found;\n codes.forEach(function (code) {\n if (found) return;\n var cleanedLng = _this.formatLanguageCode(code);\n if (!_this.options.supportedLngs || _this.isSupportedCode(cleanedLng)) found = cleanedLng;\n });\n if (!found && this.options.supportedLngs) {\n codes.forEach(function (code) {\n if (found) return;\n var lngOnly = _this.getLanguagePartFromCode(code);\n if (_this.isSupportedCode(lngOnly)) return found = lngOnly;\n found = _this.options.supportedLngs.find(function (supportedLng) {\n if (supportedLng.indexOf(lngOnly) === 0) return supportedLng;\n });\n });\n }\n if (!found) found = this.getFallbackCodes(this.options.fallbackLng)[0];\n return found;\n }\n }, {\n key: \"getFallbackCodes\",\n value: function getFallbackCodes(fallbacks, code) {\n if (!fallbacks) return [];\n if (typeof fallbacks === 'function') fallbacks = fallbacks(code);\n if (typeof fallbacks === 'string') fallbacks = [fallbacks];\n if (Object.prototype.toString.apply(fallbacks) === '[object Array]') return fallbacks;\n if (!code) return fallbacks[\"default\"] || [];\n var found = fallbacks[code];\n if (!found) found = fallbacks[this.getScriptPartFromCode(code)];\n if (!found) found = fallbacks[this.formatLanguageCode(code)];\n if (!found) found = fallbacks[this.getLanguagePartFromCode(code)];\n if (!found) found = fallbacks[\"default\"];\n return found || [];\n }\n }, {\n key: \"toResolveHierarchy\",\n value: function toResolveHierarchy(code, fallbackCode) {\n var _this2 = this;\n var fallbackCodes = this.getFallbackCodes(fallbackCode || this.options.fallbackLng || [], code);\n var codes = [];\n var addCode = function addCode(c) {\n if (!c) return;\n if (_this2.isSupportedCode(c)) {\n codes.push(c);\n } else {\n _this2.logger.warn(\"rejecting language code not found in supportedLngs: \".concat(c));\n }\n };\n if (typeof code === 'string' && code.indexOf('-') > -1) {\n if (this.options.load !== 'languageOnly') addCode(this.formatLanguageCode(code));\n if (this.options.load !== 'languageOnly' && this.options.load !== 'currentOnly') addCode(this.getScriptPartFromCode(code));\n if (this.options.load !== 'currentOnly') addCode(this.getLanguagePartFromCode(code));\n } else if (typeof code === 'string') {\n addCode(this.formatLanguageCode(code));\n }\n fallbackCodes.forEach(function (fc) {\n if (codes.indexOf(fc) < 0) addCode(_this2.formatLanguageCode(fc));\n });\n return codes;\n }\n }]);\n return LanguageUtil;\n}();\n\nvar sets = [{\n lngs: ['ach', 'ak', 'am', 'arn', 'br', 'fil', 'gun', 'ln', 'mfe', 'mg', 'mi', 'oc', 'pt', 'pt-BR', 'tg', 'tl', 'ti', 'tr', 'uz', 'wa'],\n nr: [1, 2],\n fc: 1\n}, {\n lngs: ['af', 'an', 'ast', 'az', 'bg', 'bn', 'ca', 'da', 'de', 'dev', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fi', 'fo', 'fur', 'fy', 'gl', 'gu', 'ha', 'hi', 'hu', 'hy', 'ia', 'it', 'kk', 'kn', 'ku', 'lb', 'mai', 'ml', 'mn', 'mr', 'nah', 'nap', 'nb', 'ne', 'nl', 'nn', 'no', 'nso', 'pa', 'pap', 'pms', 'ps', 'pt-PT', 'rm', 'sco', 'se', 'si', 'so', 'son', 'sq', 'sv', 'sw', 'ta', 'te', 'tk', 'ur', 'yo'],\n nr: [1, 2],\n fc: 2\n}, {\n lngs: ['ay', 'bo', 'cgg', 'fa', 'ht', 'id', 'ja', 'jbo', 'ka', 'km', 'ko', 'ky', 'lo', 'ms', 'sah', 'su', 'th', 'tt', 'ug', 'vi', 'wo', 'zh'],\n nr: [1],\n fc: 3\n}, {\n lngs: ['be', 'bs', 'cnr', 'dz', 'hr', 'ru', 'sr', 'uk'],\n nr: [1, 2, 5],\n fc: 4\n}, {\n lngs: ['ar'],\n nr: [0, 1, 2, 3, 11, 100],\n fc: 5\n}, {\n lngs: ['cs', 'sk'],\n nr: [1, 2, 5],\n fc: 6\n}, {\n lngs: ['csb', 'pl'],\n nr: [1, 2, 5],\n fc: 7\n}, {\n lngs: ['cy'],\n nr: [1, 2, 3, 8],\n fc: 8\n}, {\n lngs: ['fr'],\n nr: [1, 2],\n fc: 9\n}, {\n lngs: ['ga'],\n nr: [1, 2, 3, 7, 11],\n fc: 10\n}, {\n lngs: ['gd'],\n nr: [1, 2, 3, 20],\n fc: 11\n}, {\n lngs: ['is'],\n nr: [1, 2],\n fc: 12\n}, {\n lngs: ['jv'],\n nr: [0, 1],\n fc: 13\n}, {\n lngs: ['kw'],\n nr: [1, 2, 3, 4],\n fc: 14\n}, {\n lngs: ['lt'],\n nr: [1, 2, 10],\n fc: 15\n}, {\n lngs: ['lv'],\n nr: [1, 2, 0],\n fc: 16\n}, {\n lngs: ['mk'],\n nr: [1, 2],\n fc: 17\n}, {\n lngs: ['mnk'],\n nr: [0, 1, 2],\n fc: 18\n}, {\n lngs: ['mt'],\n nr: [1, 2, 11, 20],\n fc: 19\n}, {\n lngs: ['or'],\n nr: [2, 1],\n fc: 2\n}, {\n lngs: ['ro'],\n nr: [1, 2, 20],\n fc: 20\n}, {\n lngs: ['sl'],\n nr: [5, 1, 2, 3],\n fc: 21\n}, {\n lngs: ['he', 'iw'],\n nr: [1, 2, 20, 21],\n fc: 22\n}];\nvar _rulesPluralsTypes = {\n 1: function _(n) {\n return Number(n > 1);\n },\n 2: function _(n) {\n return Number(n != 1);\n },\n 3: function _(n) {\n return 0;\n },\n 4: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 5: function _(n) {\n return Number(n == 0 ? 0 : n == 1 ? 1 : n == 2 ? 2 : n % 100 >= 3 && n % 100 <= 10 ? 3 : n % 100 >= 11 ? 4 : 5);\n },\n 6: function _(n) {\n return Number(n == 1 ? 0 : n >= 2 && n <= 4 ? 1 : 2);\n },\n 7: function _(n) {\n return Number(n == 1 ? 0 : n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 8: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n != 8 && n != 11 ? 2 : 3);\n },\n 9: function _(n) {\n return Number(n >= 2);\n },\n 10: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n < 7 ? 2 : n < 11 ? 3 : 4);\n },\n 11: function _(n) {\n return Number(n == 1 || n == 11 ? 0 : n == 2 || n == 12 ? 1 : n > 2 && n < 20 ? 2 : 3);\n },\n 12: function _(n) {\n return Number(n % 10 != 1 || n % 100 == 11);\n },\n 13: function _(n) {\n return Number(n !== 0);\n },\n 14: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : n == 3 ? 2 : 3);\n },\n 15: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n % 10 >= 2 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2);\n },\n 16: function _(n) {\n return Number(n % 10 == 1 && n % 100 != 11 ? 0 : n !== 0 ? 1 : 2);\n },\n 17: function _(n) {\n return Number(n == 1 || n % 10 == 1 && n % 100 != 11 ? 0 : 1);\n },\n 18: function _(n) {\n return Number(n == 0 ? 0 : n == 1 ? 1 : 2);\n },\n 19: function _(n) {\n return Number(n == 1 ? 0 : n == 0 || n % 100 > 1 && n % 100 < 11 ? 1 : n % 100 > 10 && n % 100 < 20 ? 2 : 3);\n },\n 20: function _(n) {\n return Number(n == 1 ? 0 : n == 0 || n % 100 > 0 && n % 100 < 20 ? 1 : 2);\n },\n 21: function _(n) {\n return Number(n % 100 == 1 ? 1 : n % 100 == 2 ? 2 : n % 100 == 3 || n % 100 == 4 ? 3 : 0);\n },\n 22: function _(n) {\n return Number(n == 1 ? 0 : n == 2 ? 1 : (n < 0 || n > 10) && n % 10 == 0 ? 2 : 3);\n }\n};\nvar deprecatedJsonVersions = ['v1', 'v2', 'v3'];\nvar suffixesOrder = {\n zero: 0,\n one: 1,\n two: 2,\n few: 3,\n many: 4,\n other: 5\n};\nfunction createRules() {\n var rules = {};\n sets.forEach(function (set) {\n set.lngs.forEach(function (l) {\n rules[l] = {\n numbers: set.nr,\n plurals: _rulesPluralsTypes[set.fc]\n };\n });\n });\n return rules;\n}\nvar PluralResolver = function () {\n function PluralResolver(languageUtils) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n _classCallCheck__default[\"default\"](this, PluralResolver);\n this.languageUtils = languageUtils;\n this.options = options;\n this.logger = baseLogger.create('pluralResolver');\n if ((!this.options.compatibilityJSON || this.options.compatibilityJSON === 'v4') && (typeof Intl === 'undefined' || !Intl.PluralRules)) {\n this.options.compatibilityJSON = 'v3';\n this.logger.error('Your environment seems not to be Intl API compatible, use an Intl.PluralRules polyfill. Will fallback to the compatibilityJSON v3 format handling.');\n }\n this.rules = createRules();\n }\n _createClass__default[\"default\"](PluralResolver, [{\n key: \"addRule\",\n value: function addRule(lng, obj) {\n this.rules[lng] = obj;\n }\n }, {\n key: \"getRule\",\n value: function getRule(code) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n if (this.shouldUseIntlApi()) {\n try {\n return new Intl.PluralRules(code, {\n type: options.ordinal ? 'ordinal' : 'cardinal'\n });\n } catch (_unused) {\n return;\n }\n }\n return this.rules[code] || this.rules[this.languageUtils.getLanguagePartFromCode(code)];\n }\n }, {\n key: \"needsPlural\",\n value: function needsPlural(code) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var rule = this.getRule(code, options);\n if (this.shouldUseIntlApi()) {\n return rule && rule.resolvedOptions().pluralCategories.length > 1;\n }\n return rule && rule.numbers.length > 1;\n }\n }, {\n key: \"getPluralFormsOfKey\",\n value: function getPluralFormsOfKey(code, key) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n return this.getSuffixes(code, options).map(function (suffix) {\n return \"\".concat(key).concat(suffix);\n });\n }\n }, {\n key: \"getSuffixes\",\n value: function getSuffixes(code) {\n var _this = this;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var rule = this.getRule(code, options);\n if (!rule) {\n return [];\n }\n if (this.shouldUseIntlApi()) {\n return rule.resolvedOptions().pluralCategories.sort(function (pluralCategory1, pluralCategory2) {\n return suffixesOrder[pluralCategory1] - suffixesOrder[pluralCategory2];\n }).map(function (pluralCategory) {\n return \"\".concat(_this.options.prepend).concat(pluralCategory);\n });\n }\n return rule.numbers.map(function (number) {\n return _this.getSuffix(code, number, options);\n });\n }\n }, {\n key: \"getSuffix\",\n value: function getSuffix(code, count) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var rule = this.getRule(code, options);\n if (rule) {\n if (this.shouldUseIntlApi()) {\n return \"\".concat(this.options.prepend).concat(rule.select(count));\n }\n return this.getSuffixRetroCompatible(rule, count);\n }\n this.logger.warn(\"no plural rule found for: \".concat(code));\n return '';\n }\n }, {\n key: \"getSuffixRetroCompatible\",\n value: function getSuffixRetroCompatible(rule, count) {\n var _this2 = this;\n var idx = rule.noAbs ? rule.plurals(count) : rule.plurals(Math.abs(count));\n var suffix = rule.numbers[idx];\n if (this.options.simplifyPluralSuffix && rule.numbers.length === 2 && rule.numbers[0] === 1) {\n if (suffix === 2) {\n suffix = 'plural';\n } else if (suffix === 1) {\n suffix = '';\n }\n }\n var returnSuffix = function returnSuffix() {\n return _this2.options.prepend && suffix.toString() ? _this2.options.prepend + suffix.toString() : suffix.toString();\n };\n if (this.options.compatibilityJSON === 'v1') {\n if (suffix === 1) return '';\n if (typeof suffix === 'number') return \"_plural_\".concat(suffix.toString());\n return returnSuffix();\n } else if (this.options.compatibilityJSON === 'v2') {\n return returnSuffix();\n } else if (this.options.simplifyPluralSuffix && rule.numbers.length === 2 && rule.numbers[0] === 1) {\n return returnSuffix();\n }\n return this.options.prepend && idx.toString() ? this.options.prepend + idx.toString() : idx.toString();\n }\n }, {\n key: \"shouldUseIntlApi\",\n value: function shouldUseIntlApi() {\n return !deprecatedJsonVersions.includes(this.options.compatibilityJSON);\n }\n }]);\n return PluralResolver;\n}();\n\nfunction ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$3(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nvar Interpolator = function () {\n function Interpolator() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n _classCallCheck__default[\"default\"](this, Interpolator);\n this.logger = baseLogger.create('interpolator');\n this.options = options;\n this.format = options.interpolation && options.interpolation.format || function (value) {\n return value;\n };\n this.init(options);\n }\n _createClass__default[\"default\"](Interpolator, [{\n key: \"init\",\n value: function init() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n if (!options.interpolation) options.interpolation = {\n escapeValue: true\n };\n var iOpts = options.interpolation;\n this.escape = iOpts.escape !== undefined ? iOpts.escape : escape;\n this.escapeValue = iOpts.escapeValue !== undefined ? iOpts.escapeValue : true;\n this.useRawValueToEscape = iOpts.useRawValueToEscape !== undefined ? iOpts.useRawValueToEscape : false;\n this.prefix = iOpts.prefix ? regexEscape(iOpts.prefix) : iOpts.prefixEscaped || '{{';\n this.suffix = iOpts.suffix ? regexEscape(iOpts.suffix) : iOpts.suffixEscaped || '}}';\n this.formatSeparator = iOpts.formatSeparator ? iOpts.formatSeparator : iOpts.formatSeparator || ',';\n this.unescapePrefix = iOpts.unescapeSuffix ? '' : iOpts.unescapePrefix || '-';\n this.unescapeSuffix = this.unescapePrefix ? '' : iOpts.unescapeSuffix || '';\n this.nestingPrefix = iOpts.nestingPrefix ? regexEscape(iOpts.nestingPrefix) : iOpts.nestingPrefixEscaped || regexEscape('$t(');\n this.nestingSuffix = iOpts.nestingSuffix ? regexEscape(iOpts.nestingSuffix) : iOpts.nestingSuffixEscaped || regexEscape(')');\n this.nestingOptionsSeparator = iOpts.nestingOptionsSeparator ? iOpts.nestingOptionsSeparator : iOpts.nestingOptionsSeparator || ',';\n this.maxReplaces = iOpts.maxReplaces ? iOpts.maxReplaces : 1000;\n this.alwaysFormat = iOpts.alwaysFormat !== undefined ? iOpts.alwaysFormat : false;\n this.resetRegExp();\n }\n }, {\n key: \"reset\",\n value: function reset() {\n if (this.options) this.init(this.options);\n }\n }, {\n key: \"resetRegExp\",\n value: function resetRegExp() {\n var regexpStr = \"\".concat(this.prefix, \"(.+?)\").concat(this.suffix);\n this.regexp = new RegExp(regexpStr, 'g');\n var regexpUnescapeStr = \"\".concat(this.prefix).concat(this.unescapePrefix, \"(.+?)\").concat(this.unescapeSuffix).concat(this.suffix);\n this.regexpUnescape = new RegExp(regexpUnescapeStr, 'g');\n var nestingRegexpStr = \"\".concat(this.nestingPrefix, \"(.+?)\").concat(this.nestingSuffix);\n this.nestingRegexp = new RegExp(nestingRegexpStr, 'g');\n }\n }, {\n key: \"interpolate\",\n value: function interpolate(str, data, lng, options) {\n var _this = this;\n var match;\n var value;\n var replaces;\n var defaultData = this.options && this.options.interpolation && this.options.interpolation.defaultVariables || {};\n function regexSafe(val) {\n return val.replace(/\\$/g, '$$$$');\n }\n var handleFormat = function handleFormat(key) {\n if (key.indexOf(_this.formatSeparator) < 0) {\n var path = getPathWithDefaults(data, defaultData, key);\n return _this.alwaysFormat ? _this.format(path, undefined, lng, _objectSpread$3(_objectSpread$3(_objectSpread$3({}, options), data), {}, {\n interpolationkey: key\n })) : path;\n }\n var p = key.split(_this.formatSeparator);\n var k = p.shift().trim();\n var f = p.join(_this.formatSeparator).trim();\n return _this.format(getPathWithDefaults(data, defaultData, k), f, lng, _objectSpread$3(_objectSpread$3(_objectSpread$3({}, options), data), {}, {\n interpolationkey: k\n }));\n };\n this.resetRegExp();\n var missingInterpolationHandler = options && options.missingInterpolationHandler || this.options.missingInterpolationHandler;\n var skipOnVariables = options && options.interpolation && options.interpolation.skipOnVariables !== undefined ? options.interpolation.skipOnVariables : this.options.interpolation.skipOnVariables;\n var todos = [{\n regex: this.regexpUnescape,\n safeValue: function safeValue(val) {\n return regexSafe(val);\n }\n }, {\n regex: this.regexp,\n safeValue: function safeValue(val) {\n return _this.escapeValue ? regexSafe(_this.escape(val)) : regexSafe(val);\n }\n }];\n todos.forEach(function (todo) {\n replaces = 0;\n while (match = todo.regex.exec(str)) {\n var matchedVar = match[1].trim();\n value = handleFormat(matchedVar);\n if (value === undefined) {\n if (typeof missingInterpolationHandler === 'function') {\n var temp = missingInterpolationHandler(str, match, options);\n value = typeof temp === 'string' ? temp : '';\n } else if (options && options.hasOwnProperty(matchedVar)) {\n value = '';\n } else if (skipOnVariables) {\n value = match[0];\n continue;\n } else {\n _this.logger.warn(\"missed to pass in variable \".concat(matchedVar, \" for interpolating \").concat(str));\n value = '';\n }\n } else if (typeof value !== 'string' && !_this.useRawValueToEscape) {\n value = makeString(value);\n }\n var safeValue = todo.safeValue(value);\n str = str.replace(match[0], safeValue);\n if (skipOnVariables) {\n todo.regex.lastIndex += value.length;\n todo.regex.lastIndex -= match[0].length;\n } else {\n todo.regex.lastIndex = 0;\n }\n replaces++;\n if (replaces >= _this.maxReplaces) {\n break;\n }\n }\n });\n return str;\n }\n }, {\n key: \"nest\",\n value: function nest(str, fc) {\n var _this2 = this;\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var match;\n var value;\n var clonedOptions;\n function handleHasOptions(key, inheritedOptions) {\n var sep = this.nestingOptionsSeparator;\n if (key.indexOf(sep) < 0) return key;\n var c = key.split(new RegExp(\"\".concat(sep, \"[ ]*{\")));\n var optionsString = \"{\".concat(c[1]);\n key = c[0];\n optionsString = this.interpolate(optionsString, clonedOptions);\n var matchedSingleQuotes = optionsString.match(/'/g);\n var matchedDoubleQuotes = optionsString.match(/\"/g);\n if (matchedSingleQuotes && matchedSingleQuotes.length % 2 === 0 && !matchedDoubleQuotes || matchedDoubleQuotes.length % 2 !== 0) {\n optionsString = optionsString.replace(/'/g, '\"');\n }\n try {\n clonedOptions = JSON.parse(optionsString);\n if (inheritedOptions) clonedOptions = _objectSpread$3(_objectSpread$3({}, inheritedOptions), clonedOptions);\n } catch (e) {\n this.logger.warn(\"failed parsing options string in nesting for key \".concat(key), e);\n return \"\".concat(key).concat(sep).concat(optionsString);\n }\n delete clonedOptions.defaultValue;\n return key;\n }\n while (match = this.nestingRegexp.exec(str)) {\n var formatters = [];\n clonedOptions = _objectSpread$3({}, options);\n clonedOptions.applyPostProcessor = false;\n delete clonedOptions.defaultValue;\n var doReduce = false;\n if (match[0].indexOf(this.formatSeparator) !== -1 && !/{.*}/.test(match[1])) {\n var r = match[1].split(this.formatSeparator).map(function (elem) {\n return elem.trim();\n });\n match[1] = r.shift();\n formatters = r;\n doReduce = true;\n }\n value = fc(handleHasOptions.call(this, match[1].trim(), clonedOptions), clonedOptions);\n if (value && match[0] === str && typeof value !== 'string') return value;\n if (typeof value !== 'string') value = makeString(value);\n if (!value) {\n this.logger.warn(\"missed to resolve \".concat(match[1], \" for nesting \").concat(str));\n value = '';\n }\n if (doReduce) {\n value = formatters.reduce(function (v, f) {\n return _this2.format(v, f, options.lng, _objectSpread$3(_objectSpread$3({}, options), {}, {\n interpolationkey: match[1].trim()\n }));\n }, value.trim());\n }\n str = str.replace(match[0], value);\n this.regexp.lastIndex = 0;\n }\n return str;\n }\n }]);\n return Interpolator;\n}();\n\nfunction ownKeys$2(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction parseFormatStr(formatStr) {\n var formatName = formatStr.toLowerCase().trim();\n var formatOptions = {};\n if (formatStr.indexOf('(') > -1) {\n var p = formatStr.split('(');\n formatName = p[0].toLowerCase().trim();\n var optStr = p[1].substring(0, p[1].length - 1);\n if (formatName === 'currency' && optStr.indexOf(':') < 0) {\n if (!formatOptions.currency) formatOptions.currency = optStr.trim();\n } else if (formatName === 'relativetime' && optStr.indexOf(':') < 0) {\n if (!formatOptions.range) formatOptions.range = optStr.trim();\n } else {\n var opts = optStr.split(';');\n opts.forEach(function (opt) {\n if (!opt) return;\n var _opt$split = opt.split(':'),\n _opt$split2 = _toArray__default[\"default\"](_opt$split),\n key = _opt$split2[0],\n rest = _opt$split2.slice(1);\n var val = rest.join(':').trim().replace(/^'+|'+$/g, '');\n if (!formatOptions[key.trim()]) formatOptions[key.trim()] = val;\n if (val === 'false') formatOptions[key.trim()] = false;\n if (val === 'true') formatOptions[key.trim()] = true;\n if (!isNaN(val)) formatOptions[key.trim()] = parseInt(val, 10);\n });\n }\n }\n return {\n formatName: formatName,\n formatOptions: formatOptions\n };\n}\nfunction createCachedFormatter(fn) {\n var cache = {};\n return function invokeFormatter(val, lng, options) {\n var key = lng + JSON.stringify(options);\n var formatter = cache[key];\n if (!formatter) {\n formatter = fn(lng, options);\n cache[key] = formatter;\n }\n return formatter(val);\n };\n}\nvar Formatter = function () {\n function Formatter() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n _classCallCheck__default[\"default\"](this, Formatter);\n this.logger = baseLogger.create('formatter');\n this.options = options;\n this.formats = {\n number: createCachedFormatter(function (lng, options) {\n var formatter = new Intl.NumberFormat(lng, options);\n return function (val) {\n return formatter.format(val);\n };\n }),\n currency: createCachedFormatter(function (lng, options) {\n var formatter = new Intl.NumberFormat(lng, _objectSpread$2(_objectSpread$2({}, options), {}, {\n style: 'currency'\n }));\n return function (val) {\n return formatter.format(val);\n };\n }),\n datetime: createCachedFormatter(function (lng, options) {\n var formatter = new Intl.DateTimeFormat(lng, _objectSpread$2({}, options));\n return function (val) {\n return formatter.format(val);\n };\n }),\n relativetime: createCachedFormatter(function (lng, options) {\n var formatter = new Intl.RelativeTimeFormat(lng, _objectSpread$2({}, options));\n return function (val) {\n return formatter.format(val, options.range || 'day');\n };\n }),\n list: createCachedFormatter(function (lng, options) {\n var formatter = new Intl.ListFormat(lng, _objectSpread$2({}, options));\n return function (val) {\n return formatter.format(val);\n };\n })\n };\n this.init(options);\n }\n _createClass__default[\"default\"](Formatter, [{\n key: \"init\",\n value: function init(services) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n interpolation: {}\n };\n var iOpts = options.interpolation;\n this.formatSeparator = iOpts.formatSeparator ? iOpts.formatSeparator : iOpts.formatSeparator || ',';\n }\n }, {\n key: \"add\",\n value: function add(name, fc) {\n this.formats[name.toLowerCase().trim()] = fc;\n }\n }, {\n key: \"addCached\",\n value: function addCached(name, fc) {\n this.formats[name.toLowerCase().trim()] = createCachedFormatter(fc);\n }\n }, {\n key: \"format\",\n value: function format(value, _format, lng, options) {\n var _this = this;\n var formats = _format.split(this.formatSeparator);\n var result = formats.reduce(function (mem, f) {\n var _parseFormatStr = parseFormatStr(f),\n formatName = _parseFormatStr.formatName,\n formatOptions = _parseFormatStr.formatOptions;\n if (_this.formats[formatName]) {\n var formatted = mem;\n try {\n var valOptions = options && options.formatParams && options.formatParams[options.interpolationkey] || {};\n var l = valOptions.locale || valOptions.lng || options.locale || options.lng || lng;\n formatted = _this.formats[formatName](mem, l, _objectSpread$2(_objectSpread$2(_objectSpread$2({}, formatOptions), options), valOptions));\n } catch (error) {\n _this.logger.warn(error);\n }\n return formatted;\n } else {\n _this.logger.warn(\"there was no format function for \".concat(formatName));\n }\n return mem;\n }, value);\n return result;\n }\n }]);\n return Formatter;\n}();\n\nfunction ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _createSuper$1(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct$1(); return function _createSuperInternal() { var Super = _getPrototypeOf__default[\"default\"](Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf__default[\"default\"](this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn__default[\"default\"](this, result); }; }\nfunction _isNativeReflectConstruct$1() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction removePending(q, name) {\n if (q.pending[name] !== undefined) {\n delete q.pending[name];\n q.pendingCount--;\n }\n}\nvar Connector = function (_EventEmitter) {\n _inherits__default[\"default\"](Connector, _EventEmitter);\n var _super = _createSuper$1(Connector);\n function Connector(backend, store, services) {\n var _this;\n var options = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};\n _classCallCheck__default[\"default\"](this, Connector);\n _this = _super.call(this);\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized__default[\"default\"](_this));\n }\n _this.backend = backend;\n _this.store = store;\n _this.services = services;\n _this.languageUtils = services.languageUtils;\n _this.options = options;\n _this.logger = baseLogger.create('backendConnector');\n _this.waitingReads = [];\n _this.maxParallelReads = options.maxParallelReads || 10;\n _this.readingCalls = 0;\n _this.maxRetries = options.maxRetries >= 0 ? options.maxRetries : 5;\n _this.retryTimeout = options.retryTimeout >= 1 ? options.retryTimeout : 350;\n _this.state = {};\n _this.queue = [];\n if (_this.backend && _this.backend.init) {\n _this.backend.init(services, options.backend, options);\n }\n return _this;\n }\n _createClass__default[\"default\"](Connector, [{\n key: \"queueLoad\",\n value: function queueLoad(languages, namespaces, options, callback) {\n var _this2 = this;\n var toLoad = {};\n var pending = {};\n var toLoadLanguages = {};\n var toLoadNamespaces = {};\n languages.forEach(function (lng) {\n var hasAllNamespaces = true;\n namespaces.forEach(function (ns) {\n var name = \"\".concat(lng, \"|\").concat(ns);\n if (!options.reload && _this2.store.hasResourceBundle(lng, ns)) {\n _this2.state[name] = 2;\n } else if (_this2.state[name] < 0) ; else if (_this2.state[name] === 1) {\n if (pending[name] === undefined) pending[name] = true;\n } else {\n _this2.state[name] = 1;\n hasAllNamespaces = false;\n if (pending[name] === undefined) pending[name] = true;\n if (toLoad[name] === undefined) toLoad[name] = true;\n if (toLoadNamespaces[ns] === undefined) toLoadNamespaces[ns] = true;\n }\n });\n if (!hasAllNamespaces) toLoadLanguages[lng] = true;\n });\n if (Object.keys(toLoad).length || Object.keys(pending).length) {\n this.queue.push({\n pending: pending,\n pendingCount: Object.keys(pending).length,\n loaded: {},\n errors: [],\n callback: callback\n });\n }\n return {\n toLoad: Object.keys(toLoad),\n pending: Object.keys(pending),\n toLoadLanguages: Object.keys(toLoadLanguages),\n toLoadNamespaces: Object.keys(toLoadNamespaces)\n };\n }\n }, {\n key: \"loaded\",\n value: function loaded(name, err, data) {\n var s = name.split('|');\n var lng = s[0];\n var ns = s[1];\n if (err) this.emit('failedLoading', lng, ns, err);\n if (data) {\n this.store.addResourceBundle(lng, ns, data);\n }\n this.state[name] = err ? -1 : 2;\n var loaded = {};\n this.queue.forEach(function (q) {\n pushPath(q.loaded, [lng], ns);\n removePending(q, name);\n if (err) q.errors.push(err);\n if (q.pendingCount === 0 && !q.done) {\n Object.keys(q.loaded).forEach(function (l) {\n if (!loaded[l]) loaded[l] = {};\n var loadedKeys = q.loaded[l];\n if (loadedKeys.length) {\n loadedKeys.forEach(function (ns) {\n if (loaded[l][ns] === undefined) loaded[l][ns] = true;\n });\n }\n });\n q.done = true;\n if (q.errors.length) {\n q.callback(q.errors);\n } else {\n q.callback();\n }\n }\n });\n this.emit('loaded', loaded);\n this.queue = this.queue.filter(function (q) {\n return !q.done;\n });\n }\n }, {\n key: \"read\",\n value: function read(lng, ns, fcName) {\n var _this3 = this;\n var tried = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;\n var wait = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : this.retryTimeout;\n var callback = arguments.length > 5 ? arguments[5] : undefined;\n if (!lng.length) return callback(null, {});\n if (this.readingCalls >= this.maxParallelReads) {\n this.waitingReads.push({\n lng: lng,\n ns: ns,\n fcName: fcName,\n tried: tried,\n wait: wait,\n callback: callback\n });\n return;\n }\n this.readingCalls++;\n var resolver = function resolver(err, data) {\n _this3.readingCalls--;\n if (_this3.waitingReads.length > 0) {\n var next = _this3.waitingReads.shift();\n _this3.read(next.lng, next.ns, next.fcName, next.tried, next.wait, next.callback);\n }\n if (err && data && tried < _this3.maxRetries) {\n setTimeout(function () {\n _this3.read.call(_this3, lng, ns, fcName, tried + 1, wait * 2, callback);\n }, wait);\n return;\n }\n callback(err, data);\n };\n var fc = this.backend[fcName].bind(this.backend);\n if (fc.length === 2) {\n try {\n var r = fc(lng, ns);\n if (r && typeof r.then === 'function') {\n r.then(function (data) {\n return resolver(null, data);\n })[\"catch\"](resolver);\n } else {\n resolver(null, r);\n }\n } catch (err) {\n resolver(err);\n }\n return;\n }\n return fc(lng, ns, resolver);\n }\n }, {\n key: \"prepareLoading\",\n value: function prepareLoading(languages, namespaces) {\n var _this4 = this;\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var callback = arguments.length > 3 ? arguments[3] : undefined;\n if (!this.backend) {\n this.logger.warn('No backend was added via i18next.use. Will not load resources.');\n return callback && callback();\n }\n if (typeof languages === 'string') languages = this.languageUtils.toResolveHierarchy(languages);\n if (typeof namespaces === 'string') namespaces = [namespaces];\n var toLoad = this.queueLoad(languages, namespaces, options, callback);\n if (!toLoad.toLoad.length) {\n if (!toLoad.pending.length) callback();\n return null;\n }\n toLoad.toLoad.forEach(function (name) {\n _this4.loadOne(name);\n });\n }\n }, {\n key: \"load\",\n value: function load(languages, namespaces, callback) {\n this.prepareLoading(languages, namespaces, {}, callback);\n }\n }, {\n key: \"reload\",\n value: function reload(languages, namespaces, callback) {\n this.prepareLoading(languages, namespaces, {\n reload: true\n }, callback);\n }\n }, {\n key: \"loadOne\",\n value: function loadOne(name) {\n var _this5 = this;\n var prefix = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n var s = name.split('|');\n var lng = s[0];\n var ns = s[1];\n this.read(lng, ns, 'read', undefined, undefined, function (err, data) {\n if (err) _this5.logger.warn(\"\".concat(prefix, \"loading namespace \").concat(ns, \" for language \").concat(lng, \" failed\"), err);\n if (!err && data) _this5.logger.log(\"\".concat(prefix, \"loaded namespace \").concat(ns, \" for language \").concat(lng), data);\n _this5.loaded(name, err, data);\n });\n }\n }, {\n key: \"saveMissing\",\n value: function saveMissing(languages, namespace, key, fallbackValue, isUpdate) {\n var options = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : {};\n var clb = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : function () {};\n if (this.services.utils && this.services.utils.hasLoadedNamespace && !this.services.utils.hasLoadedNamespace(namespace)) {\n this.logger.warn(\"did not save key \\\"\".concat(key, \"\\\" as the namespace \\\"\").concat(namespace, \"\\\" was not yet loaded\"), 'This means something IS WRONG in your setup. You access the t function before i18next.init / i18next.loadNamespace / i18next.changeLanguage was done. Wait for the callback or Promise to resolve before accessing it!!!');\n return;\n }\n if (key === undefined || key === null || key === '') return;\n if (this.backend && this.backend.create) {\n var opts = _objectSpread$1(_objectSpread$1({}, options), {}, {\n isUpdate: isUpdate\n });\n var fc = this.backend.create.bind(this.backend);\n if (fc.length < 6) {\n try {\n var r;\n if (fc.length === 5) {\n r = fc(languages, namespace, key, fallbackValue, opts);\n } else {\n r = fc(languages, namespace, key, fallbackValue);\n }\n if (r && typeof r.then === 'function') {\n r.then(function (data) {\n return clb(null, data);\n })[\"catch\"](clb);\n } else {\n clb(null, r);\n }\n } catch (err) {\n clb(err);\n }\n } else {\n fc(languages, namespace, key, fallbackValue, clb, opts);\n }\n }\n if (!languages || !languages[0]) return;\n this.store.addResource(languages[0], namespace, key, fallbackValue);\n }\n }]);\n return Connector;\n}(EventEmitter);\n\nfunction get() {\n return {\n debug: false,\n initImmediate: true,\n ns: ['translation'],\n defaultNS: ['translation'],\n fallbackLng: ['dev'],\n fallbackNS: false,\n supportedLngs: false,\n nonExplicitSupportedLngs: false,\n load: 'all',\n preload: false,\n simplifyPluralSuffix: true,\n keySeparator: '.',\n nsSeparator: ':',\n pluralSeparator: '_',\n contextSeparator: '_',\n partialBundledLanguages: false,\n saveMissing: false,\n updateMissing: false,\n saveMissingTo: 'fallback',\n saveMissingPlurals: true,\n missingKeyHandler: false,\n missingInterpolationHandler: false,\n postProcess: false,\n postProcessPassResolved: false,\n returnNull: true,\n returnEmptyString: true,\n returnObjects: false,\n joinArrays: false,\n returnedObjectHandler: false,\n parseMissingKeyHandler: false,\n appendNamespaceToMissingKey: false,\n appendNamespaceToCIMode: false,\n overloadTranslationOptionHandler: function handle(args) {\n var ret = {};\n if (_typeof__default[\"default\"](args[1]) === 'object') ret = args[1];\n if (typeof args[1] === 'string') ret.defaultValue = args[1];\n if (typeof args[2] === 'string') ret.tDescription = args[2];\n if (_typeof__default[\"default\"](args[2]) === 'object' || _typeof__default[\"default\"](args[3]) === 'object') {\n var options = args[3] || args[2];\n Object.keys(options).forEach(function (key) {\n ret[key] = options[key];\n });\n }\n return ret;\n },\n interpolation: {\n escapeValue: true,\n format: function format(value, _format, lng, options) {\n return value;\n },\n prefix: '{{',\n suffix: '}}',\n formatSeparator: ',',\n unescapePrefix: '-',\n nestingPrefix: '$t(',\n nestingSuffix: ')',\n nestingOptionsSeparator: ',',\n maxReplaces: 1000,\n skipOnVariables: true\n }\n };\n}\nfunction transformOptions(options) {\n if (typeof options.ns === 'string') options.ns = [options.ns];\n if (typeof options.fallbackLng === 'string') options.fallbackLng = [options.fallbackLng];\n if (typeof options.fallbackNS === 'string') options.fallbackNS = [options.fallbackNS];\n if (options.supportedLngs && options.supportedLngs.indexOf('cimode') < 0) {\n options.supportedLngs = options.supportedLngs.concat(['cimode']);\n }\n return options;\n}\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty__default[\"default\"](target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf__default[\"default\"](Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf__default[\"default\"](this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn__default[\"default\"](this, result); }; }\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction noop() {}\nfunction bindMemberFunctions(inst) {\n var mems = Object.getOwnPropertyNames(Object.getPrototypeOf(inst));\n mems.forEach(function (mem) {\n if (typeof inst[mem] === 'function') {\n inst[mem] = inst[mem].bind(inst);\n }\n });\n}\nvar I18n = function (_EventEmitter) {\n _inherits__default[\"default\"](I18n, _EventEmitter);\n var _super = _createSuper(I18n);\n function I18n() {\n var _this;\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n _classCallCheck__default[\"default\"](this, I18n);\n _this = _super.call(this);\n if (isIE10) {\n EventEmitter.call(_assertThisInitialized__default[\"default\"](_this));\n }\n _this.options = transformOptions(options);\n _this.services = {};\n _this.logger = baseLogger;\n _this.modules = {\n external: []\n };\n bindMemberFunctions(_assertThisInitialized__default[\"default\"](_this));\n if (callback && !_this.isInitialized && !options.isClone) {\n if (!_this.options.initImmediate) {\n _this.init(options, callback);\n return _possibleConstructorReturn__default[\"default\"](_this, _assertThisInitialized__default[\"default\"](_this));\n }\n setTimeout(function () {\n _this.init(options, callback);\n }, 0);\n }\n return _this;\n }\n _createClass__default[\"default\"](I18n, [{\n key: \"init\",\n value: function init() {\n var _this2 = this;\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n if (typeof options === 'function') {\n callback = options;\n options = {};\n }\n if (!options.defaultNS && options.defaultNS !== false && options.ns) {\n if (typeof options.ns === 'string') {\n options.defaultNS = options.ns;\n } else if (options.ns.indexOf('translation') < 0) {\n options.defaultNS = options.ns[0];\n }\n }\n var defOpts = get();\n this.options = _objectSpread(_objectSpread(_objectSpread({}, defOpts), this.options), transformOptions(options));\n if (this.options.compatibilityAPI !== 'v1') {\n this.options.interpolation = _objectSpread(_objectSpread({}, defOpts.interpolation), this.options.interpolation);\n }\n if (options.keySeparator !== undefined) {\n this.options.userDefinedKeySeparator = options.keySeparator;\n }\n if (options.nsSeparator !== undefined) {\n this.options.userDefinedNsSeparator = options.nsSeparator;\n }\n function createClassOnDemand(ClassOrObject) {\n if (!ClassOrObject) return null;\n if (typeof ClassOrObject === 'function') return new ClassOrObject();\n return ClassOrObject;\n }\n if (!this.options.isClone) {\n if (this.modules.logger) {\n baseLogger.init(createClassOnDemand(this.modules.logger), this.options);\n } else {\n baseLogger.init(null, this.options);\n }\n var formatter;\n if (this.modules.formatter) {\n formatter = this.modules.formatter;\n } else if (typeof Intl !== 'undefined') {\n formatter = Formatter;\n }\n var lu = new LanguageUtil(this.options);\n this.store = new ResourceStore(this.options.resources, this.options);\n var s = this.services;\n s.logger = baseLogger;\n s.resourceStore = this.store;\n s.languageUtils = lu;\n s.pluralResolver = new PluralResolver(lu, {\n prepend: this.options.pluralSeparator,\n compatibilityJSON: this.options.compatibilityJSON,\n simplifyPluralSuffix: this.options.simplifyPluralSuffix\n });\n if (formatter && (!this.options.interpolation.format || this.options.interpolation.format === defOpts.interpolation.format)) {\n s.formatter = createClassOnDemand(formatter);\n s.formatter.init(s, this.options);\n this.options.interpolation.format = s.formatter.format.bind(s.formatter);\n }\n s.interpolator = new Interpolator(this.options);\n s.utils = {\n hasLoadedNamespace: this.hasLoadedNamespace.bind(this)\n };\n s.backendConnector = new Connector(createClassOnDemand(this.modules.backend), s.resourceStore, s, this.options);\n s.backendConnector.on('*', function (event) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n _this2.emit.apply(_this2, [event].concat(args));\n });\n if (this.modules.languageDetector) {\n s.languageDetector = createClassOnDemand(this.modules.languageDetector);\n if (s.languageDetector.init) s.languageDetector.init(s, this.options.detection, this.options);\n }\n if (this.modules.i18nFormat) {\n s.i18nFormat = createClassOnDemand(this.modules.i18nFormat);\n if (s.i18nFormat.init) s.i18nFormat.init(this);\n }\n this.translator = new Translator(this.services, this.options);\n this.translator.on('*', function (event) {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n _this2.emit.apply(_this2, [event].concat(args));\n });\n this.modules.external.forEach(function (m) {\n if (m.init) m.init(_this2);\n });\n }\n this.format = this.options.interpolation.format;\n if (!callback) callback = noop;\n if (this.options.fallbackLng && !this.services.languageDetector && !this.options.lng) {\n var codes = this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);\n if (codes.length > 0 && codes[0] !== 'dev') this.options.lng = codes[0];\n }\n if (!this.services.languageDetector && !this.options.lng) {\n this.logger.warn('init: no languageDetector is used and no lng is defined');\n }\n var storeApi = ['getResource', 'hasResourceBundle', 'getResourceBundle', 'getDataByLanguage'];\n storeApi.forEach(function (fcName) {\n _this2[fcName] = function () {\n var _this2$store;\n return (_this2$store = _this2.store)[fcName].apply(_this2$store, arguments);\n };\n });\n var storeApiChained = ['addResource', 'addResources', 'addResourceBundle', 'removeResourceBundle'];\n storeApiChained.forEach(function (fcName) {\n _this2[fcName] = function () {\n var _this2$store2;\n (_this2$store2 = _this2.store)[fcName].apply(_this2$store2, arguments);\n return _this2;\n };\n });\n var deferred = defer();\n var load = function load() {\n var finish = function finish(err, t) {\n if (_this2.isInitialized && !_this2.initializedStoreOnce) _this2.logger.warn('init: i18next is already initialized. You should call init just once!');\n _this2.isInitialized = true;\n if (!_this2.options.isClone) _this2.logger.log('initialized', _this2.options);\n _this2.emit('initialized', _this2.options);\n deferred.resolve(t);\n callback(err, t);\n };\n if (_this2.languages && _this2.options.compatibilityAPI !== 'v1' && !_this2.isInitialized) return finish(null, _this2.t.bind(_this2));\n _this2.changeLanguage(_this2.options.lng, finish);\n };\n if (this.options.resources || !this.options.initImmediate) {\n load();\n } else {\n setTimeout(load, 0);\n }\n return deferred;\n }\n }, {\n key: \"loadResources\",\n value: function loadResources(language) {\n var _this3 = this;\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n var usedCallback = callback;\n var usedLng = typeof language === 'string' ? language : this.language;\n if (typeof language === 'function') usedCallback = language;\n if (!this.options.resources || this.options.partialBundledLanguages) {\n if (usedLng && usedLng.toLowerCase() === 'cimode') return usedCallback();\n var toLoad = [];\n var append = function append(lng) {\n if (!lng) return;\n var lngs = _this3.services.languageUtils.toResolveHierarchy(lng);\n lngs.forEach(function (l) {\n if (toLoad.indexOf(l) < 0) toLoad.push(l);\n });\n };\n if (!usedLng) {\n var fallbacks = this.services.languageUtils.getFallbackCodes(this.options.fallbackLng);\n fallbacks.forEach(function (l) {\n return append(l);\n });\n } else {\n append(usedLng);\n }\n if (this.options.preload) {\n this.options.preload.forEach(function (l) {\n return append(l);\n });\n }\n this.services.backendConnector.load(toLoad, this.options.ns, function (e) {\n if (!e && !_this3.resolvedLanguage && _this3.language) _this3.setResolvedLanguage(_this3.language);\n usedCallback(e);\n });\n } else {\n usedCallback(null);\n }\n }\n }, {\n key: \"reloadResources\",\n value: function reloadResources(lngs, ns, callback) {\n var deferred = defer();\n if (!lngs) lngs = this.languages;\n if (!ns) ns = this.options.ns;\n if (!callback) callback = noop;\n this.services.backendConnector.reload(lngs, ns, function (err) {\n deferred.resolve();\n callback(err);\n });\n return deferred;\n }\n }, {\n key: \"use\",\n value: function use(module) {\n if (!module) throw new Error('You are passing an undefined module! Please check the object you are passing to i18next.use()');\n if (!module.type) throw new Error('You are passing a wrong module! Please check the object you are passing to i18next.use()');\n if (module.type === 'backend') {\n this.modules.backend = module;\n }\n if (module.type === 'logger' || module.log && module.warn && module.error) {\n this.modules.logger = module;\n }\n if (module.type === 'languageDetector') {\n this.modules.languageDetector = module;\n }\n if (module.type === 'i18nFormat') {\n this.modules.i18nFormat = module;\n }\n if (module.type === 'postProcessor') {\n postProcessor.addPostProcessor(module);\n }\n if (module.type === 'formatter') {\n this.modules.formatter = module;\n }\n if (module.type === '3rdParty') {\n this.modules.external.push(module);\n }\n return this;\n }\n }, {\n key: \"setResolvedLanguage\",\n value: function setResolvedLanguage(l) {\n if (!l || !this.languages) return;\n if (['cimode', 'dev'].indexOf(l) > -1) return;\n for (var li = 0; li < this.languages.length; li++) {\n var lngInLngs = this.languages[li];\n if (['cimode', 'dev'].indexOf(lngInLngs) > -1) continue;\n if (this.store.hasLanguageSomeTranslations(lngInLngs)) {\n this.resolvedLanguage = lngInLngs;\n break;\n }\n }\n }\n }, {\n key: \"changeLanguage\",\n value: function changeLanguage(lng, callback) {\n var _this4 = this;\n this.isLanguageChangingTo = lng;\n var deferred = defer();\n this.emit('languageChanging', lng);\n var setLngProps = function setLngProps(l) {\n _this4.language = l;\n _this4.languages = _this4.services.languageUtils.toResolveHierarchy(l);\n _this4.resolvedLanguage = undefined;\n _this4.setResolvedLanguage(l);\n };\n var done = function done(err, l) {\n if (l) {\n setLngProps(l);\n _this4.translator.changeLanguage(l);\n _this4.isLanguageChangingTo = undefined;\n _this4.emit('languageChanged', l);\n _this4.logger.log('languageChanged', l);\n } else {\n _this4.isLanguageChangingTo = undefined;\n }\n deferred.resolve(function () {\n return _this4.t.apply(_this4, arguments);\n });\n if (callback) callback(err, function () {\n return _this4.t.apply(_this4, arguments);\n });\n };\n var setLng = function setLng(lngs) {\n if (!lng && !lngs && _this4.services.languageDetector) lngs = [];\n var l = typeof lngs === 'string' ? lngs : _this4.services.languageUtils.getBestMatchFromCodes(lngs);\n if (l) {\n if (!_this4.language) {\n setLngProps(l);\n }\n if (!_this4.translator.language) _this4.translator.changeLanguage(l);\n if (_this4.services.languageDetector && _this4.services.languageDetector.cacheUserLanguage) _this4.services.languageDetector.cacheUserLanguage(l);\n }\n _this4.loadResources(l, function (err) {\n done(err, l);\n });\n };\n if (!lng && this.services.languageDetector && !this.services.languageDetector.async) {\n setLng(this.services.languageDetector.detect());\n } else if (!lng && this.services.languageDetector && this.services.languageDetector.async) {\n if (this.services.languageDetector.detect.length === 0) {\n this.services.languageDetector.detect().then(setLng);\n } else {\n this.services.languageDetector.detect(setLng);\n }\n } else {\n setLng(lng);\n }\n return deferred;\n }\n }, {\n key: \"getFixedT\",\n value: function getFixedT(lng, ns, keyPrefix) {\n var _this5 = this;\n var fixedT = function fixedT(key, opts) {\n var options;\n if (_typeof__default[\"default\"](opts) !== 'object') {\n for (var _len3 = arguments.length, rest = new Array(_len3 > 2 ? _len3 - 2 : 0), _key3 = 2; _key3 < _len3; _key3++) {\n rest[_key3 - 2] = arguments[_key3];\n }\n options = _this5.options.overloadTranslationOptionHandler([key, opts].concat(rest));\n } else {\n options = _objectSpread({}, opts);\n }\n options.lng = options.lng || fixedT.lng;\n options.lngs = options.lngs || fixedT.lngs;\n options.ns = options.ns || fixedT.ns;\n options.keyPrefix = options.keyPrefix || keyPrefix || fixedT.keyPrefix;\n var keySeparator = _this5.options.keySeparator || '.';\n var resultKey = options.keyPrefix ? \"\".concat(options.keyPrefix).concat(keySeparator).concat(key) : key;\n return _this5.t(resultKey, options);\n };\n if (typeof lng === 'string') {\n fixedT.lng = lng;\n } else {\n fixedT.lngs = lng;\n }\n fixedT.ns = ns;\n fixedT.keyPrefix = keyPrefix;\n return fixedT;\n }\n }, {\n key: \"t\",\n value: function t() {\n var _this$translator;\n return this.translator && (_this$translator = this.translator).translate.apply(_this$translator, arguments);\n }\n }, {\n key: \"exists\",\n value: function exists() {\n var _this$translator2;\n return this.translator && (_this$translator2 = this.translator).exists.apply(_this$translator2, arguments);\n }\n }, {\n key: \"setDefaultNamespace\",\n value: function setDefaultNamespace(ns) {\n this.options.defaultNS = ns;\n }\n }, {\n key: \"hasLoadedNamespace\",\n value: function hasLoadedNamespace(ns) {\n var _this6 = this;\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n if (!this.isInitialized) {\n this.logger.warn('hasLoadedNamespace: i18next was not initialized', this.languages);\n return false;\n }\n if (!this.languages || !this.languages.length) {\n this.logger.warn('hasLoadedNamespace: i18n.languages were undefined or empty', this.languages);\n return false;\n }\n var lng = this.resolvedLanguage || this.languages[0];\n var fallbackLng = this.options ? this.options.fallbackLng : false;\n var lastLng = this.languages[this.languages.length - 1];\n if (lng.toLowerCase() === 'cimode') return true;\n var loadNotPending = function loadNotPending(l, n) {\n var loadState = _this6.services.backendConnector.state[\"\".concat(l, \"|\").concat(n)];\n return loadState === -1 || loadState === 2;\n };\n if (options.precheck) {\n var preResult = options.precheck(this, loadNotPending);\n if (preResult !== undefined) return preResult;\n }\n if (this.hasResourceBundle(lng, ns)) return true;\n if (!this.services.backendConnector.backend || this.options.resources && !this.options.partialBundledLanguages) return true;\n if (loadNotPending(lng, ns) && (!fallbackLng || loadNotPending(lastLng, ns))) return true;\n return false;\n }\n }, {\n key: \"loadNamespaces\",\n value: function loadNamespaces(ns, callback) {\n var _this7 = this;\n var deferred = defer();\n if (!this.options.ns) {\n callback && callback();\n return Promise.resolve();\n }\n if (typeof ns === 'string') ns = [ns];\n ns.forEach(function (n) {\n if (_this7.options.ns.indexOf(n) < 0) _this7.options.ns.push(n);\n });\n this.loadResources(function (err) {\n deferred.resolve();\n if (callback) callback(err);\n });\n return deferred;\n }\n }, {\n key: \"loadLanguages\",\n value: function loadLanguages(lngs, callback) {\n var deferred = defer();\n if (typeof lngs === 'string') lngs = [lngs];\n var preloaded = this.options.preload || [];\n var newLngs = lngs.filter(function (lng) {\n return preloaded.indexOf(lng) < 0;\n });\n if (!newLngs.length) {\n if (callback) callback();\n return Promise.resolve();\n }\n this.options.preload = preloaded.concat(newLngs);\n this.loadResources(function (err) {\n deferred.resolve();\n if (callback) callback(err);\n });\n return deferred;\n }\n }, {\n key: \"dir\",\n value: function dir(lng) {\n if (!lng) lng = this.resolvedLanguage || (this.languages && this.languages.length > 0 ? this.languages[0] : this.language);\n if (!lng) return 'rtl';\n var rtlLngs = ['ar', 'shu', 'sqr', 'ssh', 'xaa', 'yhd', 'yud', 'aao', 'abh', 'abv', 'acm', 'acq', 'acw', 'acx', 'acy', 'adf', 'ads', 'aeb', 'aec', 'afb', 'ajp', 'apc', 'apd', 'arb', 'arq', 'ars', 'ary', 'arz', 'auz', 'avl', 'ayh', 'ayl', 'ayn', 'ayp', 'bbz', 'pga', 'he', 'iw', 'ps', 'pbt', 'pbu', 'pst', 'prp', 'prd', 'ug', 'ur', 'ydd', 'yds', 'yih', 'ji', 'yi', 'hbo', 'men', 'xmn', 'fa', 'jpr', 'peo', 'pes', 'prs', 'dv', 'sam', 'ckb'];\n var languageUtils = this.services && this.services.languageUtils || new LanguageUtil(get());\n return rtlLngs.indexOf(languageUtils.getLanguagePartFromCode(lng)) > -1 || lng.toLowerCase().indexOf('-arab') > 1 ? 'rtl' : 'ltr';\n }\n }, {\n key: \"cloneInstance\",\n value: function cloneInstance() {\n var _this8 = this;\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n var mergedOptions = _objectSpread(_objectSpread(_objectSpread({}, this.options), options), {\n isClone: true\n });\n var clone = new I18n(mergedOptions);\n if (options.debug !== undefined || options.prefix !== undefined) {\n clone.logger = clone.logger.clone(options);\n }\n var membersToCopy = ['store', 'services', 'language'];\n membersToCopy.forEach(function (m) {\n clone[m] = _this8[m];\n });\n clone.services = _objectSpread({}, this.services);\n clone.services.utils = {\n hasLoadedNamespace: clone.hasLoadedNamespace.bind(clone)\n };\n clone.translator = new Translator(clone.services, clone.options);\n clone.translator.on('*', function (event) {\n for (var _len4 = arguments.length, args = new Array(_len4 > 1 ? _len4 - 1 : 0), _key4 = 1; _key4 < _len4; _key4++) {\n args[_key4 - 1] = arguments[_key4];\n }\n clone.emit.apply(clone, [event].concat(args));\n });\n clone.init(mergedOptions, callback);\n clone.translator.options = clone.options;\n clone.translator.backendConnector.services.utils = {\n hasLoadedNamespace: clone.hasLoadedNamespace.bind(clone)\n };\n return clone;\n }\n }, {\n key: \"toJSON\",\n value: function toJSON() {\n return {\n options: this.options,\n store: this.store,\n language: this.language,\n languages: this.languages,\n resolvedLanguage: this.resolvedLanguage\n };\n }\n }]);\n return I18n;\n}(EventEmitter);\n_defineProperty__default[\"default\"](I18n, \"createInstance\", function () {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var callback = arguments.length > 1 ? arguments[1] : undefined;\n return new I18n(options, callback);\n});\nvar instance = I18n.createInstance();\ninstance.createInstance = I18n.createInstance;\n\nmodule.exports = instance;\n","/*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> */\nexports.read = function (buffer, offset, isLE, mLen, nBytes) {\n var e, m\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var nBits = -7\n var i = isLE ? (nBytes - 1) : 0\n var d = isLE ? -1 : 1\n var s = buffer[offset + i]\n\n i += d\n\n e = s & ((1 << (-nBits)) - 1)\n s >>= (-nBits)\n nBits += eLen\n for (; nBits > 0; e = (e * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n m = e & ((1 << (-nBits)) - 1)\n e >>= (-nBits)\n nBits += mLen\n for (; nBits > 0; m = (m * 256) + buffer[offset + i], i += d, nBits -= 8) {}\n\n if (e === 0) {\n e = 1 - eBias\n } else if (e === eMax) {\n return m ? NaN : ((s ? -1 : 1) * Infinity)\n } else {\n m = m + Math.pow(2, mLen)\n e = e - eBias\n }\n return (s ? -1 : 1) * m * Math.pow(2, e - mLen)\n}\n\nexports.write = function (buffer, value, offset, isLE, mLen, nBytes) {\n var e, m, c\n var eLen = (nBytes * 8) - mLen - 1\n var eMax = (1 << eLen) - 1\n var eBias = eMax >> 1\n var rt = (mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0)\n var i = isLE ? 0 : (nBytes - 1)\n var d = isLE ? 1 : -1\n var s = value < 0 || (value === 0 && 1 / value < 0) ? 1 : 0\n\n value = Math.abs(value)\n\n if (isNaN(value) || value === Infinity) {\n m = isNaN(value) ? 1 : 0\n e = eMax\n } else {\n e = Math.floor(Math.log(value) / Math.LN2)\n if (value * (c = Math.pow(2, -e)) < 1) {\n e--\n c *= 2\n }\n if (e + eBias >= 1) {\n value += rt / c\n } else {\n value += rt * Math.pow(2, 1 - eBias)\n }\n if (value * c >= 2) {\n e++\n c /= 2\n }\n\n if (e + eBias >= eMax) {\n m = 0\n e = eMax\n } else if (e + eBias >= 1) {\n m = ((value * c) - 1) * Math.pow(2, mLen)\n e = e + eBias\n } else {\n m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen)\n e = 0\n }\n }\n\n for (; mLen >= 8; buffer[offset + i] = m & 0xff, i += d, m /= 256, mLen -= 8) {}\n\n e = (e << mLen) | m\n eLen += mLen\n for (; eLen > 0; buffer[offset + i] = e & 0xff, i += d, e /= 256, eLen -= 8) {}\n\n buffer[offset + i - d] |= s * 128\n}\n","module.exports = [\n {\"name\":\"Abkhaz\", \"local\":\"Аҧсуа\", \"1\":\"ab\", \"2\":\"abk\", \"2T\":\"abk\", \"2B\":\"abk\", \"3\":\"abk\"},\n {\"name\":\"Afar\", \"local\":\"Afaraf\", \"1\":\"aa\", \"2\":\"aar\", \"2T\":\"aar\", \"2B\":\"aar\", \"3\":\"aar\"},\n {\"name\":\"Afrikaans\", \"local\":\"Afrikaans\", \"1\":\"af\", \"2\":\"afr\", \"2T\":\"afr\", \"2B\":\"afr\", \"3\":\"afr\"},\n {\"name\":\"Akan\", \"local\":\"Akan\", \"1\":\"ak\", \"2\":\"aka\", \"2T\":\"aka\", \"2B\":\"aka\", \"3\":\"aka\"},\n {\"name\":\"Albanian\", \"local\":\"Shqip\", \"1\":\"sq\", \"2\":\"sqi\", \"2T\":\"sqi\", \"2B\":\"alb\", \"3\":\"sqi\"},\n {\"name\":\"Amharic\", \"local\":\"አማርኛ\", \"1\":\"am\", \"2\":\"amh\", \"2T\":\"amh\", \"2B\":\"amh\", \"3\":\"amh\"},\n {\"name\":\"Arabic\", \"local\":\"العربية\", \"1\":\"ar\", \"2\":\"ara\", \"2T\":\"ara\", \"2B\":\"ara\", \"3\":\"ara\"},\n {\"name\":\"Aragonese\", \"local\":\"Aragonés\", \"1\":\"an\", \"2\":\"arg\", \"2T\":\"arg\", \"2B\":\"arg\", \"3\":\"arg\"},\n {\"name\":\"Armenian\", \"local\":\"Հայերեն\", \"1\":\"hy\", \"2\":\"hye\", \"2T\":\"hye\", \"2B\":\"arm\", \"3\":\"hye\"},\n {\"name\":\"Assamese\", \"local\":\"অসমীয়া\", \"1\":\"as\", \"2\":\"asm\", \"2T\":\"asm\", \"2B\":\"asm\", \"3\":\"asm\"},\n {\"name\":\"Avaric\", \"local\":\"Авар\", \"1\":\"av\", \"2\":\"ava\", \"2T\":\"ava\", \"2B\":\"ava\", \"3\":\"ava\"},\n {\"name\":\"Avestan\", \"local\":\"avesta\", \"1\":\"ae\", \"2\":\"ave\", \"2T\":\"ave\", \"2B\":\"ave\", \"3\":\"ave\"},\n {\"name\":\"Aymara\", \"local\":\"Aymar\", \"1\":\"ay\", \"2\":\"aym\", \"2T\":\"aym\", \"2B\":\"aym\", \"3\":\"aym\"},\n {\"name\":\"Azerbaijani\", \"local\":\"Azərbaycanca\", \"1\":\"az\", \"2\":\"aze\", \"2T\":\"aze\", \"2B\":\"aze\", \"3\":\"aze\"},\n {\"name\":\"Bambara\", \"local\":\"Bamanankan\", \"1\":\"bm\", \"2\":\"bam\", \"2T\":\"bam\", \"2B\":\"bam\", \"3\":\"bam\"},\n {\"name\":\"Bashkir\", \"local\":\"Башҡортса\", \"1\":\"ba\", \"2\":\"bak\", \"2T\":\"bak\", \"2B\":\"bak\", \"3\":\"bak\"},\n {\"name\":\"Basque\", \"local\":\"Euskara\", \"1\":\"eu\", \"2\":\"eus\", \"2T\":\"eus\", \"2B\":\"baq\", \"3\":\"eus\"},\n {\"name\":\"Belarusian\", \"local\":\"Беларуская\", \"1\":\"be\", \"2\":\"bel\", \"2T\":\"bel\", \"2B\":\"bel\", \"3\":\"bel\"},\n {\"name\":\"Bengali\", \"local\":\"বাংলা\", \"1\":\"bn\", \"2\":\"ben\", \"2T\":\"ben\", \"2B\":\"ben\", \"3\":\"ben\"},\n {\"name\":\"Bihari\", \"local\":\"भोजपुरी\", \"1\":\"bh\", \"2\":\"bih\", \"2T\":\"bih\", \"2B\":\"bih\", \"3\":\"bih\"},\n {\"name\":\"Bislama\", \"local\":\"Bislama\", \"1\":\"bi\", \"2\":\"bis\", \"2T\":\"bis\", \"2B\":\"bis\", \"3\":\"bis\"},\n {\"name\":\"Bosnian\", \"local\":\"Bosanski\", \"1\":\"bs\", \"2\":\"bos\", \"2T\":\"bos\", \"2B\":\"bos\", \"3\":\"bos\"},\n {\"name\":\"Breton\", \"local\":\"Brezhoneg\", \"1\":\"br\", \"2\":\"bre\", \"2T\":\"bre\", \"2B\":\"bre\", \"3\":\"bre\"},\n {\"name\":\"Bulgarian\", \"local\":\"Български\", \"1\":\"bg\", \"2\":\"bul\", \"2T\":\"bul\", \"2B\":\"bul\", \"3\":\"bul\"},\n {\"name\":\"Burmese\", \"local\":\"မြန်မာဘာသာ\", \"1\":\"my\", \"2\":\"mya\", \"2T\":\"mya\", \"2B\":\"bur\", \"3\":\"mya\"},\n {\"name\":\"Catalan\", \"local\":\"Català\", \"1\":\"ca\", \"2\":\"cat\", \"2T\":\"cat\", \"2B\":\"cat\", \"3\":\"cat\"},\n {\"name\":\"Chamorro\", \"local\":\"Chamoru\", \"1\":\"ch\", \"2\":\"cha\", \"2T\":\"cha\", \"2B\":\"cha\", \"3\":\"cha\"},\n {\"name\":\"Chechen\", \"local\":\"Нохчийн\", \"1\":\"ce\", \"2\":\"che\", \"2T\":\"che\", \"2B\":\"che\", \"3\":\"che\"},\n {\"name\":\"Chichewa\", \"local\":\"Chichewa\", \"1\":\"ny\", \"2\":\"nya\", \"2T\":\"nya\", \"2B\":\"nya\", \"3\":\"nya\"},\n {\"name\":\"Chinese\", \"local\":\"中文\", \"1\":\"zh\", \"2\":\"zho\", \"2T\":\"zho\", \"2B\":\"chi\", \"3\":\"zho\"},\n {\"name\":\"Chuvash\", \"local\":\"Чӑвашла\", \"1\":\"cv\", \"2\":\"chv\", \"2T\":\"chv\", \"2B\":\"chv\", \"3\":\"chv\"},\n {\"name\":\"Cornish\", \"local\":\"Kernewek\", \"1\":\"kw\", \"2\":\"cor\", \"2T\":\"cor\", \"2B\":\"cor\", \"3\":\"cor\"},\n {\"name\":\"Corsican\", \"local\":\"Corsu\", \"1\":\"co\", \"2\":\"cos\", \"2T\":\"cos\", \"2B\":\"cos\", \"3\":\"cos\"},\n {\"name\":\"Cree\", \"local\":\"ᓀᐦᐃᔭᐍᐏᐣ\", \"1\":\"cr\", \"2\":\"cre\", \"2T\":\"cre\", \"2B\":\"cre\", \"3\":\"cre\"},\n {\"name\":\"Croatian\", \"local\":\"Hrvatski\", \"1\":\"hr\", \"2\":\"hrv\", \"2T\":\"hrv\", \"2B\":\"hrv\", \"3\":\"hrv\"},\n {\"name\":\"Czech\", \"local\":\"Čeština\", \"1\":\"cs\", \"2\":\"ces\", \"2T\":\"ces\", \"2B\":\"cze\", \"3\":\"ces\"},\n {\"name\":\"Danish\", \"local\":\"Dansk\", \"1\":\"da\", \"2\":\"dan\", \"2T\":\"dan\", \"2B\":\"dan\", \"3\":\"dan\"},\n {\"name\":\"Divehi\", \"local\":\"Divehi\", \"1\":\"dv\", \"2\":\"div\", \"2T\":\"div\", \"2B\":\"div\", \"3\":\"div\"},\n {\"name\":\"Dutch\", \"local\":\"Nederlands\", \"1\":\"nl\", \"2\":\"nld\", \"2T\":\"nld\", \"2B\":\"dut\", \"3\":\"nld\"},\n {\"name\":\"Dzongkha\", \"local\":\"རྫོང་ཁ\", \"1\":\"dz\", \"2\":\"dzo\", \"2T\":\"dzo\", \"2B\":\"dzo\", \"3\":\"dzo\"},\n {\"name\":\"English\", \"local\":\"English\", \"1\":\"en\", \"2\":\"eng\", \"2T\":\"eng\", \"2B\":\"eng\", \"3\":\"eng\"},\n {\"name\":\"Esperanto\", \"local\":\"Esperanto\", \"1\":\"eo\", \"2\":\"epo\", \"2T\":\"epo\", \"2B\":\"epo\", \"3\":\"epo\"},\n {\"name\":\"Estonian\", \"local\":\"Eesti\", \"1\":\"et\", \"2\":\"est\", \"2T\":\"est\", \"2B\":\"est\", \"3\":\"est\"},\n {\"name\":\"Ewe\", \"local\":\"Eʋegbe\", \"1\":\"ee\", \"2\":\"ewe\", \"2T\":\"ewe\", \"2B\":\"ewe\", \"3\":\"ewe\"},\n {\"name\":\"Faroese\", \"local\":\"Føroyskt\", \"1\":\"fo\", \"2\":\"fao\", \"2T\":\"fao\", \"2B\":\"fao\", \"3\":\"fao\"},\n {\"name\":\"Fijian\", \"local\":\"Na Vosa Vaka-Viti\", \"1\":\"fj\", \"2\":\"fij\", \"2T\":\"fij\", \"2B\":\"fij\", \"3\":\"fij\"},\n {\"name\":\"Finnish\", \"local\":\"Suomi\", \"1\":\"fi\", \"2\":\"fin\", \"2T\":\"fin\", \"2B\":\"fin\", \"3\":\"fin\"},\n {\"name\":\"French\", \"local\":\"Français\", \"1\":\"fr\", \"2\":\"fra\", \"2T\":\"fra\", \"2B\":\"fre\", \"3\":\"fra\"},\n {\"name\":\"Fula\", \"local\":\"Fulfulde\", \"1\":\"ff\", \"2\":\"ful\", \"2T\":\"ful\", \"2B\":\"ful\", \"3\":\"ful\"},\n {\"name\":\"Galician\", \"local\":\"Galego\", \"1\":\"gl\", \"2\":\"glg\", \"2T\":\"glg\", \"2B\":\"glg\", \"3\":\"glg\"},\n {\"name\":\"Georgian\", \"local\":\"ქართული\", \"1\":\"ka\", \"2\":\"kat\", \"2T\":\"kat\", \"2B\":\"geo\", \"3\":\"kat\"},\n {\"name\":\"German\", \"local\":\"Deutsch\", \"1\":\"de\", \"2\":\"deu\", \"2T\":\"deu\", \"2B\":\"ger\", \"3\":\"deu\"},\n {\"name\":\"Greek\", \"local\":\"Ελληνικά\", \"1\":\"el\", \"2\":\"ell\", \"2T\":\"ell\", \"2B\":\"gre\", \"3\":\"ell\"},\n {\"name\":\"Guaraní\", \"local\":\"Avañe'ẽ\", \"1\":\"gn\", \"2\":\"grn\", \"2T\":\"grn\", \"2B\":\"grn\", \"3\":\"grn\"},\n {\"name\":\"Gujarati\", \"local\":\"ગુજરાતી\", \"1\":\"gu\", \"2\":\"guj\", \"2T\":\"guj\", \"2B\":\"guj\", \"3\":\"guj\"},\n {\"name\":\"Haitian\", \"local\":\"Kreyòl Ayisyen\", \"1\":\"ht\", \"2\":\"hat\", \"2T\":\"hat\", \"2B\":\"hat\", \"3\":\"hat\"},\n {\"name\":\"Hausa\", \"local\":\"هَوُسَ\", \"1\":\"ha\", \"2\":\"hau\", \"2T\":\"hau\", \"2B\":\"hau\", \"3\":\"hau\"},\n {\"name\":\"Hebrew\", \"local\":\"עברית\", \"1\":\"he\", \"2\":\"heb\", \"2T\":\"heb\", \"2B\":\"heb\", \"3\":\"heb\"},\n {\"name\":\"Herero\", \"local\":\"Otjiherero\", \"1\":\"hz\", \"2\":\"her\", \"2T\":\"her\", \"2B\":\"her\", \"3\":\"her\"},\n {\"name\":\"Hindi\", \"local\":\"हिन्दी\", \"1\":\"hi\", \"2\":\"hin\", \"2T\":\"hin\", \"2B\":\"hin\", \"3\":\"hin\"},\n {\"name\":\"Hiri Motu\", \"local\":\"Hiri Motu\", \"1\":\"ho\", \"2\":\"hmo\", \"2T\":\"hmo\", \"2B\":\"hmo\", \"3\":\"hmo\"},\n {\"name\":\"Hungarian\", \"local\":\"Magyar\", \"1\":\"hu\", \"2\":\"hun\", \"2T\":\"hun\", \"2B\":\"hun\", \"3\":\"hun\"},\n {\"name\":\"Interlingua\", \"local\":\"Interlingua\", \"1\":\"ia\", \"2\":\"ina\", \"2T\":\"ina\", \"2B\":\"ina\", \"3\":\"ina\"},\n {\"name\":\"Indonesian\", \"local\":\"Bahasa Indonesia\", \"1\":\"id\", \"2\":\"ind\", \"2T\":\"ind\", \"2B\":\"ind\", \"3\":\"ind\"},\n {\"name\":\"Interlingue\", \"local\":\"Interlingue\", \"1\":\"ie\", \"2\":\"ile\", \"2T\":\"ile\", \"2B\":\"ile\", \"3\":\"ile\"},\n {\"name\":\"Irish\", \"local\":\"Gaeilge\", \"1\":\"ga\", \"2\":\"gle\", \"2T\":\"gle\", \"2B\":\"gle\", \"3\":\"gle\"},\n {\"name\":\"Igbo\", \"local\":\"Igbo\", \"1\":\"ig\", \"2\":\"ibo\", \"2T\":\"ibo\", \"2B\":\"ibo\", \"3\":\"ibo\"},\n {\"name\":\"Inupiaq\", \"local\":\"Iñupiak\", \"1\":\"ik\", \"2\":\"ipk\", \"2T\":\"ipk\", \"2B\":\"ipk\", \"3\":\"ipk\"},\n {\"name\":\"Ido\", \"local\":\"Ido\", \"1\":\"io\", \"2\":\"ido\", \"2T\":\"ido\", \"2B\":\"ido\", \"3\":\"ido\"},\n {\"name\":\"Icelandic\", \"local\":\"Íslenska\", \"1\":\"is\", \"2\":\"isl\", \"2T\":\"isl\", \"2B\":\"ice\", \"3\":\"isl\"},\n {\"name\":\"Italian\", \"local\":\"Italiano\", \"1\":\"it\", \"2\":\"ita\", \"2T\":\"ita\", \"2B\":\"ita\", \"3\":\"ita\"},\n {\"name\":\"Inuktitut\", \"local\":\"ᐃᓄᒃᑎᑐᑦ\", \"1\":\"iu\", \"2\":\"iku\", \"2T\":\"iku\", \"2B\":\"iku\", \"3\":\"iku\"},\n {\"name\":\"Japanese\", \"local\":\"日本語\", \"1\":\"ja\", \"2\":\"jpn\", \"2T\":\"jpn\", \"2B\":\"jpn\", \"3\":\"jpn\"},\n {\"name\":\"Javanese\", \"local\":\"Basa Jawa\", \"1\":\"jv\", \"2\":\"jav\", \"2T\":\"jav\", \"2B\":\"jav\", \"3\":\"jav\"},\n {\"name\":\"Kalaallisut\", \"local\":\"Kalaallisut\", \"1\":\"kl\", \"2\":\"kal\", \"2T\":\"kal\", \"2B\":\"kal\", \"3\":\"kal\"},\n {\"name\":\"Kannada\", \"local\":\"ಕನ್ನಡ\", \"1\":\"kn\", \"2\":\"kan\", \"2T\":\"kan\", \"2B\":\"kan\", \"3\":\"kan\"},\n {\"name\":\"Kanuri\", \"local\":\"Kanuri\", \"1\":\"kr\", \"2\":\"kau\", \"2T\":\"kau\", \"2B\":\"kau\", \"3\":\"kau\"},\n {\"name\":\"Kashmiri\", \"local\":\"كشميري\", \"1\":\"ks\", \"2\":\"kas\", \"2T\":\"kas\", \"2B\":\"kas\", \"3\":\"kas\"},\n {\"name\":\"Kazakh\", \"local\":\"Қазақша\", \"1\":\"kk\", \"2\":\"kaz\", \"2T\":\"kaz\", \"2B\":\"kaz\", \"3\":\"kaz\"},\n {\"name\":\"Khmer\", \"local\":\"ភាសាខ្មែរ\", \"1\":\"km\", \"2\":\"khm\", \"2T\":\"khm\", \"2B\":\"khm\", \"3\":\"khm\"},\n {\"name\":\"Kikuyu\", \"local\":\"Gĩkũyũ\", \"1\":\"ki\", \"2\":\"kik\", \"2T\":\"kik\", \"2B\":\"kik\", \"3\":\"kik\"},\n {\"name\":\"Kinyarwanda\", \"local\":\"Kinyarwanda\", \"1\":\"rw\", \"2\":\"kin\", \"2T\":\"kin\", \"2B\":\"kin\", \"3\":\"kin\"},\n {\"name\":\"Kyrgyz\", \"local\":\"Кыргызча\", \"1\":\"ky\", \"2\":\"kir\", \"2T\":\"kir\", \"2B\":\"kir\", \"3\":\"kir\"},\n {\"name\":\"Komi\", \"local\":\"Коми\", \"1\":\"kv\", \"2\":\"kom\", \"2T\":\"kom\", \"2B\":\"kom\", \"3\":\"kom\"},\n {\"name\":\"Kongo\", \"local\":\"Kongo\", \"1\":\"kg\", \"2\":\"kon\", \"2T\":\"kon\", \"2B\":\"kon\", \"3\":\"kon\"},\n {\"name\":\"Korean\", \"local\":\"한국어\", \"1\":\"ko\", \"2\":\"kor\", \"2T\":\"kor\", \"2B\":\"kor\", \"3\":\"kor\"},\n {\"name\":\"Kurdish\", \"local\":\"Kurdî\", \"1\":\"ku\", \"2\":\"kur\", \"2T\":\"kur\", \"2B\":\"kur\", \"3\":\"kur\"},\n {\"name\":\"Kwanyama\", \"local\":\"Kuanyama\", \"1\":\"kj\", \"2\":\"kua\", \"2T\":\"kua\", \"2B\":\"kua\", \"3\":\"kua\"},\n {\"name\":\"Latin\", \"local\":\"Latina\", \"1\":\"la\", \"2\":\"lat\", \"2T\":\"lat\", \"2B\":\"lat\", \"3\":\"lat\"},\n {\"name\":\"Luxembourgish\", \"local\":\"Lëtzebuergesch\", \"1\":\"lb\", \"2\":\"ltz\", \"2T\":\"ltz\", \"2B\":\"ltz\", \"3\":\"ltz\"},\n {\"name\":\"Ganda\", \"local\":\"Luganda\", \"1\":\"lg\", \"2\":\"lug\", \"2T\":\"lug\", \"2B\":\"lug\", \"3\":\"lug\"},\n {\"name\":\"Limburgish\", \"local\":\"Limburgs\", \"1\":\"li\", \"2\":\"lim\", \"2T\":\"lim\", \"2B\":\"lim\", \"3\":\"lim\"},\n {\"name\":\"Lingala\", \"local\":\"Lingála\", \"1\":\"ln\", \"2\":\"lin\", \"2T\":\"lin\", \"2B\":\"lin\", \"3\":\"lin\"},\n {\"name\":\"Lao\", \"local\":\"ພາສາລາວ\", \"1\":\"lo\", \"2\":\"lao\", \"2T\":\"lao\", \"2B\":\"lao\", \"3\":\"lao\"},\n {\"name\":\"Lithuanian\", \"local\":\"Lietuvių\", \"1\":\"lt\", \"2\":\"lit\", \"2T\":\"lit\", \"2B\":\"lit\", \"3\":\"lit\"},\n {\"name\":\"Luba-Katanga\", \"local\":\"Tshiluba\", \"1\":\"lu\", \"2\":\"lub\", \"2T\":\"lub\", \"2B\":\"lub\", \"3\":\"lub\"},\n {\"name\":\"Latvian\", \"local\":\"Latviešu\", \"1\":\"lv\", \"2\":\"lav\", \"2T\":\"lav\", \"2B\":\"lav\", \"3\":\"lav\"},\n {\"name\":\"Manx\", \"local\":\"Gaelg\", \"1\":\"gv\", \"2\":\"glv\", \"2T\":\"glv\", \"2B\":\"glv\", \"3\":\"glv\"},\n {\"name\":\"Macedonian\", \"local\":\"Македонски\", \"1\":\"mk\", \"2\":\"mkd\", \"2T\":\"mkd\", \"2B\":\"mac\", \"3\":\"mkd\"},\n {\"name\":\"Malagasy\", \"local\":\"Malagasy\", \"1\":\"mg\", \"2\":\"mlg\", \"2T\":\"mlg\", \"2B\":\"mlg\", \"3\":\"mlg\"},\n {\"name\":\"Malay\", \"local\":\"Bahasa Melayu\", \"1\":\"ms\", \"2\":\"msa\", \"2T\":\"msa\", \"2B\":\"may\", \"3\":\"msa\"},\n {\"name\":\"Malayalam\", \"local\":\"മലയാളം\", \"1\":\"ml\", \"2\":\"mal\", \"2T\":\"mal\", \"2B\":\"mal\", \"3\":\"mal\"},\n {\"name\":\"Maltese\", \"local\":\"Malti\", \"1\":\"mt\", \"2\":\"mlt\", \"2T\":\"mlt\", \"2B\":\"mlt\", \"3\":\"mlt\"},\n {\"name\":\"Māori\", \"local\":\"Māori\", \"1\":\"mi\", \"2\":\"mri\", \"2T\":\"mri\", \"2B\":\"mao\", \"3\":\"mri\"},\n {\"name\":\"Marathi\", \"local\":\"मराठी\", \"1\":\"mr\", \"2\":\"mar\", \"2T\":\"mar\", \"2B\":\"mar\", \"3\":\"mar\"},\n {\"name\":\"Marshallese\", \"local\":\"Kajin M̧ajeļ\", \"1\":\"mh\", \"2\":\"mah\", \"2T\":\"mah\", \"2B\":\"mah\", \"3\":\"mah\"},\n {\"name\":\"Mongolian\", \"local\":\"Монгол\", \"1\":\"mn\", \"2\":\"mon\", \"2T\":\"mon\", \"2B\":\"mon\", \"3\":\"mon\"},\n {\"name\":\"Nauru\", \"local\":\"Dorerin Naoero\", \"1\":\"na\", \"2\":\"nau\", \"2T\":\"nau\", \"2B\":\"nau\", \"3\":\"nau\"},\n {\"name\":\"Navajo\", \"local\":\"Diné Bizaad\", \"1\":\"nv\", \"2\":\"nav\", \"2T\":\"nav\", \"2B\":\"nav\", \"3\":\"nav\"},\n {\"name\":\"Northern Ndebele\", \"local\":\"isiNdebele\", \"1\":\"nd\", \"2\":\"nde\", \"2T\":\"nde\", \"2B\":\"nde\", \"3\":\"nde\"},\n {\"name\":\"Nepali\", \"local\":\"नेपाली\", \"1\":\"ne\", \"2\":\"nep\", \"2T\":\"nep\", \"2B\":\"nep\", \"3\":\"nep\"},\n {\"name\":\"Ndonga\", \"local\":\"Owambo\", \"1\":\"ng\", \"2\":\"ndo\", \"2T\":\"ndo\", \"2B\":\"ndo\", \"3\":\"ndo\"},\n {\"name\":\"Norwegian Bokmål\", \"local\":\"Norsk (Bokmål)\", \"1\":\"nb\", \"2\":\"nob\", \"2T\":\"nob\", \"2B\":\"nob\", \"3\":\"nob\"},\n {\"name\":\"Norwegian Nynorsk\", \"local\":\"Norsk (Nynorsk)\", \"1\":\"nn\", \"2\":\"nno\", \"2T\":\"nno\", \"2B\":\"nno\", \"3\":\"nno\"},\n {\"name\":\"Norwegian\", \"local\":\"Norsk\", \"1\":\"no\", \"2\":\"nor\", \"2T\":\"nor\", \"2B\":\"nor\", \"3\":\"nor\"},\n {\"name\":\"Nuosu\", \"local\":\"ꆈꌠ꒿ Nuosuhxop\", \"1\":\"ii\", \"2\":\"iii\", \"2T\":\"iii\", \"2B\":\"iii\", \"3\":\"iii\"},\n {\"name\":\"Southern Ndebele\", \"local\":\"isiNdebele\", \"1\":\"nr\", \"2\":\"nbl\", \"2T\":\"nbl\", \"2B\":\"nbl\", \"3\":\"nbl\"},\n {\"name\":\"Occitan\", \"local\":\"Occitan\", \"1\":\"oc\", \"2\":\"oci\", \"2T\":\"oci\", \"2B\":\"oci\", \"3\":\"oci\"},\n {\"name\":\"Ojibwe\", \"local\":\"ᐊᓂᔑᓈᐯᒧᐎᓐ\", \"1\":\"oj\", \"2\":\"oji\", \"2T\":\"oji\", \"2B\":\"oji\", \"3\":\"oji\"},\n {\"name\":\"Old Church Slavonic\", \"local\":\"Словѣ́ньскъ\", \"1\":\"cu\", \"2\":\"chu\", \"2T\":\"chu\", \"2B\":\"chu\", \"3\":\"chu\"},\n {\"name\":\"Oromo\", \"local\":\"Afaan Oromoo\", \"1\":\"om\", \"2\":\"orm\", \"2T\":\"orm\", \"2B\":\"orm\", \"3\":\"orm\"},\n {\"name\":\"Oriya\", \"local\":\"ଓଡି଼ଆ\", \"1\":\"or\", \"2\":\"ori\", \"2T\":\"ori\", \"2B\":\"ori\", \"3\":\"ori\"},\n {\"name\":\"Ossetian\", \"local\":\"Ирон æвзаг\", \"1\":\"os\", \"2\":\"oss\", \"2T\":\"oss\", \"2B\":\"oss\", \"3\":\"oss\"},\n {\"name\":\"Panjabi\", \"local\":\"ਪੰਜਾਬੀ\", \"1\":\"pa\", \"2\":\"pan\", \"2T\":\"pan\", \"2B\":\"pan\", \"3\":\"pan\"},\n {\"name\":\"Pāli\", \"local\":\"पाऴि\", \"1\":\"pi\", \"2\":\"pli\", \"2T\":\"pli\", \"2B\":\"pli\", \"3\":\"pli\"},\n {\"name\":\"Persian\", \"local\":\"فارسی\", \"1\":\"fa\", \"2\":\"fas\", \"2T\":\"fas\", \"2B\":\"per\", \"3\":\"fas\"},\n {\"name\":\"Polish\", \"local\":\"Polski\", \"1\":\"pl\", \"2\":\"pol\", \"2T\":\"pol\", \"2B\":\"pol\", \"3\":\"pol\"},\n {\"name\":\"Pashto\", \"local\":\"پښتو\", \"1\":\"ps\", \"2\":\"pus\", \"2T\":\"pus\", \"2B\":\"pus\", \"3\":\"pus\"},\n {\"name\":\"Portuguese\", \"local\":\"Português\", \"1\":\"pt\", \"2\":\"por\", \"2T\":\"por\", \"2B\":\"por\", \"3\":\"por\"},\n {\"name\":\"Quechua\", \"local\":\"Runa Simi\", \"1\":\"qu\", \"2\":\"que\", \"2T\":\"que\", \"2B\":\"que\", \"3\":\"que\"},\n {\"name\":\"Romansh\", \"local\":\"Rumantsch\", \"1\":\"rm\", \"2\":\"roh\", \"2T\":\"roh\", \"2B\":\"roh\", \"3\":\"roh\"},\n {\"name\":\"Kirundi\", \"local\":\"Kirundi\", \"1\":\"rn\", \"2\":\"run\", \"2T\":\"run\", \"2B\":\"run\", \"3\":\"run\"},\n {\"name\":\"Romanian\", \"local\":\"Română\", \"1\":\"ro\", \"2\":\"ron\", \"2T\":\"ron\", \"2B\":\"rum\", \"3\":\"ron\"},\n {\"name\":\"Russian\", \"local\":\"Русский\", \"1\":\"ru\", \"2\":\"rus\", \"2T\":\"rus\", \"2B\":\"rus\", \"3\":\"rus\"},\n {\"name\":\"Sanskrit\", \"local\":\"संस्कृतम्\", \"1\":\"sa\", \"2\":\"san\", \"2T\":\"san\", \"2B\":\"san\", \"3\":\"san\"},\n {\"name\":\"Sardinian\", \"local\":\"Sardu\", \"1\":\"sc\", \"2\":\"srd\", \"2T\":\"srd\", \"2B\":\"srd\", \"3\":\"srd\"},\n {\"name\":\"Sindhi\", \"local\":\"سنڌي‎\", \"1\":\"sd\", \"2\":\"snd\", \"2T\":\"snd\", \"2B\":\"snd\", \"3\":\"snd\"},\n {\"name\":\"Northern Sami\", \"local\":\"Sámegiella\", \"1\":\"se\", \"2\":\"sme\", \"2T\":\"sme\", \"2B\":\"sme\", \"3\":\"sme\"},\n {\"name\":\"Samoan\", \"local\":\"Gagana Sāmoa\", \"1\":\"sm\", \"2\":\"smo\", \"2T\":\"smo\", \"2B\":\"smo\", \"3\":\"smo\"},\n {\"name\":\"Sango\", \"local\":\"Sängö\", \"1\":\"sg\", \"2\":\"sag\", \"2T\":\"sag\", \"2B\":\"sag\", \"3\":\"sag\"},\n {\"name\":\"Serbian\", \"local\":\"Српски\", \"1\":\"sr\", \"2\":\"srp\", \"2T\":\"srp\", \"2B\":\"srp\", \"3\":\"srp\"},\n {\"name\":\"Gaelic\", \"local\":\"Gàidhlig\", \"1\":\"gd\", \"2\":\"gla\", \"2T\":\"gla\", \"2B\":\"gla\", \"3\":\"gla\"},\n {\"name\":\"Shona\", \"local\":\"ChiShona\", \"1\":\"sn\", \"2\":\"sna\", \"2T\":\"sna\", \"2B\":\"sna\", \"3\":\"sna\"},\n {\"name\":\"Sinhala\", \"local\":\"සිංහල\", \"1\":\"si\", \"2\":\"sin\", \"2T\":\"sin\", \"2B\":\"sin\", \"3\":\"sin\"},\n {\"name\":\"Slovak\", \"local\":\"Slovenčina\", \"1\":\"sk\", \"2\":\"slk\", \"2T\":\"slk\", \"2B\":\"slo\", \"3\":\"slk\"},\n {\"name\":\"Slovene\", \"local\":\"Slovenščina\", \"1\":\"sl\", \"2\":\"slv\", \"2T\":\"slv\", \"2B\":\"slv\", \"3\":\"slv\"},\n {\"name\":\"Somali\", \"local\":\"Soomaaliga\", \"1\":\"so\", \"2\":\"som\", \"2T\":\"som\", \"2B\":\"som\", \"3\":\"som\"},\n {\"name\":\"Southern Sotho\", \"local\":\"Sesotho\", \"1\":\"st\", \"2\":\"sot\", \"2T\":\"sot\", \"2B\":\"sot\", \"3\":\"sot\"},\n {\"name\":\"Spanish\", \"local\":\"Español\", \"1\":\"es\", \"2\":\"spa\", \"2T\":\"spa\", \"2B\":\"spa\", \"3\":\"spa\"},\n {\"name\":\"Sundanese\", \"local\":\"Basa Sunda\", \"1\":\"su\", \"2\":\"sun\", \"2T\":\"sun\", \"2B\":\"sun\", \"3\":\"sun\"},\n {\"name\":\"Swahili\", \"local\":\"Kiswahili\", \"1\":\"sw\", \"2\":\"swa\", \"2T\":\"swa\", \"2B\":\"swa\", \"3\":\"swa\"},\n {\"name\":\"Swati\", \"local\":\"SiSwati\", \"1\":\"ss\", \"2\":\"ssw\", \"2T\":\"ssw\", \"2B\":\"ssw\", \"3\":\"ssw\"},\n {\"name\":\"Swedish\", \"local\":\"Svenska\", \"1\":\"sv\", \"2\":\"swe\", \"2T\":\"swe\", \"2B\":\"swe\", \"3\":\"swe\"},\n {\"name\":\"Tamil\", \"local\":\"தமிழ்\", \"1\":\"ta\", \"2\":\"tam\", \"2T\":\"tam\", \"2B\":\"tam\", \"3\":\"tam\"},\n {\"name\":\"Telugu\", \"local\":\"తెలుగు\", \"1\":\"te\", \"2\":\"tel\", \"2T\":\"tel\", \"2B\":\"tel\", \"3\":\"tel\"},\n {\"name\":\"Tajik\", \"local\":\"Тоҷикӣ\", \"1\":\"tg\", \"2\":\"tgk\", \"2T\":\"tgk\", \"2B\":\"tgk\", \"3\":\"tgk\"},\n {\"name\":\"Thai\", \"local\":\"ภาษาไทย\", \"1\":\"th\", \"2\":\"tha\", \"2T\":\"tha\", \"2B\":\"tha\", \"3\":\"tha\"},\n {\"name\":\"Tigrinya\", \"local\":\"ትግርኛ\", \"1\":\"ti\", \"2\":\"tir\", \"2T\":\"tir\", \"2B\":\"tir\", \"3\":\"tir\"},\n {\"name\":\"Tibetan Standard\", \"local\":\"བོད་ཡིག\", \"1\":\"bo\", \"2\":\"bod\", \"2T\":\"bod\", \"2B\":\"tib\", \"3\":\"bod\"},\n {\"name\":\"Turkmen\", \"local\":\"Türkmençe\", \"1\":\"tk\", \"2\":\"tuk\", \"2T\":\"tuk\", \"2B\":\"tuk\", \"3\":\"tuk\"},\n {\"name\":\"Tagalog\", \"local\":\"Tagalog\", \"1\":\"tl\", \"2\":\"tgl\", \"2T\":\"tgl\", \"2B\":\"tgl\", \"3\":\"tgl\"},\n {\"name\":\"Tswana\", \"local\":\"Setswana\", \"1\":\"tn\", \"2\":\"tsn\", \"2T\":\"tsn\", \"2B\":\"tsn\", \"3\":\"tsn\"},\n {\"name\":\"Tonga\", \"local\":\"faka Tonga\", \"1\":\"to\", \"2\":\"ton\", \"2T\":\"ton\", \"2B\":\"ton\", \"3\":\"ton\"},\n {\"name\":\"Turkish\", \"local\":\"Türkçe\", \"1\":\"tr\", \"2\":\"tur\", \"2T\":\"tur\", \"2B\":\"tur\", \"3\":\"tur\"},\n {\"name\":\"Tsonga\", \"local\":\"Xitsonga\", \"1\":\"ts\", \"2\":\"tso\", \"2T\":\"tso\", \"2B\":\"tso\", \"3\":\"tso\"},\n {\"name\":\"Tatar\", \"local\":\"Татарча\", \"1\":\"tt\", \"2\":\"tat\", \"2T\":\"tat\", \"2B\":\"tat\", \"3\":\"tat\"},\n {\"name\":\"Twi\", \"local\":\"Twi\", \"1\":\"tw\", \"2\":\"twi\", \"2T\":\"twi\", \"2B\":\"twi\", \"3\":\"twi\"},\n {\"name\":\"Tahitian\", \"local\":\"Reo Mā’ohi\", \"1\":\"ty\", \"2\":\"tah\", \"2T\":\"tah\", \"2B\":\"tah\", \"3\":\"tah\"},\n {\"name\":\"Uyghur\", \"local\":\"ئۇيغۇرچه\", \"1\":\"ug\", \"2\":\"uig\", \"2T\":\"uig\", \"2B\":\"uig\", \"3\":\"uig\"},\n {\"name\":\"Ukrainian\", \"local\":\"Українська\", \"1\":\"uk\", \"2\":\"ukr\", \"2T\":\"ukr\", \"2B\":\"ukr\", \"3\":\"ukr\"},\n {\"name\":\"Urdu\", \"local\":\"اردو\", \"1\":\"ur\", \"2\":\"urd\", \"2T\":\"urd\", \"2B\":\"urd\", \"3\":\"urd\"},\n {\"name\":\"Uzbek\", \"local\":\"O‘zbek\", \"1\":\"uz\", \"2\":\"uzb\", \"2T\":\"uzb\", \"2B\":\"uzb\", \"3\":\"uzb\"},\n {\"name\":\"Venda\", \"local\":\"Tshivenḓa\", \"1\":\"ve\", \"2\":\"ven\", \"2T\":\"ven\", \"2B\":\"ven\", \"3\":\"ven\"},\n {\"name\":\"Vietnamese\", \"local\":\"Tiếng Việt\", \"1\":\"vi\", \"2\":\"vie\", \"2T\":\"vie\", \"2B\":\"vie\", \"3\":\"vie\"},\n {\"name\":\"Volapük\", \"local\":\"Volapük\", \"1\":\"vo\", \"2\":\"vol\", \"2T\":\"vol\", \"2B\":\"vol\", \"3\":\"vol\"},\n {\"name\":\"Walloon\", \"local\":\"Walon\", \"1\":\"wa\", \"2\":\"wln\", \"2T\":\"wln\", \"2B\":\"wln\", \"3\":\"wln\"},\n {\"name\":\"Welsh\", \"local\":\"Cymraeg\", \"1\":\"cy\", \"2\":\"cym\", \"2T\":\"cym\", \"2B\":\"wel\", \"3\":\"cym\"},\n {\"name\":\"Wolof\", \"local\":\"Wolof\", \"1\":\"wo\", \"2\":\"wol\", \"2T\":\"wol\", \"2B\":\"wol\", \"3\":\"wol\"},\n {\"name\":\"Western Frisian\", \"local\":\"Frysk\", \"1\":\"fy\", \"2\":\"fry\", \"2T\":\"fry\", \"2B\":\"fry\", \"3\":\"fry\"},\n {\"name\":\"Xhosa\", \"local\":\"isiXhosa\", \"1\":\"xh\", \"2\":\"xho\", \"2T\":\"xho\", \"2B\":\"xho\", \"3\":\"xho\"},\n {\"name\":\"Yiddish\", \"local\":\"ייִדיש\", \"1\":\"yi\", \"2\":\"yid\", \"2T\":\"yid\", \"2B\":\"yid\", \"3\":\"yid\"},\n {\"name\":\"Yoruba\", \"local\":\"Yorùbá\", \"1\":\"yo\", \"2\":\"yor\", \"2T\":\"yor\", \"2B\":\"yor\", \"3\":\"yor\"},\n {\"name\":\"Zhuang\", \"local\":\"Cuengh\", \"1\":\"za\", \"2\":\"zha\", \"2T\":\"zha\", \"2B\":\"zha\", \"3\":\"zha\"},\n {\"name\":\"Zulu\", \"local\":\"isiZulu\", \"1\":\"zu\", \"2\":\"zul\", \"2T\":\"zul\", \"2B\":\"zul\", \"3\":\"zul\"}\n];\n","var data = require('./data');\n\nvar langs = {\n all: allLanguages,\n has: hasLanguage,\n codes: getCodes,\n names: getNames,\n where: findBy\n};\n\nmodule.exports = langs;\n\n// allLanguages :: -> Language[]\nfunction allLanguages() {\n return data;\n}\n\n// hasLanguage :: String, String -> Boolean\nfunction hasLanguage(crit, val) {\n return void(0) !== findBy(crit, val);\n}\n\n// getCodes :: String -> String[]\nfunction getCodes(type) {\n if (isValidType(type)) {\n return forAll(data, function getCodesIterator(row) {\n return row[type];\n });\n }\n}\n\n// getNames :: Boolean -> String[]\nfunction getNames(local) {\n return forAll(data, function getNamesIterator(row) {\n return local ? row.local : row.name;\n });\n}\n\n// findBy :: String, String -> Language\nfunction findBy(crit, val) {\n for (var i = 0; i < data.length; i++) {\n if (val === data[i][crit]) {\n return data[i];\n }\n }\n}\n\n// forAll :: Array, Function -> Array\nfunction forAll(arr, fn) {\n var out = [], i;\n for (i = 0; i < arr.length; i++) {\n out.push(fn(arr[i], i));\n }\n\n return out;\n}\n\n// isValidType :: String -> Boolean\nfunction isValidType(type) {\n var types = [1, 2, 3, '1', '2', '2B', '2T', '3'];\n return -1 !== types.indexOf(type);\n}\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/**\n * Adds the key-value `pair` to `map`.\n *\n * @private\n * @param {Object} map The map to modify.\n * @param {Array} pair The key-value pair to add.\n * @returns {Object} Returns `map`.\n */\nfunction addMapEntry(map, pair) {\n // Don't return `map.set` because it's not chainable in IE 11.\n map.set(pair[0], pair[1]);\n return map;\n}\n\n/**\n * Adds `value` to `set`.\n *\n * @private\n * @param {Object} set The set to modify.\n * @param {*} value The value to add.\n * @returns {Object} Returns `set`.\n */\nfunction addSetEntry(set, value) {\n // Don't return `set.add` because it's not chainable in IE 11.\n set.add(value);\n return set;\n}\n\n/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array ? array.length : 0;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.reduce` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @param {*} [accumulator] The initial value.\n * @param {boolean} [initAccum] Specify using the first element of `array` as\n * the initial value.\n * @returns {*} Returns the accumulated value.\n */\nfunction arrayReduce(array, iteratee, accumulator, initAccum) {\n var index = -1,\n length = array ? array.length : 0;\n\n if (initAccum && length) {\n accumulator = array[++index];\n }\n while (++index < length) {\n accumulator = iteratee(accumulator, array[index], index, array);\n }\n return accumulator;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n // Many host objects are `Object` objects that can coerce to strings\n // despite having improperly defined `toString` methods.\n var result = false;\n if (value != null && typeof value.toString != 'function') {\n try {\n result = !!(value + '');\n } catch (e) {}\n }\n return result;\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n getPrototype = overArg(Object.getPrototypeOf, Object),\n objectCreate = Object.create,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n return this.has(key) && delete this.__data__[key];\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n return getMapData(this, key)['delete'](key);\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n getMapData(this, key).set(key, value);\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n this.__data__ = new ListCache(entries);\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n return this.__data__['delete'](key);\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var cache = this.__data__;\n if (cache instanceof ListCache) {\n var pairs = cache.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n return this;\n }\n cache = this.__data__ = new MapCache(pairs);\n }\n cache.set(key, value);\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n // Safari 9 makes `arguments.length` enumerable in strict mode.\n var result = (isArray(value) || isArguments(value))\n ? baseTimes(value.length, String)\n : [];\n\n var length = result.length,\n skipIndexes = !!length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (key == 'length' || isIndex(key, length)))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n object[key] = value;\n }\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `_.assign` without support for multiple sources\n * or `customizer` functions.\n *\n * @private\n * @param {Object} object The destination object.\n * @param {Object} source The source object.\n * @returns {Object} Returns `object`.\n */\nfunction baseAssign(object, source) {\n return object && copyObject(source, keys(source), object);\n}\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @param {boolean} [isFull] Specify a clone including symbols.\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, isDeep, isFull, customizer, key, object, stack) {\n var result;\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n if (isHostObject(value)) {\n return object ? value : {};\n }\n result = initCloneObject(isFunc ? {} : value);\n if (!isDeep) {\n return copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, baseClone, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (!isArr) {\n var props = isFull ? getAllKeys(value) : keys(value);\n }\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, isDeep, isFull, customizer, key, value, stack));\n });\n return result;\n}\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} prototype The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nfunction baseCreate(proto) {\n return isObject(proto) ? objectCreate(proto) : {};\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n return objectToString.call(value);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var result = new buffer.constructor(buffer.length);\n buffer.copy(result);\n return result;\n}\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\n/**\n * Creates a clone of `map`.\n *\n * @private\n * @param {Object} map The map to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned map.\n */\nfunction cloneMap(map, isDeep, cloneFunc) {\n var array = isDeep ? cloneFunc(mapToArray(map), true) : mapToArray(map);\n return arrayReduce(array, addMapEntry, new map.constructor);\n}\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\n/**\n * Creates a clone of `set`.\n *\n * @private\n * @param {Object} set The set to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned set.\n */\nfunction cloneSet(set, isDeep, cloneFunc) {\n var array = isDeep ? cloneFunc(setToArray(set), true) : setToArray(set);\n return arrayReduce(array, addSetEntry, new set.constructor);\n}\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\n/**\n * Copies the values of `source` to `array`.\n *\n * @private\n * @param {Array} source The array to copy values from.\n * @param {Array} [array=[]] The array to copy values to.\n * @returns {Array} Returns `array`.\n */\nfunction copyArray(source, array) {\n var index = -1,\n length = source.length;\n\n array || (array = Array(length));\n while (++index < length) {\n array[index] = source[index];\n }\n return array;\n}\n\n/**\n * Copies properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy properties from.\n * @param {Array} props The property identifiers to copy.\n * @param {Object} [object={}] The object to copy properties to.\n * @param {Function} [customizer] The function to customize copied values.\n * @returns {Object} Returns `object`.\n */\nfunction copyObject(source, props, object, customizer) {\n object || (object = {});\n\n var index = -1,\n length = props.length;\n\n while (++index < length) {\n var key = props[index];\n\n var newValue = customizer\n ? customizer(object[key], source[key], key, object, source)\n : undefined;\n\n assignValue(object, key, newValue === undefined ? source[key] : newValue);\n }\n return object;\n}\n\n/**\n * Copies own symbol properties of `source` to `object`.\n *\n * @private\n * @param {Object} source The object to copy symbols from.\n * @param {Object} [object={}] The object to copy symbols to.\n * @returns {Object} Returns `object`.\n */\nfunction copySymbols(source, object) {\n return copyObject(source, getSymbols(source), object);\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * Creates an array of the own enumerable symbol properties of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = nativeGetSymbols ? overArg(nativeGetSymbols, Object) : stubArray;\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11,\n// for data views in Edge < 14, and promises in Node.js.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = objectToString.call(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : undefined;\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {Function} cloneFunc The function to clone values.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, cloneFunc, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return cloneMap(object, isDeep, cloneFunc);\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return cloneSet(object, isDeep, cloneFunc);\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to process.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, true, true);\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nfunction isArguments(value) {\n // Safari 8.1 makes `arguments.callee` enumerable in strict mode.\n return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') &&\n (!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag);\n}\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 8-9 which returns 'object' for typed array and other constructors.\n var tag = isObject(value) ? objectToString.call(value) : '';\n return tag == funcTag || tag == genTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = cloneDeep;\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n result = wait - timeSinceLastCall;\n\n return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = debounce;\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/**\n * A faster alternative to `Function#apply`, this function invokes `func`\n * with the `this` binding of `thisArg` and the arguments of `args`.\n *\n * @private\n * @param {Function} func The function to invoke.\n * @param {*} thisArg The `this` binding of `func`.\n * @param {Array} args The arguments to invoke `func` with.\n * @returns {*} Returns the result of `func`.\n */\nfunction apply(func, thisArg, args) {\n switch (args.length) {\n case 0: return func.call(thisArg);\n case 1: return func.call(thisArg, args[0]);\n case 2: return func.call(thisArg, args[0], args[1]);\n case 3: return func.call(thisArg, args[0], args[1], args[2]);\n }\n return func.apply(thisArg, args);\n}\n\n/**\n * A specialized version of `_.includes` for arrays without support for\n * specifying an index to search from.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludes(array, value) {\n var length = array ? array.length : 0;\n return !!length && baseIndexOf(array, value, 0) > -1;\n}\n\n/**\n * This function is like `arrayIncludes` except that it accepts a comparator.\n *\n * @private\n * @param {Array} [array] The array to inspect.\n * @param {*} target The value to search for.\n * @param {Function} comparator The comparator invoked per element.\n * @returns {boolean} Returns `true` if `target` is found, else `false`.\n */\nfunction arrayIncludesWith(array, value, comparator) {\n var index = -1,\n length = array ? array.length : 0;\n\n while (++index < length) {\n if (comparator(value, array[index])) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array ? array.length : 0,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.findIndex` and `_.findLastIndex` without\n * support for iteratee shorthands.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {Function} predicate The function invoked per iteration.\n * @param {number} fromIndex The index to search from.\n * @param {boolean} [fromRight] Specify iterating from right to left.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseFindIndex(array, predicate, fromIndex, fromRight) {\n var length = array.length,\n index = fromIndex + (fromRight ? 1 : -1);\n\n while ((fromRight ? index-- : ++index < length)) {\n if (predicate(array[index], index, array)) {\n return index;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `_.indexOf` without `fromIndex` bounds checks.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} value The value to search for.\n * @param {number} fromIndex The index to search from.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction baseIndexOf(array, value, fromIndex) {\n if (value !== value) {\n return baseFindIndex(array, baseIsNaN, fromIndex);\n }\n var index = fromIndex - 1,\n length = array.length;\n\n while (++index < length) {\n if (array[index] === value) {\n return index;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `_.isNaN` without support for number objects.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.\n */\nfunction baseIsNaN(value) {\n return value !== value;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a cache value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Checks if `value` is a host object in IE < 9.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a host object, else `false`.\n */\nfunction isHostObject(value) {\n // Many host objects are `Object` objects that can coerce to strings\n // despite having improperly defined `toString` methods.\n var result = false;\n if (value != null && typeof value.toString != 'function') {\n try {\n result = !!(value + '');\n } catch (e) {}\n }\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map'),\n nativeCreate = getNative(Object, 'create');\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n return this.has(key) && delete this.__data__[key];\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? data[key] !== undefined : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries ? entries.length : 0;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n return getMapData(this, key)['delete'](key);\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n getMapData(this, key).set(key, value);\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values ? values.length : 0;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of methods like `_.intersection`, without support\n * for iteratee shorthands, that accepts an array of arrays to inspect.\n *\n * @private\n * @param {Array} arrays The arrays to inspect.\n * @param {Function} [iteratee] The iteratee invoked per element.\n * @param {Function} [comparator] The comparator invoked per element.\n * @returns {Array} Returns the new array of shared values.\n */\nfunction baseIntersection(arrays, iteratee, comparator) {\n var includes = comparator ? arrayIncludesWith : arrayIncludes,\n length = arrays[0].length,\n othLength = arrays.length,\n othIndex = othLength,\n caches = Array(othLength),\n maxLength = Infinity,\n result = [];\n\n while (othIndex--) {\n var array = arrays[othIndex];\n if (othIndex && iteratee) {\n array = arrayMap(array, baseUnary(iteratee));\n }\n maxLength = nativeMin(array.length, maxLength);\n caches[othIndex] = !comparator && (iteratee || (length >= 120 && array.length >= 120))\n ? new SetCache(othIndex && array)\n : undefined;\n }\n array = arrays[0];\n\n var index = -1,\n seen = caches[0];\n\n outer:\n while (++index < length && result.length < maxLength) {\n var value = array[index],\n computed = iteratee ? iteratee(value) : value;\n\n value = (comparator || value !== 0) ? value : 0;\n if (!(seen\n ? cacheHas(seen, computed)\n : includes(result, computed, comparator)\n )) {\n othIndex = othLength;\n while (--othIndex) {\n var cache = caches[othIndex];\n if (!(cache\n ? cacheHas(cache, computed)\n : includes(arrays[othIndex], computed, comparator))\n ) {\n continue outer;\n }\n }\n if (seen) {\n seen.push(computed);\n }\n result.push(value);\n }\n }\n return result;\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = (isFunction(value) || isHostObject(value)) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.rest` which doesn't validate or coerce arguments.\n *\n * @private\n * @param {Function} func The function to apply a rest parameter to.\n * @param {number} [start=func.length-1] The start position of the rest parameter.\n * @returns {Function} Returns the new function.\n */\nfunction baseRest(func, start) {\n start = nativeMax(start === undefined ? (func.length - 1) : start, 0);\n return function() {\n var args = arguments,\n index = -1,\n length = nativeMax(args.length - start, 0),\n array = Array(length);\n\n while (++index < length) {\n array[index] = args[start + index];\n }\n index = -1;\n var otherArgs = Array(start + 1);\n while (++index < start) {\n otherArgs[index] = args[index];\n }\n otherArgs[start] = array;\n return apply(func, this, otherArgs);\n };\n}\n\n/**\n * Casts `value` to an empty array if it's not an array like object.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {Array|Object} Returns the cast array-like object.\n */\nfunction castArrayLikeObject(value) {\n return isArrayLikeObject(value) ? value : [];\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to process.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Creates an array of unique values that are included in all given arrays\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons. The order of result values is determined by the\n * order they occur in the first array.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Array\n * @param {...Array} [arrays] The arrays to inspect.\n * @returns {Array} Returns the new array of intersecting values.\n * @example\n *\n * _.intersection([2, 1], [2, 3]);\n * // => [2]\n */\nvar intersection = baseRest(function(arrays) {\n var mapped = arrayMap(arrays, castArrayLikeObject);\n return (mapped.length && mapped[0] === arrays[0])\n ? baseIntersection(mapped)\n : [];\n});\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * This method is like `_.isArrayLike` except that it also checks if `value`\n * is an object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array-like object,\n * else `false`.\n * @example\n *\n * _.isArrayLikeObject([1, 2, 3]);\n * // => true\n *\n * _.isArrayLikeObject(document.body.children);\n * // => true\n *\n * _.isArrayLikeObject('abc');\n * // => false\n *\n * _.isArrayLikeObject(_.noop);\n * // => false\n */\nfunction isArrayLikeObject(value) {\n return isObjectLike(value) && isArrayLike(value);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 8-9 which returns 'object' for typed array and other constructors.\n var tag = isObject(value) ? objectToString.call(value) : '';\n return tag == funcTag || tag == genTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\nmodule.exports = intersection;\n","/**\n * Lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors <https://js.foundation/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n","/**\n * lodash (Custom Build) <https://lodash.com/>\n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright jQuery Foundation and other contributors <https://jquery.org/>\n * Released under MIT license <https://lodash.com/license>\n * Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE>\n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the `TypeError` message for \"Functions\" methods. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/** Used as references for various `Number` constants. */\nvar NAN = 0 / 0;\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/** Used to match leading and trailing whitespace. */\nvar reTrim = /^\\s+|\\s+$/g;\n\n/** Used to detect bad signed hexadecimal string values. */\nvar reIsBadHex = /^[-+]0x[0-9a-f]+$/i;\n\n/** Used to detect binary string values. */\nvar reIsBinary = /^0b[01]+$/i;\n\n/** Used to detect octal string values. */\nvar reIsOctal = /^0o[0-7]+$/i;\n\n/** Built-in method references without a dependency on `root`. */\nvar freeParseInt = parseInt;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar objectToString = objectProto.toString;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeMax = Math.max,\n nativeMin = Math.min;\n\n/**\n * Gets the timestamp of the number of milliseconds that have elapsed since\n * the Unix epoch (1 January 1970 00:00:00 UTC).\n *\n * @static\n * @memberOf _\n * @since 2.4.0\n * @category Date\n * @returns {number} Returns the timestamp.\n * @example\n *\n * _.defer(function(stamp) {\n * console.log(_.now() - stamp);\n * }, _.now());\n * // => Logs the number of milliseconds it took for the deferred invocation.\n */\nvar now = function() {\n return root.Date.now();\n};\n\n/**\n * Creates a debounced function that delays invoking `func` until after `wait`\n * milliseconds have elapsed since the last time the debounced function was\n * invoked. The debounced function comes with a `cancel` method to cancel\n * delayed `func` invocations and a `flush` method to immediately invoke them.\n * Provide `options` to indicate whether `func` should be invoked on the\n * leading and/or trailing edge of the `wait` timeout. The `func` is invoked\n * with the last arguments provided to the debounced function. Subsequent\n * calls to the debounced function return the result of the last `func`\n * invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the debounced function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.debounce` and `_.throttle`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to debounce.\n * @param {number} [wait=0] The number of milliseconds to delay.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=false]\n * Specify invoking on the leading edge of the timeout.\n * @param {number} [options.maxWait]\n * The maximum time `func` is allowed to be delayed before it's invoked.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new debounced function.\n * @example\n *\n * // Avoid costly calculations while the window size is in flux.\n * jQuery(window).on('resize', _.debounce(calculateLayout, 150));\n *\n * // Invoke `sendMail` when clicked, debouncing subsequent calls.\n * jQuery(element).on('click', _.debounce(sendMail, 300, {\n * 'leading': true,\n * 'trailing': false\n * }));\n *\n * // Ensure `batchLog` is invoked once after 1 second of debounced calls.\n * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });\n * var source = new EventSource('/stream');\n * jQuery(source).on('message', debounced);\n *\n * // Cancel the trailing debounced invocation.\n * jQuery(window).on('popstate', debounced.cancel);\n */\nfunction debounce(func, wait, options) {\n var lastArgs,\n lastThis,\n maxWait,\n result,\n timerId,\n lastCallTime,\n lastInvokeTime = 0,\n leading = false,\n maxing = false,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n wait = toNumber(wait) || 0;\n if (isObject(options)) {\n leading = !!options.leading;\n maxing = 'maxWait' in options;\n maxWait = maxing ? nativeMax(toNumber(options.maxWait) || 0, wait) : maxWait;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n\n function invokeFunc(time) {\n var args = lastArgs,\n thisArg = lastThis;\n\n lastArgs = lastThis = undefined;\n lastInvokeTime = time;\n result = func.apply(thisArg, args);\n return result;\n }\n\n function leadingEdge(time) {\n // Reset any `maxWait` timer.\n lastInvokeTime = time;\n // Start the timer for the trailing edge.\n timerId = setTimeout(timerExpired, wait);\n // Invoke the leading edge.\n return leading ? invokeFunc(time) : result;\n }\n\n function remainingWait(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime,\n result = wait - timeSinceLastCall;\n\n return maxing ? nativeMin(result, maxWait - timeSinceLastInvoke) : result;\n }\n\n function shouldInvoke(time) {\n var timeSinceLastCall = time - lastCallTime,\n timeSinceLastInvoke = time - lastInvokeTime;\n\n // Either this is the first call, activity has stopped and we're at the\n // trailing edge, the system time has gone backwards and we're treating\n // it as the trailing edge, or we've hit the `maxWait` limit.\n return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||\n (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));\n }\n\n function timerExpired() {\n var time = now();\n if (shouldInvoke(time)) {\n return trailingEdge(time);\n }\n // Restart the timer.\n timerId = setTimeout(timerExpired, remainingWait(time));\n }\n\n function trailingEdge(time) {\n timerId = undefined;\n\n // Only invoke if we have `lastArgs` which means `func` has been\n // debounced at least once.\n if (trailing && lastArgs) {\n return invokeFunc(time);\n }\n lastArgs = lastThis = undefined;\n return result;\n }\n\n function cancel() {\n if (timerId !== undefined) {\n clearTimeout(timerId);\n }\n lastInvokeTime = 0;\n lastArgs = lastCallTime = lastThis = timerId = undefined;\n }\n\n function flush() {\n return timerId === undefined ? result : trailingEdge(now());\n }\n\n function debounced() {\n var time = now(),\n isInvoking = shouldInvoke(time);\n\n lastArgs = arguments;\n lastThis = this;\n lastCallTime = time;\n\n if (isInvoking) {\n if (timerId === undefined) {\n return leadingEdge(lastCallTime);\n }\n if (maxing) {\n // Handle invocations in a tight loop.\n timerId = setTimeout(timerExpired, wait);\n return invokeFunc(lastCallTime);\n }\n }\n if (timerId === undefined) {\n timerId = setTimeout(timerExpired, wait);\n }\n return result;\n }\n debounced.cancel = cancel;\n debounced.flush = flush;\n return debounced;\n}\n\n/**\n * Creates a throttled function that only invokes `func` at most once per\n * every `wait` milliseconds. The throttled function comes with a `cancel`\n * method to cancel delayed `func` invocations and a `flush` method to\n * immediately invoke them. Provide `options` to indicate whether `func`\n * should be invoked on the leading and/or trailing edge of the `wait`\n * timeout. The `func` is invoked with the last arguments provided to the\n * throttled function. Subsequent calls to the throttled function return the\n * result of the last `func` invocation.\n *\n * **Note:** If `leading` and `trailing` options are `true`, `func` is\n * invoked on the trailing edge of the timeout only if the throttled function\n * is invoked more than once during the `wait` timeout.\n *\n * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred\n * until to the next tick, similar to `setTimeout` with a timeout of `0`.\n *\n * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)\n * for details over the differences between `_.throttle` and `_.debounce`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to throttle.\n * @param {number} [wait=0] The number of milliseconds to throttle invocations to.\n * @param {Object} [options={}] The options object.\n * @param {boolean} [options.leading=true]\n * Specify invoking on the leading edge of the timeout.\n * @param {boolean} [options.trailing=true]\n * Specify invoking on the trailing edge of the timeout.\n * @returns {Function} Returns the new throttled function.\n * @example\n *\n * // Avoid excessively updating the position while scrolling.\n * jQuery(window).on('scroll', _.throttle(updatePosition, 100));\n *\n * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.\n * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });\n * jQuery(element).on('click', throttled);\n *\n * // Cancel the trailing throttled invocation.\n * jQuery(window).on('popstate', throttled.cancel);\n */\nfunction throttle(func, wait, options) {\n var leading = true,\n trailing = true;\n\n if (typeof func != 'function') {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n if (isObject(options)) {\n leading = 'leading' in options ? !!options.leading : leading;\n trailing = 'trailing' in options ? !!options.trailing : trailing;\n }\n return debounce(func, wait, {\n 'leading': leading,\n 'maxWait': wait,\n 'trailing': trailing\n });\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return !!value && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return !!value && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && objectToString.call(value) == symbolTag);\n}\n\n/**\n * Converts `value` to a number.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to process.\n * @returns {number} Returns the number.\n * @example\n *\n * _.toNumber(3.2);\n * // => 3.2\n *\n * _.toNumber(Number.MIN_VALUE);\n * // => 5e-324\n *\n * _.toNumber(Infinity);\n * // => Infinity\n *\n * _.toNumber('3.2');\n * // => 3.2\n */\nfunction toNumber(value) {\n if (typeof value == 'number') {\n return value;\n }\n if (isSymbol(value)) {\n return NAN;\n }\n if (isObject(value)) {\n var other = typeof value.valueOf == 'function' ? value.valueOf() : value;\n value = isObject(other) ? (other + '') : other;\n }\n if (typeof value != 'string') {\n return value === 0 ? value : +value;\n }\n value = value.replace(reTrim, '');\n var isBinary = reIsBinary.test(value);\n return (isBinary || reIsOctal.test(value))\n ? freeParseInt(value.slice(2), isBinary ? 2 : 8)\n : (reIsBadHex.test(value) ? NAN : +value);\n}\n\nmodule.exports = throttle;\n","/*! magnet-uri. MIT License. WebTorrent LLC <https://webtorrent.io/opensource> */\nmodule.exports = magnetURIDecode\nmodule.exports.decode = magnetURIDecode\nmodule.exports.encode = magnetURIEncode\n\nconst base32 = require('thirty-two')\nconst bep53Range = require('bep53-range')\n\n/**\n * Parse a magnet URI and return an object of keys/values\n *\n * @param {string} uri\n * @return {Object} parsed uri\n */\nfunction magnetURIDecode (uri) {\n const result = {}\n\n // Support 'magnet:' and 'stream-magnet:' uris\n const data = uri.split('magnet:?')[1]\n\n const params = (data && data.length >= 0)\n ? data.split('&')\n : []\n\n params.forEach(param => {\n const keyval = param.split('=')\n\n // This keyval is invalid, skip it\n if (keyval.length !== 2) return\n\n const key = keyval[0]\n let val = keyval[1]\n\n // Clean up torrent name\n if (key === 'dn') val = decodeURIComponent(val).replace(/\\+/g, ' ')\n\n // Address tracker (tr), exact source (xs), and acceptable source (as) are encoded\n // URIs, so decode them\n if (key === 'tr' || key === 'xs' || key === 'as' || key === 'ws') {\n val = decodeURIComponent(val)\n }\n\n // Return keywords as an array\n if (key === 'kt') val = decodeURIComponent(val).split('+')\n\n // Cast file index (ix) to a number\n if (key === 'ix') val = Number(val)\n\n // bep53\n if (key === 'so') val = bep53Range.parse(decodeURIComponent(val).split(','))\n\n // If there are repeated parameters, return an array of values\n if (result[key]) {\n if (!Array.isArray(result[key])) {\n result[key] = [result[key]]\n }\n\n result[key].push(val)\n } else {\n result[key] = val\n }\n })\n\n // Convenience properties for parity with `parse-torrent-file` module\n let m\n if (result.xt) {\n const xts = Array.isArray(result.xt) ? result.xt : [result.xt]\n xts.forEach(xt => {\n if ((m = xt.match(/^urn:btih:(.{40})/))) {\n result.infoHash = m[1].toLowerCase()\n } else if ((m = xt.match(/^urn:btih:(.{32})/))) {\n const decodedStr = base32.decode(m[1])\n result.infoHash = Buffer.from(decodedStr, 'binary').toString('hex')\n } else if ((m = xt.match(/^urn:btmh:1220(.{64})/))) {\n result.infoHashV2 = m[1].toLowerCase()\n }\n })\n }\n\n if (result.xs) {\n const xss = Array.isArray(result.xs) ? result.xs : [result.xs]\n xss.forEach(xs => {\n if ((m = xs.match(/^urn:btpk:(.{64})/))) {\n result.publicKey = m[1].toLowerCase()\n }\n })\n }\n\n if (result.infoHash) result.infoHashBuffer = Buffer.from(result.infoHash, 'hex')\n if (result.infoHashV2) result.infoHashV2Buffer = Buffer.from(result.infoHashV2, 'hex')\n if (result.publicKey) result.publicKeyBuffer = Buffer.from(result.publicKey, 'hex')\n\n if (result.dn) result.name = result.dn\n if (result.kt) result.keywords = result.kt\n\n result.announce = []\n if (typeof result.tr === 'string' || Array.isArray(result.tr)) {\n result.announce = result.announce.concat(result.tr)\n }\n\n result.urlList = []\n if (typeof result.as === 'string' || Array.isArray(result.as)) {\n result.urlList = result.urlList.concat(result.as)\n }\n if (typeof result.ws === 'string' || Array.isArray(result.ws)) {\n result.urlList = result.urlList.concat(result.ws)\n }\n\n result.peerAddresses = []\n if (typeof result['x.pe'] === 'string' || Array.isArray(result['x.pe'])) {\n result.peerAddresses = result.peerAddresses.concat(result['x.pe'])\n }\n\n // remove duplicates by converting to Set and back\n result.announce = Array.from(new Set(result.announce))\n result.urlList = Array.from(new Set(result.urlList))\n result.peerAddresses = Array.from(new Set(result.peerAddresses))\n\n return result\n}\n\nfunction magnetURIEncode (obj) {\n obj = Object.assign({}, obj) // clone obj, so we can mutate it\n\n // support using convenience names, in addition to spec names\n // (example: `infoHash` for `xt`, `name` for `dn`)\n\n // Deduplicate xt by using a set\n let xts = new Set()\n if (obj.xt && typeof obj.xt === 'string') xts.add(obj.xt)\n if (obj.xt && Array.isArray(obj.xt)) xts = new Set(obj.xt)\n if (obj.infoHashBuffer) xts.add(`urn:btih:${obj.infoHashBuffer.toString('hex')}`)\n if (obj.infoHash) xts.add(`urn:btih:${obj.infoHash}`)\n if (obj.infoHashV2Buffer) xts.add(obj.xt = `urn:btmh:1220${obj.infoHashV2Buffer.toString('hex')}`)\n if (obj.infoHashV2) xts.add(`urn:btmh:1220${obj.infoHashV2}`)\n const xtsDeduped = Array.from(xts)\n if (xtsDeduped.length === 1) obj.xt = xtsDeduped[0]\n if (xtsDeduped.length > 1) obj.xt = xtsDeduped\n\n if (obj.publicKeyBuffer) obj.xs = `urn:btpk:${obj.publicKeyBuffer.toString('hex')}`\n if (obj.publicKey) obj.xs = `urn:btpk:${obj.publicKey}`\n if (obj.name) obj.dn = obj.name\n if (obj.keywords) obj.kt = obj.keywords\n if (obj.announce) obj.tr = obj.announce\n if (obj.urlList) {\n obj.ws = obj.urlList\n delete obj.as\n }\n if (obj.peerAddresses) obj['x.pe'] = obj.peerAddresses\n\n let result = 'magnet:?'\n Object.keys(obj)\n .filter(key => key.length === 2 || key === 'x.pe')\n .forEach((key, i) => {\n const values = Array.isArray(obj[key]) ? obj[key] : [obj[key]]\n values.forEach((val, j) => {\n if ((i > 0 || j > 0) && ((key !== 'kt' && key !== 'so') || j === 0)) result += '&'\n\n if (key === 'dn') val = encodeURIComponent(val).replace(/%20/g, '+')\n if (key === 'tr' || key === 'as' || key === 'ws') {\n val = encodeURIComponent(val)\n }\n // Don't URI encode BEP46 keys\n if (key === 'xs' && !val.startsWith('urn:btpk:')) {\n val = encodeURIComponent(val)\n }\n if (key === 'kt') val = encodeURIComponent(val)\n if (key === 'so') return\n\n if (key === 'kt' && j > 0) result += `+${val}`\n else result += `${key}=${val}`\n })\n if (key === 'so') result += `${key}=${bep53Range.compose(values)}`\n })\n\n return result\n}\n","// extracted by mini-css-extract-plugin\nmodule.exports = {\"error-container\":\"error-container-OJnoc\",\"error-image\":\"error-image-qU9Qo\",\"error-message\":\"error-message-kW59Z\",\"buttons-container\":\"buttons-container-tQonN\",\"button-container\":\"button-container-vLSQK\",\"label\":\"label-Up_te\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"fade-in\":\"fade-in-pFkt_\",\"toasts-container\":\"toasts-container-oKECy\",\"router\":\"router-_65XU\",\"error-container\":\"error-container-VZXwH\",\"loader-container\":\"loader-container-vwvnb\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"addon-details-container\":\"addon-details-container-ZQqDB\",\"title-container\":\"title-container-fR02m\",\"icon\":\"icon-ScXNu\",\"logo\":\"logo-BujW_\",\"name-container\":\"name-container-Gfhqw\",\"name\":\"name-XNqfo\",\"version\":\"version-w_xoN\",\"section-container\":\"section-container-l3YaI\",\"section-header\":\"section-header-bs8iy\",\"section-label\":\"section-label-rYxQh\",\"transport-url-label\":\"transport-url-label-EW7I5\",\"disclaimer-label\":\"disclaimer-label-IGdd3\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"addon-details-modal-container\":\"addon-details-modal-container-_bwQ0\",\"addon-details-container\":\"addon-details-container-AmNx2\",\"addon-details-message-container\":\"addon-details-message-container-VEzeN\",\"cancel-button\":\"cancel-button-luYIO\",\"install-button\":\"install-button-XUzqz\",\"uninstall-button\":\"uninstall-button-X2JXr\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"button-container\":\"button-container-HNufV\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"checkbox-container\":\"checkbox-container-heGq4\",\"icon\":\"icon-NUvac\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"color-picker-container\":\"color-picker-container-deFkW\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"color-input-container\":\"color-input-container-jRZsi\",\"transparent-label-container\":\"transparent-label-container-Tx2fI\",\"transparent-label\":\"transparent-label-omLaY\",\"color-picker-container\":\"color-picker-container-C4puR\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"main-nav-bars-container\":\"main-nav-bars-container-fA7pO\",\"horizontal-nav-bar\":\"horizontal-nav-bar-x5sxp\",\"vertical-nav-bar\":\"vertical-nav-bar-JNw53\",\"nav-content-container\":\"nav-content-container-VHwOU\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-item-container\":\"meta-item-container-drt6V\",\"poster-shape-poster\":\"poster-shape-poster-F_CO5\",\"poster-container\":\"poster-container-Fruke\",\"poster-shape-square\":\"poster-shape-square-UCby3\",\"poster-shape-landscape\":\"poster-shape-landscape-BPmb1\",\"poster-image-layer\":\"poster-image-layer-CdxrT\",\"poster-image\":\"poster-image-lt9zC\",\"placeholder-icon\":\"placeholder-icon-uYwsv\",\"play-icon-layer\":\"play-icon-layer-_75Lo\",\"play-icon\":\"play-icon-d9_ll\",\"progress-bar-layer\":\"progress-bar-layer-r81Qx\",\"progress-bar\":\"progress-bar-E3QY9\",\"title-bar-container\":\"title-bar-container-DFXJK\",\"title-label\":\"title-label-dZZ_A\",\"menu-label-container\":\"menu-label-container-dlL1I\",\"icon\":\"icon-IfJ81\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"action-button-container\":\"action-button-container-TmbQ2\",\"icon-container\":\"icon-container-hvLw4\",\"icon\":\"icon-DG4TM\",\"label-container\":\"label-container-eh2bk\",\"label\":\"label-YhHvD\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-links-container\":\"meta-links-container-wSrm1\",\"label-container\":\"label-container-zWFke\",\"links-container\":\"links-container-o4RUG\",\"link-container\":\"link-container-HUDqV\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-preview-placeholder-container\":\"meta-preview-placeholder-container-AQ4ld\",\"meta-info-container\":\"meta-info-container-pEOFb\",\"logo-container\":\"logo-container-g5eNB\",\"duration-release-info-container\":\"duration-release-info-container-lNaI6\",\"duration-container\":\"duration-container-x2E01\",\"release-info-container\":\"release-info-container-PEmeu\",\"description-container\":\"description-container-yGOO4\",\"description-label-container\":\"description-label-container-G_0pj\",\"genres-container\":\"genres-container-v3H7A\",\"genres-header-container\":\"genres-header-container-lsPLU\",\"genre-label-container\":\"genre-label-container-z7kU8\",\"action-buttons-container\":\"action-buttons-container-U3sbl\",\"action-button-container\":\"action-button-container-xJmjB\",\"action-button-icon\":\"action-button-icon-E7Epc\",\"action-button-label\":\"action-button-label-R7UPL\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-preview-container\":\"meta-preview-container-bgBNf\",\"compact\":\"compact-Wbl4Q\",\"meta-info-container\":\"meta-info-container-tlmcb\",\"logo\":\"logo-X9v1A\",\"logo-placeholder\":\"logo-placeholder-kIy0x\",\"runtime-release-info-container\":\"runtime-release-info-container-lXo3K\",\"release-info-label\":\"release-info-label-XmqSY\",\"runtime-label\":\"runtime-label-B29EN\",\"description-container\":\"description-container-eSGft\",\"action-buttons-container\":\"action-buttons-container-qQrnO\",\"action-button\":\"action-button-R44aX\",\"background-image-layer\":\"background-image-layer-GstuA\",\"background-image\":\"background-image-B0d6i\",\"imdb-button-container\":\"imdb-button-container-qCbl7\",\"icon\":\"icon-MBu8k\",\"label\":\"label-_DfnK\",\"name-container\":\"name-container-HsS4c\",\"meta-links\":\"meta-links-mTHUo\",\"share-prompt\":\"share-prompt-F8qOC\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-row-placeholder-container\":\"meta-row-placeholder-container-wpHNk\",\"header-container\":\"header-container-GCHdB\",\"title-container\":\"title-container-Bjp93\",\"see-all-container\":\"see-all-container-FnlIf\",\"label\":\"label-dU3S2\",\"icon\":\"icon-FLhtv\",\"meta-items-container\":\"meta-items-container-dbGXx\",\"meta-item\":\"meta-item-IegjY\",\"poster-container\":\"poster-container-RlQMV\",\"title-bar-container\":\"title-bar-container-YJZrl\",\"title-label\":\"title-label-Ka1vs\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"meta-row-container\":\"meta-row-container-ucOuu\",\"header-container\":\"header-container-RherZ\",\"title-container\":\"title-container-SJ0nR\",\"see-all-container\":\"see-all-container-HlJ4b\",\"label\":\"label-isJw8\",\"icon\":\"icon-PO0GH\",\"message-container\":\"message-container-bIcjN\",\"meta-items-container\":\"meta-items-container-TqzFs\",\"meta-item\":\"meta-item-x28TU\",\"poster-shape-poster\":\"poster-shape-poster-B1QR0\",\"poster-shape-square\":\"poster-shape-square-m5r_O\",\"poster-shape-landscape\":\"poster-shape-landscape-_FSOH\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"modal-container\":\"modal-container-jZglc\",\"modal-dialog-container\":\"modal-dialog-container-QgsId\",\"close-button-container\":\"close-button-container-QrgQo\",\"icon\":\"icon-hRjWc\",\"title-container\":\"title-container-wqhp3\",\"modal-dialog-content\":\"modal-dialog-content-ChXwF\",\"buttons-container\":\"buttons-container-EJKJF\",\"action-button\":\"action-button-bi6FL\",\"label\":\"label-_ADoX\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"label-container\":\"label-container-ZHk2S\",\"label\":\"label-kz1K0\",\"icon\":\"icon-YGvLz\",\"modal-container\":\"modal-container-BQwj3\",\"menu-container\":\"menu-container-Z1Pou\",\"option-container\":\"option-container-yVj1o\",\"no-options-container\":\"no-options-container-NYx9Z\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"nav-menu-container\":\"nav-menu-container-VSzwW\",\"user-info-container\":\"user-info-container-BR8yb\",\"avatar-container\":\"avatar-container-jmlBM\",\"email-container\":\"email-container-fvFrL\",\"email-label\":\"email-label-WBX2T\",\"logout-button-container\":\"logout-button-container-hSW_i\",\"logout-label\":\"logout-label-dUa8B\",\"nav-menu-section\":\"nav-menu-section-oMELF\",\"nav-menu-option-container\":\"nav-menu-option-container-gZ1gT\",\"icon\":\"icon-OSgm6\",\"nav-menu-option-label\":\"nav-menu-option-label-XNuY6\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"search-bar-container\":\"search-bar-container-TNPzI\",\"search-input\":\"search-input-aOiJ2\",\"placeholder-label\":\"placeholder-label-Irklk\",\"submit-button-container\":\"submit-button-container-jPP5J\",\"icon\":\"icon-FT4bG\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"horizontal-nav-bar-container\":\"horizontal-nav-bar-container-jFw5Y\",\"logo-container\":\"logo-container-fnFzY\",\"logo\":\"logo-RVSxt\",\"spacing\":\"spacing-jzj7t\",\"title\":\"title-_UxXH\",\"search-bar\":\"search-bar-NopQ6\",\"button-container\":\"button-container-B23qB\",\"back-button-container\":\"back-button-container-K9AwF\",\"icon\":\"icon-wrBcp\",\"menu-button-container\":\"menu-button-container-WWcwa\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"nav-tab-button-container\":\"nav-tab-button-container-r8HUb\",\"icon\":\"icon-vxKmB\",\"label\":\"label-mc9eB\",\"logo\":\"logo-ST06l\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"vertical-nav-bar-container\":\"vertical-nav-bar-container-AsGLM\",\"nav-tab-button\":\"nav-tab-button-noMv6\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"pagination-input-container\":\"pagination-input-container-vXhi6\",\"next-button-container\":\"next-button-container-zNwG6\",\"prev-button-container\":\"prev-button-container-qmJ1m\",\"icon\":\"icon-UoyQ9\",\"label-container\":\"label-container-VwInD\",\"label\":\"label-cJKC1\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"background\":\"background-FNyrF\",\"icon\":\"icon-XXj2q\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"label-container\":\"label-container-iBMb9\",\"menu-container\":\"menu-container-bfvDO\",\"menu-direction-top-left\":\"menu-direction-top-left-KpAQN\",\"menu-direction-bottom-left\":\"menu-direction-bottom-left-Uw06K\",\"menu-direction-top-right\":\"menu-direction-top-right-jOtwq\",\"menu-direction-bottom-right\":\"menu-direction-bottom-right-XZ9Ch\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"search-bar-container\":\"search-bar-container-Vb_fz\",\"search-input\":\"search-input-BWyeG\",\"icon\":\"icon-poa62\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"search-bar-container\":\"search-bar-container-MpNBA\",\"search-input\":\"search-input-ge2wu\",\"icon\":\"icon-Z_Hni\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"share-prompt-container\":\"share-prompt-container-YsJwl\",\"buttons-container\":\"buttons-container-Oc7PG\",\"button-container\":\"button-container-oMOnv\",\"icon\":\"icon-FVvQH\",\"label\":\"label-iOGrs\",\"facebook-button\":\"facebook-button-KaNwb\",\"twitter-button\":\"twitter-button-pJka2\",\"url-container\":\"url-container-fMSp4\",\"url-text-input\":\"url-text-input-Yka4x\",\"copy-button\":\"copy-button-ShwCB\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"active-slider-within\":\"active-slider-within-lQFc1\",\"slider-container\":\"slider-container-aRzVq\",\"track-before\":\"track-before-FwOXh\",\"track\":\"track-jWhBI\",\"thumb\":\"thumb-tfDk6\",\"layer\":\"layer-FqnD7\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"warning-container\":\"warning-container-FIITF\",\"warning-statement\":\"warning-statement-I7pdD\",\"warning-button\":\"warning-button-zlx_V\",\"warning-label\":\"warning-label-XJnBc\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"text-input\":\"text-input-jR2Nr\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"toast-item-container\":\"toast-item-container-nG0uk\",\"success\":\"success-eIDTa\",\"icon-container\":\"icon-container-rjAiH\",\"icon\":\"icon-Y4I_O\",\"error\":\"error-quyOd\",\"info-container\":\"info-container-xD9V6\",\"title-container\":\"title-container-VFReJ\",\"message-container\":\"message-container-znkCj\",\"close-button-container\":\"close-button-container-YtyYE\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"addon-container\":\"addon-container-lC5KN\",\"logo-container\":\"logo-container-ZcSSC\",\"logo\":\"logo-WrsGF\",\"icon\":\"icon-GxVbY\",\"info-container\":\"info-container-AdMB6\",\"name-container\":\"name-container-qIAg8\",\"version-container\":\"version-container-zdPyN\",\"types-container\":\"types-container-DaOrg\",\"description-container\":\"description-container-v7Jhe\",\"buttons-container\":\"buttons-container-g0xXr\",\"action-buttons-container\":\"action-buttons-container-xMVmz\",\"configure-button-container\":\"configure-button-container-VwVAQ\",\"install-button-container\":\"install-button-container-yfcq5\",\"share-button-container\":\"share-button-container-s3gwP\",\"uninstall-button-container\":\"uninstall-button-container-oV4Yo\",\"label\":\"label-OnWh2\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"addons-container\":\"addons-container-ogGYu\",\"addons-content\":\"addons-content-zhFBl\",\"selectable-inputs-container\":\"selectable-inputs-container-tUul1\",\"add-button-container\":\"add-button-container-SkafT\",\"icon\":\"icon-HsyZS\",\"add-button-label\":\"add-button-label-NN6bu\",\"select-input-container\":\"select-input-container-KqG8N\",\"spacing\":\"spacing-wH1w5\",\"search-bar\":\"search-bar-k7MXd\",\"filter-button\":\"filter-button-lLJ1X\",\"filter-icon\":\"filter-icon-LUDTS\",\"message-container\":\"message-container-GBw0P\",\"addons-list-container\":\"addons-list-container-Ovr2Z\",\"addon\":\"addon-whmdO\",\"filters-modal\":\"filters-modal-w6oWY\",\"add-addon-modal-container\":\"add-addon-modal-container-KR5ny\",\"notice\":\"notice-UQkO1\",\"addon-url-input\":\"addon-url-input-ucetZ\",\"cancel-button\":\"cancel-button-R2AxR\",\"share-modal-container\":\"share-modal-container-DkzPM\",\"title-container\":\"title-container-La49g\",\"logo\":\"logo-PmYDP\",\"name-container\":\"name-container-m_Sz0\",\"name\":\"name-YD0xd\",\"version\":\"version-wuAFB\",\"share-prompt-container\":\"share-prompt-container-vaK4P\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"board-container\":\"board-container-DTN_b\",\"board-content-container\":\"board-content-container-ToQTz\",\"board-content\":\"board-content-nPWv1\",\"board-row\":\"board-row-CoJrZ\",\"board-warning-container\":\"board-warning-container-a4m04\",\"board-row-landscape\":\"board-row-landscape-FRGXx\",\"board-row-poster\":\"board-row-poster-QPQqC\",\"board-row-square\":\"board-row-square-pgaZ3\",\"continue-watching-row\":\"continue-watching-row-ZiNSa\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"discover-container\":\"discover-container-L6OGL\",\"discover-content\":\"discover-content-CRsRg\",\"catalog-container\":\"catalog-container-VNK_T\",\"selectable-inputs-container\":\"selectable-inputs-container-IRz50\",\"select-input\":\"select-input-CHDbe\",\"filter-container\":\"filter-container-BVkqT\",\"filter-icon\":\"filter-icon-zlFnX\",\"missing-addon-warning-container\":\"missing-addon-warning-container-IXGuv\",\"warning-label\":\"warning-label-f19Jg\",\"install-button\":\"install-button-SmJe1\",\"label\":\"label-ToW4S\",\"message-container\":\"message-container-Zv9eF\",\"image\":\"image-txC9E\",\"message-label\":\"message-label-mRyRX\",\"meta-items-container\":\"meta-items-container-n8vNz\",\"meta-item-placeholder\":\"meta-item-placeholder-wxG4I\",\"poster-container\":\"poster-container-Dch4R\",\"title-bar-container\":\"title-bar-container-dtDnk\",\"title-label\":\"title-label-vHdQd\",\"meta-preview-container\":\"meta-preview-container-CoWs5\",\"selectable-inputs-modal\":\"selectable-inputs-modal-ChpOa\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"consent-checkbox-container\":\"consent-checkbox-container-WV60T\",\"label\":\"label-l3LSw\",\"link\":\"link-UppYg\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"password-reset-modal-container\":\"password-reset-modal-container-KzJPQ\",\"credentials-text-input\":\"credentials-text-input-ncrIR\",\"error-message\":\"error-message-DkekN\",\"cancel-button\":\"cancel-button-AneJE\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"intro-container\":\"intro-container-tkNS6\",\"form-container\":\"form-container-HMlEh\",\"logo-container\":\"logo-container-W49kt\",\"logo\":\"logo-WJ36F\",\"name\":\"name-BNo9R\",\"form-button\":\"form-button-vyqqj\",\"icon\":\"icon-L_6b6\",\"label\":\"label-uHD7L\",\"facebook-button\":\"facebook-button-LZ_kG\",\"login-form-button\":\"login-form-button-DqJUV\",\"login-label\":\"login-label-AelYq\",\"credentials-text-input\":\"credentials-text-input-QMCZz\",\"forgot-password-link-container\":\"forgot-password-link-container-ygZqb\",\"forgot-password-link\":\"forgot-password-link-NxNUD\",\"error-message\":\"error-message-cKdzB\",\"submit-button\":\"submit-button-x3L8z\",\"guest-login-button\":\"guest-login-button-D8DWZ\",\"signup-form-button\":\"signup-form-button-UGmSk\",\"loading-modal-container\":\"loading-modal-container-eLyTm\",\"loader-container\":\"loader-container-oe8rU\",\"flash\":\"flash-wUFXY\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"library-container\":\"library-container-zM_bj\",\"library-content\":\"library-content-PgX4O\",\"selectable-inputs-container\":\"selectable-inputs-container-hR3or\",\"select-input-container\":\"select-input-container-H1VZ1\",\"filter-container\":\"filter-container-oRBlw\",\"filter-icon\":\"filter-icon-ZhMyS\",\"spacing\":\"spacing-Rdiyt\",\"pagination-input\":\"pagination-input-DvMtv\",\"pagination-input-placeholder\":\"pagination-input-placeholder-vZeuq\",\"message-container\":\"message-container-MhY5t\",\"no-user-message-container\":\"no-user-message-container-KMLpE\",\"login-button-container\":\"login-button-container-RoEh7\",\"label\":\"label-QqYmf\",\"image\":\"image-csRHm\",\"message-label\":\"message-label-UExl3\",\"meta-items-container\":\"meta-items-container-IKrND\",\"selectable-inputs-modal\":\"selectable-inputs-modal-rHlo7\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"stream-placeholder-container\":\"stream-placeholder-container-T1nxv\",\"addon-container\":\"addon-container-pm1P0\",\"addon-name\":\"addon-name-zAOKP\",\"info-container\":\"info-container-Z1Dl6\",\"description-container\":\"description-container-ZOMcn\",\"play-icon\":\"play-icon-MXqj3\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"stream-container\":\"stream-container-JPdah\",\"play-icon\":\"play-icon-w1yb5\",\"addon-name-container\":\"addon-name-container-IZ2De\",\"thumbnail-container\":\"thumbnail-container-ptbAk\",\"thumbnail\":\"thumbnail-whoms\",\"placeholder-icon\":\"placeholder-icon-znYz0\",\"addon-name\":\"addon-name-tC8PX\",\"info-container\":\"info-container-TihQo\",\"progress-bar-container\":\"progress-bar-container-ADRp_\",\"progress-bar\":\"progress-bar-XrEBL\",\"stream-containerfocus\":\"stream-containerfocus-xiWVj\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"streams-list-container\":\"streams-list-container-xYMJo\",\"message-container\":\"message-container-f9_L4\",\"image\":\"image-rIyu6\",\"label\":\"label-luvnO\",\"select-input-container\":\"select-input-container-irGn_\",\"streams-container\":\"streams-container-bbSc4\",\"install-button-container\":\"install-button-container-Q60yJ\",\"icon\":\"icon-SoFgF\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"seasons-bar-placeholder-container\":\"seasons-bar-placeholder-container-M81RN\",\"next-season-button\":\"next-season-button-oGnlT\",\"prev-season-button\":\"prev-season-button-TCbOq\",\"icon\":\"icon-UzQjF\",\"label\":\"label-lmBnj\",\"seasons-popup-label-container\":\"seasons-popup-label-container-r2UDB\",\"seasons-popup-label\":\"seasons-popup-label-xBinL\",\"seasons-popup-icon\":\"seasons-popup-icon-p1T5d\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"seasons-bar-container\":\"seasons-bar-container-nOZjG\",\"next-season-button\":\"next-season-button-RrYAq\",\"prev-season-button\":\"prev-season-button-bs1GQ\",\"label\":\"label-uJbfD\",\"icon\":\"icon-_ZBEE\",\"seasons-popup-label-container\":\"seasons-popup-label-container-fZcu4\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"video-placeholder-container\":\"video-placeholder-container-uDsav\",\"info-container\":\"info-container-KTKtT\",\"name-container\":\"name-container-Jvesr\",\"released-container\":\"released-container-uoc4E\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"video-container\":\"video-container-UBBpR\",\"thumbnail-container\":\"thumbnail-container-n_jp7\",\"thumbnail\":\"thumbnail-MiS3K\",\"placeholder-icon\":\"placeholder-icon-LzVIO\",\"info-container\":\"info-container-szYxP\",\"title-container\":\"title-container-EMXpV\",\"flex-row-container\":\"flex-row-container-ExEua\",\"released-container\":\"released-container-zA91y\",\"upcoming-watched-container\":\"upcoming-watched-container-y_ijd\",\"upcoming-container\":\"upcoming-container-ASE1L\",\"watched-container\":\"watched-container-LCso2\",\"flag-label\":\"flag-label-dIdBb\",\"progress-bar-container\":\"progress-bar-container-gMpiB\",\"progress-bar\":\"progress-bar-Yhl4z\",\"context-menu-content\":\"context-menu-content-MGBhW\",\"context-menu-option-container\":\"context-menu-option-container-VlNjD\",\"context-menu-option-label\":\"context-menu-option-label-hOUnH\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"videos-list-container\":\"videos-list-container-NepX5\",\"message-container\":\"message-container-_hhmQ\",\"image\":\"image-_xAbP\",\"label\":\"label-Ff1_X\",\"seasons-bar\":\"seasons-bar-Ma8vp\",\"search-bar\":\"search-bar-mZHWa\",\"videos-container\":\"videos-container-msX8s\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"metadetails-container\":\"metadetails-container-K_Dqa\",\"nav-bar\":\"nav-bar-MH6Vk\",\"metadetails-content\":\"metadetails-content-Uz5EV\",\"vertical-nav-bar\":\"vertical-nav-bar-B39nq\",\"background-image-layer\":\"background-image-layer-wJa90\",\"background-image\":\"background-image-tSjYu\",\"meta-message-container\":\"meta-message-container-MJZN5\",\"image\":\"image-R1LcJ\",\"message-label\":\"message-label-Uz4_P\",\"meta-preview\":\"meta-preview-ES0h3\",\"spacing\":\"spacing-rgIYg\",\"streams-list\":\"streams-list-Y1lCM\",\"videos-list\":\"videos-list-nE0LJ\",\"meta-extension-modal-container\":\"meta-extension-modal-container-gHjqy\",\"meta-extension-modal-iframe\":\"meta-extension-modal-iframe-GGHlm\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"not-found-container\":\"not-found-container-Q1qsP\",\"nav-bar\":\"nav-bar-Eu3_y\",\"not-found-content\":\"not-found-content-z_Eza\",\"not-found-image\":\"not-found-image-Qab4G\",\"not-found-label\":\"not-found-label-mmwyZ\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"buffering-loader-container\":\"buffering-loader-container-P7S0m\",\"buffering-loader\":\"buffering-loader-fMSpb\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"seek-bar-container\":\"seek-bar-container-JGGTa\",\"slider\":\"slider-hBDOf\",\"label\":\"label-QFbsS\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"volume-slider\":\"volume-slider-G_xAt\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"control-bar-container\":\"control-bar-container-xsWA7\",\"seek-bar\":\"seek-bar-I7WeY\",\"control-bar-buttons-container\":\"control-bar-buttons-container-SWhkU\",\"control-bar-button\":\"control-bar-button-FQUsj\",\"icon\":\"icon-qy6I6\",\"volume-slider\":\"volume-slider-U9jfo\",\"spacing\":\"spacing-p8NJQ\",\"control-bar-buttons-menu-button\":\"control-bar-buttons-menu-button-h0MWd\",\"control-bar-buttons-menu-container\":\"control-bar-buttons-menu-container-M6L0_\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"info-menu-container\":\"info-menu-container-R1QKH\",\"stream\":\"stream-MY2Oy\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"next-video-popup-container\":\"next-video-popup-container-H4wnL\",\"slide-fade-in\":\"slide-fade-in-rk2M8\",\"poster-container\":\"poster-container-tXZjA\",\"poster-image\":\"poster-image-2D6wg\",\"placeholder-icon\":\"placeholder-icon-fu1rK\",\"info-container\":\"info-container-KLOMx\",\"details-container\":\"details-container-bUOTZ\",\"name\":\"name-sIiDL\",\"description\":\"description-gIXiC\",\"buttons-container\":\"buttons-container-iYrpZ\",\"spacing\":\"spacing-iFwsN\",\"button-container\":\"button-container-i4F7t\",\"play-button\":\"play-button-Dluk6\",\"icon\":\"icon-N3Ewm\",\"label\":\"label-zOq_w\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"option-container\":\"option-container-m_jZq\",\"icon\":\"icon-krR0X\",\"label\":\"label-cmqqu\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"options-menu-container\":\"options-menu-container-qlzLt\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"option\":\"option-_O96j\",\"icon\":\"icon-kqaPF\",\"label\":\"label-FEOiu\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"speed-menu-container\":\"speed-menu-container-ABjzc\",\"title\":\"title-Hu2Dm\",\"options-container\":\"options-container-DNn3D\",\"option\":\"option-GcPlB\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"discrete-input-container\":\"discrete-input-container-CMThy\",\"header\":\"header-n0jWL\",\"input-container\":\"input-container-TNuI2\",\"button-container\":\"button-container-ciSB5\",\"icon\":\"icon-JDltr\",\"option-label\":\"option-label-tjeeT\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"subtitles-menu-container\":\"subtitles-menu-container-PxBRZ\",\"languages-container\":\"languages-container-NS7H9\",\"subtitles-settings-container\":\"subtitles-settings-container-LhRGS\",\"variants-container\":\"variants-container-XglzH\",\"languages-header\":\"languages-header-jGNcK\",\"settings-header\":\"settings-header-eaWnm\",\"variants-header\":\"variants-header-TsVSR\",\"languages-list\":\"languages-list-sxIwI\",\"variants-list\":\"variants-list-yZo6B\",\"language-option\":\"language-option-O1Yr9\",\"variant-option\":\"variant-option-t7_LA\",\"language-label\":\"language-label-FjjqA\",\"variant-label\":\"variant-label-opjnP\",\"icon\":\"icon-I1Ruh\",\"no-variants-container\":\"no-variants-container-q6u1Q\",\"no-variants-label\":\"no-variants-label-RmDKZ\",\"spacing\":\"spacing-AWJpt\",\"discrete-input\":\"discrete-input-fXELp\",\"advanced-button\":\"advanced-button-YGN5T\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"video-container\":\"video-container-v9_vA\",\"video\":\"video-tkpQm\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"videos-menu-container\":\"videos-menu-container-ATzKq\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"player-container\":\"player-container-wIELK\",\"immersed\":\"immersed-Y0hn1\",\"control-bar-layer\":\"control-bar-layer-m2jto\",\"menu-layer\":\"menu-layer-HZFG9\",\"nav-bar-layer\":\"nav-bar-layer-r9HT5\",\"layer\":\"layer-qalDW\",\"error-layer\":\"error-layer-RCEZC\",\"error-label\":\"error-label-FPIMw\",\"playlist-button\":\"playlist-button-CB2WC\",\"icon\":\"icon-aMPEE\",\"label\":\"label-njZqk\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"search-container\":\"search-container-uXEFf\",\"search-content\":\"search-content-LX6un\",\"search-row\":\"search-row-EQLaD\",\"search-hints-container\":\"search-hints-container-FHpPM\",\"search-hint-container\":\"search-hint-container-kd8iX\",\"icon\":\"icon-fOZZl\",\"label\":\"label-l6wxz\",\"message-container\":\"message-container-YAunr\",\"image\":\"image-Xuwya\",\"message-label\":\"message-label-K8LPz\",\"search-row-landscape\":\"search-row-landscape-o3Lfv\",\"search-row-poster\":\"search-row-poster-m7CUE\",\"search-row-square\":\"search-row-square-VesJA\"};","// extracted by mini-css-extract-plugin\nmodule.exports = {\"settings-container\":\"settings-container-b0DCu\",\"settings-content\":\"settings-content-lLXmk\",\"side-menu-container\":\"side-menu-container-NG17D\",\"side-menu-button\":\"side-menu-button-vbkJ1\",\"selected\":\"selected-yhdng\",\"spacing\":\"spacing-fpLUM\",\"version-info-label\":\"version-info-label-uMkm7\",\"sections-container\":\"sections-container-EUKAe\",\"section-container\":\"section-container-twzKQ\",\"section-title\":\"section-title-Nt71Z\",\"option-container\":\"option-container-EGlcv\",\"user-info-option-container\":\"user-info-option-container-oRLJc\",\"avatar-container\":\"avatar-container-YWq9E\",\"email-logout-container\":\"email-logout-container-kYQDM\",\"email-label-container\":\"email-label-container-oVmiO\",\"logout-button-container\":\"logout-button-container-jLrU2\",\"email-label\":\"email-label-Q__sJ\",\"logout-label\":\"logout-label-zo4ES\",\"user-panel-container\":\"user-panel-container-kkrJG\",\"user-panel-label\":\"user-panel-label-beAQl\",\"option-input-container\":\"option-input-container-NPgpT\",\"option-name-container\":\"option-name-container-exGMI\",\"icon\":\"icon-REQkK\",\"label\":\"label-FFamJ\",\"button-container\":\"button-container-ENMae\",\"multiselect-container\":\"multiselect-container-w0c9l\",\"link-container\":\"link-container-ERYsD\",\"checkbox-container\":\"checkbox-container-R9LLN\",\"color-input-container\":\"color-input-container-WclA_\",\"info-container\":\"info-container-wfFcS\",\"selectable\":\"selectable-eucrJ\",\"configure-input-container\":\"configure-input-container-PMyIY\",\"configure-button-container\":\"configure-button-container-xGFgg\",\"shortcut-container\":\"shortcut-container-ZSm5O\",\"configure-server-url-modal-container\":\"configure-server-url-modal-container-vSL44\",\"server-url-input\":\"server-url-input-Dfazw\",\"cancel-button\":\"cancel-button-iydew\"};","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","/*! https://mths.be/punycode v1.3.2 by @mathias */\n;(function(root) {\n\n\t/** Detect free variables */\n\tvar freeExports = typeof exports == 'object' && exports &&\n\t\t!exports.nodeType && exports;\n\tvar freeModule = typeof module == 'object' && module &&\n\t\t!module.nodeType && module;\n\tvar freeGlobal = typeof global == 'object' && global;\n\tif (\n\t\tfreeGlobal.global === freeGlobal ||\n\t\tfreeGlobal.window === freeGlobal ||\n\t\tfreeGlobal.self === freeGlobal\n\t) {\n\t\troot = freeGlobal;\n\t}\n\n\t/**\n\t * The `punycode` object.\n\t * @name punycode\n\t * @type Object\n\t */\n\tvar punycode,\n\n\t/** Highest positive signed 32-bit float value */\n\tmaxInt = 2147483647, // aka. 0x7FFFFFFF or 2^31-1\n\n\t/** Bootstring parameters */\n\tbase = 36,\n\ttMin = 1,\n\ttMax = 26,\n\tskew = 38,\n\tdamp = 700,\n\tinitialBias = 72,\n\tinitialN = 128, // 0x80\n\tdelimiter = '-', // '\\x2D'\n\n\t/** Regular expressions */\n\tregexPunycode = /^xn--/,\n\tregexNonASCII = /[^\\x20-\\x7E]/, // unprintable ASCII chars + non-ASCII chars\n\tregexSeparators = /[\\x2E\\u3002\\uFF0E\\uFF61]/g, // RFC 3490 separators\n\n\t/** Error messages */\n\terrors = {\n\t\t'overflow': 'Overflow: input needs wider integers to process',\n\t\t'not-basic': 'Illegal input >= 0x80 (not a basic code point)',\n\t\t'invalid-input': 'Invalid input'\n\t},\n\n\t/** Convenience shortcuts */\n\tbaseMinusTMin = base - tMin,\n\tfloor = Math.floor,\n\tstringFromCharCode = String.fromCharCode,\n\n\t/** Temporary variable */\n\tkey;\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/**\n\t * A generic error utility function.\n\t * @private\n\t * @param {String} type The error type.\n\t * @returns {Error} Throws a `RangeError` with the applicable error message.\n\t */\n\tfunction error(type) {\n\t\tthrow RangeError(errors[type]);\n\t}\n\n\t/**\n\t * A generic `Array#map` utility function.\n\t * @private\n\t * @param {Array} array The array to iterate over.\n\t * @param {Function} callback The function that gets called for every array\n\t * item.\n\t * @returns {Array} A new array of values returned by the callback function.\n\t */\n\tfunction map(array, fn) {\n\t\tvar length = array.length;\n\t\tvar result = [];\n\t\twhile (length--) {\n\t\t\tresult[length] = fn(array[length]);\n\t\t}\n\t\treturn result;\n\t}\n\n\t/**\n\t * A simple `Array#map`-like wrapper to work with domain name strings or email\n\t * addresses.\n\t * @private\n\t * @param {String} domain The domain name or email address.\n\t * @param {Function} callback The function that gets called for every\n\t * character.\n\t * @returns {Array} A new string of characters returned by the callback\n\t * function.\n\t */\n\tfunction mapDomain(string, fn) {\n\t\tvar parts = string.split('@');\n\t\tvar result = '';\n\t\tif (parts.length > 1) {\n\t\t\t// In email addresses, only the domain name should be punycoded. Leave\n\t\t\t// the local part (i.e. everything up to `@`) intact.\n\t\t\tresult = parts[0] + '@';\n\t\t\tstring = parts[1];\n\t\t}\n\t\t// Avoid `split(regex)` for IE8 compatibility. See #17.\n\t\tstring = string.replace(regexSeparators, '\\x2E');\n\t\tvar labels = string.split('.');\n\t\tvar encoded = map(labels, fn).join('.');\n\t\treturn result + encoded;\n\t}\n\n\t/**\n\t * Creates an array containing the numeric code points of each Unicode\n\t * character in the string. While JavaScript uses UCS-2 internally,\n\t * this function will convert a pair of surrogate halves (each of which\n\t * UCS-2 exposes as separate characters) into a single code point,\n\t * matching UTF-16.\n\t * @see `punycode.ucs2.encode`\n\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t * @memberOf punycode.ucs2\n\t * @name decode\n\t * @param {String} string The Unicode input string (UCS-2).\n\t * @returns {Array} The new array of code points.\n\t */\n\tfunction ucs2decode(string) {\n\t\tvar output = [],\n\t\t counter = 0,\n\t\t length = string.length,\n\t\t value,\n\t\t extra;\n\t\twhile (counter < length) {\n\t\t\tvalue = string.charCodeAt(counter++);\n\t\t\tif (value >= 0xD800 && value <= 0xDBFF && counter < length) {\n\t\t\t\t// high surrogate, and there is a next character\n\t\t\t\textra = string.charCodeAt(counter++);\n\t\t\t\tif ((extra & 0xFC00) == 0xDC00) { // low surrogate\n\t\t\t\t\toutput.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);\n\t\t\t\t} else {\n\t\t\t\t\t// unmatched surrogate; only append this code unit, in case the next\n\t\t\t\t\t// code unit is the high surrogate of a surrogate pair\n\t\t\t\t\toutput.push(value);\n\t\t\t\t\tcounter--;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\toutput.push(value);\n\t\t\t}\n\t\t}\n\t\treturn output;\n\t}\n\n\t/**\n\t * Creates a string based on an array of numeric code points.\n\t * @see `punycode.ucs2.decode`\n\t * @memberOf punycode.ucs2\n\t * @name encode\n\t * @param {Array} codePoints The array of numeric code points.\n\t * @returns {String} The new Unicode string (UCS-2).\n\t */\n\tfunction ucs2encode(array) {\n\t\treturn map(array, function(value) {\n\t\t\tvar output = '';\n\t\t\tif (value > 0xFFFF) {\n\t\t\t\tvalue -= 0x10000;\n\t\t\t\toutput += stringFromCharCode(value >>> 10 & 0x3FF | 0xD800);\n\t\t\t\tvalue = 0xDC00 | value & 0x3FF;\n\t\t\t}\n\t\t\toutput += stringFromCharCode(value);\n\t\t\treturn output;\n\t\t}).join('');\n\t}\n\n\t/**\n\t * Converts a basic code point into a digit/integer.\n\t * @see `digitToBasic()`\n\t * @private\n\t * @param {Number} codePoint The basic numeric code point value.\n\t * @returns {Number} The numeric value of a basic code point (for use in\n\t * representing integers) in the range `0` to `base - 1`, or `base` if\n\t * the code point does not represent a value.\n\t */\n\tfunction basicToDigit(codePoint) {\n\t\tif (codePoint - 48 < 10) {\n\t\t\treturn codePoint - 22;\n\t\t}\n\t\tif (codePoint - 65 < 26) {\n\t\t\treturn codePoint - 65;\n\t\t}\n\t\tif (codePoint - 97 < 26) {\n\t\t\treturn codePoint - 97;\n\t\t}\n\t\treturn base;\n\t}\n\n\t/**\n\t * Converts a digit/integer into a basic code point.\n\t * @see `basicToDigit()`\n\t * @private\n\t * @param {Number} digit The numeric value of a basic code point.\n\t * @returns {Number} The basic code point whose value (when used for\n\t * representing integers) is `digit`, which needs to be in the range\n\t * `0` to `base - 1`. If `flag` is non-zero, the uppercase form is\n\t * used; else, the lowercase form is used. The behavior is undefined\n\t * if `flag` is non-zero and `digit` has no uppercase form.\n\t */\n\tfunction digitToBasic(digit, flag) {\n\t\t// 0..25 map to ASCII a..z or A..Z\n\t\t// 26..35 map to ASCII 0..9\n\t\treturn digit + 22 + 75 * (digit < 26) - ((flag != 0) << 5);\n\t}\n\n\t/**\n\t * Bias adaptation function as per section 3.4 of RFC 3492.\n\t * http://tools.ietf.org/html/rfc3492#section-3.4\n\t * @private\n\t */\n\tfunction adapt(delta, numPoints, firstTime) {\n\t\tvar k = 0;\n\t\tdelta = firstTime ? floor(delta / damp) : delta >> 1;\n\t\tdelta += floor(delta / numPoints);\n\t\tfor (/* no initialization */; delta > baseMinusTMin * tMax >> 1; k += base) {\n\t\t\tdelta = floor(delta / baseMinusTMin);\n\t\t}\n\t\treturn floor(k + (baseMinusTMin + 1) * delta / (delta + skew));\n\t}\n\n\t/**\n\t * Converts a Punycode string of ASCII-only symbols to a string of Unicode\n\t * symbols.\n\t * @memberOf punycode\n\t * @param {String} input The Punycode string of ASCII-only symbols.\n\t * @returns {String} The resulting string of Unicode symbols.\n\t */\n\tfunction decode(input) {\n\t\t// Don't use UCS-2\n\t\tvar output = [],\n\t\t inputLength = input.length,\n\t\t out,\n\t\t i = 0,\n\t\t n = initialN,\n\t\t bias = initialBias,\n\t\t basic,\n\t\t j,\n\t\t index,\n\t\t oldi,\n\t\t w,\n\t\t k,\n\t\t digit,\n\t\t t,\n\t\t /** Cached calculation results */\n\t\t baseMinusT;\n\n\t\t// Handle the basic code points: let `basic` be the number of input code\n\t\t// points before the last delimiter, or `0` if there is none, then copy\n\t\t// the first basic code points to the output.\n\n\t\tbasic = input.lastIndexOf(delimiter);\n\t\tif (basic < 0) {\n\t\t\tbasic = 0;\n\t\t}\n\n\t\tfor (j = 0; j < basic; ++j) {\n\t\t\t// if it's not a basic code point\n\t\t\tif (input.charCodeAt(j) >= 0x80) {\n\t\t\t\terror('not-basic');\n\t\t\t}\n\t\t\toutput.push(input.charCodeAt(j));\n\t\t}\n\n\t\t// Main decoding loop: start just after the last delimiter if any basic code\n\t\t// points were copied; start at the beginning otherwise.\n\n\t\tfor (index = basic > 0 ? basic + 1 : 0; index < inputLength; /* no final expression */) {\n\n\t\t\t// `index` is the index of the next character to be consumed.\n\t\t\t// Decode a generalized variable-length integer into `delta`,\n\t\t\t// which gets added to `i`. The overflow checking is easier\n\t\t\t// if we increase `i` as we go, then subtract off its starting\n\t\t\t// value at the end to obtain `delta`.\n\t\t\tfor (oldi = i, w = 1, k = base; /* no condition */; k += base) {\n\n\t\t\t\tif (index >= inputLength) {\n\t\t\t\t\terror('invalid-input');\n\t\t\t\t}\n\n\t\t\t\tdigit = basicToDigit(input.charCodeAt(index++));\n\n\t\t\t\tif (digit >= base || digit > floor((maxInt - i) / w)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\ti += digit * w;\n\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\n\t\t\t\tif (digit < t) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tbaseMinusT = base - t;\n\t\t\t\tif (w > floor(maxInt / baseMinusT)) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tw *= baseMinusT;\n\n\t\t\t}\n\n\t\t\tout = output.length + 1;\n\t\t\tbias = adapt(i - oldi, out, oldi == 0);\n\n\t\t\t// `i` was supposed to wrap around from `out` to `0`,\n\t\t\t// incrementing `n` each time, so we'll fix that now:\n\t\t\tif (floor(i / out) > maxInt - n) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tn += floor(i / out);\n\t\t\ti %= out;\n\n\t\t\t// Insert `n` at position `i` of the output\n\t\t\toutput.splice(i++, 0, n);\n\n\t\t}\n\n\t\treturn ucs2encode(output);\n\t}\n\n\t/**\n\t * Converts a string of Unicode symbols (e.g. a domain name label) to a\n\t * Punycode string of ASCII-only symbols.\n\t * @memberOf punycode\n\t * @param {String} input The string of Unicode symbols.\n\t * @returns {String} The resulting Punycode string of ASCII-only symbols.\n\t */\n\tfunction encode(input) {\n\t\tvar n,\n\t\t delta,\n\t\t handledCPCount,\n\t\t basicLength,\n\t\t bias,\n\t\t j,\n\t\t m,\n\t\t q,\n\t\t k,\n\t\t t,\n\t\t currentValue,\n\t\t output = [],\n\t\t /** `inputLength` will hold the number of code points in `input`. */\n\t\t inputLength,\n\t\t /** Cached calculation results */\n\t\t handledCPCountPlusOne,\n\t\t baseMinusT,\n\t\t qMinusT;\n\n\t\t// Convert the input in UCS-2 to Unicode\n\t\tinput = ucs2decode(input);\n\n\t\t// Cache the length\n\t\tinputLength = input.length;\n\n\t\t// Initialize the state\n\t\tn = initialN;\n\t\tdelta = 0;\n\t\tbias = initialBias;\n\n\t\t// Handle the basic code points\n\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\tcurrentValue = input[j];\n\t\t\tif (currentValue < 0x80) {\n\t\t\t\toutput.push(stringFromCharCode(currentValue));\n\t\t\t}\n\t\t}\n\n\t\thandledCPCount = basicLength = output.length;\n\n\t\t// `handledCPCount` is the number of code points that have been handled;\n\t\t// `basicLength` is the number of basic code points.\n\n\t\t// Finish the basic string - if it is not empty - with a delimiter\n\t\tif (basicLength) {\n\t\t\toutput.push(delimiter);\n\t\t}\n\n\t\t// Main encoding loop:\n\t\twhile (handledCPCount < inputLength) {\n\n\t\t\t// All non-basic code points < n have been handled already. Find the next\n\t\t\t// larger one:\n\t\t\tfor (m = maxInt, j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\t\t\t\tif (currentValue >= n && currentValue < m) {\n\t\t\t\t\tm = currentValue;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t// Increase `delta` enough to advance the decoder's <n,i> state to <m,0>,\n\t\t\t// but guard against overflow\n\t\t\thandledCPCountPlusOne = handledCPCount + 1;\n\t\t\tif (m - n > floor((maxInt - delta) / handledCPCountPlusOne)) {\n\t\t\t\terror('overflow');\n\t\t\t}\n\n\t\t\tdelta += (m - n) * handledCPCountPlusOne;\n\t\t\tn = m;\n\n\t\t\tfor (j = 0; j < inputLength; ++j) {\n\t\t\t\tcurrentValue = input[j];\n\n\t\t\t\tif (currentValue < n && ++delta > maxInt) {\n\t\t\t\t\terror('overflow');\n\t\t\t\t}\n\n\t\t\t\tif (currentValue == n) {\n\t\t\t\t\t// Represent delta as a generalized variable-length integer\n\t\t\t\t\tfor (q = delta, k = base; /* no condition */; k += base) {\n\t\t\t\t\t\tt = k <= bias ? tMin : (k >= bias + tMax ? tMax : k - bias);\n\t\t\t\t\t\tif (q < t) {\n\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tqMinusT = q - t;\n\t\t\t\t\t\tbaseMinusT = base - t;\n\t\t\t\t\t\toutput.push(\n\t\t\t\t\t\t\tstringFromCharCode(digitToBasic(t + qMinusT % baseMinusT, 0))\n\t\t\t\t\t\t);\n\t\t\t\t\t\tq = floor(qMinusT / baseMinusT);\n\t\t\t\t\t}\n\n\t\t\t\t\toutput.push(stringFromCharCode(digitToBasic(q, 0)));\n\t\t\t\t\tbias = adapt(delta, handledCPCountPlusOne, handledCPCount == basicLength);\n\t\t\t\t\tdelta = 0;\n\t\t\t\t\t++handledCPCount;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\t++delta;\n\t\t\t++n;\n\n\t\t}\n\t\treturn output.join('');\n\t}\n\n\t/**\n\t * Converts a Punycode string representing a domain name or an email address\n\t * to Unicode. Only the Punycoded parts of the input will be converted, i.e.\n\t * it doesn't matter if you call it on a string that has already been\n\t * converted to Unicode.\n\t * @memberOf punycode\n\t * @param {String} input The Punycoded domain name or email address to\n\t * convert to Unicode.\n\t * @returns {String} The Unicode representation of the given Punycode\n\t * string.\n\t */\n\tfunction toUnicode(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexPunycode.test(string)\n\t\t\t\t? decode(string.slice(4).toLowerCase())\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/**\n\t * Converts a Unicode string representing a domain name or an email address to\n\t * Punycode. Only the non-ASCII parts of the domain name will be converted,\n\t * i.e. it doesn't matter if you call it with a domain that's already in\n\t * ASCII.\n\t * @memberOf punycode\n\t * @param {String} input The domain name or email address to convert, as a\n\t * Unicode string.\n\t * @returns {String} The Punycode representation of the given domain name or\n\t * email address.\n\t */\n\tfunction toASCII(input) {\n\t\treturn mapDomain(input, function(string) {\n\t\t\treturn regexNonASCII.test(string)\n\t\t\t\t? 'xn--' + encode(string)\n\t\t\t\t: string;\n\t\t});\n\t}\n\n\t/*--------------------------------------------------------------------------*/\n\n\t/** Define the public API */\n\tpunycode = {\n\t\t/**\n\t\t * A string representing the current Punycode.js version number.\n\t\t * @memberOf punycode\n\t\t * @type String\n\t\t */\n\t\t'version': '1.3.2',\n\t\t/**\n\t\t * An object of methods to convert from JavaScript's internal character\n\t\t * representation (UCS-2) to Unicode code points, and back.\n\t\t * @see <https://mathiasbynens.be/notes/javascript-encoding>\n\t\t * @memberOf punycode\n\t\t * @type Object\n\t\t */\n\t\t'ucs2': {\n\t\t\t'decode': ucs2decode,\n\t\t\t'encode': ucs2encode\n\t\t},\n\t\t'decode': decode,\n\t\t'encode': encode,\n\t\t'toASCII': toASCII,\n\t\t'toUnicode': toUnicode\n\t};\n\n\t/** Expose `punycode` */\n\t// Some AMD build optimizers, like r.js, check for specific condition patterns\n\t// like the following:\n\tif (\n\t\ttypeof define == 'function' &&\n\t\ttypeof define.amd == 'object' &&\n\t\tdefine.amd\n\t) {\n\t\tdefine('punycode', function() {\n\t\t\treturn punycode;\n\t\t});\n\t} else if (freeExports && freeModule) {\n\t\tif (module.exports == freeExports) { // in Node.js or RingoJS v0.8.0+\n\t\t\tfreeModule.exports = punycode;\n\t\t} else { // in Narwhal or RingoJS v0.7.0-\n\t\t\tfor (key in punycode) {\n\t\t\t\tpunycode.hasOwnProperty(key) && (freeExports[key] = punycode[key]);\n\t\t\t}\n\t\t}\n\t} else { // in Rhino or a web browser\n\t\troot.punycode = punycode;\n\t}\n\n}(this));\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\n// If obj.hasOwnProperty has been overridden, then calling\n// obj.hasOwnProperty(prop) will break.\n// See: https://github.com/joyent/node/issues/1707\nfunction hasOwnProperty(obj, prop) {\n return Object.prototype.hasOwnProperty.call(obj, prop);\n}\n\nmodule.exports = function(qs, sep, eq, options) {\n sep = sep || '&';\n eq = eq || '=';\n var obj = {};\n\n if (typeof qs !== 'string' || qs.length === 0) {\n return obj;\n }\n\n var regexp = /\\+/g;\n qs = qs.split(sep);\n\n var maxKeys = 1000;\n if (options && typeof options.maxKeys === 'number') {\n maxKeys = options.maxKeys;\n }\n\n var len = qs.length;\n // maxKeys <= 0 means that we should not limit keys count\n if (maxKeys > 0 && len > maxKeys) {\n len = maxKeys;\n }\n\n for (var i = 0; i < len; ++i) {\n var x = qs[i].replace(regexp, '%20'),\n idx = x.indexOf(eq),\n kstr, vstr, k, v;\n\n if (idx >= 0) {\n kstr = x.substr(0, idx);\n vstr = x.substr(idx + 1);\n } else {\n kstr = x;\n vstr = '';\n }\n\n k = decodeURIComponent(kstr);\n v = decodeURIComponent(vstr);\n\n if (!hasOwnProperty(obj, k)) {\n obj[k] = v;\n } else if (Array.isArray(obj[k])) {\n obj[k].push(v);\n } else {\n obj[k] = [obj[k], v];\n }\n }\n\n return obj;\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar stringifyPrimitive = function(v) {\n switch (typeof v) {\n case 'string':\n return v;\n\n case 'boolean':\n return v ? 'true' : 'false';\n\n case 'number':\n return isFinite(v) ? v : '';\n\n default:\n return '';\n }\n};\n\nmodule.exports = function(obj, sep, eq, name) {\n sep = sep || '&';\n eq = eq || '=';\n if (obj === null) {\n obj = undefined;\n }\n\n if (typeof obj === 'object') {\n return Object.keys(obj).map(function(k) {\n var ks = encodeURIComponent(stringifyPrimitive(k)) + eq;\n if (Array.isArray(obj[k])) {\n return obj[k].map(function(v) {\n return ks + encodeURIComponent(stringifyPrimitive(v));\n }).join(sep);\n } else {\n return ks + encodeURIComponent(stringifyPrimitive(obj[k]));\n }\n }).join(sep);\n\n }\n\n if (!name) return '';\n return encodeURIComponent(stringifyPrimitive(name)) + eq +\n encodeURIComponent(stringifyPrimitive(obj));\n};\n","'use strict';\n\nexports.decode = exports.parse = require('./decode');\nexports.encode = exports.stringify = require('./encode');\n","/**\n * @license React\n * react-dom.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n/*\n Modernizr 3.0.0pre (Custom Build) | MIT\n*/\n'use strict';var aa=require(\"react\"),ca=require(\"scheduler\");function p(a){for(var b=\"https://reactjs.org/docs/error-decoder.html?invariant=\"+a,c=1;c<arguments.length;c++)b+=\"&args[]=\"+encodeURIComponent(arguments[c]);return\"Minified React error #\"+a+\"; visit \"+b+\" for the full message or use the non-minified dev environment for full errors and additional helpful warnings.\"}var da=new Set,ea={};function fa(a,b){ha(a,b);ha(a+\"Capture\",b)}\nfunction ha(a,b){ea[a]=b;for(a=0;a<b.length;a++)da.add(b[a])}\nvar ia=!(\"undefined\"===typeof window||\"undefined\"===typeof window.document||\"undefined\"===typeof window.document.createElement),ja=Object.prototype.hasOwnProperty,ka=/^[:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD][:A-Z_a-z\\u00C0-\\u00D6\\u00D8-\\u00F6\\u00F8-\\u02FF\\u0370-\\u037D\\u037F-\\u1FFF\\u200C-\\u200D\\u2070-\\u218F\\u2C00-\\u2FEF\\u3001-\\uD7FF\\uF900-\\uFDCF\\uFDF0-\\uFFFD\\-.0-9\\u00B7\\u0300-\\u036F\\u203F-\\u2040]*$/,la=\n{},ma={};function oa(a){if(ja.call(ma,a))return!0;if(ja.call(la,a))return!1;if(ka.test(a))return ma[a]=!0;la[a]=!0;return!1}function pa(a,b,c,d){if(null!==c&&0===c.type)return!1;switch(typeof b){case \"function\":case \"symbol\":return!0;case \"boolean\":if(d)return!1;if(null!==c)return!c.acceptsBooleans;a=a.toLowerCase().slice(0,5);return\"data-\"!==a&&\"aria-\"!==a;default:return!1}}\nfunction qa(a,b,c,d){if(null===b||\"undefined\"===typeof b||pa(a,b,c,d))return!0;if(d)return!1;if(null!==c)switch(c.type){case 3:return!b;case 4:return!1===b;case 5:return isNaN(b);case 6:return isNaN(b)||1>b}return!1}function v(a,b,c,d,e,f,g){this.acceptsBooleans=2===b||3===b||4===b;this.attributeName=d;this.attributeNamespace=e;this.mustUseProperty=c;this.propertyName=a;this.type=b;this.sanitizeURL=f;this.removeEmptyString=g}var z={};\n\"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style\".split(\" \").forEach(function(a){z[a]=new v(a,0,!1,a,null,!1,!1)});[[\"acceptCharset\",\"accept-charset\"],[\"className\",\"class\"],[\"htmlFor\",\"for\"],[\"httpEquiv\",\"http-equiv\"]].forEach(function(a){var b=a[0];z[b]=new v(b,1,!1,a[1],null,!1,!1)});[\"contentEditable\",\"draggable\",\"spellCheck\",\"value\"].forEach(function(a){z[a]=new v(a,2,!1,a.toLowerCase(),null,!1,!1)});\n[\"autoReverse\",\"externalResourcesRequired\",\"focusable\",\"preserveAlpha\"].forEach(function(a){z[a]=new v(a,2,!1,a,null,!1,!1)});\"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope\".split(\" \").forEach(function(a){z[a]=new v(a,3,!1,a.toLowerCase(),null,!1,!1)});\n[\"checked\",\"multiple\",\"muted\",\"selected\"].forEach(function(a){z[a]=new v(a,3,!0,a,null,!1,!1)});[\"capture\",\"download\"].forEach(function(a){z[a]=new v(a,4,!1,a,null,!1,!1)});[\"cols\",\"rows\",\"size\",\"span\"].forEach(function(a){z[a]=new v(a,6,!1,a,null,!1,!1)});[\"rowSpan\",\"start\"].forEach(function(a){z[a]=new v(a,5,!1,a.toLowerCase(),null,!1,!1)});var ra=/[\\-:]([a-z])/g;function sa(a){return a[1].toUpperCase()}\n\"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height\".split(\" \").forEach(function(a){var b=a.replace(ra,\nsa);z[b]=new v(b,1,!1,a,null,!1,!1)});\"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type\".split(\" \").forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/1999/xlink\",!1,!1)});[\"xml:base\",\"xml:lang\",\"xml:space\"].forEach(function(a){var b=a.replace(ra,sa);z[b]=new v(b,1,!1,a,\"http://www.w3.org/XML/1998/namespace\",!1,!1)});[\"tabIndex\",\"crossOrigin\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!1,!1)});\nz.xlinkHref=new v(\"xlinkHref\",1,!1,\"xlink:href\",\"http://www.w3.org/1999/xlink\",!0,!1);[\"src\",\"href\",\"action\",\"formAction\"].forEach(function(a){z[a]=new v(a,1,!1,a.toLowerCase(),null,!0,!0)});\nfunction ta(a,b,c,d){var e=z.hasOwnProperty(b)?z[b]:null;if(null!==e?0!==e.type:d||!(2<b.length)||\"o\"!==b[0]&&\"O\"!==b[0]||\"n\"!==b[1]&&\"N\"!==b[1])qa(b,c,e,d)&&(c=null),d||null===e?oa(b)&&(null===c?a.removeAttribute(b):a.setAttribute(b,\"\"+c)):e.mustUseProperty?a[e.propertyName]=null===c?3===e.type?!1:\"\":c:(b=e.attributeName,d=e.attributeNamespace,null===c?a.removeAttribute(b):(e=e.type,c=3===e||4===e&&!0===c?\"\":\"\"+c,d?a.setAttributeNS(d,b,c):a.setAttribute(b,c)))}\nvar ua=aa.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED,va=Symbol.for(\"react.element\"),wa=Symbol.for(\"react.portal\"),ya=Symbol.for(\"react.fragment\"),za=Symbol.for(\"react.strict_mode\"),Aa=Symbol.for(\"react.profiler\"),Ba=Symbol.for(\"react.provider\"),Ca=Symbol.for(\"react.context\"),Da=Symbol.for(\"react.forward_ref\"),Ea=Symbol.for(\"react.suspense\"),Fa=Symbol.for(\"react.suspense_list\"),Ga=Symbol.for(\"react.memo\"),Ha=Symbol.for(\"react.lazy\");Symbol.for(\"react.scope\");Symbol.for(\"react.debug_trace_mode\");\nvar Ia=Symbol.for(\"react.offscreen\");Symbol.for(\"react.legacy_hidden\");Symbol.for(\"react.cache\");Symbol.for(\"react.tracing_marker\");var Ja=Symbol.iterator;function Ka(a){if(null===a||\"object\"!==typeof a)return null;a=Ja&&a[Ja]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}var A=Object.assign,La;function Ma(a){if(void 0===La)try{throw Error();}catch(c){var b=c.stack.trim().match(/\\n( *(at )?)/);La=b&&b[1]||\"\"}return\"\\n\"+La+a}var Na=!1;\nfunction Oa(a,b){if(!a||Na)return\"\";Na=!0;var c=Error.prepareStackTrace;Error.prepareStackTrace=void 0;try{if(b)if(b=function(){throw Error();},Object.defineProperty(b.prototype,\"props\",{set:function(){throw Error();}}),\"object\"===typeof Reflect&&Reflect.construct){try{Reflect.construct(b,[])}catch(l){var d=l}Reflect.construct(a,[],b)}else{try{b.call()}catch(l){d=l}a.call(b.prototype)}else{try{throw Error();}catch(l){d=l}a()}}catch(l){if(l&&d&&\"string\"===typeof l.stack){for(var e=l.stack.split(\"\\n\"),\nf=d.stack.split(\"\\n\"),g=e.length-1,h=f.length-1;1<=g&&0<=h&&e[g]!==f[h];)h--;for(;1<=g&&0<=h;g--,h--)if(e[g]!==f[h]){if(1!==g||1!==h){do if(g--,h--,0>h||e[g]!==f[h]){var k=\"\\n\"+e[g].replace(\" at new \",\" at \");a.displayName&&k.includes(\"<anonymous>\")&&(k=k.replace(\"<anonymous>\",a.displayName));return k}while(1<=g&&0<=h)}break}}}finally{Na=!1,Error.prepareStackTrace=c}return(a=a?a.displayName||a.name:\"\")?Ma(a):\"\"}\nfunction Pa(a){switch(a.tag){case 5:return Ma(a.type);case 16:return Ma(\"Lazy\");case 13:return Ma(\"Suspense\");case 19:return Ma(\"SuspenseList\");case 0:case 2:case 15:return a=Oa(a.type,!1),a;case 11:return a=Oa(a.type.render,!1),a;case 1:return a=Oa(a.type,!0),a;default:return\"\"}}\nfunction Qa(a){if(null==a)return null;if(\"function\"===typeof a)return a.displayName||a.name||null;if(\"string\"===typeof a)return a;switch(a){case ya:return\"Fragment\";case wa:return\"Portal\";case Aa:return\"Profiler\";case za:return\"StrictMode\";case Ea:return\"Suspense\";case Fa:return\"SuspenseList\"}if(\"object\"===typeof a)switch(a.$$typeof){case Ca:return(a.displayName||\"Context\")+\".Consumer\";case Ba:return(a._context.displayName||\"Context\")+\".Provider\";case Da:var b=a.render;a=a.displayName;a||(a=b.displayName||\nb.name||\"\",a=\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");return a;case Ga:return b=a.displayName||null,null!==b?b:Qa(a.type)||\"Memo\";case Ha:b=a._payload;a=a._init;try{return Qa(a(b))}catch(c){}}return null}\nfunction Ra(a){var b=a.type;switch(a.tag){case 24:return\"Cache\";case 9:return(b.displayName||\"Context\")+\".Consumer\";case 10:return(b._context.displayName||\"Context\")+\".Provider\";case 18:return\"DehydratedFragment\";case 11:return a=b.render,a=a.displayName||a.name||\"\",b.displayName||(\"\"!==a?\"ForwardRef(\"+a+\")\":\"ForwardRef\");case 7:return\"Fragment\";case 5:return b;case 4:return\"Portal\";case 3:return\"Root\";case 6:return\"Text\";case 16:return Qa(b);case 8:return b===za?\"StrictMode\":\"Mode\";case 22:return\"Offscreen\";\ncase 12:return\"Profiler\";case 21:return\"Scope\";case 13:return\"Suspense\";case 19:return\"SuspenseList\";case 25:return\"TracingMarker\";case 1:case 0:case 17:case 2:case 14:case 15:if(\"function\"===typeof b)return b.displayName||b.name||null;if(\"string\"===typeof b)return b}return null}function Sa(a){switch(typeof a){case \"boolean\":case \"number\":case \"string\":case \"undefined\":return a;case \"object\":return a;default:return\"\"}}\nfunction Ta(a){var b=a.type;return(a=a.nodeName)&&\"input\"===a.toLowerCase()&&(\"checkbox\"===b||\"radio\"===b)}\nfunction Ua(a){var b=Ta(a)?\"checked\":\"value\",c=Object.getOwnPropertyDescriptor(a.constructor.prototype,b),d=\"\"+a[b];if(!a.hasOwnProperty(b)&&\"undefined\"!==typeof c&&\"function\"===typeof c.get&&\"function\"===typeof c.set){var e=c.get,f=c.set;Object.defineProperty(a,b,{configurable:!0,get:function(){return e.call(this)},set:function(a){d=\"\"+a;f.call(this,a)}});Object.defineProperty(a,b,{enumerable:c.enumerable});return{getValue:function(){return d},setValue:function(a){d=\"\"+a},stopTracking:function(){a._valueTracker=\nnull;delete a[b]}}}}function Va(a){a._valueTracker||(a._valueTracker=Ua(a))}function Wa(a){if(!a)return!1;var b=a._valueTracker;if(!b)return!0;var c=b.getValue();var d=\"\";a&&(d=Ta(a)?a.checked?\"true\":\"false\":a.value);a=d;return a!==c?(b.setValue(a),!0):!1}function Xa(a){a=a||(\"undefined\"!==typeof document?document:void 0);if(\"undefined\"===typeof a)return null;try{return a.activeElement||a.body}catch(b){return a.body}}\nfunction Ya(a,b){var c=b.checked;return A({},b,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:null!=c?c:a._wrapperState.initialChecked})}function Za(a,b){var c=null==b.defaultValue?\"\":b.defaultValue,d=null!=b.checked?b.checked:b.defaultChecked;c=Sa(null!=b.value?b.value:c);a._wrapperState={initialChecked:d,initialValue:c,controlled:\"checkbox\"===b.type||\"radio\"===b.type?null!=b.checked:null!=b.value}}function ab(a,b){b=b.checked;null!=b&&ta(a,\"checked\",b,!1)}\nfunction bb(a,b){ab(a,b);var c=Sa(b.value),d=b.type;if(null!=c)if(\"number\"===d){if(0===c&&\"\"===a.value||a.value!=c)a.value=\"\"+c}else a.value!==\"\"+c&&(a.value=\"\"+c);else if(\"submit\"===d||\"reset\"===d){a.removeAttribute(\"value\");return}b.hasOwnProperty(\"value\")?cb(a,b.type,c):b.hasOwnProperty(\"defaultValue\")&&cb(a,b.type,Sa(b.defaultValue));null==b.checked&&null!=b.defaultChecked&&(a.defaultChecked=!!b.defaultChecked)}\nfunction db(a,b,c){if(b.hasOwnProperty(\"value\")||b.hasOwnProperty(\"defaultValue\")){var d=b.type;if(!(\"submit\"!==d&&\"reset\"!==d||void 0!==b.value&&null!==b.value))return;b=\"\"+a._wrapperState.initialValue;c||b===a.value||(a.value=b);a.defaultValue=b}c=a.name;\"\"!==c&&(a.name=\"\");a.defaultChecked=!!a._wrapperState.initialChecked;\"\"!==c&&(a.name=c)}\nfunction cb(a,b,c){if(\"number\"!==b||Xa(a.ownerDocument)!==a)null==c?a.defaultValue=\"\"+a._wrapperState.initialValue:a.defaultValue!==\"\"+c&&(a.defaultValue=\"\"+c)}var eb=Array.isArray;\nfunction fb(a,b,c,d){a=a.options;if(b){b={};for(var e=0;e<c.length;e++)b[\"$\"+c[e]]=!0;for(c=0;c<a.length;c++)e=b.hasOwnProperty(\"$\"+a[c].value),a[c].selected!==e&&(a[c].selected=e),e&&d&&(a[c].defaultSelected=!0)}else{c=\"\"+Sa(c);b=null;for(e=0;e<a.length;e++){if(a[e].value===c){a[e].selected=!0;d&&(a[e].defaultSelected=!0);return}null!==b||a[e].disabled||(b=a[e])}null!==b&&(b.selected=!0)}}\nfunction gb(a,b){if(null!=b.dangerouslySetInnerHTML)throw Error(p(91));return A({},b,{value:void 0,defaultValue:void 0,children:\"\"+a._wrapperState.initialValue})}function hb(a,b){var c=b.value;if(null==c){c=b.children;b=b.defaultValue;if(null!=c){if(null!=b)throw Error(p(92));if(eb(c)){if(1<c.length)throw Error(p(93));c=c[0]}b=c}null==b&&(b=\"\");c=b}a._wrapperState={initialValue:Sa(c)}}\nfunction ib(a,b){var c=Sa(b.value),d=Sa(b.defaultValue);null!=c&&(c=\"\"+c,c!==a.value&&(a.value=c),null==b.defaultValue&&a.defaultValue!==c&&(a.defaultValue=c));null!=d&&(a.defaultValue=\"\"+d)}function jb(a){var b=a.textContent;b===a._wrapperState.initialValue&&\"\"!==b&&null!==b&&(a.value=b)}function kb(a){switch(a){case \"svg\":return\"http://www.w3.org/2000/svg\";case \"math\":return\"http://www.w3.org/1998/Math/MathML\";default:return\"http://www.w3.org/1999/xhtml\"}}\nfunction lb(a,b){return null==a||\"http://www.w3.org/1999/xhtml\"===a?kb(b):\"http://www.w3.org/2000/svg\"===a&&\"foreignObject\"===b?\"http://www.w3.org/1999/xhtml\":a}\nvar mb,nb=function(a){return\"undefined\"!==typeof MSApp&&MSApp.execUnsafeLocalFunction?function(b,c,d,e){MSApp.execUnsafeLocalFunction(function(){return a(b,c,d,e)})}:a}(function(a,b){if(\"http://www.w3.org/2000/svg\"!==a.namespaceURI||\"innerHTML\"in a)a.innerHTML=b;else{mb=mb||document.createElement(\"div\");mb.innerHTML=\"<svg>\"+b.valueOf().toString()+\"</svg>\";for(b=mb.firstChild;a.firstChild;)a.removeChild(a.firstChild);for(;b.firstChild;)a.appendChild(b.firstChild)}});\nfunction ob(a,b){if(b){var c=a.firstChild;if(c&&c===a.lastChild&&3===c.nodeType){c.nodeValue=b;return}}a.textContent=b}\nvar pb={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,\nzoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},qb=[\"Webkit\",\"ms\",\"Moz\",\"O\"];Object.keys(pb).forEach(function(a){qb.forEach(function(b){b=b+a.charAt(0).toUpperCase()+a.substring(1);pb[b]=pb[a]})});function rb(a,b,c){return null==b||\"boolean\"===typeof b||\"\"===b?\"\":c||\"number\"!==typeof b||0===b||pb.hasOwnProperty(a)&&pb[a]?(\"\"+b).trim():b+\"px\"}\nfunction sb(a,b){a=a.style;for(var c in b)if(b.hasOwnProperty(c)){var d=0===c.indexOf(\"--\"),e=rb(c,b[c],d);\"float\"===c&&(c=\"cssFloat\");d?a.setProperty(c,e):a[c]=e}}var tb=A({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});\nfunction ub(a,b){if(b){if(tb[a]&&(null!=b.children||null!=b.dangerouslySetInnerHTML))throw Error(p(137,a));if(null!=b.dangerouslySetInnerHTML){if(null!=b.children)throw Error(p(60));if(\"object\"!==typeof b.dangerouslySetInnerHTML||!(\"__html\"in b.dangerouslySetInnerHTML))throw Error(p(61));}if(null!=b.style&&\"object\"!==typeof b.style)throw Error(p(62));}}\nfunction vb(a,b){if(-1===a.indexOf(\"-\"))return\"string\"===typeof b.is;switch(a){case \"annotation-xml\":case \"color-profile\":case \"font-face\":case \"font-face-src\":case \"font-face-uri\":case \"font-face-format\":case \"font-face-name\":case \"missing-glyph\":return!1;default:return!0}}var wb=null;function xb(a){a=a.target||a.srcElement||window;a.correspondingUseElement&&(a=a.correspondingUseElement);return 3===a.nodeType?a.parentNode:a}var yb=null,zb=null,Ab=null;\nfunction Bb(a){if(a=Cb(a)){if(\"function\"!==typeof yb)throw Error(p(280));var b=a.stateNode;b&&(b=Db(b),yb(a.stateNode,a.type,b))}}function Eb(a){zb?Ab?Ab.push(a):Ab=[a]:zb=a}function Fb(){if(zb){var a=zb,b=Ab;Ab=zb=null;Bb(a);if(b)for(a=0;a<b.length;a++)Bb(b[a])}}function Gb(a,b){return a(b)}function Hb(){}var Ib=!1;function Jb(a,b,c){if(Ib)return a(b,c);Ib=!0;try{return Gb(a,b,c)}finally{if(Ib=!1,null!==zb||null!==Ab)Hb(),Fb()}}\nfunction Kb(a,b){var c=a.stateNode;if(null===c)return null;var d=Db(c);if(null===d)return null;c=d[b];a:switch(b){case \"onClick\":case \"onClickCapture\":case \"onDoubleClick\":case \"onDoubleClickCapture\":case \"onMouseDown\":case \"onMouseDownCapture\":case \"onMouseMove\":case \"onMouseMoveCapture\":case \"onMouseUp\":case \"onMouseUpCapture\":case \"onMouseEnter\":(d=!d.disabled)||(a=a.type,d=!(\"button\"===a||\"input\"===a||\"select\"===a||\"textarea\"===a));a=!d;break a;default:a=!1}if(a)return null;if(c&&\"function\"!==\ntypeof c)throw Error(p(231,b,typeof c));return c}var Lb=!1;if(ia)try{var Mb={};Object.defineProperty(Mb,\"passive\",{get:function(){Lb=!0}});window.addEventListener(\"test\",Mb,Mb);window.removeEventListener(\"test\",Mb,Mb)}catch(a){Lb=!1}function Nb(a,b,c,d,e,f,g,h,k){var l=Array.prototype.slice.call(arguments,3);try{b.apply(c,l)}catch(m){this.onError(m)}}var Ob=!1,Pb=null,Qb=!1,Rb=null,Sb={onError:function(a){Ob=!0;Pb=a}};function Tb(a,b,c,d,e,f,g,h,k){Ob=!1;Pb=null;Nb.apply(Sb,arguments)}\nfunction Ub(a,b,c,d,e,f,g,h,k){Tb.apply(this,arguments);if(Ob){if(Ob){var l=Pb;Ob=!1;Pb=null}else throw Error(p(198));Qb||(Qb=!0,Rb=l)}}function Vb(a){var b=a,c=a;if(a.alternate)for(;b.return;)b=b.return;else{a=b;do b=a,0!==(b.flags&4098)&&(c=b.return),a=b.return;while(a)}return 3===b.tag?c:null}function Wb(a){if(13===a.tag){var b=a.memoizedState;null===b&&(a=a.alternate,null!==a&&(b=a.memoizedState));if(null!==b)return b.dehydrated}return null}function Xb(a){if(Vb(a)!==a)throw Error(p(188));}\nfunction Yb(a){var b=a.alternate;if(!b){b=Vb(a);if(null===b)throw Error(p(188));return b!==a?null:a}for(var c=a,d=b;;){var e=c.return;if(null===e)break;var f=e.alternate;if(null===f){d=e.return;if(null!==d){c=d;continue}break}if(e.child===f.child){for(f=e.child;f;){if(f===c)return Xb(e),a;if(f===d)return Xb(e),b;f=f.sibling}throw Error(p(188));}if(c.return!==d.return)c=e,d=f;else{for(var g=!1,h=e.child;h;){if(h===c){g=!0;c=e;d=f;break}if(h===d){g=!0;d=e;c=f;break}h=h.sibling}if(!g){for(h=f.child;h;){if(h===\nc){g=!0;c=f;d=e;break}if(h===d){g=!0;d=f;c=e;break}h=h.sibling}if(!g)throw Error(p(189));}}if(c.alternate!==d)throw Error(p(190));}if(3!==c.tag)throw Error(p(188));return c.stateNode.current===c?a:b}function Zb(a){a=Yb(a);return null!==a?$b(a):null}function $b(a){if(5===a.tag||6===a.tag)return a;for(a=a.child;null!==a;){var b=$b(a);if(null!==b)return b;a=a.sibling}return null}\nvar ac=ca.unstable_scheduleCallback,bc=ca.unstable_cancelCallback,cc=ca.unstable_shouldYield,dc=ca.unstable_requestPaint,B=ca.unstable_now,ec=ca.unstable_getCurrentPriorityLevel,fc=ca.unstable_ImmediatePriority,gc=ca.unstable_UserBlockingPriority,hc=ca.unstable_NormalPriority,ic=ca.unstable_LowPriority,jc=ca.unstable_IdlePriority,kc=null,lc=null;function mc(a){if(lc&&\"function\"===typeof lc.onCommitFiberRoot)try{lc.onCommitFiberRoot(kc,a,void 0,128===(a.current.flags&128))}catch(b){}}\nvar oc=Math.clz32?Math.clz32:nc,pc=Math.log,qc=Math.LN2;function nc(a){a>>>=0;return 0===a?32:31-(pc(a)/qc|0)|0}var rc=64,sc=4194304;\nfunction tc(a){switch(a&-a){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return a&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return a&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;\ndefault:return a}}function uc(a,b){var c=a.pendingLanes;if(0===c)return 0;var d=0,e=a.suspendedLanes,f=a.pingedLanes,g=c&268435455;if(0!==g){var h=g&~e;0!==h?d=tc(h):(f&=g,0!==f&&(d=tc(f)))}else g=c&~e,0!==g?d=tc(g):0!==f&&(d=tc(f));if(0===d)return 0;if(0!==b&&b!==d&&0===(b&e)&&(e=d&-d,f=b&-b,e>=f||16===e&&0!==(f&4194240)))return b;0!==(d&4)&&(d|=c&16);b=a.entangledLanes;if(0!==b)for(a=a.entanglements,b&=d;0<b;)c=31-oc(b),e=1<<c,d|=a[c],b&=~e;return d}\nfunction vc(a,b){switch(a){case 1:case 2:case 4:return b+250;case 8:case 16:case 32:case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return b+5E3;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return-1;case 134217728:case 268435456:case 536870912:case 1073741824:return-1;default:return-1}}\nfunction wc(a,b){for(var c=a.suspendedLanes,d=a.pingedLanes,e=a.expirationTimes,f=a.pendingLanes;0<f;){var g=31-oc(f),h=1<<g,k=e[g];if(-1===k){if(0===(h&c)||0!==(h&d))e[g]=vc(h,b)}else k<=b&&(a.expiredLanes|=h);f&=~h}}function xc(a){a=a.pendingLanes&-1073741825;return 0!==a?a:a&1073741824?1073741824:0}function yc(){var a=rc;rc<<=1;0===(rc&4194240)&&(rc=64);return a}function zc(a){for(var b=[],c=0;31>c;c++)b.push(a);return b}\nfunction Ac(a,b,c){a.pendingLanes|=b;536870912!==b&&(a.suspendedLanes=0,a.pingedLanes=0);a=a.eventTimes;b=31-oc(b);a[b]=c}function Bc(a,b){var c=a.pendingLanes&~b;a.pendingLanes=b;a.suspendedLanes=0;a.pingedLanes=0;a.expiredLanes&=b;a.mutableReadLanes&=b;a.entangledLanes&=b;b=a.entanglements;var d=a.eventTimes;for(a=a.expirationTimes;0<c;){var e=31-oc(c),f=1<<e;b[e]=0;d[e]=-1;a[e]=-1;c&=~f}}\nfunction Cc(a,b){var c=a.entangledLanes|=b;for(a=a.entanglements;c;){var d=31-oc(c),e=1<<d;e&b|a[d]&b&&(a[d]|=b);c&=~e}}var C=0;function Dc(a){a&=-a;return 1<a?4<a?0!==(a&268435455)?16:536870912:4:1}var Ec,Fc,Gc,Hc,Ic,Jc=!1,Kc=[],Lc=null,Mc=null,Nc=null,Oc=new Map,Pc=new Map,Qc=[],Rc=\"mousedown mouseup touchcancel touchend touchstart auxclick dblclick pointercancel pointerdown pointerup dragend dragstart drop compositionend compositionstart keydown keypress keyup input textInput copy cut paste click change contextmenu reset submit\".split(\" \");\nfunction Sc(a,b){switch(a){case \"focusin\":case \"focusout\":Lc=null;break;case \"dragenter\":case \"dragleave\":Mc=null;break;case \"mouseover\":case \"mouseout\":Nc=null;break;case \"pointerover\":case \"pointerout\":Oc.delete(b.pointerId);break;case \"gotpointercapture\":case \"lostpointercapture\":Pc.delete(b.pointerId)}}\nfunction Tc(a,b,c,d,e,f){if(null===a||a.nativeEvent!==f)return a={blockedOn:b,domEventName:c,eventSystemFlags:d,nativeEvent:f,targetContainers:[e]},null!==b&&(b=Cb(b),null!==b&&Fc(b)),a;a.eventSystemFlags|=d;b=a.targetContainers;null!==e&&-1===b.indexOf(e)&&b.push(e);return a}\nfunction Uc(a,b,c,d,e){switch(b){case \"focusin\":return Lc=Tc(Lc,a,b,c,d,e),!0;case \"dragenter\":return Mc=Tc(Mc,a,b,c,d,e),!0;case \"mouseover\":return Nc=Tc(Nc,a,b,c,d,e),!0;case \"pointerover\":var f=e.pointerId;Oc.set(f,Tc(Oc.get(f)||null,a,b,c,d,e));return!0;case \"gotpointercapture\":return f=e.pointerId,Pc.set(f,Tc(Pc.get(f)||null,a,b,c,d,e)),!0}return!1}\nfunction Vc(a){var b=Wc(a.target);if(null!==b){var c=Vb(b);if(null!==c)if(b=c.tag,13===b){if(b=Wb(c),null!==b){a.blockedOn=b;Ic(a.priority,function(){Gc(c)});return}}else if(3===b&&c.stateNode.current.memoizedState.isDehydrated){a.blockedOn=3===c.tag?c.stateNode.containerInfo:null;return}}a.blockedOn=null}\nfunction Xc(a){if(null!==a.blockedOn)return!1;for(var b=a.targetContainers;0<b.length;){var c=Yc(a.domEventName,a.eventSystemFlags,b[0],a.nativeEvent);if(null===c){c=a.nativeEvent;var d=new c.constructor(c.type,c);wb=d;c.target.dispatchEvent(d);wb=null}else return b=Cb(c),null!==b&&Fc(b),a.blockedOn=c,!1;b.shift()}return!0}function Zc(a,b,c){Xc(a)&&c.delete(b)}function $c(){Jc=!1;null!==Lc&&Xc(Lc)&&(Lc=null);null!==Mc&&Xc(Mc)&&(Mc=null);null!==Nc&&Xc(Nc)&&(Nc=null);Oc.forEach(Zc);Pc.forEach(Zc)}\nfunction ad(a,b){a.blockedOn===b&&(a.blockedOn=null,Jc||(Jc=!0,ca.unstable_scheduleCallback(ca.unstable_NormalPriority,$c)))}\nfunction bd(a){function b(b){return ad(b,a)}if(0<Kc.length){ad(Kc[0],a);for(var c=1;c<Kc.length;c++){var d=Kc[c];d.blockedOn===a&&(d.blockedOn=null)}}null!==Lc&&ad(Lc,a);null!==Mc&&ad(Mc,a);null!==Nc&&ad(Nc,a);Oc.forEach(b);Pc.forEach(b);for(c=0;c<Qc.length;c++)d=Qc[c],d.blockedOn===a&&(d.blockedOn=null);for(;0<Qc.length&&(c=Qc[0],null===c.blockedOn);)Vc(c),null===c.blockedOn&&Qc.shift()}var cd=ua.ReactCurrentBatchConfig,dd=!0;\nfunction ed(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=1,fd(a,b,c,d)}finally{C=e,cd.transition=f}}function gd(a,b,c,d){var e=C,f=cd.transition;cd.transition=null;try{C=4,fd(a,b,c,d)}finally{C=e,cd.transition=f}}\nfunction fd(a,b,c,d){if(dd){var e=Yc(a,b,c,d);if(null===e)hd(a,b,d,id,c),Sc(a,d);else if(Uc(e,a,b,c,d))d.stopPropagation();else if(Sc(a,d),b&4&&-1<Rc.indexOf(a)){for(;null!==e;){var f=Cb(e);null!==f&&Ec(f);f=Yc(a,b,c,d);null===f&&hd(a,b,d,id,c);if(f===e)break;e=f}null!==e&&d.stopPropagation()}else hd(a,b,d,null,c)}}var id=null;\nfunction Yc(a,b,c,d){id=null;a=xb(d);a=Wc(a);if(null!==a)if(b=Vb(a),null===b)a=null;else if(c=b.tag,13===c){a=Wb(b);if(null!==a)return a;a=null}else if(3===c){if(b.stateNode.current.memoizedState.isDehydrated)return 3===b.tag?b.stateNode.containerInfo:null;a=null}else b!==a&&(a=null);id=a;return null}\nfunction jd(a){switch(a){case \"cancel\":case \"click\":case \"close\":case \"contextmenu\":case \"copy\":case \"cut\":case \"auxclick\":case \"dblclick\":case \"dragend\":case \"dragstart\":case \"drop\":case \"focusin\":case \"focusout\":case \"input\":case \"invalid\":case \"keydown\":case \"keypress\":case \"keyup\":case \"mousedown\":case \"mouseup\":case \"paste\":case \"pause\":case \"play\":case \"pointercancel\":case \"pointerdown\":case \"pointerup\":case \"ratechange\":case \"reset\":case \"resize\":case \"seeked\":case \"submit\":case \"touchcancel\":case \"touchend\":case \"touchstart\":case \"volumechange\":case \"change\":case \"selectionchange\":case \"textInput\":case \"compositionstart\":case \"compositionend\":case \"compositionupdate\":case \"beforeblur\":case \"afterblur\":case \"beforeinput\":case \"blur\":case \"fullscreenchange\":case \"focus\":case \"hashchange\":case \"popstate\":case \"select\":case \"selectstart\":return 1;case \"drag\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"mousemove\":case \"mouseout\":case \"mouseover\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"scroll\":case \"toggle\":case \"touchmove\":case \"wheel\":case \"mouseenter\":case \"mouseleave\":case \"pointerenter\":case \"pointerleave\":return 4;\ncase \"message\":switch(ec()){case fc:return 1;case gc:return 4;case hc:case ic:return 16;case jc:return 536870912;default:return 16}default:return 16}}var kd=null,ld=null,md=null;function nd(){if(md)return md;var a,b=ld,c=b.length,d,e=\"value\"in kd?kd.value:kd.textContent,f=e.length;for(a=0;a<c&&b[a]===e[a];a++);var g=c-a;for(d=1;d<=g&&b[c-d]===e[f-d];d++);return md=e.slice(a,1<d?1-d:void 0)}\nfunction od(a){var b=a.keyCode;\"charCode\"in a?(a=a.charCode,0===a&&13===b&&(a=13)):a=b;10===a&&(a=13);return 32<=a||13===a?a:0}function pd(){return!0}function qd(){return!1}\nfunction rd(a){function b(b,d,e,f,g){this._reactName=b;this._targetInst=e;this.type=d;this.nativeEvent=f;this.target=g;this.currentTarget=null;for(var c in a)a.hasOwnProperty(c)&&(b=a[c],this[c]=b?b(f):f[c]);this.isDefaultPrevented=(null!=f.defaultPrevented?f.defaultPrevented:!1===f.returnValue)?pd:qd;this.isPropagationStopped=qd;return this}A(b.prototype,{preventDefault:function(){this.defaultPrevented=!0;var a=this.nativeEvent;a&&(a.preventDefault?a.preventDefault():\"unknown\"!==typeof a.returnValue&&\n(a.returnValue=!1),this.isDefaultPrevented=pd)},stopPropagation:function(){var a=this.nativeEvent;a&&(a.stopPropagation?a.stopPropagation():\"unknown\"!==typeof a.cancelBubble&&(a.cancelBubble=!0),this.isPropagationStopped=pd)},persist:function(){},isPersistent:pd});return b}\nvar sd={eventPhase:0,bubbles:0,cancelable:0,timeStamp:function(a){return a.timeStamp||Date.now()},defaultPrevented:0,isTrusted:0},td=rd(sd),ud=A({},sd,{view:0,detail:0}),vd=rd(ud),wd,xd,yd,Ad=A({},ud,{screenX:0,screenY:0,clientX:0,clientY:0,pageX:0,pageY:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,getModifierState:zd,button:0,buttons:0,relatedTarget:function(a){return void 0===a.relatedTarget?a.fromElement===a.srcElement?a.toElement:a.fromElement:a.relatedTarget},movementX:function(a){if(\"movementX\"in\na)return a.movementX;a!==yd&&(yd&&\"mousemove\"===a.type?(wd=a.screenX-yd.screenX,xd=a.screenY-yd.screenY):xd=wd=0,yd=a);return wd},movementY:function(a){return\"movementY\"in a?a.movementY:xd}}),Bd=rd(Ad),Cd=A({},Ad,{dataTransfer:0}),Dd=rd(Cd),Ed=A({},ud,{relatedTarget:0}),Fd=rd(Ed),Gd=A({},sd,{animationName:0,elapsedTime:0,pseudoElement:0}),Hd=rd(Gd),Id=A({},sd,{clipboardData:function(a){return\"clipboardData\"in a?a.clipboardData:window.clipboardData}}),Jd=rd(Id),Kd=A({},sd,{data:0}),Ld=rd(Kd),Md={Esc:\"Escape\",\nSpacebar:\" \",Left:\"ArrowLeft\",Up:\"ArrowUp\",Right:\"ArrowRight\",Down:\"ArrowDown\",Del:\"Delete\",Win:\"OS\",Menu:\"ContextMenu\",Apps:\"ContextMenu\",Scroll:\"ScrollLock\",MozPrintableKey:\"Unidentified\"},Nd={8:\"Backspace\",9:\"Tab\",12:\"Clear\",13:\"Enter\",16:\"Shift\",17:\"Control\",18:\"Alt\",19:\"Pause\",20:\"CapsLock\",27:\"Escape\",32:\" \",33:\"PageUp\",34:\"PageDown\",35:\"End\",36:\"Home\",37:\"ArrowLeft\",38:\"ArrowUp\",39:\"ArrowRight\",40:\"ArrowDown\",45:\"Insert\",46:\"Delete\",112:\"F1\",113:\"F2\",114:\"F3\",115:\"F4\",116:\"F5\",117:\"F6\",118:\"F7\",\n119:\"F8\",120:\"F9\",121:\"F10\",122:\"F11\",123:\"F12\",144:\"NumLock\",145:\"ScrollLock\",224:\"Meta\"},Od={Alt:\"altKey\",Control:\"ctrlKey\",Meta:\"metaKey\",Shift:\"shiftKey\"};function Pd(a){var b=this.nativeEvent;return b.getModifierState?b.getModifierState(a):(a=Od[a])?!!b[a]:!1}function zd(){return Pd}\nvar Qd=A({},ud,{key:function(a){if(a.key){var b=Md[a.key]||a.key;if(\"Unidentified\"!==b)return b}return\"keypress\"===a.type?(a=od(a),13===a?\"Enter\":String.fromCharCode(a)):\"keydown\"===a.type||\"keyup\"===a.type?Nd[a.keyCode]||\"Unidentified\":\"\"},code:0,location:0,ctrlKey:0,shiftKey:0,altKey:0,metaKey:0,repeat:0,locale:0,getModifierState:zd,charCode:function(a){return\"keypress\"===a.type?od(a):0},keyCode:function(a){return\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0},which:function(a){return\"keypress\"===\na.type?od(a):\"keydown\"===a.type||\"keyup\"===a.type?a.keyCode:0}}),Rd=rd(Qd),Sd=A({},Ad,{pointerId:0,width:0,height:0,pressure:0,tangentialPressure:0,tiltX:0,tiltY:0,twist:0,pointerType:0,isPrimary:0}),Td=rd(Sd),Ud=A({},ud,{touches:0,targetTouches:0,changedTouches:0,altKey:0,metaKey:0,ctrlKey:0,shiftKey:0,getModifierState:zd}),Vd=rd(Ud),Wd=A({},sd,{propertyName:0,elapsedTime:0,pseudoElement:0}),Xd=rd(Wd),Yd=A({},Ad,{deltaX:function(a){return\"deltaX\"in a?a.deltaX:\"wheelDeltaX\"in a?-a.wheelDeltaX:0},\ndeltaY:function(a){return\"deltaY\"in a?a.deltaY:\"wheelDeltaY\"in a?-a.wheelDeltaY:\"wheelDelta\"in a?-a.wheelDelta:0},deltaZ:0,deltaMode:0}),Zd=rd(Yd),$d=[9,13,27,32],ae=ia&&\"CompositionEvent\"in window,be=null;ia&&\"documentMode\"in document&&(be=document.documentMode);var ce=ia&&\"TextEvent\"in window&&!be,de=ia&&(!ae||be&&8<be&&11>=be),ee=String.fromCharCode(32),fe=!1;\nfunction ge(a,b){switch(a){case \"keyup\":return-1!==$d.indexOf(b.keyCode);case \"keydown\":return 229!==b.keyCode;case \"keypress\":case \"mousedown\":case \"focusout\":return!0;default:return!1}}function he(a){a=a.detail;return\"object\"===typeof a&&\"data\"in a?a.data:null}var ie=!1;function je(a,b){switch(a){case \"compositionend\":return he(b);case \"keypress\":if(32!==b.which)return null;fe=!0;return ee;case \"textInput\":return a=b.data,a===ee&&fe?null:a;default:return null}}\nfunction ke(a,b){if(ie)return\"compositionend\"===a||!ae&&ge(a,b)?(a=nd(),md=ld=kd=null,ie=!1,a):null;switch(a){case \"paste\":return null;case \"keypress\":if(!(b.ctrlKey||b.altKey||b.metaKey)||b.ctrlKey&&b.altKey){if(b.char&&1<b.char.length)return b.char;if(b.which)return String.fromCharCode(b.which)}return null;case \"compositionend\":return de&&\"ko\"!==b.locale?null:b.data;default:return null}}\nvar le={color:!0,date:!0,datetime:!0,\"datetime-local\":!0,email:!0,month:!0,number:!0,password:!0,range:!0,search:!0,tel:!0,text:!0,time:!0,url:!0,week:!0};function me(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return\"input\"===b?!!le[a.type]:\"textarea\"===b?!0:!1}function ne(a,b,c,d){Eb(d);b=oe(b,\"onChange\");0<b.length&&(c=new td(\"onChange\",\"change\",null,c,d),a.push({event:c,listeners:b}))}var pe=null,qe=null;function re(a){se(a,0)}function te(a){var b=ue(a);if(Wa(b))return a}\nfunction ve(a,b){if(\"change\"===a)return b}var we=!1;if(ia){var xe;if(ia){var ye=\"oninput\"in document;if(!ye){var ze=document.createElement(\"div\");ze.setAttribute(\"oninput\",\"return;\");ye=\"function\"===typeof ze.oninput}xe=ye}else xe=!1;we=xe&&(!document.documentMode||9<document.documentMode)}function Ae(){pe&&(pe.detachEvent(\"onpropertychange\",Be),qe=pe=null)}function Be(a){if(\"value\"===a.propertyName&&te(qe)){var b=[];ne(b,qe,a,xb(a));Jb(re,b)}}\nfunction Ce(a,b,c){\"focusin\"===a?(Ae(),pe=b,qe=c,pe.attachEvent(\"onpropertychange\",Be)):\"focusout\"===a&&Ae()}function De(a){if(\"selectionchange\"===a||\"keyup\"===a||\"keydown\"===a)return te(qe)}function Ee(a,b){if(\"click\"===a)return te(b)}function Fe(a,b){if(\"input\"===a||\"change\"===a)return te(b)}function Ge(a,b){return a===b&&(0!==a||1/a===1/b)||a!==a&&b!==b}var He=\"function\"===typeof Object.is?Object.is:Ge;\nfunction Ie(a,b){if(He(a,b))return!0;if(\"object\"!==typeof a||null===a||\"object\"!==typeof b||null===b)return!1;var c=Object.keys(a),d=Object.keys(b);if(c.length!==d.length)return!1;for(d=0;d<c.length;d++){var e=c[d];if(!ja.call(b,e)||!He(a[e],b[e]))return!1}return!0}function Je(a){for(;a&&a.firstChild;)a=a.firstChild;return a}\nfunction Ke(a,b){var c=Je(a);a=0;for(var d;c;){if(3===c.nodeType){d=a+c.textContent.length;if(a<=b&&d>=b)return{node:c,offset:b-a};a=d}a:{for(;c;){if(c.nextSibling){c=c.nextSibling;break a}c=c.parentNode}c=void 0}c=Je(c)}}function Le(a,b){return a&&b?a===b?!0:a&&3===a.nodeType?!1:b&&3===b.nodeType?Le(a,b.parentNode):\"contains\"in a?a.contains(b):a.compareDocumentPosition?!!(a.compareDocumentPosition(b)&16):!1:!1}\nfunction Me(){for(var a=window,b=Xa();b instanceof a.HTMLIFrameElement;){try{var c=\"string\"===typeof b.contentWindow.location.href}catch(d){c=!1}if(c)a=b.contentWindow;else break;b=Xa(a.document)}return b}function Ne(a){var b=a&&a.nodeName&&a.nodeName.toLowerCase();return b&&(\"input\"===b&&(\"text\"===a.type||\"search\"===a.type||\"tel\"===a.type||\"url\"===a.type||\"password\"===a.type)||\"textarea\"===b||\"true\"===a.contentEditable)}\nfunction Oe(a){var b=Me(),c=a.focusedElem,d=a.selectionRange;if(b!==c&&c&&c.ownerDocument&&Le(c.ownerDocument.documentElement,c)){if(null!==d&&Ne(c))if(b=d.start,a=d.end,void 0===a&&(a=b),\"selectionStart\"in c)c.selectionStart=b,c.selectionEnd=Math.min(a,c.value.length);else if(a=(b=c.ownerDocument||document)&&b.defaultView||window,a.getSelection){a=a.getSelection();var e=c.textContent.length,f=Math.min(d.start,e);d=void 0===d.end?f:Math.min(d.end,e);!a.extend&&f>d&&(e=d,d=f,f=e);e=Ke(c,f);var g=Ke(c,\nd);e&&g&&(1!==a.rangeCount||a.anchorNode!==e.node||a.anchorOffset!==e.offset||a.focusNode!==g.node||a.focusOffset!==g.offset)&&(b=b.createRange(),b.setStart(e.node,e.offset),a.removeAllRanges(),f>d?(a.addRange(b),a.extend(g.node,g.offset)):(b.setEnd(g.node,g.offset),a.addRange(b)))}b=[];for(a=c;a=a.parentNode;)1===a.nodeType&&b.push({element:a,left:a.scrollLeft,top:a.scrollTop});\"function\"===typeof c.focus&&c.focus();for(c=0;c<b.length;c++)a=b[c],a.element.scrollLeft=a.left,a.element.scrollTop=a.top}}\nvar Pe=ia&&\"documentMode\"in document&&11>=document.documentMode,Qe=null,Re=null,Se=null,Te=!1;\nfunction Ue(a,b,c){var d=c.window===c?c.document:9===c.nodeType?c:c.ownerDocument;Te||null==Qe||Qe!==Xa(d)||(d=Qe,\"selectionStart\"in d&&Ne(d)?d={start:d.selectionStart,end:d.selectionEnd}:(d=(d.ownerDocument&&d.ownerDocument.defaultView||window).getSelection(),d={anchorNode:d.anchorNode,anchorOffset:d.anchorOffset,focusNode:d.focusNode,focusOffset:d.focusOffset}),Se&&Ie(Se,d)||(Se=d,d=oe(Re,\"onSelect\"),0<d.length&&(b=new td(\"onSelect\",\"select\",null,b,c),a.push({event:b,listeners:d}),b.target=Qe)))}\nfunction Ve(a,b){var c={};c[a.toLowerCase()]=b.toLowerCase();c[\"Webkit\"+a]=\"webkit\"+b;c[\"Moz\"+a]=\"moz\"+b;return c}var We={animationend:Ve(\"Animation\",\"AnimationEnd\"),animationiteration:Ve(\"Animation\",\"AnimationIteration\"),animationstart:Ve(\"Animation\",\"AnimationStart\"),transitionend:Ve(\"Transition\",\"TransitionEnd\")},Xe={},Ye={};\nia&&(Ye=document.createElement(\"div\").style,\"AnimationEvent\"in window||(delete We.animationend.animation,delete We.animationiteration.animation,delete We.animationstart.animation),\"TransitionEvent\"in window||delete We.transitionend.transition);function Ze(a){if(Xe[a])return Xe[a];if(!We[a])return a;var b=We[a],c;for(c in b)if(b.hasOwnProperty(c)&&c in Ye)return Xe[a]=b[c];return a}var $e=Ze(\"animationend\"),af=Ze(\"animationiteration\"),bf=Ze(\"animationstart\"),cf=Ze(\"transitionend\"),df=new Map,ef=\"abort auxClick cancel canPlay canPlayThrough click close contextMenu copy cut drag dragEnd dragEnter dragExit dragLeave dragOver dragStart drop durationChange emptied encrypted ended error gotPointerCapture input invalid keyDown keyPress keyUp load loadedData loadedMetadata loadStart lostPointerCapture mouseDown mouseMove mouseOut mouseOver mouseUp paste pause play playing pointerCancel pointerDown pointerMove pointerOut pointerOver pointerUp progress rateChange reset resize seeked seeking stalled submit suspend timeUpdate touchCancel touchEnd touchStart volumeChange scroll toggle touchMove waiting wheel\".split(\" \");\nfunction ff(a,b){df.set(a,b);fa(b,[a])}for(var gf=0;gf<ef.length;gf++){var hf=ef[gf],jf=hf.toLowerCase(),kf=hf[0].toUpperCase()+hf.slice(1);ff(jf,\"on\"+kf)}ff($e,\"onAnimationEnd\");ff(af,\"onAnimationIteration\");ff(bf,\"onAnimationStart\");ff(\"dblclick\",\"onDoubleClick\");ff(\"focusin\",\"onFocus\");ff(\"focusout\",\"onBlur\");ff(cf,\"onTransitionEnd\");ha(\"onMouseEnter\",[\"mouseout\",\"mouseover\"]);ha(\"onMouseLeave\",[\"mouseout\",\"mouseover\"]);ha(\"onPointerEnter\",[\"pointerout\",\"pointerover\"]);\nha(\"onPointerLeave\",[\"pointerout\",\"pointerover\"]);fa(\"onChange\",\"change click focusin focusout input keydown keyup selectionchange\".split(\" \"));fa(\"onSelect\",\"focusout contextmenu dragend focusin keydown keyup mousedown mouseup selectionchange\".split(\" \"));fa(\"onBeforeInput\",[\"compositionend\",\"keypress\",\"textInput\",\"paste\"]);fa(\"onCompositionEnd\",\"compositionend focusout keydown keypress keyup mousedown\".split(\" \"));fa(\"onCompositionStart\",\"compositionstart focusout keydown keypress keyup mousedown\".split(\" \"));\nfa(\"onCompositionUpdate\",\"compositionupdate focusout keydown keypress keyup mousedown\".split(\" \"));var lf=\"abort canplay canplaythrough durationchange emptied encrypted ended error loadeddata loadedmetadata loadstart pause play playing progress ratechange resize seeked seeking stalled suspend timeupdate volumechange waiting\".split(\" \"),mf=new Set(\"cancel close invalid load scroll toggle\".split(\" \").concat(lf));\nfunction nf(a,b,c){var d=a.type||\"unknown-event\";a.currentTarget=c;Ub(d,b,void 0,a);a.currentTarget=null}\nfunction se(a,b){b=0!==(b&4);for(var c=0;c<a.length;c++){var d=a[c],e=d.event;d=d.listeners;a:{var f=void 0;if(b)for(var g=d.length-1;0<=g;g--){var h=d[g],k=h.instance,l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}else for(g=0;g<d.length;g++){h=d[g];k=h.instance;l=h.currentTarget;h=h.listener;if(k!==f&&e.isPropagationStopped())break a;nf(e,h,l);f=k}}}if(Qb)throw a=Rb,Qb=!1,Rb=null,a;}\nfunction D(a,b){var c=b[of];void 0===c&&(c=b[of]=new Set);var d=a+\"__bubble\";c.has(d)||(pf(b,a,2,!1),c.add(d))}function qf(a,b,c){var d=0;b&&(d|=4);pf(c,a,d,b)}var rf=\"_reactListening\"+Math.random().toString(36).slice(2);function sf(a){if(!a[rf]){a[rf]=!0;da.forEach(function(b){\"selectionchange\"!==b&&(mf.has(b)||qf(b,!1,a),qf(b,!0,a))});var b=9===a.nodeType?a:a.ownerDocument;null===b||b[rf]||(b[rf]=!0,qf(\"selectionchange\",!1,b))}}\nfunction pf(a,b,c,d){switch(jd(b)){case 1:var e=ed;break;case 4:e=gd;break;default:e=fd}c=e.bind(null,b,c,a);e=void 0;!Lb||\"touchstart\"!==b&&\"touchmove\"!==b&&\"wheel\"!==b||(e=!0);d?void 0!==e?a.addEventListener(b,c,{capture:!0,passive:e}):a.addEventListener(b,c,!0):void 0!==e?a.addEventListener(b,c,{passive:e}):a.addEventListener(b,c,!1)}\nfunction hd(a,b,c,d,e){var f=d;if(0===(b&1)&&0===(b&2)&&null!==d)a:for(;;){if(null===d)return;var g=d.tag;if(3===g||4===g){var h=d.stateNode.containerInfo;if(h===e||8===h.nodeType&&h.parentNode===e)break;if(4===g)for(g=d.return;null!==g;){var k=g.tag;if(3===k||4===k)if(k=g.stateNode.containerInfo,k===e||8===k.nodeType&&k.parentNode===e)return;g=g.return}for(;null!==h;){g=Wc(h);if(null===g)return;k=g.tag;if(5===k||6===k){d=f=g;continue a}h=h.parentNode}}d=d.return}Jb(function(){var d=f,e=xb(c),g=[];\na:{var h=df.get(a);if(void 0!==h){var k=td,n=a;switch(a){case \"keypress\":if(0===od(c))break a;case \"keydown\":case \"keyup\":k=Rd;break;case \"focusin\":n=\"focus\";k=Fd;break;case \"focusout\":n=\"blur\";k=Fd;break;case \"beforeblur\":case \"afterblur\":k=Fd;break;case \"click\":if(2===c.button)break a;case \"auxclick\":case \"dblclick\":case \"mousedown\":case \"mousemove\":case \"mouseup\":case \"mouseout\":case \"mouseover\":case \"contextmenu\":k=Bd;break;case \"drag\":case \"dragend\":case \"dragenter\":case \"dragexit\":case \"dragleave\":case \"dragover\":case \"dragstart\":case \"drop\":k=\nDd;break;case \"touchcancel\":case \"touchend\":case \"touchmove\":case \"touchstart\":k=Vd;break;case $e:case af:case bf:k=Hd;break;case cf:k=Xd;break;case \"scroll\":k=vd;break;case \"wheel\":k=Zd;break;case \"copy\":case \"cut\":case \"paste\":k=Jd;break;case \"gotpointercapture\":case \"lostpointercapture\":case \"pointercancel\":case \"pointerdown\":case \"pointermove\":case \"pointerout\":case \"pointerover\":case \"pointerup\":k=Td}var t=0!==(b&4),J=!t&&\"scroll\"===a,x=t?null!==h?h+\"Capture\":null:h;t=[];for(var w=d,u;null!==\nw;){u=w;var F=u.stateNode;5===u.tag&&null!==F&&(u=F,null!==x&&(F=Kb(w,x),null!=F&&t.push(tf(w,F,u))));if(J)break;w=w.return}0<t.length&&(h=new k(h,n,null,c,e),g.push({event:h,listeners:t}))}}if(0===(b&7)){a:{h=\"mouseover\"===a||\"pointerover\"===a;k=\"mouseout\"===a||\"pointerout\"===a;if(h&&c!==wb&&(n=c.relatedTarget||c.fromElement)&&(Wc(n)||n[uf]))break a;if(k||h){h=e.window===e?e:(h=e.ownerDocument)?h.defaultView||h.parentWindow:window;if(k){if(n=c.relatedTarget||c.toElement,k=d,n=n?Wc(n):null,null!==\nn&&(J=Vb(n),n!==J||5!==n.tag&&6!==n.tag))n=null}else k=null,n=d;if(k!==n){t=Bd;F=\"onMouseLeave\";x=\"onMouseEnter\";w=\"mouse\";if(\"pointerout\"===a||\"pointerover\"===a)t=Td,F=\"onPointerLeave\",x=\"onPointerEnter\",w=\"pointer\";J=null==k?h:ue(k);u=null==n?h:ue(n);h=new t(F,w+\"leave\",k,c,e);h.target=J;h.relatedTarget=u;F=null;Wc(e)===d&&(t=new t(x,w+\"enter\",n,c,e),t.target=u,t.relatedTarget=J,F=t);J=F;if(k&&n)b:{t=k;x=n;w=0;for(u=t;u;u=vf(u))w++;u=0;for(F=x;F;F=vf(F))u++;for(;0<w-u;)t=vf(t),w--;for(;0<u-w;)x=\nvf(x),u--;for(;w--;){if(t===x||null!==x&&t===x.alternate)break b;t=vf(t);x=vf(x)}t=null}else t=null;null!==k&&wf(g,h,k,t,!1);null!==n&&null!==J&&wf(g,J,n,t,!0)}}}a:{h=d?ue(d):window;k=h.nodeName&&h.nodeName.toLowerCase();if(\"select\"===k||\"input\"===k&&\"file\"===h.type)var na=ve;else if(me(h))if(we)na=Fe;else{na=De;var xa=Ce}else(k=h.nodeName)&&\"input\"===k.toLowerCase()&&(\"checkbox\"===h.type||\"radio\"===h.type)&&(na=Ee);if(na&&(na=na(a,d))){ne(g,na,c,e);break a}xa&&xa(a,h,d);\"focusout\"===a&&(xa=h._wrapperState)&&\nxa.controlled&&\"number\"===h.type&&cb(h,\"number\",h.value)}xa=d?ue(d):window;switch(a){case \"focusin\":if(me(xa)||\"true\"===xa.contentEditable)Qe=xa,Re=d,Se=null;break;case \"focusout\":Se=Re=Qe=null;break;case \"mousedown\":Te=!0;break;case \"contextmenu\":case \"mouseup\":case \"dragend\":Te=!1;Ue(g,c,e);break;case \"selectionchange\":if(Pe)break;case \"keydown\":case \"keyup\":Ue(g,c,e)}var $a;if(ae)b:{switch(a){case \"compositionstart\":var ba=\"onCompositionStart\";break b;case \"compositionend\":ba=\"onCompositionEnd\";\nbreak b;case \"compositionupdate\":ba=\"onCompositionUpdate\";break b}ba=void 0}else ie?ge(a,c)&&(ba=\"onCompositionEnd\"):\"keydown\"===a&&229===c.keyCode&&(ba=\"onCompositionStart\");ba&&(de&&\"ko\"!==c.locale&&(ie||\"onCompositionStart\"!==ba?\"onCompositionEnd\"===ba&&ie&&($a=nd()):(kd=e,ld=\"value\"in kd?kd.value:kd.textContent,ie=!0)),xa=oe(d,ba),0<xa.length&&(ba=new Ld(ba,a,null,c,e),g.push({event:ba,listeners:xa}),$a?ba.data=$a:($a=he(c),null!==$a&&(ba.data=$a))));if($a=ce?je(a,c):ke(a,c))d=oe(d,\"onBeforeInput\"),\n0<d.length&&(e=new Ld(\"onBeforeInput\",\"beforeinput\",null,c,e),g.push({event:e,listeners:d}),e.data=$a)}se(g,b)})}function tf(a,b,c){return{instance:a,listener:b,currentTarget:c}}function oe(a,b){for(var c=b+\"Capture\",d=[];null!==a;){var e=a,f=e.stateNode;5===e.tag&&null!==f&&(e=f,f=Kb(a,c),null!=f&&d.unshift(tf(a,f,e)),f=Kb(a,b),null!=f&&d.push(tf(a,f,e)));a=a.return}return d}function vf(a){if(null===a)return null;do a=a.return;while(a&&5!==a.tag);return a?a:null}\nfunction wf(a,b,c,d,e){for(var f=b._reactName,g=[];null!==c&&c!==d;){var h=c,k=h.alternate,l=h.stateNode;if(null!==k&&k===d)break;5===h.tag&&null!==l&&(h=l,e?(k=Kb(c,f),null!=k&&g.unshift(tf(c,k,h))):e||(k=Kb(c,f),null!=k&&g.push(tf(c,k,h))));c=c.return}0!==g.length&&a.push({event:b,listeners:g})}var xf=/\\r\\n?/g,yf=/\\u0000|\\uFFFD/g;function zf(a){return(\"string\"===typeof a?a:\"\"+a).replace(xf,\"\\n\").replace(yf,\"\")}function Af(a,b,c){b=zf(b);if(zf(a)!==b&&c)throw Error(p(425));}function Bf(){}\nvar Cf=null,Df=null;function Ef(a,b){return\"textarea\"===a||\"noscript\"===a||\"string\"===typeof b.children||\"number\"===typeof b.children||\"object\"===typeof b.dangerouslySetInnerHTML&&null!==b.dangerouslySetInnerHTML&&null!=b.dangerouslySetInnerHTML.__html}\nvar Ff=\"function\"===typeof setTimeout?setTimeout:void 0,Gf=\"function\"===typeof clearTimeout?clearTimeout:void 0,Hf=\"function\"===typeof Promise?Promise:void 0,Jf=\"function\"===typeof queueMicrotask?queueMicrotask:\"undefined\"!==typeof Hf?function(a){return Hf.resolve(null).then(a).catch(If)}:Ff;function If(a){setTimeout(function(){throw a;})}\nfunction Kf(a,b){var c=b,d=0;do{var e=c.nextSibling;a.removeChild(c);if(e&&8===e.nodeType)if(c=e.data,\"/$\"===c){if(0===d){a.removeChild(e);bd(b);return}d--}else\"$\"!==c&&\"$?\"!==c&&\"$!\"!==c||d++;c=e}while(c);bd(b)}function Lf(a){for(;null!=a;a=a.nextSibling){var b=a.nodeType;if(1===b||3===b)break;if(8===b){b=a.data;if(\"$\"===b||\"$!\"===b||\"$?\"===b)break;if(\"/$\"===b)return null}}return a}\nfunction Mf(a){a=a.previousSibling;for(var b=0;a;){if(8===a.nodeType){var c=a.data;if(\"$\"===c||\"$!\"===c||\"$?\"===c){if(0===b)return a;b--}else\"/$\"===c&&b++}a=a.previousSibling}return null}var Nf=Math.random().toString(36).slice(2),Of=\"__reactFiber$\"+Nf,Pf=\"__reactProps$\"+Nf,uf=\"__reactContainer$\"+Nf,of=\"__reactEvents$\"+Nf,Qf=\"__reactListeners$\"+Nf,Rf=\"__reactHandles$\"+Nf;\nfunction Wc(a){var b=a[Of];if(b)return b;for(var c=a.parentNode;c;){if(b=c[uf]||c[Of]){c=b.alternate;if(null!==b.child||null!==c&&null!==c.child)for(a=Mf(a);null!==a;){if(c=a[Of])return c;a=Mf(a)}return b}a=c;c=a.parentNode}return null}function Cb(a){a=a[Of]||a[uf];return!a||5!==a.tag&&6!==a.tag&&13!==a.tag&&3!==a.tag?null:a}function ue(a){if(5===a.tag||6===a.tag)return a.stateNode;throw Error(p(33));}function Db(a){return a[Pf]||null}var Sf=[],Tf=-1;function Uf(a){return{current:a}}\nfunction E(a){0>Tf||(a.current=Sf[Tf],Sf[Tf]=null,Tf--)}function G(a,b){Tf++;Sf[Tf]=a.current;a.current=b}var Vf={},H=Uf(Vf),Wf=Uf(!1),Xf=Vf;function Yf(a,b){var c=a.type.contextTypes;if(!c)return Vf;var d=a.stateNode;if(d&&d.__reactInternalMemoizedUnmaskedChildContext===b)return d.__reactInternalMemoizedMaskedChildContext;var e={},f;for(f in c)e[f]=b[f];d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=b,a.__reactInternalMemoizedMaskedChildContext=e);return e}\nfunction Zf(a){a=a.childContextTypes;return null!==a&&void 0!==a}function $f(){E(Wf);E(H)}function ag(a,b,c){if(H.current!==Vf)throw Error(p(168));G(H,b);G(Wf,c)}function bg(a,b,c){var d=a.stateNode;b=b.childContextTypes;if(\"function\"!==typeof d.getChildContext)return c;d=d.getChildContext();for(var e in d)if(!(e in b))throw Error(p(108,Ra(a)||\"Unknown\",e));return A({},c,d)}\nfunction cg(a){a=(a=a.stateNode)&&a.__reactInternalMemoizedMergedChildContext||Vf;Xf=H.current;G(H,a);G(Wf,Wf.current);return!0}function dg(a,b,c){var d=a.stateNode;if(!d)throw Error(p(169));c?(a=bg(a,b,Xf),d.__reactInternalMemoizedMergedChildContext=a,E(Wf),E(H),G(H,a)):E(Wf);G(Wf,c)}var eg=null,fg=!1,gg=!1;function hg(a){null===eg?eg=[a]:eg.push(a)}function ig(a){fg=!0;hg(a)}\nfunction jg(){if(!gg&&null!==eg){gg=!0;var a=0,b=C;try{var c=eg;for(C=1;a<c.length;a++){var d=c[a];do d=d(!0);while(null!==d)}eg=null;fg=!1}catch(e){throw null!==eg&&(eg=eg.slice(a+1)),ac(fc,jg),e;}finally{C=b,gg=!1}}return null}var kg=[],lg=0,mg=null,ng=0,og=[],pg=0,qg=null,rg=1,sg=\"\";function tg(a,b){kg[lg++]=ng;kg[lg++]=mg;mg=a;ng=b}\nfunction ug(a,b,c){og[pg++]=rg;og[pg++]=sg;og[pg++]=qg;qg=a;var d=rg;a=sg;var e=32-oc(d)-1;d&=~(1<<e);c+=1;var f=32-oc(b)+e;if(30<f){var g=e-e%5;f=(d&(1<<g)-1).toString(32);d>>=g;e-=g;rg=1<<32-oc(b)+e|c<<e|d;sg=f+a}else rg=1<<f|c<<e|d,sg=a}function vg(a){null!==a.return&&(tg(a,1),ug(a,1,0))}function wg(a){for(;a===mg;)mg=kg[--lg],kg[lg]=null,ng=kg[--lg],kg[lg]=null;for(;a===qg;)qg=og[--pg],og[pg]=null,sg=og[--pg],og[pg]=null,rg=og[--pg],og[pg]=null}var xg=null,yg=null,I=!1,zg=null;\nfunction Ag(a,b){var c=Bg(5,null,null,0);c.elementType=\"DELETED\";c.stateNode=b;c.return=a;b=a.deletions;null===b?(a.deletions=[c],a.flags|=16):b.push(c)}\nfunction Cg(a,b){switch(a.tag){case 5:var c=a.type;b=1!==b.nodeType||c.toLowerCase()!==b.nodeName.toLowerCase()?null:b;return null!==b?(a.stateNode=b,xg=a,yg=Lf(b.firstChild),!0):!1;case 6:return b=\"\"===a.pendingProps||3!==b.nodeType?null:b,null!==b?(a.stateNode=b,xg=a,yg=null,!0):!1;case 13:return b=8!==b.nodeType?null:b,null!==b?(c=null!==qg?{id:rg,overflow:sg}:null,a.memoizedState={dehydrated:b,treeContext:c,retryLane:1073741824},c=Bg(18,null,null,0),c.stateNode=b,c.return=a,a.child=c,xg=a,yg=\nnull,!0):!1;default:return!1}}function Dg(a){return 0!==(a.mode&1)&&0===(a.flags&128)}function Eg(a){if(I){var b=yg;if(b){var c=b;if(!Cg(a,b)){if(Dg(a))throw Error(p(418));b=Lf(c.nextSibling);var d=xg;b&&Cg(a,b)?Ag(d,c):(a.flags=a.flags&-4097|2,I=!1,xg=a)}}else{if(Dg(a))throw Error(p(418));a.flags=a.flags&-4097|2;I=!1;xg=a}}}function Fg(a){for(a=a.return;null!==a&&5!==a.tag&&3!==a.tag&&13!==a.tag;)a=a.return;xg=a}\nfunction Gg(a){if(a!==xg)return!1;if(!I)return Fg(a),I=!0,!1;var b;(b=3!==a.tag)&&!(b=5!==a.tag)&&(b=a.type,b=\"head\"!==b&&\"body\"!==b&&!Ef(a.type,a.memoizedProps));if(b&&(b=yg)){if(Dg(a))throw Hg(),Error(p(418));for(;b;)Ag(a,b),b=Lf(b.nextSibling)}Fg(a);if(13===a.tag){a=a.memoizedState;a=null!==a?a.dehydrated:null;if(!a)throw Error(p(317));a:{a=a.nextSibling;for(b=0;a;){if(8===a.nodeType){var c=a.data;if(\"/$\"===c){if(0===b){yg=Lf(a.nextSibling);break a}b--}else\"$\"!==c&&\"$!\"!==c&&\"$?\"!==c||b++}a=a.nextSibling}yg=\nnull}}else yg=xg?Lf(a.stateNode.nextSibling):null;return!0}function Hg(){for(var a=yg;a;)a=Lf(a.nextSibling)}function Ig(){yg=xg=null;I=!1}function Jg(a){null===zg?zg=[a]:zg.push(a)}var Kg=ua.ReactCurrentBatchConfig;function Lg(a,b){if(a&&a.defaultProps){b=A({},b);a=a.defaultProps;for(var c in a)void 0===b[c]&&(b[c]=a[c]);return b}return b}var Mg=Uf(null),Ng=null,Og=null,Pg=null;function Qg(){Pg=Og=Ng=null}function Rg(a){var b=Mg.current;E(Mg);a._currentValue=b}\nfunction Sg(a,b,c){for(;null!==a;){var d=a.alternate;(a.childLanes&b)!==b?(a.childLanes|=b,null!==d&&(d.childLanes|=b)):null!==d&&(d.childLanes&b)!==b&&(d.childLanes|=b);if(a===c)break;a=a.return}}function Tg(a,b){Ng=a;Pg=Og=null;a=a.dependencies;null!==a&&null!==a.firstContext&&(0!==(a.lanes&b)&&(Ug=!0),a.firstContext=null)}\nfunction Vg(a){var b=a._currentValue;if(Pg!==a)if(a={context:a,memoizedValue:b,next:null},null===Og){if(null===Ng)throw Error(p(308));Og=a;Ng.dependencies={lanes:0,firstContext:a}}else Og=Og.next=a;return b}var Wg=null;function Xg(a){null===Wg?Wg=[a]:Wg.push(a)}function Yg(a,b,c,d){var e=b.interleaved;null===e?(c.next=c,Xg(b)):(c.next=e.next,e.next=c);b.interleaved=c;return Zg(a,d)}\nfunction Zg(a,b){a.lanes|=b;var c=a.alternate;null!==c&&(c.lanes|=b);c=a;for(a=a.return;null!==a;)a.childLanes|=b,c=a.alternate,null!==c&&(c.childLanes|=b),c=a,a=a.return;return 3===c.tag?c.stateNode:null}var $g=!1;function ah(a){a.updateQueue={baseState:a.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}\nfunction bh(a,b){a=a.updateQueue;b.updateQueue===a&&(b.updateQueue={baseState:a.baseState,firstBaseUpdate:a.firstBaseUpdate,lastBaseUpdate:a.lastBaseUpdate,shared:a.shared,effects:a.effects})}function ch(a,b){return{eventTime:a,lane:b,tag:0,payload:null,callback:null,next:null}}\nfunction dh(a,b,c){var d=a.updateQueue;if(null===d)return null;d=d.shared;if(0!==(K&2)){var e=d.pending;null===e?b.next=b:(b.next=e.next,e.next=b);d.pending=b;return Zg(a,c)}e=d.interleaved;null===e?(b.next=b,Xg(d)):(b.next=e.next,e.next=b);d.interleaved=b;return Zg(a,c)}function eh(a,b,c){b=b.updateQueue;if(null!==b&&(b=b.shared,0!==(c&4194240))){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nfunction fh(a,b){var c=a.updateQueue,d=a.alternate;if(null!==d&&(d=d.updateQueue,c===d)){var e=null,f=null;c=c.firstBaseUpdate;if(null!==c){do{var g={eventTime:c.eventTime,lane:c.lane,tag:c.tag,payload:c.payload,callback:c.callback,next:null};null===f?e=f=g:f=f.next=g;c=c.next}while(null!==c);null===f?e=f=b:f=f.next=b}else e=f=b;c={baseState:d.baseState,firstBaseUpdate:e,lastBaseUpdate:f,shared:d.shared,effects:d.effects};a.updateQueue=c;return}a=c.lastBaseUpdate;null===a?c.firstBaseUpdate=b:a.next=\nb;c.lastBaseUpdate=b}\nfunction gh(a,b,c,d){var e=a.updateQueue;$g=!1;var f=e.firstBaseUpdate,g=e.lastBaseUpdate,h=e.shared.pending;if(null!==h){e.shared.pending=null;var k=h,l=k.next;k.next=null;null===g?f=l:g.next=l;g=k;var m=a.alternate;null!==m&&(m=m.updateQueue,h=m.lastBaseUpdate,h!==g&&(null===h?m.firstBaseUpdate=l:h.next=l,m.lastBaseUpdate=k))}if(null!==f){var q=e.baseState;g=0;m=l=k=null;h=f;do{var r=h.lane,y=h.eventTime;if((d&r)===r){null!==m&&(m=m.next={eventTime:y,lane:0,tag:h.tag,payload:h.payload,callback:h.callback,\nnext:null});a:{var n=a,t=h;r=b;y=c;switch(t.tag){case 1:n=t.payload;if(\"function\"===typeof n){q=n.call(y,q,r);break a}q=n;break a;case 3:n.flags=n.flags&-65537|128;case 0:n=t.payload;r=\"function\"===typeof n?n.call(y,q,r):n;if(null===r||void 0===r)break a;q=A({},q,r);break a;case 2:$g=!0}}null!==h.callback&&0!==h.lane&&(a.flags|=64,r=e.effects,null===r?e.effects=[h]:r.push(h))}else y={eventTime:y,lane:r,tag:h.tag,payload:h.payload,callback:h.callback,next:null},null===m?(l=m=y,k=q):m=m.next=y,g|=r;\nh=h.next;if(null===h)if(h=e.shared.pending,null===h)break;else r=h,h=r.next,r.next=null,e.lastBaseUpdate=r,e.shared.pending=null}while(1);null===m&&(k=q);e.baseState=k;e.firstBaseUpdate=l;e.lastBaseUpdate=m;b=e.shared.interleaved;if(null!==b){e=b;do g|=e.lane,e=e.next;while(e!==b)}else null===f&&(e.shared.lanes=0);hh|=g;a.lanes=g;a.memoizedState=q}}\nfunction ih(a,b,c){a=b.effects;b.effects=null;if(null!==a)for(b=0;b<a.length;b++){var d=a[b],e=d.callback;if(null!==e){d.callback=null;d=c;if(\"function\"!==typeof e)throw Error(p(191,e));e.call(d)}}}var jh=(new aa.Component).refs;function kh(a,b,c,d){b=a.memoizedState;c=c(d,b);c=null===c||void 0===c?b:A({},b,c);a.memoizedState=c;0===a.lanes&&(a.updateQueue.baseState=c)}\nvar nh={isMounted:function(a){return(a=a._reactInternals)?Vb(a)===a:!1},enqueueSetState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueReplaceState:function(a,b,c){a=a._reactInternals;var d=L(),e=lh(a),f=ch(d,e);f.tag=1;f.payload=b;void 0!==c&&null!==c&&(f.callback=c);b=dh(a,f,e);null!==b&&(mh(b,a,e,d),eh(b,a,e))},enqueueForceUpdate:function(a,b){a=a._reactInternals;var c=L(),d=\nlh(a),e=ch(c,d);e.tag=2;void 0!==b&&null!==b&&(e.callback=b);b=dh(a,e,d);null!==b&&(mh(b,a,d,c),eh(b,a,d))}};function oh(a,b,c,d,e,f,g){a=a.stateNode;return\"function\"===typeof a.shouldComponentUpdate?a.shouldComponentUpdate(d,f,g):b.prototype&&b.prototype.isPureReactComponent?!Ie(c,d)||!Ie(e,f):!0}\nfunction ph(a,b,c){var d=!1,e=Vf;var f=b.contextType;\"object\"===typeof f&&null!==f?f=Vg(f):(e=Zf(b)?Xf:H.current,d=b.contextTypes,f=(d=null!==d&&void 0!==d)?Yf(a,e):Vf);b=new b(c,f);a.memoizedState=null!==b.state&&void 0!==b.state?b.state:null;b.updater=nh;a.stateNode=b;b._reactInternals=a;d&&(a=a.stateNode,a.__reactInternalMemoizedUnmaskedChildContext=e,a.__reactInternalMemoizedMaskedChildContext=f);return b}\nfunction qh(a,b,c,d){a=b.state;\"function\"===typeof b.componentWillReceiveProps&&b.componentWillReceiveProps(c,d);\"function\"===typeof b.UNSAFE_componentWillReceiveProps&&b.UNSAFE_componentWillReceiveProps(c,d);b.state!==a&&nh.enqueueReplaceState(b,b.state,null)}\nfunction rh(a,b,c,d){var e=a.stateNode;e.props=c;e.state=a.memoizedState;e.refs=jh;ah(a);var f=b.contextType;\"object\"===typeof f&&null!==f?e.context=Vg(f):(f=Zf(b)?Xf:H.current,e.context=Yf(a,f));e.state=a.memoizedState;f=b.getDerivedStateFromProps;\"function\"===typeof f&&(kh(a,b,f,c),e.state=a.memoizedState);\"function\"===typeof b.getDerivedStateFromProps||\"function\"===typeof e.getSnapshotBeforeUpdate||\"function\"!==typeof e.UNSAFE_componentWillMount&&\"function\"!==typeof e.componentWillMount||(b=e.state,\n\"function\"===typeof e.componentWillMount&&e.componentWillMount(),\"function\"===typeof e.UNSAFE_componentWillMount&&e.UNSAFE_componentWillMount(),b!==e.state&&nh.enqueueReplaceState(e,e.state,null),gh(a,c,e,d),e.state=a.memoizedState);\"function\"===typeof e.componentDidMount&&(a.flags|=4194308)}\nfunction sh(a,b,c){a=c.ref;if(null!==a&&\"function\"!==typeof a&&\"object\"!==typeof a){if(c._owner){c=c._owner;if(c){if(1!==c.tag)throw Error(p(309));var d=c.stateNode}if(!d)throw Error(p(147,a));var e=d,f=\"\"+a;if(null!==b&&null!==b.ref&&\"function\"===typeof b.ref&&b.ref._stringRef===f)return b.ref;b=function(a){var b=e.refs;b===jh&&(b=e.refs={});null===a?delete b[f]:b[f]=a};b._stringRef=f;return b}if(\"string\"!==typeof a)throw Error(p(284));if(!c._owner)throw Error(p(290,a));}return a}\nfunction th(a,b){a=Object.prototype.toString.call(b);throw Error(p(31,\"[object Object]\"===a?\"object with keys {\"+Object.keys(b).join(\", \")+\"}\":a));}function uh(a){var b=a._init;return b(a._payload)}\nfunction vh(a){function b(b,c){if(a){var d=b.deletions;null===d?(b.deletions=[c],b.flags|=16):d.push(c)}}function c(c,d){if(!a)return null;for(;null!==d;)b(c,d),d=d.sibling;return null}function d(a,b){for(a=new Map;null!==b;)null!==b.key?a.set(b.key,b):a.set(b.index,b),b=b.sibling;return a}function e(a,b){a=wh(a,b);a.index=0;a.sibling=null;return a}function f(b,c,d){b.index=d;if(!a)return b.flags|=1048576,c;d=b.alternate;if(null!==d)return d=d.index,d<c?(b.flags|=2,c):d;b.flags|=2;return c}function g(b){a&&\nnull===b.alternate&&(b.flags|=2);return b}function h(a,b,c,d){if(null===b||6!==b.tag)return b=xh(c,a.mode,d),b.return=a,b;b=e(b,c);b.return=a;return b}function k(a,b,c,d){var f=c.type;if(f===ya)return m(a,b,c.props.children,d,c.key);if(null!==b&&(b.elementType===f||\"object\"===typeof f&&null!==f&&f.$$typeof===Ha&&uh(f)===b.type))return d=e(b,c.props),d.ref=sh(a,b,c),d.return=a,d;d=yh(c.type,c.key,c.props,null,a.mode,d);d.ref=sh(a,b,c);d.return=a;return d}function l(a,b,c,d){if(null===b||4!==b.tag||\nb.stateNode.containerInfo!==c.containerInfo||b.stateNode.implementation!==c.implementation)return b=zh(c,a.mode,d),b.return=a,b;b=e(b,c.children||[]);b.return=a;return b}function m(a,b,c,d,f){if(null===b||7!==b.tag)return b=Ah(c,a.mode,d,f),b.return=a,b;b=e(b,c);b.return=a;return b}function q(a,b,c){if(\"string\"===typeof b&&\"\"!==b||\"number\"===typeof b)return b=xh(\"\"+b,a.mode,c),b.return=a,b;if(\"object\"===typeof b&&null!==b){switch(b.$$typeof){case va:return c=yh(b.type,b.key,b.props,null,a.mode,c),\nc.ref=sh(a,null,b),c.return=a,c;case wa:return b=zh(b,a.mode,c),b.return=a,b;case Ha:var d=b._init;return q(a,d(b._payload),c)}if(eb(b)||Ka(b))return b=Ah(b,a.mode,c,null),b.return=a,b;th(a,b)}return null}function r(a,b,c,d){var e=null!==b?b.key:null;if(\"string\"===typeof c&&\"\"!==c||\"number\"===typeof c)return null!==e?null:h(a,b,\"\"+c,d);if(\"object\"===typeof c&&null!==c){switch(c.$$typeof){case va:return c.key===e?k(a,b,c,d):null;case wa:return c.key===e?l(a,b,c,d):null;case Ha:return e=c._init,r(a,\nb,e(c._payload),d)}if(eb(c)||Ka(c))return null!==e?null:m(a,b,c,d,null);th(a,c)}return null}function y(a,b,c,d,e){if(\"string\"===typeof d&&\"\"!==d||\"number\"===typeof d)return a=a.get(c)||null,h(b,a,\"\"+d,e);if(\"object\"===typeof d&&null!==d){switch(d.$$typeof){case va:return a=a.get(null===d.key?c:d.key)||null,k(b,a,d,e);case wa:return a=a.get(null===d.key?c:d.key)||null,l(b,a,d,e);case Ha:var f=d._init;return y(a,b,c,f(d._payload),e)}if(eb(d)||Ka(d))return a=a.get(c)||null,m(b,a,d,e,null);th(b,d)}return null}\nfunction n(e,g,h,k){for(var l=null,m=null,u=g,w=g=0,x=null;null!==u&&w<h.length;w++){u.index>w?(x=u,u=null):x=u.sibling;var n=r(e,u,h[w],k);if(null===n){null===u&&(u=x);break}a&&u&&null===n.alternate&&b(e,u);g=f(n,g,w);null===m?l=n:m.sibling=n;m=n;u=x}if(w===h.length)return c(e,u),I&&tg(e,w),l;if(null===u){for(;w<h.length;w++)u=q(e,h[w],k),null!==u&&(g=f(u,g,w),null===m?l=u:m.sibling=u,m=u);I&&tg(e,w);return l}for(u=d(e,u);w<h.length;w++)x=y(u,e,w,h[w],k),null!==x&&(a&&null!==x.alternate&&u.delete(null===\nx.key?w:x.key),g=f(x,g,w),null===m?l=x:m.sibling=x,m=x);a&&u.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function t(e,g,h,k){var l=Ka(h);if(\"function\"!==typeof l)throw Error(p(150));h=l.call(h);if(null==h)throw Error(p(151));for(var u=l=null,m=g,w=g=0,x=null,n=h.next();null!==m&&!n.done;w++,n=h.next()){m.index>w?(x=m,m=null):x=m.sibling;var t=r(e,m,n.value,k);if(null===t){null===m&&(m=x);break}a&&m&&null===t.alternate&&b(e,m);g=f(t,g,w);null===u?l=t:u.sibling=t;u=t;m=x}if(n.done)return c(e,\nm),I&&tg(e,w),l;if(null===m){for(;!n.done;w++,n=h.next())n=q(e,n.value,k),null!==n&&(g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);I&&tg(e,w);return l}for(m=d(e,m);!n.done;w++,n=h.next())n=y(m,e,w,n.value,k),null!==n&&(a&&null!==n.alternate&&m.delete(null===n.key?w:n.key),g=f(n,g,w),null===u?l=n:u.sibling=n,u=n);a&&m.forEach(function(a){return b(e,a)});I&&tg(e,w);return l}function J(a,d,f,h){\"object\"===typeof f&&null!==f&&f.type===ya&&null===f.key&&(f=f.props.children);if(\"object\"===typeof f&&null!==f){switch(f.$$typeof){case va:a:{for(var k=\nf.key,l=d;null!==l;){if(l.key===k){k=f.type;if(k===ya){if(7===l.tag){c(a,l.sibling);d=e(l,f.props.children);d.return=a;a=d;break a}}else if(l.elementType===k||\"object\"===typeof k&&null!==k&&k.$$typeof===Ha&&uh(k)===l.type){c(a,l.sibling);d=e(l,f.props);d.ref=sh(a,l,f);d.return=a;a=d;break a}c(a,l);break}else b(a,l);l=l.sibling}f.type===ya?(d=Ah(f.props.children,a.mode,h,f.key),d.return=a,a=d):(h=yh(f.type,f.key,f.props,null,a.mode,h),h.ref=sh(a,d,f),h.return=a,a=h)}return g(a);case wa:a:{for(l=f.key;null!==\nd;){if(d.key===l)if(4===d.tag&&d.stateNode.containerInfo===f.containerInfo&&d.stateNode.implementation===f.implementation){c(a,d.sibling);d=e(d,f.children||[]);d.return=a;a=d;break a}else{c(a,d);break}else b(a,d);d=d.sibling}d=zh(f,a.mode,h);d.return=a;a=d}return g(a);case Ha:return l=f._init,J(a,d,l(f._payload),h)}if(eb(f))return n(a,d,f,h);if(Ka(f))return t(a,d,f,h);th(a,f)}return\"string\"===typeof f&&\"\"!==f||\"number\"===typeof f?(f=\"\"+f,null!==d&&6===d.tag?(c(a,d.sibling),d=e(d,f),d.return=a,a=d):\n(c(a,d),d=xh(f,a.mode,h),d.return=a,a=d),g(a)):c(a,d)}return J}var Bh=vh(!0),Ch=vh(!1),Dh={},Eh=Uf(Dh),Fh=Uf(Dh),Gh=Uf(Dh);function Hh(a){if(a===Dh)throw Error(p(174));return a}function Ih(a,b){G(Gh,b);G(Fh,a);G(Eh,Dh);a=b.nodeType;switch(a){case 9:case 11:b=(b=b.documentElement)?b.namespaceURI:lb(null,\"\");break;default:a=8===a?b.parentNode:b,b=a.namespaceURI||null,a=a.tagName,b=lb(b,a)}E(Eh);G(Eh,b)}function Jh(){E(Eh);E(Fh);E(Gh)}\nfunction Kh(a){Hh(Gh.current);var b=Hh(Eh.current);var c=lb(b,a.type);b!==c&&(G(Fh,a),G(Eh,c))}function Lh(a){Fh.current===a&&(E(Eh),E(Fh))}var M=Uf(0);\nfunction Mh(a){for(var b=a;null!==b;){if(13===b.tag){var c=b.memoizedState;if(null!==c&&(c=c.dehydrated,null===c||\"$?\"===c.data||\"$!\"===c.data))return b}else if(19===b.tag&&void 0!==b.memoizedProps.revealOrder){if(0!==(b.flags&128))return b}else if(null!==b.child){b.child.return=b;b=b.child;continue}if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return null;b=b.return}b.sibling.return=b.return;b=b.sibling}return null}var Nh=[];\nfunction Oh(){for(var a=0;a<Nh.length;a++)Nh[a]._workInProgressVersionPrimary=null;Nh.length=0}var Ph=ua.ReactCurrentDispatcher,Qh=ua.ReactCurrentBatchConfig,Rh=0,N=null,O=null,P=null,Sh=!1,Th=!1,Uh=0,Vh=0;function Q(){throw Error(p(321));}function Wh(a,b){if(null===b)return!1;for(var c=0;c<b.length&&c<a.length;c++)if(!He(a[c],b[c]))return!1;return!0}\nfunction Xh(a,b,c,d,e,f){Rh=f;N=b;b.memoizedState=null;b.updateQueue=null;b.lanes=0;Ph.current=null===a||null===a.memoizedState?Yh:Zh;a=c(d,e);if(Th){f=0;do{Th=!1;Uh=0;if(25<=f)throw Error(p(301));f+=1;P=O=null;b.updateQueue=null;Ph.current=$h;a=c(d,e)}while(Th)}Ph.current=ai;b=null!==O&&null!==O.next;Rh=0;P=O=N=null;Sh=!1;if(b)throw Error(p(300));return a}function bi(){var a=0!==Uh;Uh=0;return a}\nfunction ci(){var a={memoizedState:null,baseState:null,baseQueue:null,queue:null,next:null};null===P?N.memoizedState=P=a:P=P.next=a;return P}function di(){if(null===O){var a=N.alternate;a=null!==a?a.memoizedState:null}else a=O.next;var b=null===P?N.memoizedState:P.next;if(null!==b)P=b,O=a;else{if(null===a)throw Error(p(310));O=a;a={memoizedState:O.memoizedState,baseState:O.baseState,baseQueue:O.baseQueue,queue:O.queue,next:null};null===P?N.memoizedState=P=a:P=P.next=a}return P}\nfunction ei(a,b){return\"function\"===typeof b?b(a):b}\nfunction fi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=O,e=d.baseQueue,f=c.pending;if(null!==f){if(null!==e){var g=e.next;e.next=f.next;f.next=g}d.baseQueue=e=f;c.pending=null}if(null!==e){f=e.next;d=d.baseState;var h=g=null,k=null,l=f;do{var m=l.lane;if((Rh&m)===m)null!==k&&(k=k.next={lane:0,action:l.action,hasEagerState:l.hasEagerState,eagerState:l.eagerState,next:null}),d=l.hasEagerState?l.eagerState:a(d,l.action);else{var q={lane:m,action:l.action,hasEagerState:l.hasEagerState,\neagerState:l.eagerState,next:null};null===k?(h=k=q,g=d):k=k.next=q;N.lanes|=m;hh|=m}l=l.next}while(null!==l&&l!==f);null===k?g=d:k.next=h;He(d,b.memoizedState)||(Ug=!0);b.memoizedState=d;b.baseState=g;b.baseQueue=k;c.lastRenderedState=d}a=c.interleaved;if(null!==a){e=a;do f=e.lane,N.lanes|=f,hh|=f,e=e.next;while(e!==a)}else null===e&&(c.lanes=0);return[b.memoizedState,c.dispatch]}\nfunction gi(a){var b=di(),c=b.queue;if(null===c)throw Error(p(311));c.lastRenderedReducer=a;var d=c.dispatch,e=c.pending,f=b.memoizedState;if(null!==e){c.pending=null;var g=e=e.next;do f=a(f,g.action),g=g.next;while(g!==e);He(f,b.memoizedState)||(Ug=!0);b.memoizedState=f;null===b.baseQueue&&(b.baseState=f);c.lastRenderedState=f}return[f,d]}function hi(){}\nfunction ii(a,b){var c=N,d=di(),e=b(),f=!He(d.memoizedState,e);f&&(d.memoizedState=e,Ug=!0);d=d.queue;ji(ki.bind(null,c,d,a),[a]);if(d.getSnapshot!==b||f||null!==P&&P.memoizedState.tag&1){c.flags|=2048;li(9,mi.bind(null,c,d,e,b),void 0,null);if(null===R)throw Error(p(349));0!==(Rh&30)||ni(c,b,e)}return e}function ni(a,b,c){a.flags|=16384;a={getSnapshot:b,value:c};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.stores=[a]):(c=b.stores,null===c?b.stores=[a]:c.push(a))}\nfunction mi(a,b,c,d){b.value=c;b.getSnapshot=d;oi(b)&&pi(a)}function ki(a,b,c){return c(function(){oi(b)&&pi(a)})}function oi(a){var b=a.getSnapshot;a=a.value;try{var c=b();return!He(a,c)}catch(d){return!0}}function pi(a){var b=Zg(a,1);null!==b&&mh(b,a,1,-1)}\nfunction qi(a){var b=ci();\"function\"===typeof a&&(a=a());b.memoizedState=b.baseState=a;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:ei,lastRenderedState:a};b.queue=a;a=a.dispatch=ri.bind(null,N,a);return[b.memoizedState,a]}\nfunction li(a,b,c,d){a={tag:a,create:b,destroy:c,deps:d,next:null};b=N.updateQueue;null===b?(b={lastEffect:null,stores:null},N.updateQueue=b,b.lastEffect=a.next=a):(c=b.lastEffect,null===c?b.lastEffect=a.next=a:(d=c.next,c.next=a,a.next=d,b.lastEffect=a));return a}function si(){return di().memoizedState}function ti(a,b,c,d){var e=ci();N.flags|=a;e.memoizedState=li(1|b,c,void 0,void 0===d?null:d)}\nfunction ui(a,b,c,d){var e=di();d=void 0===d?null:d;var f=void 0;if(null!==O){var g=O.memoizedState;f=g.destroy;if(null!==d&&Wh(d,g.deps)){e.memoizedState=li(b,c,f,d);return}}N.flags|=a;e.memoizedState=li(1|b,c,f,d)}function vi(a,b){return ti(8390656,8,a,b)}function ji(a,b){return ui(2048,8,a,b)}function wi(a,b){return ui(4,2,a,b)}function xi(a,b){return ui(4,4,a,b)}\nfunction yi(a,b){if(\"function\"===typeof b)return a=a(),b(a),function(){b(null)};if(null!==b&&void 0!==b)return a=a(),b.current=a,function(){b.current=null}}function zi(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ui(4,4,yi.bind(null,b,a),c)}function Ai(){}function Bi(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];c.memoizedState=[a,b];return a}\nfunction Ci(a,b){var c=di();b=void 0===b?null:b;var d=c.memoizedState;if(null!==d&&null!==b&&Wh(b,d[1]))return d[0];a=a();c.memoizedState=[a,b];return a}function Di(a,b,c){if(0===(Rh&21))return a.baseState&&(a.baseState=!1,Ug=!0),a.memoizedState=c;He(c,b)||(c=yc(),N.lanes|=c,hh|=c,a.baseState=!0);return b}function Ei(a,b){var c=C;C=0!==c&&4>c?c:4;a(!0);var d=Qh.transition;Qh.transition={};try{a(!1),b()}finally{C=c,Qh.transition=d}}function Fi(){return di().memoizedState}\nfunction Gi(a,b,c){var d=lh(a);c={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,c);else if(c=Yg(a,b,c,d),null!==c){var e=L();mh(c,a,d,e);Ji(c,b,d)}}\nfunction ri(a,b,c){var d=lh(a),e={lane:d,action:c,hasEagerState:!1,eagerState:null,next:null};if(Hi(a))Ii(b,e);else{var f=a.alternate;if(0===a.lanes&&(null===f||0===f.lanes)&&(f=b.lastRenderedReducer,null!==f))try{var g=b.lastRenderedState,h=f(g,c);e.hasEagerState=!0;e.eagerState=h;if(He(h,g)){var k=b.interleaved;null===k?(e.next=e,Xg(b)):(e.next=k.next,k.next=e);b.interleaved=e;return}}catch(l){}finally{}c=Yg(a,b,e,d);null!==c&&(e=L(),mh(c,a,d,e),Ji(c,b,d))}}\nfunction Hi(a){var b=a.alternate;return a===N||null!==b&&b===N}function Ii(a,b){Th=Sh=!0;var c=a.pending;null===c?b.next=b:(b.next=c.next,c.next=b);a.pending=b}function Ji(a,b,c){if(0!==(c&4194240)){var d=b.lanes;d&=a.pendingLanes;c|=d;b.lanes=c;Cc(a,c)}}\nvar ai={readContext:Vg,useCallback:Q,useContext:Q,useEffect:Q,useImperativeHandle:Q,useInsertionEffect:Q,useLayoutEffect:Q,useMemo:Q,useReducer:Q,useRef:Q,useState:Q,useDebugValue:Q,useDeferredValue:Q,useTransition:Q,useMutableSource:Q,useSyncExternalStore:Q,useId:Q,unstable_isNewReconciler:!1},Yh={readContext:Vg,useCallback:function(a,b){ci().memoizedState=[a,void 0===b?null:b];return a},useContext:Vg,useEffect:vi,useImperativeHandle:function(a,b,c){c=null!==c&&void 0!==c?c.concat([a]):null;return ti(4194308,\n4,yi.bind(null,b,a),c)},useLayoutEffect:function(a,b){return ti(4194308,4,a,b)},useInsertionEffect:function(a,b){return ti(4,2,a,b)},useMemo:function(a,b){var c=ci();b=void 0===b?null:b;a=a();c.memoizedState=[a,b];return a},useReducer:function(a,b,c){var d=ci();b=void 0!==c?c(b):b;d.memoizedState=d.baseState=b;a={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:a,lastRenderedState:b};d.queue=a;a=a.dispatch=Gi.bind(null,N,a);return[d.memoizedState,a]},useRef:function(a){var b=\nci();a={current:a};return b.memoizedState=a},useState:qi,useDebugValue:Ai,useDeferredValue:function(a){return ci().memoizedState=a},useTransition:function(){var a=qi(!1),b=a[0];a=Ei.bind(null,a[1]);ci().memoizedState=a;return[b,a]},useMutableSource:function(){},useSyncExternalStore:function(a,b,c){var d=N,e=ci();if(I){if(void 0===c)throw Error(p(407));c=c()}else{c=b();if(null===R)throw Error(p(349));0!==(Rh&30)||ni(d,b,c)}e.memoizedState=c;var f={value:c,getSnapshot:b};e.queue=f;vi(ki.bind(null,d,\nf,a),[a]);d.flags|=2048;li(9,mi.bind(null,d,f,c,b),void 0,null);return c},useId:function(){var a=ci(),b=R.identifierPrefix;if(I){var c=sg;var d=rg;c=(d&~(1<<32-oc(d)-1)).toString(32)+c;b=\":\"+b+\"R\"+c;c=Uh++;0<c&&(b+=\"H\"+c.toString(32));b+=\":\"}else c=Vh++,b=\":\"+b+\"r\"+c.toString(32)+\":\";return a.memoizedState=b},unstable_isNewReconciler:!1},Zh={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:fi,useRef:si,useState:function(){return fi(ei)},\nuseDebugValue:Ai,useDeferredValue:function(a){var b=di();return Di(b,O.memoizedState,a)},useTransition:function(){var a=fi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1},$h={readContext:Vg,useCallback:Bi,useContext:Vg,useEffect:ji,useImperativeHandle:zi,useInsertionEffect:wi,useLayoutEffect:xi,useMemo:Ci,useReducer:gi,useRef:si,useState:function(){return gi(ei)},useDebugValue:Ai,useDeferredValue:function(a){var b=di();return null===\nO?b.memoizedState=a:Di(b,O.memoizedState,a)},useTransition:function(){var a=gi(ei)[0],b=di().memoizedState;return[a,b]},useMutableSource:hi,useSyncExternalStore:ii,useId:Fi,unstable_isNewReconciler:!1};function Ki(a,b){try{var c=\"\",d=b;do c+=Pa(d),d=d.return;while(d);var e=c}catch(f){e=\"\\nError generating stack: \"+f.message+\"\\n\"+f.stack}return{value:a,source:b,stack:e,digest:null}}function Li(a,b,c){return{value:a,source:null,stack:null!=c?c:null,digest:null!=b?b:null}}\nfunction Mi(a,b){try{console.error(b.value)}catch(c){setTimeout(function(){throw c;})}}var Ni=\"function\"===typeof WeakMap?WeakMap:Map;function Oi(a,b,c){c=ch(-1,c);c.tag=3;c.payload={element:null};var d=b.value;c.callback=function(){Pi||(Pi=!0,Qi=d);Mi(a,b)};return c}\nfunction Ri(a,b,c){c=ch(-1,c);c.tag=3;var d=a.type.getDerivedStateFromError;if(\"function\"===typeof d){var e=b.value;c.payload=function(){return d(e)};c.callback=function(){Mi(a,b)}}var f=a.stateNode;null!==f&&\"function\"===typeof f.componentDidCatch&&(c.callback=function(){Mi(a,b);\"function\"!==typeof d&&(null===Si?Si=new Set([this]):Si.add(this));var c=b.stack;this.componentDidCatch(b.value,{componentStack:null!==c?c:\"\"})});return c}\nfunction Ti(a,b,c){var d=a.pingCache;if(null===d){d=a.pingCache=new Ni;var e=new Set;d.set(b,e)}else e=d.get(b),void 0===e&&(e=new Set,d.set(b,e));e.has(c)||(e.add(c),a=Ui.bind(null,a,b,c),b.then(a,a))}function Vi(a){do{var b;if(b=13===a.tag)b=a.memoizedState,b=null!==b?null!==b.dehydrated?!0:!1:!0;if(b)return a;a=a.return}while(null!==a);return null}\nfunction Wi(a,b,c,d,e){if(0===(a.mode&1))return a===b?a.flags|=65536:(a.flags|=128,c.flags|=131072,c.flags&=-52805,1===c.tag&&(null===c.alternate?c.tag=17:(b=ch(-1,1),b.tag=2,dh(c,b,1))),c.lanes|=1),a;a.flags|=65536;a.lanes=e;return a}var Xi=ua.ReactCurrentOwner,Ug=!1;function Yi(a,b,c,d){b.child=null===a?Ch(b,null,c,d):Bh(b,a.child,c,d)}\nfunction Zi(a,b,c,d,e){c=c.render;var f=b.ref;Tg(b,e);d=Xh(a,b,c,d,f,e);c=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&c&&vg(b);b.flags|=1;Yi(a,b,d,e);return b.child}\nfunction aj(a,b,c,d,e){if(null===a){var f=c.type;if(\"function\"===typeof f&&!bj(f)&&void 0===f.defaultProps&&null===c.compare&&void 0===c.defaultProps)return b.tag=15,b.type=f,cj(a,b,f,d,e);a=yh(c.type,null,d,b,b.mode,e);a.ref=b.ref;a.return=b;return b.child=a}f=a.child;if(0===(a.lanes&e)){var g=f.memoizedProps;c=c.compare;c=null!==c?c:Ie;if(c(g,d)&&a.ref===b.ref)return $i(a,b,e)}b.flags|=1;a=wh(f,d);a.ref=b.ref;a.return=b;return b.child=a}\nfunction cj(a,b,c,d,e){if(null!==a){var f=a.memoizedProps;if(Ie(f,d)&&a.ref===b.ref)if(Ug=!1,b.pendingProps=d=f,0!==(a.lanes&e))0!==(a.flags&131072)&&(Ug=!0);else return b.lanes=a.lanes,$i(a,b,e)}return dj(a,b,c,d,e)}\nfunction ej(a,b,c){var d=b.pendingProps,e=d.children,f=null!==a?a.memoizedState:null;if(\"hidden\"===d.mode)if(0===(b.mode&1))b.memoizedState={baseLanes:0,cachePool:null,transitions:null},G(fj,gj),gj|=c;else{if(0===(c&1073741824))return a=null!==f?f.baseLanes|c:c,b.lanes=b.childLanes=1073741824,b.memoizedState={baseLanes:a,cachePool:null,transitions:null},b.updateQueue=null,G(fj,gj),gj|=a,null;b.memoizedState={baseLanes:0,cachePool:null,transitions:null};d=null!==f?f.baseLanes:c;G(fj,gj);gj|=d}else null!==\nf?(d=f.baseLanes|c,b.memoizedState=null):d=c,G(fj,gj),gj|=d;Yi(a,b,e,c);return b.child}function hj(a,b){var c=b.ref;if(null===a&&null!==c||null!==a&&a.ref!==c)b.flags|=512,b.flags|=2097152}function dj(a,b,c,d,e){var f=Zf(c)?Xf:H.current;f=Yf(b,f);Tg(b,e);c=Xh(a,b,c,d,f,e);d=bi();if(null!==a&&!Ug)return b.updateQueue=a.updateQueue,b.flags&=-2053,a.lanes&=~e,$i(a,b,e);I&&d&&vg(b);b.flags|=1;Yi(a,b,c,e);return b.child}\nfunction ij(a,b,c,d,e){if(Zf(c)){var f=!0;cg(b)}else f=!1;Tg(b,e);if(null===b.stateNode)jj(a,b),ph(b,c,d),rh(b,c,d,e),d=!0;else if(null===a){var g=b.stateNode,h=b.memoizedProps;g.props=h;var k=g.context,l=c.contextType;\"object\"===typeof l&&null!==l?l=Vg(l):(l=Zf(c)?Xf:H.current,l=Yf(b,l));var m=c.getDerivedStateFromProps,q=\"function\"===typeof m||\"function\"===typeof g.getSnapshotBeforeUpdate;q||\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||\n(h!==d||k!==l)&&qh(b,g,d,l);$g=!1;var r=b.memoizedState;g.state=r;gh(b,d,g,e);k=b.memoizedState;h!==d||r!==k||Wf.current||$g?(\"function\"===typeof m&&(kh(b,c,m,d),k=b.memoizedState),(h=$g||oh(b,c,h,d,r,k,l))?(q||\"function\"!==typeof g.UNSAFE_componentWillMount&&\"function\"!==typeof g.componentWillMount||(\"function\"===typeof g.componentWillMount&&g.componentWillMount(),\"function\"===typeof g.UNSAFE_componentWillMount&&g.UNSAFE_componentWillMount()),\"function\"===typeof g.componentDidMount&&(b.flags|=4194308)):\n(\"function\"===typeof g.componentDidMount&&(b.flags|=4194308),b.memoizedProps=d,b.memoizedState=k),g.props=d,g.state=k,g.context=l,d=h):(\"function\"===typeof g.componentDidMount&&(b.flags|=4194308),d=!1)}else{g=b.stateNode;bh(a,b);h=b.memoizedProps;l=b.type===b.elementType?h:Lg(b.type,h);g.props=l;q=b.pendingProps;r=g.context;k=c.contextType;\"object\"===typeof k&&null!==k?k=Vg(k):(k=Zf(c)?Xf:H.current,k=Yf(b,k));var y=c.getDerivedStateFromProps;(m=\"function\"===typeof y||\"function\"===typeof g.getSnapshotBeforeUpdate)||\n\"function\"!==typeof g.UNSAFE_componentWillReceiveProps&&\"function\"!==typeof g.componentWillReceiveProps||(h!==q||r!==k)&&qh(b,g,d,k);$g=!1;r=b.memoizedState;g.state=r;gh(b,d,g,e);var n=b.memoizedState;h!==q||r!==n||Wf.current||$g?(\"function\"===typeof y&&(kh(b,c,y,d),n=b.memoizedState),(l=$g||oh(b,c,l,d,r,n,k)||!1)?(m||\"function\"!==typeof g.UNSAFE_componentWillUpdate&&\"function\"!==typeof g.componentWillUpdate||(\"function\"===typeof g.componentWillUpdate&&g.componentWillUpdate(d,n,k),\"function\"===typeof g.UNSAFE_componentWillUpdate&&\ng.UNSAFE_componentWillUpdate(d,n,k)),\"function\"===typeof g.componentDidUpdate&&(b.flags|=4),\"function\"===typeof g.getSnapshotBeforeUpdate&&(b.flags|=1024)):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),b.memoizedProps=d,b.memoizedState=n),g.props=d,g.state=n,g.context=k,d=l):(\"function\"!==typeof g.componentDidUpdate||h===a.memoizedProps&&r===\na.memoizedState||(b.flags|=4),\"function\"!==typeof g.getSnapshotBeforeUpdate||h===a.memoizedProps&&r===a.memoizedState||(b.flags|=1024),d=!1)}return kj(a,b,c,d,f,e)}\nfunction kj(a,b,c,d,e,f){hj(a,b);var g=0!==(b.flags&128);if(!d&&!g)return e&&dg(b,c,!1),$i(a,b,f);d=b.stateNode;Xi.current=b;var h=g&&\"function\"!==typeof c.getDerivedStateFromError?null:d.render();b.flags|=1;null!==a&&g?(b.child=Bh(b,a.child,null,f),b.child=Bh(b,null,h,f)):Yi(a,b,h,f);b.memoizedState=d.state;e&&dg(b,c,!0);return b.child}function lj(a){var b=a.stateNode;b.pendingContext?ag(a,b.pendingContext,b.pendingContext!==b.context):b.context&&ag(a,b.context,!1);Ih(a,b.containerInfo)}\nfunction mj(a,b,c,d,e){Ig();Jg(e);b.flags|=256;Yi(a,b,c,d);return b.child}var nj={dehydrated:null,treeContext:null,retryLane:0};function oj(a){return{baseLanes:a,cachePool:null,transitions:null}}\nfunction pj(a,b,c){var d=b.pendingProps,e=M.current,f=!1,g=0!==(b.flags&128),h;(h=g)||(h=null!==a&&null===a.memoizedState?!1:0!==(e&2));if(h)f=!0,b.flags&=-129;else if(null===a||null!==a.memoizedState)e|=1;G(M,e&1);if(null===a){Eg(b);a=b.memoizedState;if(null!==a&&(a=a.dehydrated,null!==a))return 0===(b.mode&1)?b.lanes=1:\"$!\"===a.data?b.lanes=8:b.lanes=1073741824,null;g=d.children;a=d.fallback;return f?(d=b.mode,f=b.child,g={mode:\"hidden\",children:g},0===(d&1)&&null!==f?(f.childLanes=0,f.pendingProps=\ng):f=qj(g,d,0,null),a=Ah(a,d,c,null),f.return=b,a.return=b,f.sibling=a,b.child=f,b.child.memoizedState=oj(c),b.memoizedState=nj,a):rj(b,g)}e=a.memoizedState;if(null!==e&&(h=e.dehydrated,null!==h))return sj(a,b,g,d,h,e,c);if(f){f=d.fallback;g=b.mode;e=a.child;h=e.sibling;var k={mode:\"hidden\",children:d.children};0===(g&1)&&b.child!==e?(d=b.child,d.childLanes=0,d.pendingProps=k,b.deletions=null):(d=wh(e,k),d.subtreeFlags=e.subtreeFlags&14680064);null!==h?f=wh(h,f):(f=Ah(f,g,c,null),f.flags|=2);f.return=\nb;d.return=b;d.sibling=f;b.child=d;d=f;f=b.child;g=a.child.memoizedState;g=null===g?oj(c):{baseLanes:g.baseLanes|c,cachePool:null,transitions:g.transitions};f.memoizedState=g;f.childLanes=a.childLanes&~c;b.memoizedState=nj;return d}f=a.child;a=f.sibling;d=wh(f,{mode:\"visible\",children:d.children});0===(b.mode&1)&&(d.lanes=c);d.return=b;d.sibling=null;null!==a&&(c=b.deletions,null===c?(b.deletions=[a],b.flags|=16):c.push(a));b.child=d;b.memoizedState=null;return d}\nfunction rj(a,b){b=qj({mode:\"visible\",children:b},a.mode,0,null);b.return=a;return a.child=b}function tj(a,b,c,d){null!==d&&Jg(d);Bh(b,a.child,null,c);a=rj(b,b.pendingProps.children);a.flags|=2;b.memoizedState=null;return a}\nfunction sj(a,b,c,d,e,f,g){if(c){if(b.flags&256)return b.flags&=-257,d=Li(Error(p(422))),tj(a,b,g,d);if(null!==b.memoizedState)return b.child=a.child,b.flags|=128,null;f=d.fallback;e=b.mode;d=qj({mode:\"visible\",children:d.children},e,0,null);f=Ah(f,e,g,null);f.flags|=2;d.return=b;f.return=b;d.sibling=f;b.child=d;0!==(b.mode&1)&&Bh(b,a.child,null,g);b.child.memoizedState=oj(g);b.memoizedState=nj;return f}if(0===(b.mode&1))return tj(a,b,g,null);if(\"$!\"===e.data){d=e.nextSibling&&e.nextSibling.dataset;\nif(d)var h=d.dgst;d=h;f=Error(p(419));d=Li(f,d,void 0);return tj(a,b,g,d)}h=0!==(g&a.childLanes);if(Ug||h){d=R;if(null!==d){switch(g&-g){case 4:e=2;break;case 16:e=8;break;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:e=32;break;case 536870912:e=268435456;break;default:e=0}e=0!==(e&(d.suspendedLanes|g))?0:e;\n0!==e&&e!==f.retryLane&&(f.retryLane=e,Zg(a,e),mh(d,a,e,-1))}uj();d=Li(Error(p(421)));return tj(a,b,g,d)}if(\"$?\"===e.data)return b.flags|=128,b.child=a.child,b=vj.bind(null,a),e._reactRetry=b,null;a=f.treeContext;yg=Lf(e.nextSibling);xg=b;I=!0;zg=null;null!==a&&(og[pg++]=rg,og[pg++]=sg,og[pg++]=qg,rg=a.id,sg=a.overflow,qg=b);b=rj(b,d.children);b.flags|=4096;return b}function wj(a,b,c){a.lanes|=b;var d=a.alternate;null!==d&&(d.lanes|=b);Sg(a.return,b,c)}\nfunction xj(a,b,c,d,e){var f=a.memoizedState;null===f?a.memoizedState={isBackwards:b,rendering:null,renderingStartTime:0,last:d,tail:c,tailMode:e}:(f.isBackwards=b,f.rendering=null,f.renderingStartTime=0,f.last=d,f.tail=c,f.tailMode=e)}\nfunction yj(a,b,c){var d=b.pendingProps,e=d.revealOrder,f=d.tail;Yi(a,b,d.children,c);d=M.current;if(0!==(d&2))d=d&1|2,b.flags|=128;else{if(null!==a&&0!==(a.flags&128))a:for(a=b.child;null!==a;){if(13===a.tag)null!==a.memoizedState&&wj(a,c,b);else if(19===a.tag)wj(a,c,b);else if(null!==a.child){a.child.return=a;a=a.child;continue}if(a===b)break a;for(;null===a.sibling;){if(null===a.return||a.return===b)break a;a=a.return}a.sibling.return=a.return;a=a.sibling}d&=1}G(M,d);if(0===(b.mode&1))b.memoizedState=\nnull;else switch(e){case \"forwards\":c=b.child;for(e=null;null!==c;)a=c.alternate,null!==a&&null===Mh(a)&&(e=c),c=c.sibling;c=e;null===c?(e=b.child,b.child=null):(e=c.sibling,c.sibling=null);xj(b,!1,e,c,f);break;case \"backwards\":c=null;e=b.child;for(b.child=null;null!==e;){a=e.alternate;if(null!==a&&null===Mh(a)){b.child=e;break}a=e.sibling;e.sibling=c;c=e;e=a}xj(b,!0,c,null,f);break;case \"together\":xj(b,!1,null,null,void 0);break;default:b.memoizedState=null}return b.child}\nfunction jj(a,b){0===(b.mode&1)&&null!==a&&(a.alternate=null,b.alternate=null,b.flags|=2)}function $i(a,b,c){null!==a&&(b.dependencies=a.dependencies);hh|=b.lanes;if(0===(c&b.childLanes))return null;if(null!==a&&b.child!==a.child)throw Error(p(153));if(null!==b.child){a=b.child;c=wh(a,a.pendingProps);b.child=c;for(c.return=b;null!==a.sibling;)a=a.sibling,c=c.sibling=wh(a,a.pendingProps),c.return=b;c.sibling=null}return b.child}\nfunction zj(a,b,c){switch(b.tag){case 3:lj(b);Ig();break;case 5:Kh(b);break;case 1:Zf(b.type)&&cg(b);break;case 4:Ih(b,b.stateNode.containerInfo);break;case 10:var d=b.type._context,e=b.memoizedProps.value;G(Mg,d._currentValue);d._currentValue=e;break;case 13:d=b.memoizedState;if(null!==d){if(null!==d.dehydrated)return G(M,M.current&1),b.flags|=128,null;if(0!==(c&b.child.childLanes))return pj(a,b,c);G(M,M.current&1);a=$i(a,b,c);return null!==a?a.sibling:null}G(M,M.current&1);break;case 19:d=0!==(c&\nb.childLanes);if(0!==(a.flags&128)){if(d)return yj(a,b,c);b.flags|=128}e=b.memoizedState;null!==e&&(e.rendering=null,e.tail=null,e.lastEffect=null);G(M,M.current);if(d)break;else return null;case 22:case 23:return b.lanes=0,ej(a,b,c)}return $i(a,b,c)}var Aj,Bj,Cj,Dj;\nAj=function(a,b){for(var c=b.child;null!==c;){if(5===c.tag||6===c.tag)a.appendChild(c.stateNode);else if(4!==c.tag&&null!==c.child){c.child.return=c;c=c.child;continue}if(c===b)break;for(;null===c.sibling;){if(null===c.return||c.return===b)return;c=c.return}c.sibling.return=c.return;c=c.sibling}};Bj=function(){};\nCj=function(a,b,c,d){var e=a.memoizedProps;if(e!==d){a=b.stateNode;Hh(Eh.current);var f=null;switch(c){case \"input\":e=Ya(a,e);d=Ya(a,d);f=[];break;case \"select\":e=A({},e,{value:void 0});d=A({},d,{value:void 0});f=[];break;case \"textarea\":e=gb(a,e);d=gb(a,d);f=[];break;default:\"function\"!==typeof e.onClick&&\"function\"===typeof d.onClick&&(a.onclick=Bf)}ub(c,d);var g;c=null;for(l in e)if(!d.hasOwnProperty(l)&&e.hasOwnProperty(l)&&null!=e[l])if(\"style\"===l){var h=e[l];for(g in h)h.hasOwnProperty(g)&&\n(c||(c={}),c[g]=\"\")}else\"dangerouslySetInnerHTML\"!==l&&\"children\"!==l&&\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&\"autoFocus\"!==l&&(ea.hasOwnProperty(l)?f||(f=[]):(f=f||[]).push(l,null));for(l in d){var k=d[l];h=null!=e?e[l]:void 0;if(d.hasOwnProperty(l)&&k!==h&&(null!=k||null!=h))if(\"style\"===l)if(h){for(g in h)!h.hasOwnProperty(g)||k&&k.hasOwnProperty(g)||(c||(c={}),c[g]=\"\");for(g in k)k.hasOwnProperty(g)&&h[g]!==k[g]&&(c||(c={}),c[g]=k[g])}else c||(f||(f=[]),f.push(l,\nc)),c=k;else\"dangerouslySetInnerHTML\"===l?(k=k?k.__html:void 0,h=h?h.__html:void 0,null!=k&&h!==k&&(f=f||[]).push(l,k)):\"children\"===l?\"string\"!==typeof k&&\"number\"!==typeof k||(f=f||[]).push(l,\"\"+k):\"suppressContentEditableWarning\"!==l&&\"suppressHydrationWarning\"!==l&&(ea.hasOwnProperty(l)?(null!=k&&\"onScroll\"===l&&D(\"scroll\",a),f||h===k||(f=[])):(f=f||[]).push(l,k))}c&&(f=f||[]).push(\"style\",c);var l=f;if(b.updateQueue=l)b.flags|=4}};Dj=function(a,b,c,d){c!==d&&(b.flags|=4)};\nfunction Ej(a,b){if(!I)switch(a.tailMode){case \"hidden\":b=a.tail;for(var c=null;null!==b;)null!==b.alternate&&(c=b),b=b.sibling;null===c?a.tail=null:c.sibling=null;break;case \"collapsed\":c=a.tail;for(var d=null;null!==c;)null!==c.alternate&&(d=c),c=c.sibling;null===d?b||null===a.tail?a.tail=null:a.tail.sibling=null:d.sibling=null}}\nfunction S(a){var b=null!==a.alternate&&a.alternate.child===a.child,c=0,d=0;if(b)for(var e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags&14680064,d|=e.flags&14680064,e.return=a,e=e.sibling;else for(e=a.child;null!==e;)c|=e.lanes|e.childLanes,d|=e.subtreeFlags,d|=e.flags,e.return=a,e=e.sibling;a.subtreeFlags|=d;a.childLanes=c;return b}\nfunction Fj(a,b,c){var d=b.pendingProps;wg(b);switch(b.tag){case 2:case 16:case 15:case 0:case 11:case 7:case 8:case 12:case 9:case 14:return S(b),null;case 1:return Zf(b.type)&&$f(),S(b),null;case 3:d=b.stateNode;Jh();E(Wf);E(H);Oh();d.pendingContext&&(d.context=d.pendingContext,d.pendingContext=null);if(null===a||null===a.child)Gg(b)?b.flags|=4:null===a||a.memoizedState.isDehydrated&&0===(b.flags&256)||(b.flags|=1024,null!==zg&&(Gj(zg),zg=null));Bj(a,b);S(b);return null;case 5:Lh(b);var e=Hh(Gh.current);\nc=b.type;if(null!==a&&null!=b.stateNode)Cj(a,b,c,d,e),a.ref!==b.ref&&(b.flags|=512,b.flags|=2097152);else{if(!d){if(null===b.stateNode)throw Error(p(166));S(b);return null}a=Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.type;var f=b.memoizedProps;d[Of]=b;d[Pf]=f;a=0!==(b.mode&1);switch(c){case \"dialog\":D(\"cancel\",d);D(\"close\",d);break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",d);break;case \"video\":case \"audio\":for(e=0;e<lf.length;e++)D(lf[e],d);break;case \"source\":D(\"error\",d);break;case \"img\":case \"image\":case \"link\":D(\"error\",\nd);D(\"load\",d);break;case \"details\":D(\"toggle\",d);break;case \"input\":Za(d,f);D(\"invalid\",d);break;case \"select\":d._wrapperState={wasMultiple:!!f.multiple};D(\"invalid\",d);break;case \"textarea\":hb(d,f),D(\"invalid\",d)}ub(c,f);e=null;for(var g in f)if(f.hasOwnProperty(g)){var h=f[g];\"children\"===g?\"string\"===typeof h?d.textContent!==h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,h,a),e=[\"children\",h]):\"number\"===typeof h&&d.textContent!==\"\"+h&&(!0!==f.suppressHydrationWarning&&Af(d.textContent,\nh,a),e=[\"children\",\"\"+h]):ea.hasOwnProperty(g)&&null!=h&&\"onScroll\"===g&&D(\"scroll\",d)}switch(c){case \"input\":Va(d);db(d,f,!0);break;case \"textarea\":Va(d);jb(d);break;case \"select\":case \"option\":break;default:\"function\"===typeof f.onClick&&(d.onclick=Bf)}d=e;b.updateQueue=d;null!==d&&(b.flags|=4)}else{g=9===e.nodeType?e:e.ownerDocument;\"http://www.w3.org/1999/xhtml\"===a&&(a=kb(c));\"http://www.w3.org/1999/xhtml\"===a?\"script\"===c?(a=g.createElement(\"div\"),a.innerHTML=\"<script>\\x3c/script>\",a=a.removeChild(a.firstChild)):\n\"string\"===typeof d.is?a=g.createElement(c,{is:d.is}):(a=g.createElement(c),\"select\"===c&&(g=a,d.multiple?g.multiple=!0:d.size&&(g.size=d.size))):a=g.createElementNS(a,c);a[Of]=b;a[Pf]=d;Aj(a,b,!1,!1);b.stateNode=a;a:{g=vb(c,d);switch(c){case \"dialog\":D(\"cancel\",a);D(\"close\",a);e=d;break;case \"iframe\":case \"object\":case \"embed\":D(\"load\",a);e=d;break;case \"video\":case \"audio\":for(e=0;e<lf.length;e++)D(lf[e],a);e=d;break;case \"source\":D(\"error\",a);e=d;break;case \"img\":case \"image\":case \"link\":D(\"error\",\na);D(\"load\",a);e=d;break;case \"details\":D(\"toggle\",a);e=d;break;case \"input\":Za(a,d);e=Ya(a,d);D(\"invalid\",a);break;case \"option\":e=d;break;case \"select\":a._wrapperState={wasMultiple:!!d.multiple};e=A({},d,{value:void 0});D(\"invalid\",a);break;case \"textarea\":hb(a,d);e=gb(a,d);D(\"invalid\",a);break;default:e=d}ub(c,e);h=e;for(f in h)if(h.hasOwnProperty(f)){var k=h[f];\"style\"===f?sb(a,k):\"dangerouslySetInnerHTML\"===f?(k=k?k.__html:void 0,null!=k&&nb(a,k)):\"children\"===f?\"string\"===typeof k?(\"textarea\"!==\nc||\"\"!==k)&&ob(a,k):\"number\"===typeof k&&ob(a,\"\"+k):\"suppressContentEditableWarning\"!==f&&\"suppressHydrationWarning\"!==f&&\"autoFocus\"!==f&&(ea.hasOwnProperty(f)?null!=k&&\"onScroll\"===f&&D(\"scroll\",a):null!=k&&ta(a,f,k,g))}switch(c){case \"input\":Va(a);db(a,d,!1);break;case \"textarea\":Va(a);jb(a);break;case \"option\":null!=d.value&&a.setAttribute(\"value\",\"\"+Sa(d.value));break;case \"select\":a.multiple=!!d.multiple;f=d.value;null!=f?fb(a,!!d.multiple,f,!1):null!=d.defaultValue&&fb(a,!!d.multiple,d.defaultValue,\n!0);break;default:\"function\"===typeof e.onClick&&(a.onclick=Bf)}switch(c){case \"button\":case \"input\":case \"select\":case \"textarea\":d=!!d.autoFocus;break a;case \"img\":d=!0;break a;default:d=!1}}d&&(b.flags|=4)}null!==b.ref&&(b.flags|=512,b.flags|=2097152)}S(b);return null;case 6:if(a&&null!=b.stateNode)Dj(a,b,a.memoizedProps,d);else{if(\"string\"!==typeof d&&null===b.stateNode)throw Error(p(166));c=Hh(Gh.current);Hh(Eh.current);if(Gg(b)){d=b.stateNode;c=b.memoizedProps;d[Of]=b;if(f=d.nodeValue!==c)if(a=\nxg,null!==a)switch(a.tag){case 3:Af(d.nodeValue,c,0!==(a.mode&1));break;case 5:!0!==a.memoizedProps.suppressHydrationWarning&&Af(d.nodeValue,c,0!==(a.mode&1))}f&&(b.flags|=4)}else d=(9===c.nodeType?c:c.ownerDocument).createTextNode(d),d[Of]=b,b.stateNode=d}S(b);return null;case 13:E(M);d=b.memoizedState;if(null===a||null!==a.memoizedState&&null!==a.memoizedState.dehydrated){if(I&&null!==yg&&0!==(b.mode&1)&&0===(b.flags&128))Hg(),Ig(),b.flags|=98560,f=!1;else if(f=Gg(b),null!==d&&null!==d.dehydrated){if(null===\na){if(!f)throw Error(p(318));f=b.memoizedState;f=null!==f?f.dehydrated:null;if(!f)throw Error(p(317));f[Of]=b}else Ig(),0===(b.flags&128)&&(b.memoizedState=null),b.flags|=4;S(b);f=!1}else null!==zg&&(Gj(zg),zg=null),f=!0;if(!f)return b.flags&65536?b:null}if(0!==(b.flags&128))return b.lanes=c,b;d=null!==d;d!==(null!==a&&null!==a.memoizedState)&&d&&(b.child.flags|=8192,0!==(b.mode&1)&&(null===a||0!==(M.current&1)?0===T&&(T=3):uj()));null!==b.updateQueue&&(b.flags|=4);S(b);return null;case 4:return Jh(),\nBj(a,b),null===a&&sf(b.stateNode.containerInfo),S(b),null;case 10:return Rg(b.type._context),S(b),null;case 17:return Zf(b.type)&&$f(),S(b),null;case 19:E(M);f=b.memoizedState;if(null===f)return S(b),null;d=0!==(b.flags&128);g=f.rendering;if(null===g)if(d)Ej(f,!1);else{if(0!==T||null!==a&&0!==(a.flags&128))for(a=b.child;null!==a;){g=Mh(a);if(null!==g){b.flags|=128;Ej(f,!1);d=g.updateQueue;null!==d&&(b.updateQueue=d,b.flags|=4);b.subtreeFlags=0;d=c;for(c=b.child;null!==c;)f=c,a=d,f.flags&=14680066,\ng=f.alternate,null===g?(f.childLanes=0,f.lanes=a,f.child=null,f.subtreeFlags=0,f.memoizedProps=null,f.memoizedState=null,f.updateQueue=null,f.dependencies=null,f.stateNode=null):(f.childLanes=g.childLanes,f.lanes=g.lanes,f.child=g.child,f.subtreeFlags=0,f.deletions=null,f.memoizedProps=g.memoizedProps,f.memoizedState=g.memoizedState,f.updateQueue=g.updateQueue,f.type=g.type,a=g.dependencies,f.dependencies=null===a?null:{lanes:a.lanes,firstContext:a.firstContext}),c=c.sibling;G(M,M.current&1|2);return b.child}a=\na.sibling}null!==f.tail&&B()>Hj&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304)}else{if(!d)if(a=Mh(g),null!==a){if(b.flags|=128,d=!0,c=a.updateQueue,null!==c&&(b.updateQueue=c,b.flags|=4),Ej(f,!0),null===f.tail&&\"hidden\"===f.tailMode&&!g.alternate&&!I)return S(b),null}else 2*B()-f.renderingStartTime>Hj&&1073741824!==c&&(b.flags|=128,d=!0,Ej(f,!1),b.lanes=4194304);f.isBackwards?(g.sibling=b.child,b.child=g):(c=f.last,null!==c?c.sibling=g:b.child=g,f.last=g)}if(null!==f.tail)return b=f.tail,f.rendering=\nb,f.tail=b.sibling,f.renderingStartTime=B(),b.sibling=null,c=M.current,G(M,d?c&1|2:c&1),b;S(b);return null;case 22:case 23:return Ij(),d=null!==b.memoizedState,null!==a&&null!==a.memoizedState!==d&&(b.flags|=8192),d&&0!==(b.mode&1)?0!==(gj&1073741824)&&(S(b),b.subtreeFlags&6&&(b.flags|=8192)):S(b),null;case 24:return null;case 25:return null}throw Error(p(156,b.tag));}\nfunction Jj(a,b){wg(b);switch(b.tag){case 1:return Zf(b.type)&&$f(),a=b.flags,a&65536?(b.flags=a&-65537|128,b):null;case 3:return Jh(),E(Wf),E(H),Oh(),a=b.flags,0!==(a&65536)&&0===(a&128)?(b.flags=a&-65537|128,b):null;case 5:return Lh(b),null;case 13:E(M);a=b.memoizedState;if(null!==a&&null!==a.dehydrated){if(null===b.alternate)throw Error(p(340));Ig()}a=b.flags;return a&65536?(b.flags=a&-65537|128,b):null;case 19:return E(M),null;case 4:return Jh(),null;case 10:return Rg(b.type._context),null;case 22:case 23:return Ij(),\nnull;case 24:return null;default:return null}}var Kj=!1,U=!1,Lj=\"function\"===typeof WeakSet?WeakSet:Set,V=null;function Mj(a,b){var c=a.ref;if(null!==c)if(\"function\"===typeof c)try{c(null)}catch(d){W(a,b,d)}else c.current=null}function Nj(a,b,c){try{c()}catch(d){W(a,b,d)}}var Oj=!1;\nfunction Pj(a,b){Cf=dd;a=Me();if(Ne(a)){if(\"selectionStart\"in a)var c={start:a.selectionStart,end:a.selectionEnd};else a:{c=(c=a.ownerDocument)&&c.defaultView||window;var d=c.getSelection&&c.getSelection();if(d&&0!==d.rangeCount){c=d.anchorNode;var e=d.anchorOffset,f=d.focusNode;d=d.focusOffset;try{c.nodeType,f.nodeType}catch(F){c=null;break a}var g=0,h=-1,k=-1,l=0,m=0,q=a,r=null;b:for(;;){for(var y;;){q!==c||0!==e&&3!==q.nodeType||(h=g+e);q!==f||0!==d&&3!==q.nodeType||(k=g+d);3===q.nodeType&&(g+=\nq.nodeValue.length);if(null===(y=q.firstChild))break;r=q;q=y}for(;;){if(q===a)break b;r===c&&++l===e&&(h=g);r===f&&++m===d&&(k=g);if(null!==(y=q.nextSibling))break;q=r;r=q.parentNode}q=y}c=-1===h||-1===k?null:{start:h,end:k}}else c=null}c=c||{start:0,end:0}}else c=null;Df={focusedElem:a,selectionRange:c};dd=!1;for(V=b;null!==V;)if(b=V,a=b.child,0!==(b.subtreeFlags&1028)&&null!==a)a.return=b,V=a;else for(;null!==V;){b=V;try{var n=b.alternate;if(0!==(b.flags&1024))switch(b.tag){case 0:case 11:case 15:break;\ncase 1:if(null!==n){var t=n.memoizedProps,J=n.memoizedState,x=b.stateNode,w=x.getSnapshotBeforeUpdate(b.elementType===b.type?t:Lg(b.type,t),J);x.__reactInternalSnapshotBeforeUpdate=w}break;case 3:var u=b.stateNode.containerInfo;1===u.nodeType?u.textContent=\"\":9===u.nodeType&&u.documentElement&&u.removeChild(u.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(p(163));}}catch(F){W(b,b.return,F)}a=b.sibling;if(null!==a){a.return=b.return;V=a;break}V=b.return}n=Oj;Oj=!1;return n}\nfunction Qj(a,b,c){var d=b.updateQueue;d=null!==d?d.lastEffect:null;if(null!==d){var e=d=d.next;do{if((e.tag&a)===a){var f=e.destroy;e.destroy=void 0;void 0!==f&&Nj(b,c,f)}e=e.next}while(e!==d)}}function Rj(a,b){b=b.updateQueue;b=null!==b?b.lastEffect:null;if(null!==b){var c=b=b.next;do{if((c.tag&a)===a){var d=c.create;c.destroy=d()}c=c.next}while(c!==b)}}function Sj(a){var b=a.ref;if(null!==b){var c=a.stateNode;switch(a.tag){case 5:a=c;break;default:a=c}\"function\"===typeof b?b(a):b.current=a}}\nfunction Tj(a){var b=a.alternate;null!==b&&(a.alternate=null,Tj(b));a.child=null;a.deletions=null;a.sibling=null;5===a.tag&&(b=a.stateNode,null!==b&&(delete b[Of],delete b[Pf],delete b[of],delete b[Qf],delete b[Rf]));a.stateNode=null;a.return=null;a.dependencies=null;a.memoizedProps=null;a.memoizedState=null;a.pendingProps=null;a.stateNode=null;a.updateQueue=null}function Uj(a){return 5===a.tag||3===a.tag||4===a.tag}\nfunction Vj(a){a:for(;;){for(;null===a.sibling;){if(null===a.return||Uj(a.return))return null;a=a.return}a.sibling.return=a.return;for(a=a.sibling;5!==a.tag&&6!==a.tag&&18!==a.tag;){if(a.flags&2)continue a;if(null===a.child||4===a.tag)continue a;else a.child.return=a,a=a.child}if(!(a.flags&2))return a.stateNode}}\nfunction Wj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?8===c.nodeType?c.parentNode.insertBefore(a,b):c.insertBefore(a,b):(8===c.nodeType?(b=c.parentNode,b.insertBefore(a,c)):(b=c,b.appendChild(a)),c=c._reactRootContainer,null!==c&&void 0!==c||null!==b.onclick||(b.onclick=Bf));else if(4!==d&&(a=a.child,null!==a))for(Wj(a,b,c),a=a.sibling;null!==a;)Wj(a,b,c),a=a.sibling}\nfunction Xj(a,b,c){var d=a.tag;if(5===d||6===d)a=a.stateNode,b?c.insertBefore(a,b):c.appendChild(a);else if(4!==d&&(a=a.child,null!==a))for(Xj(a,b,c),a=a.sibling;null!==a;)Xj(a,b,c),a=a.sibling}var X=null,Yj=!1;function Zj(a,b,c){for(c=c.child;null!==c;)ak(a,b,c),c=c.sibling}\nfunction ak(a,b,c){if(lc&&\"function\"===typeof lc.onCommitFiberUnmount)try{lc.onCommitFiberUnmount(kc,c)}catch(h){}switch(c.tag){case 5:U||Mj(c,b);case 6:var d=X,e=Yj;X=null;Zj(a,b,c);X=d;Yj=e;null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?a.parentNode.removeChild(c):a.removeChild(c)):X.removeChild(c.stateNode));break;case 18:null!==X&&(Yj?(a=X,c=c.stateNode,8===a.nodeType?Kf(a.parentNode,c):1===a.nodeType&&Kf(a,c),bd(a)):Kf(X,c.stateNode));break;case 4:d=X;e=Yj;X=c.stateNode.containerInfo;Yj=!0;\nZj(a,b,c);X=d;Yj=e;break;case 0:case 11:case 14:case 15:if(!U&&(d=c.updateQueue,null!==d&&(d=d.lastEffect,null!==d))){e=d=d.next;do{var f=e,g=f.destroy;f=f.tag;void 0!==g&&(0!==(f&2)?Nj(c,b,g):0!==(f&4)&&Nj(c,b,g));e=e.next}while(e!==d)}Zj(a,b,c);break;case 1:if(!U&&(Mj(c,b),d=c.stateNode,\"function\"===typeof d.componentWillUnmount))try{d.props=c.memoizedProps,d.state=c.memoizedState,d.componentWillUnmount()}catch(h){W(c,b,h)}Zj(a,b,c);break;case 21:Zj(a,b,c);break;case 22:c.mode&1?(U=(d=U)||null!==\nc.memoizedState,Zj(a,b,c),U=d):Zj(a,b,c);break;default:Zj(a,b,c)}}function bk(a){var b=a.updateQueue;if(null!==b){a.updateQueue=null;var c=a.stateNode;null===c&&(c=a.stateNode=new Lj);b.forEach(function(b){var d=ck.bind(null,a,b);c.has(b)||(c.add(b),b.then(d,d))})}}\nfunction dk(a,b){var c=b.deletions;if(null!==c)for(var d=0;d<c.length;d++){var e=c[d];try{var f=a,g=b,h=g;a:for(;null!==h;){switch(h.tag){case 5:X=h.stateNode;Yj=!1;break a;case 3:X=h.stateNode.containerInfo;Yj=!0;break a;case 4:X=h.stateNode.containerInfo;Yj=!0;break a}h=h.return}if(null===X)throw Error(p(160));ak(f,g,e);X=null;Yj=!1;var k=e.alternate;null!==k&&(k.return=null);e.return=null}catch(l){W(e,b,l)}}if(b.subtreeFlags&12854)for(b=b.child;null!==b;)ek(b,a),b=b.sibling}\nfunction ek(a,b){var c=a.alternate,d=a.flags;switch(a.tag){case 0:case 11:case 14:case 15:dk(b,a);fk(a);if(d&4){try{Qj(3,a,a.return),Rj(3,a)}catch(t){W(a,a.return,t)}try{Qj(5,a,a.return)}catch(t){W(a,a.return,t)}}break;case 1:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);break;case 5:dk(b,a);fk(a);d&512&&null!==c&&Mj(c,c.return);if(a.flags&32){var e=a.stateNode;try{ob(e,\"\")}catch(t){W(a,a.return,t)}}if(d&4&&(e=a.stateNode,null!=e)){var f=a.memoizedProps,g=null!==c?c.memoizedProps:f,h=a.type,k=a.updateQueue;\na.updateQueue=null;if(null!==k)try{\"input\"===h&&\"radio\"===f.type&&null!=f.name&&ab(e,f);vb(h,g);var l=vb(h,f);for(g=0;g<k.length;g+=2){var m=k[g],q=k[g+1];\"style\"===m?sb(e,q):\"dangerouslySetInnerHTML\"===m?nb(e,q):\"children\"===m?ob(e,q):ta(e,m,q,l)}switch(h){case \"input\":bb(e,f);break;case \"textarea\":ib(e,f);break;case \"select\":var r=e._wrapperState.wasMultiple;e._wrapperState.wasMultiple=!!f.multiple;var y=f.value;null!=y?fb(e,!!f.multiple,y,!1):r!==!!f.multiple&&(null!=f.defaultValue?fb(e,!!f.multiple,\nf.defaultValue,!0):fb(e,!!f.multiple,f.multiple?[]:\"\",!1))}e[Pf]=f}catch(t){W(a,a.return,t)}}break;case 6:dk(b,a);fk(a);if(d&4){if(null===a.stateNode)throw Error(p(162));e=a.stateNode;f=a.memoizedProps;try{e.nodeValue=f}catch(t){W(a,a.return,t)}}break;case 3:dk(b,a);fk(a);if(d&4&&null!==c&&c.memoizedState.isDehydrated)try{bd(b.containerInfo)}catch(t){W(a,a.return,t)}break;case 4:dk(b,a);fk(a);break;case 13:dk(b,a);fk(a);e=a.child;e.flags&8192&&(f=null!==e.memoizedState,e.stateNode.isHidden=f,!f||\nnull!==e.alternate&&null!==e.alternate.memoizedState||(gk=B()));d&4&&bk(a);break;case 22:m=null!==c&&null!==c.memoizedState;a.mode&1?(U=(l=U)||m,dk(b,a),U=l):dk(b,a);fk(a);if(d&8192){l=null!==a.memoizedState;if((a.stateNode.isHidden=l)&&!m&&0!==(a.mode&1))for(V=a,m=a.child;null!==m;){for(q=V=m;null!==V;){r=V;y=r.child;switch(r.tag){case 0:case 11:case 14:case 15:Qj(4,r,r.return);break;case 1:Mj(r,r.return);var n=r.stateNode;if(\"function\"===typeof n.componentWillUnmount){d=r;c=r.return;try{b=d,n.props=\nb.memoizedProps,n.state=b.memoizedState,n.componentWillUnmount()}catch(t){W(d,c,t)}}break;case 5:Mj(r,r.return);break;case 22:if(null!==r.memoizedState){hk(q);continue}}null!==y?(y.return=r,V=y):hk(q)}m=m.sibling}a:for(m=null,q=a;;){if(5===q.tag){if(null===m){m=q;try{e=q.stateNode,l?(f=e.style,\"function\"===typeof f.setProperty?f.setProperty(\"display\",\"none\",\"important\"):f.display=\"none\"):(h=q.stateNode,k=q.memoizedProps.style,g=void 0!==k&&null!==k&&k.hasOwnProperty(\"display\")?k.display:null,h.style.display=\nrb(\"display\",g))}catch(t){W(a,a.return,t)}}}else if(6===q.tag){if(null===m)try{q.stateNode.nodeValue=l?\"\":q.memoizedProps}catch(t){W(a,a.return,t)}}else if((22!==q.tag&&23!==q.tag||null===q.memoizedState||q===a)&&null!==q.child){q.child.return=q;q=q.child;continue}if(q===a)break a;for(;null===q.sibling;){if(null===q.return||q.return===a)break a;m===q&&(m=null);q=q.return}m===q&&(m=null);q.sibling.return=q.return;q=q.sibling}}break;case 19:dk(b,a);fk(a);d&4&&bk(a);break;case 21:break;default:dk(b,\na),fk(a)}}function fk(a){var b=a.flags;if(b&2){try{a:{for(var c=a.return;null!==c;){if(Uj(c)){var d=c;break a}c=c.return}throw Error(p(160));}switch(d.tag){case 5:var e=d.stateNode;d.flags&32&&(ob(e,\"\"),d.flags&=-33);var f=Vj(a);Xj(a,f,e);break;case 3:case 4:var g=d.stateNode.containerInfo,h=Vj(a);Wj(a,h,g);break;default:throw Error(p(161));}}catch(k){W(a,a.return,k)}a.flags&=-3}b&4096&&(a.flags&=-4097)}function ik(a,b,c){V=a;jk(a,b,c)}\nfunction jk(a,b,c){for(var d=0!==(a.mode&1);null!==V;){var e=V,f=e.child;if(22===e.tag&&d){var g=null!==e.memoizedState||Kj;if(!g){var h=e.alternate,k=null!==h&&null!==h.memoizedState||U;h=Kj;var l=U;Kj=g;if((U=k)&&!l)for(V=e;null!==V;)g=V,k=g.child,22===g.tag&&null!==g.memoizedState?kk(e):null!==k?(k.return=g,V=k):kk(e);for(;null!==f;)V=f,jk(f,b,c),f=f.sibling;V=e;Kj=h;U=l}lk(a,b,c)}else 0!==(e.subtreeFlags&8772)&&null!==f?(f.return=e,V=f):lk(a,b,c)}}\nfunction lk(a){for(;null!==V;){var b=V;if(0!==(b.flags&8772)){var c=b.alternate;try{if(0!==(b.flags&8772))switch(b.tag){case 0:case 11:case 15:U||Rj(5,b);break;case 1:var d=b.stateNode;if(b.flags&4&&!U)if(null===c)d.componentDidMount();else{var e=b.elementType===b.type?c.memoizedProps:Lg(b.type,c.memoizedProps);d.componentDidUpdate(e,c.memoizedState,d.__reactInternalSnapshotBeforeUpdate)}var f=b.updateQueue;null!==f&&ih(b,f,d);break;case 3:var g=b.updateQueue;if(null!==g){c=null;if(null!==b.child)switch(b.child.tag){case 5:c=\nb.child.stateNode;break;case 1:c=b.child.stateNode}ih(b,g,c)}break;case 5:var h=b.stateNode;if(null===c&&b.flags&4){c=h;var k=b.memoizedProps;switch(b.type){case \"button\":case \"input\":case \"select\":case \"textarea\":k.autoFocus&&c.focus();break;case \"img\":k.src&&(c.src=k.src)}}break;case 6:break;case 4:break;case 12:break;case 13:if(null===b.memoizedState){var l=b.alternate;if(null!==l){var m=l.memoizedState;if(null!==m){var q=m.dehydrated;null!==q&&bd(q)}}}break;case 19:case 17:case 21:case 22:case 23:case 25:break;\ndefault:throw Error(p(163));}U||b.flags&512&&Sj(b)}catch(r){W(b,b.return,r)}}if(b===a){V=null;break}c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}function hk(a){for(;null!==V;){var b=V;if(b===a){V=null;break}var c=b.sibling;if(null!==c){c.return=b.return;V=c;break}V=b.return}}\nfunction kk(a){for(;null!==V;){var b=V;try{switch(b.tag){case 0:case 11:case 15:var c=b.return;try{Rj(4,b)}catch(k){W(b,c,k)}break;case 1:var d=b.stateNode;if(\"function\"===typeof d.componentDidMount){var e=b.return;try{d.componentDidMount()}catch(k){W(b,e,k)}}var f=b.return;try{Sj(b)}catch(k){W(b,f,k)}break;case 5:var g=b.return;try{Sj(b)}catch(k){W(b,g,k)}}}catch(k){W(b,b.return,k)}if(b===a){V=null;break}var h=b.sibling;if(null!==h){h.return=b.return;V=h;break}V=b.return}}\nvar mk=Math.ceil,nk=ua.ReactCurrentDispatcher,ok=ua.ReactCurrentOwner,pk=ua.ReactCurrentBatchConfig,K=0,R=null,Y=null,Z=0,gj=0,fj=Uf(0),T=0,qk=null,hh=0,rk=0,sk=0,tk=null,uk=null,gk=0,Hj=Infinity,vk=null,Pi=!1,Qi=null,Si=null,wk=!1,xk=null,yk=0,zk=0,Ak=null,Bk=-1,Ck=0;function L(){return 0!==(K&6)?B():-1!==Bk?Bk:Bk=B()}\nfunction lh(a){if(0===(a.mode&1))return 1;if(0!==(K&2)&&0!==Z)return Z&-Z;if(null!==Kg.transition)return 0===Ck&&(Ck=yc()),Ck;a=C;if(0!==a)return a;a=window.event;a=void 0===a?16:jd(a.type);return a}function mh(a,b,c,d){if(50<zk)throw zk=0,Ak=null,Error(p(185));Ac(a,c,d);if(0===(K&2)||a!==R)a===R&&(0===(K&2)&&(rk|=c),4===T&&Dk(a,Z)),Ek(a,d),1===c&&0===K&&0===(b.mode&1)&&(Hj=B()+500,fg&&jg())}\nfunction Ek(a,b){var c=a.callbackNode;wc(a,b);var d=uc(a,a===R?Z:0);if(0===d)null!==c&&bc(c),a.callbackNode=null,a.callbackPriority=0;else if(b=d&-d,a.callbackPriority!==b){null!=c&&bc(c);if(1===b)0===a.tag?ig(Fk.bind(null,a)):hg(Fk.bind(null,a)),Jf(function(){0===(K&6)&&jg()}),c=null;else{switch(Dc(d)){case 1:c=fc;break;case 4:c=gc;break;case 16:c=hc;break;case 536870912:c=jc;break;default:c=hc}c=Gk(c,Hk.bind(null,a))}a.callbackPriority=b;a.callbackNode=c}}\nfunction Hk(a,b){Bk=-1;Ck=0;if(0!==(K&6))throw Error(p(327));var c=a.callbackNode;if(Ik()&&a.callbackNode!==c)return null;var d=uc(a,a===R?Z:0);if(0===d)return null;if(0!==(d&30)||0!==(d&a.expiredLanes)||b)b=Jk(a,d);else{b=d;var e=K;K|=2;var f=Kk();if(R!==a||Z!==b)vk=null,Hj=B()+500,Lk(a,b);do try{Mk();break}catch(h){Nk(a,h)}while(1);Qg();nk.current=f;K=e;null!==Y?b=0:(R=null,Z=0,b=T)}if(0!==b){2===b&&(e=xc(a),0!==e&&(d=e,b=Ok(a,e)));if(1===b)throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;if(6===b)Dk(a,d);\nelse{e=a.current.alternate;if(0===(d&30)&&!Pk(e)&&(b=Jk(a,d),2===b&&(f=xc(a),0!==f&&(d=f,b=Ok(a,f))),1===b))throw c=qk,Lk(a,0),Dk(a,d),Ek(a,B()),c;a.finishedWork=e;a.finishedLanes=d;switch(b){case 0:case 1:throw Error(p(345));case 2:Qk(a,uk,vk);break;case 3:Dk(a,d);if((d&130023424)===d&&(b=gk+500-B(),10<b)){if(0!==uc(a,0))break;e=a.suspendedLanes;if((e&d)!==d){L();a.pingedLanes|=a.suspendedLanes&e;break}a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),b);break}Qk(a,uk,vk);break;case 4:Dk(a,d);if((d&4194240)===\nd)break;b=a.eventTimes;for(e=-1;0<d;){var g=31-oc(d);f=1<<g;g=b[g];g>e&&(e=g);d&=~f}d=e;d=B()-d;d=(120>d?120:480>d?480:1080>d?1080:1920>d?1920:3E3>d?3E3:4320>d?4320:1960*mk(d/1960))-d;if(10<d){a.timeoutHandle=Ff(Qk.bind(null,a,uk,vk),d);break}Qk(a,uk,vk);break;case 5:Qk(a,uk,vk);break;default:throw Error(p(329));}}}Ek(a,B());return a.callbackNode===c?Hk.bind(null,a):null}\nfunction Ok(a,b){var c=tk;a.current.memoizedState.isDehydrated&&(Lk(a,b).flags|=256);a=Jk(a,b);2!==a&&(b=uk,uk=c,null!==b&&Gj(b));return a}function Gj(a){null===uk?uk=a:uk.push.apply(uk,a)}\nfunction Pk(a){for(var b=a;;){if(b.flags&16384){var c=b.updateQueue;if(null!==c&&(c=c.stores,null!==c))for(var d=0;d<c.length;d++){var e=c[d],f=e.getSnapshot;e=e.value;try{if(!He(f(),e))return!1}catch(g){return!1}}}c=b.child;if(b.subtreeFlags&16384&&null!==c)c.return=b,b=c;else{if(b===a)break;for(;null===b.sibling;){if(null===b.return||b.return===a)return!0;b=b.return}b.sibling.return=b.return;b=b.sibling}}return!0}\nfunction Dk(a,b){b&=~sk;b&=~rk;a.suspendedLanes|=b;a.pingedLanes&=~b;for(a=a.expirationTimes;0<b;){var c=31-oc(b),d=1<<c;a[c]=-1;b&=~d}}function Fk(a){if(0!==(K&6))throw Error(p(327));Ik();var b=uc(a,0);if(0===(b&1))return Ek(a,B()),null;var c=Jk(a,b);if(0!==a.tag&&2===c){var d=xc(a);0!==d&&(b=d,c=Ok(a,d))}if(1===c)throw c=qk,Lk(a,0),Dk(a,b),Ek(a,B()),c;if(6===c)throw Error(p(345));a.finishedWork=a.current.alternate;a.finishedLanes=b;Qk(a,uk,vk);Ek(a,B());return null}\nfunction Rk(a,b){var c=K;K|=1;try{return a(b)}finally{K=c,0===K&&(Hj=B()+500,fg&&jg())}}function Sk(a){null!==xk&&0===xk.tag&&0===(K&6)&&Ik();var b=K;K|=1;var c=pk.transition,d=C;try{if(pk.transition=null,C=1,a)return a()}finally{C=d,pk.transition=c,K=b,0===(K&6)&&jg()}}function Ij(){gj=fj.current;E(fj)}\nfunction Lk(a,b){a.finishedWork=null;a.finishedLanes=0;var c=a.timeoutHandle;-1!==c&&(a.timeoutHandle=-1,Gf(c));if(null!==Y)for(c=Y.return;null!==c;){var d=c;wg(d);switch(d.tag){case 1:d=d.type.childContextTypes;null!==d&&void 0!==d&&$f();break;case 3:Jh();E(Wf);E(H);Oh();break;case 5:Lh(d);break;case 4:Jh();break;case 13:E(M);break;case 19:E(M);break;case 10:Rg(d.type._context);break;case 22:case 23:Ij()}c=c.return}R=a;Y=a=wh(a.current,null);Z=gj=b;T=0;qk=null;sk=rk=hh=0;uk=tk=null;if(null!==Wg){for(b=\n0;b<Wg.length;b++)if(c=Wg[b],d=c.interleaved,null!==d){c.interleaved=null;var e=d.next,f=c.pending;if(null!==f){var g=f.next;f.next=e;d.next=g}c.pending=d}Wg=null}return a}\nfunction Nk(a,b){do{var c=Y;try{Qg();Ph.current=ai;if(Sh){for(var d=N.memoizedState;null!==d;){var e=d.queue;null!==e&&(e.pending=null);d=d.next}Sh=!1}Rh=0;P=O=N=null;Th=!1;Uh=0;ok.current=null;if(null===c||null===c.return){T=1;qk=b;Y=null;break}a:{var f=a,g=c.return,h=c,k=b;b=Z;h.flags|=32768;if(null!==k&&\"object\"===typeof k&&\"function\"===typeof k.then){var l=k,m=h,q=m.tag;if(0===(m.mode&1)&&(0===q||11===q||15===q)){var r=m.alternate;r?(m.updateQueue=r.updateQueue,m.memoizedState=r.memoizedState,\nm.lanes=r.lanes):(m.updateQueue=null,m.memoizedState=null)}var y=Vi(g);if(null!==y){y.flags&=-257;Wi(y,g,h,f,b);y.mode&1&&Ti(f,l,b);b=y;k=l;var n=b.updateQueue;if(null===n){var t=new Set;t.add(k);b.updateQueue=t}else n.add(k);break a}else{if(0===(b&1)){Ti(f,l,b);uj();break a}k=Error(p(426))}}else if(I&&h.mode&1){var J=Vi(g);if(null!==J){0===(J.flags&65536)&&(J.flags|=256);Wi(J,g,h,f,b);Jg(Ki(k,h));break a}}f=k=Ki(k,h);4!==T&&(T=2);null===tk?tk=[f]:tk.push(f);f=g;do{switch(f.tag){case 3:f.flags|=65536;\nb&=-b;f.lanes|=b;var x=Oi(f,k,b);fh(f,x);break a;case 1:h=k;var w=f.type,u=f.stateNode;if(0===(f.flags&128)&&(\"function\"===typeof w.getDerivedStateFromError||null!==u&&\"function\"===typeof u.componentDidCatch&&(null===Si||!Si.has(u)))){f.flags|=65536;b&=-b;f.lanes|=b;var F=Ri(f,h,b);fh(f,F);break a}}f=f.return}while(null!==f)}Tk(c)}catch(na){b=na;Y===c&&null!==c&&(Y=c=c.return);continue}break}while(1)}function Kk(){var a=nk.current;nk.current=ai;return null===a?ai:a}\nfunction uj(){if(0===T||3===T||2===T)T=4;null===R||0===(hh&268435455)&&0===(rk&268435455)||Dk(R,Z)}function Jk(a,b){var c=K;K|=2;var d=Kk();if(R!==a||Z!==b)vk=null,Lk(a,b);do try{Uk();break}catch(e){Nk(a,e)}while(1);Qg();K=c;nk.current=d;if(null!==Y)throw Error(p(261));R=null;Z=0;return T}function Uk(){for(;null!==Y;)Vk(Y)}function Mk(){for(;null!==Y&&!cc();)Vk(Y)}function Vk(a){var b=Wk(a.alternate,a,gj);a.memoizedProps=a.pendingProps;null===b?Tk(a):Y=b;ok.current=null}\nfunction Tk(a){var b=a;do{var c=b.alternate;a=b.return;if(0===(b.flags&32768)){if(c=Fj(c,b,gj),null!==c){Y=c;return}}else{c=Jj(c,b);if(null!==c){c.flags&=32767;Y=c;return}if(null!==a)a.flags|=32768,a.subtreeFlags=0,a.deletions=null;else{T=6;Y=null;return}}b=b.sibling;if(null!==b){Y=b;return}Y=b=a}while(null!==b);0===T&&(T=5)}function Qk(a,b,c){var d=C,e=pk.transition;try{pk.transition=null,C=1,Xk(a,b,c,d)}finally{pk.transition=e,C=d}return null}\nfunction Xk(a,b,c,d){do Ik();while(null!==xk);if(0!==(K&6))throw Error(p(327));c=a.finishedWork;var e=a.finishedLanes;if(null===c)return null;a.finishedWork=null;a.finishedLanes=0;if(c===a.current)throw Error(p(177));a.callbackNode=null;a.callbackPriority=0;var f=c.lanes|c.childLanes;Bc(a,f);a===R&&(Y=R=null,Z=0);0===(c.subtreeFlags&2064)&&0===(c.flags&2064)||wk||(wk=!0,Gk(hc,function(){Ik();return null}));f=0!==(c.flags&15990);if(0!==(c.subtreeFlags&15990)||f){f=pk.transition;pk.transition=null;\nvar g=C;C=1;var h=K;K|=4;ok.current=null;Pj(a,c);ek(c,a);Oe(Df);dd=!!Cf;Df=Cf=null;a.current=c;ik(c,a,e);dc();K=h;C=g;pk.transition=f}else a.current=c;wk&&(wk=!1,xk=a,yk=e);f=a.pendingLanes;0===f&&(Si=null);mc(c.stateNode,d);Ek(a,B());if(null!==b)for(d=a.onRecoverableError,c=0;c<b.length;c++)e=b[c],d(e.value,{componentStack:e.stack,digest:e.digest});if(Pi)throw Pi=!1,a=Qi,Qi=null,a;0!==(yk&1)&&0!==a.tag&&Ik();f=a.pendingLanes;0!==(f&1)?a===Ak?zk++:(zk=0,Ak=a):zk=0;jg();return null}\nfunction Ik(){if(null!==xk){var a=Dc(yk),b=pk.transition,c=C;try{pk.transition=null;C=16>a?16:a;if(null===xk)var d=!1;else{a=xk;xk=null;yk=0;if(0!==(K&6))throw Error(p(331));var e=K;K|=4;for(V=a.current;null!==V;){var f=V,g=f.child;if(0!==(V.flags&16)){var h=f.deletions;if(null!==h){for(var k=0;k<h.length;k++){var l=h[k];for(V=l;null!==V;){var m=V;switch(m.tag){case 0:case 11:case 15:Qj(8,m,f)}var q=m.child;if(null!==q)q.return=m,V=q;else for(;null!==V;){m=V;var r=m.sibling,y=m.return;Tj(m);if(m===\nl){V=null;break}if(null!==r){r.return=y;V=r;break}V=y}}}var n=f.alternate;if(null!==n){var t=n.child;if(null!==t){n.child=null;do{var J=t.sibling;t.sibling=null;t=J}while(null!==t)}}V=f}}if(0!==(f.subtreeFlags&2064)&&null!==g)g.return=f,V=g;else b:for(;null!==V;){f=V;if(0!==(f.flags&2048))switch(f.tag){case 0:case 11:case 15:Qj(9,f,f.return)}var x=f.sibling;if(null!==x){x.return=f.return;V=x;break b}V=f.return}}var w=a.current;for(V=w;null!==V;){g=V;var u=g.child;if(0!==(g.subtreeFlags&2064)&&null!==\nu)u.return=g,V=u;else b:for(g=w;null!==V;){h=V;if(0!==(h.flags&2048))try{switch(h.tag){case 0:case 11:case 15:Rj(9,h)}}catch(na){W(h,h.return,na)}if(h===g){V=null;break b}var F=h.sibling;if(null!==F){F.return=h.return;V=F;break b}V=h.return}}K=e;jg();if(lc&&\"function\"===typeof lc.onPostCommitFiberRoot)try{lc.onPostCommitFiberRoot(kc,a)}catch(na){}d=!0}return d}finally{C=c,pk.transition=b}}return!1}function Yk(a,b,c){b=Ki(c,b);b=Oi(a,b,1);a=dh(a,b,1);b=L();null!==a&&(Ac(a,1,b),Ek(a,b))}\nfunction W(a,b,c){if(3===a.tag)Yk(a,a,c);else for(;null!==b;){if(3===b.tag){Yk(b,a,c);break}else if(1===b.tag){var d=b.stateNode;if(\"function\"===typeof b.type.getDerivedStateFromError||\"function\"===typeof d.componentDidCatch&&(null===Si||!Si.has(d))){a=Ki(c,a);a=Ri(b,a,1);b=dh(b,a,1);a=L();null!==b&&(Ac(b,1,a),Ek(b,a));break}}b=b.return}}\nfunction Ui(a,b,c){var d=a.pingCache;null!==d&&d.delete(b);b=L();a.pingedLanes|=a.suspendedLanes&c;R===a&&(Z&c)===c&&(4===T||3===T&&(Z&130023424)===Z&&500>B()-gk?Lk(a,0):sk|=c);Ek(a,b)}function Zk(a,b){0===b&&(0===(a.mode&1)?b=1:(b=sc,sc<<=1,0===(sc&130023424)&&(sc=4194304)));var c=L();a=Zg(a,b);null!==a&&(Ac(a,b,c),Ek(a,c))}function vj(a){var b=a.memoizedState,c=0;null!==b&&(c=b.retryLane);Zk(a,c)}\nfunction ck(a,b){var c=0;switch(a.tag){case 13:var d=a.stateNode;var e=a.memoizedState;null!==e&&(c=e.retryLane);break;case 19:d=a.stateNode;break;default:throw Error(p(314));}null!==d&&d.delete(b);Zk(a,c)}var Wk;\nWk=function(a,b,c){if(null!==a)if(a.memoizedProps!==b.pendingProps||Wf.current)Ug=!0;else{if(0===(a.lanes&c)&&0===(b.flags&128))return Ug=!1,zj(a,b,c);Ug=0!==(a.flags&131072)?!0:!1}else Ug=!1,I&&0!==(b.flags&1048576)&&ug(b,ng,b.index);b.lanes=0;switch(b.tag){case 2:var d=b.type;jj(a,b);a=b.pendingProps;var e=Yf(b,H.current);Tg(b,c);e=Xh(null,b,d,a,e,c);var f=bi();b.flags|=1;\"object\"===typeof e&&null!==e&&\"function\"===typeof e.render&&void 0===e.$$typeof?(b.tag=1,b.memoizedState=null,b.updateQueue=\nnull,Zf(d)?(f=!0,cg(b)):f=!1,b.memoizedState=null!==e.state&&void 0!==e.state?e.state:null,ah(b),e.updater=nh,b.stateNode=e,e._reactInternals=b,rh(b,d,a,c),b=kj(null,b,d,!0,f,c)):(b.tag=0,I&&f&&vg(b),Yi(null,b,e,c),b=b.child);return b;case 16:d=b.elementType;a:{jj(a,b);a=b.pendingProps;e=d._init;d=e(d._payload);b.type=d;e=b.tag=$k(d);a=Lg(d,a);switch(e){case 0:b=dj(null,b,d,a,c);break a;case 1:b=ij(null,b,d,a,c);break a;case 11:b=Zi(null,b,d,a,c);break a;case 14:b=aj(null,b,d,Lg(d.type,a),c);break a}throw Error(p(306,\nd,\"\"));}return b;case 0:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),dj(a,b,d,e,c);case 1:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),ij(a,b,d,e,c);case 3:a:{lj(b);if(null===a)throw Error(p(387));d=b.pendingProps;f=b.memoizedState;e=f.element;bh(a,b);gh(b,d,null,c);var g=b.memoizedState;d=g.element;if(f.isDehydrated)if(f={element:d,isDehydrated:!1,cache:g.cache,pendingSuspenseBoundaries:g.pendingSuspenseBoundaries,transitions:g.transitions},b.updateQueue.baseState=\nf,b.memoizedState=f,b.flags&256){e=Ki(Error(p(423)),b);b=mj(a,b,d,c,e);break a}else if(d!==e){e=Ki(Error(p(424)),b);b=mj(a,b,d,c,e);break a}else for(yg=Lf(b.stateNode.containerInfo.firstChild),xg=b,I=!0,zg=null,c=Ch(b,null,d,c),b.child=c;c;)c.flags=c.flags&-3|4096,c=c.sibling;else{Ig();if(d===e){b=$i(a,b,c);break a}Yi(a,b,d,c)}b=b.child}return b;case 5:return Kh(b),null===a&&Eg(b),d=b.type,e=b.pendingProps,f=null!==a?a.memoizedProps:null,g=e.children,Ef(d,e)?g=null:null!==f&&Ef(d,f)&&(b.flags|=32),\nhj(a,b),Yi(a,b,g,c),b.child;case 6:return null===a&&Eg(b),null;case 13:return pj(a,b,c);case 4:return Ih(b,b.stateNode.containerInfo),d=b.pendingProps,null===a?b.child=Bh(b,null,d,c):Yi(a,b,d,c),b.child;case 11:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),Zi(a,b,d,e,c);case 7:return Yi(a,b,b.pendingProps,c),b.child;case 8:return Yi(a,b,b.pendingProps.children,c),b.child;case 12:return Yi(a,b,b.pendingProps.children,c),b.child;case 10:a:{d=b.type._context;e=b.pendingProps;f=b.memoizedProps;\ng=e.value;G(Mg,d._currentValue);d._currentValue=g;if(null!==f)if(He(f.value,g)){if(f.children===e.children&&!Wf.current){b=$i(a,b,c);break a}}else for(f=b.child,null!==f&&(f.return=b);null!==f;){var h=f.dependencies;if(null!==h){g=f.child;for(var k=h.firstContext;null!==k;){if(k.context===d){if(1===f.tag){k=ch(-1,c&-c);k.tag=2;var l=f.updateQueue;if(null!==l){l=l.shared;var m=l.pending;null===m?k.next=k:(k.next=m.next,m.next=k);l.pending=k}}f.lanes|=c;k=f.alternate;null!==k&&(k.lanes|=c);Sg(f.return,\nc,b);h.lanes|=c;break}k=k.next}}else if(10===f.tag)g=f.type===b.type?null:f.child;else if(18===f.tag){g=f.return;if(null===g)throw Error(p(341));g.lanes|=c;h=g.alternate;null!==h&&(h.lanes|=c);Sg(g,c,b);g=f.sibling}else g=f.child;if(null!==g)g.return=f;else for(g=f;null!==g;){if(g===b){g=null;break}f=g.sibling;if(null!==f){f.return=g.return;g=f;break}g=g.return}f=g}Yi(a,b,e.children,c);b=b.child}return b;case 9:return e=b.type,d=b.pendingProps.children,Tg(b,c),e=Vg(e),d=d(e),b.flags|=1,Yi(a,b,d,c),\nb.child;case 14:return d=b.type,e=Lg(d,b.pendingProps),e=Lg(d.type,e),aj(a,b,d,e,c);case 15:return cj(a,b,b.type,b.pendingProps,c);case 17:return d=b.type,e=b.pendingProps,e=b.elementType===d?e:Lg(d,e),jj(a,b),b.tag=1,Zf(d)?(a=!0,cg(b)):a=!1,Tg(b,c),ph(b,d,e),rh(b,d,e,c),kj(null,b,d,!0,a,c);case 19:return yj(a,b,c);case 22:return ej(a,b,c)}throw Error(p(156,b.tag));};function Gk(a,b){return ac(a,b)}\nfunction al(a,b,c,d){this.tag=a;this.key=c;this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null;this.index=0;this.ref=null;this.pendingProps=b;this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null;this.mode=d;this.subtreeFlags=this.flags=0;this.deletions=null;this.childLanes=this.lanes=0;this.alternate=null}function Bg(a,b,c,d){return new al(a,b,c,d)}function bj(a){a=a.prototype;return!(!a||!a.isReactComponent)}\nfunction $k(a){if(\"function\"===typeof a)return bj(a)?1:0;if(void 0!==a&&null!==a){a=a.$$typeof;if(a===Da)return 11;if(a===Ga)return 14}return 2}\nfunction wh(a,b){var c=a.alternate;null===c?(c=Bg(a.tag,b,a.key,a.mode),c.elementType=a.elementType,c.type=a.type,c.stateNode=a.stateNode,c.alternate=a,a.alternate=c):(c.pendingProps=b,c.type=a.type,c.flags=0,c.subtreeFlags=0,c.deletions=null);c.flags=a.flags&14680064;c.childLanes=a.childLanes;c.lanes=a.lanes;c.child=a.child;c.memoizedProps=a.memoizedProps;c.memoizedState=a.memoizedState;c.updateQueue=a.updateQueue;b=a.dependencies;c.dependencies=null===b?null:{lanes:b.lanes,firstContext:b.firstContext};\nc.sibling=a.sibling;c.index=a.index;c.ref=a.ref;return c}\nfunction yh(a,b,c,d,e,f){var g=2;d=a;if(\"function\"===typeof a)bj(a)&&(g=1);else if(\"string\"===typeof a)g=5;else a:switch(a){case ya:return Ah(c.children,e,f,b);case za:g=8;e|=8;break;case Aa:return a=Bg(12,c,b,e|2),a.elementType=Aa,a.lanes=f,a;case Ea:return a=Bg(13,c,b,e),a.elementType=Ea,a.lanes=f,a;case Fa:return a=Bg(19,c,b,e),a.elementType=Fa,a.lanes=f,a;case Ia:return qj(c,e,f,b);default:if(\"object\"===typeof a&&null!==a)switch(a.$$typeof){case Ba:g=10;break a;case Ca:g=9;break a;case Da:g=11;\nbreak a;case Ga:g=14;break a;case Ha:g=16;d=null;break a}throw Error(p(130,null==a?a:typeof a,\"\"));}b=Bg(g,c,b,e);b.elementType=a;b.type=d;b.lanes=f;return b}function Ah(a,b,c,d){a=Bg(7,a,d,b);a.lanes=c;return a}function qj(a,b,c,d){a=Bg(22,a,d,b);a.elementType=Ia;a.lanes=c;a.stateNode={isHidden:!1};return a}function xh(a,b,c){a=Bg(6,a,null,b);a.lanes=c;return a}\nfunction zh(a,b,c){b=Bg(4,null!==a.children?a.children:[],a.key,b);b.lanes=c;b.stateNode={containerInfo:a.containerInfo,pendingChildren:null,implementation:a.implementation};return b}\nfunction bl(a,b,c,d,e){this.tag=b;this.containerInfo=a;this.finishedWork=this.pingCache=this.current=this.pendingChildren=null;this.timeoutHandle=-1;this.callbackNode=this.pendingContext=this.context=null;this.callbackPriority=0;this.eventTimes=zc(0);this.expirationTimes=zc(-1);this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0;this.entanglements=zc(0);this.identifierPrefix=d;this.onRecoverableError=e;this.mutableSourceEagerHydrationData=\nnull}function cl(a,b,c,d,e,f,g,h,k){a=new bl(a,b,c,h,k);1===b?(b=1,!0===f&&(b|=8)):b=0;f=Bg(3,null,null,b);a.current=f;f.stateNode=a;f.memoizedState={element:d,isDehydrated:c,cache:null,transitions:null,pendingSuspenseBoundaries:null};ah(f);return a}function dl(a,b,c){var d=3<arguments.length&&void 0!==arguments[3]?arguments[3]:null;return{$$typeof:wa,key:null==d?null:\"\"+d,children:a,containerInfo:b,implementation:c}}\nfunction el(a){if(!a)return Vf;a=a._reactInternals;a:{if(Vb(a)!==a||1!==a.tag)throw Error(p(170));var b=a;do{switch(b.tag){case 3:b=b.stateNode.context;break a;case 1:if(Zf(b.type)){b=b.stateNode.__reactInternalMemoizedMergedChildContext;break a}}b=b.return}while(null!==b);throw Error(p(171));}if(1===a.tag){var c=a.type;if(Zf(c))return bg(a,c,b)}return b}\nfunction fl(a,b,c,d,e,f,g,h,k){a=cl(c,d,!0,a,e,f,g,h,k);a.context=el(null);c=a.current;d=L();e=lh(c);f=ch(d,e);f.callback=void 0!==b&&null!==b?b:null;dh(c,f,e);a.current.lanes=e;Ac(a,e,d);Ek(a,d);return a}function gl(a,b,c,d){var e=b.current,f=L(),g=lh(e);c=el(c);null===b.context?b.context=c:b.pendingContext=c;b=ch(f,g);b.payload={element:a};d=void 0===d?null:d;null!==d&&(b.callback=d);a=dh(e,b,g);null!==a&&(mh(a,e,g,f),eh(a,e,g));return g}\nfunction hl(a){a=a.current;if(!a.child)return null;switch(a.child.tag){case 5:return a.child.stateNode;default:return a.child.stateNode}}function il(a,b){a=a.memoizedState;if(null!==a&&null!==a.dehydrated){var c=a.retryLane;a.retryLane=0!==c&&c<b?c:b}}function jl(a,b){il(a,b);(a=a.alternate)&&il(a,b)}function kl(){return null}var ll=\"function\"===typeof reportError?reportError:function(a){console.error(a)};function ml(a){this._internalRoot=a}\nnl.prototype.render=ml.prototype.render=function(a){var b=this._internalRoot;if(null===b)throw Error(p(409));gl(a,b,null,null)};nl.prototype.unmount=ml.prototype.unmount=function(){var a=this._internalRoot;if(null!==a){this._internalRoot=null;var b=a.containerInfo;Sk(function(){gl(null,a,null,null)});b[uf]=null}};function nl(a){this._internalRoot=a}\nnl.prototype.unstable_scheduleHydration=function(a){if(a){var b=Hc();a={blockedOn:null,target:a,priority:b};for(var c=0;c<Qc.length&&0!==b&&b<Qc[c].priority;c++);Qc.splice(c,0,a);0===c&&Vc(a)}};function ol(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType)}function pl(a){return!(!a||1!==a.nodeType&&9!==a.nodeType&&11!==a.nodeType&&(8!==a.nodeType||\" react-mount-point-unstable \"!==a.nodeValue))}function ql(){}\nfunction rl(a,b,c,d,e){if(e){if(\"function\"===typeof d){var f=d;d=function(){var a=hl(g);f.call(a)}}var g=fl(b,d,a,0,null,!1,!1,\"\",ql);a._reactRootContainer=g;a[uf]=g.current;sf(8===a.nodeType?a.parentNode:a);Sk();return g}for(;e=a.lastChild;)a.removeChild(e);if(\"function\"===typeof d){var h=d;d=function(){var a=hl(k);h.call(a)}}var k=cl(a,0,!1,null,null,!1,!1,\"\",ql);a._reactRootContainer=k;a[uf]=k.current;sf(8===a.nodeType?a.parentNode:a);Sk(function(){gl(b,k,c,d)});return k}\nfunction sl(a,b,c,d,e){var f=c._reactRootContainer;if(f){var g=f;if(\"function\"===typeof e){var h=e;e=function(){var a=hl(g);h.call(a)}}gl(b,g,a,e)}else g=rl(c,b,a,e,d);return hl(g)}Ec=function(a){switch(a.tag){case 3:var b=a.stateNode;if(b.current.memoizedState.isDehydrated){var c=tc(b.pendingLanes);0!==c&&(Cc(b,c|1),Ek(b,B()),0===(K&6)&&(Hj=B()+500,jg()))}break;case 13:Sk(function(){var b=Zg(a,1);if(null!==b){var c=L();mh(b,a,1,c)}}),jl(a,1)}};\nFc=function(a){if(13===a.tag){var b=Zg(a,134217728);if(null!==b){var c=L();mh(b,a,134217728,c)}jl(a,134217728)}};Gc=function(a){if(13===a.tag){var b=lh(a),c=Zg(a,b);if(null!==c){var d=L();mh(c,a,b,d)}jl(a,b)}};Hc=function(){return C};Ic=function(a,b){var c=C;try{return C=a,b()}finally{C=c}};\nyb=function(a,b,c){switch(b){case \"input\":bb(a,c);b=c.name;if(\"radio\"===c.type&&null!=b){for(c=a;c.parentNode;)c=c.parentNode;c=c.querySelectorAll(\"input[name=\"+JSON.stringify(\"\"+b)+'][type=\"radio\"]');for(b=0;b<c.length;b++){var d=c[b];if(d!==a&&d.form===a.form){var e=Db(d);if(!e)throw Error(p(90));Wa(d);bb(d,e)}}}break;case \"textarea\":ib(a,c);break;case \"select\":b=c.value,null!=b&&fb(a,!!c.multiple,b,!1)}};Gb=Rk;Hb=Sk;\nvar tl={usingClientEntryPoint:!1,Events:[Cb,ue,Db,Eb,Fb,Rk]},ul={findFiberByHostInstance:Wc,bundleType:0,version:\"18.2.0\",rendererPackageName:\"react-dom\"};\nvar vl={bundleType:ul.bundleType,version:ul.version,rendererPackageName:ul.rendererPackageName,rendererConfig:ul.rendererConfig,overrideHookState:null,overrideHookStateDeletePath:null,overrideHookStateRenamePath:null,overrideProps:null,overridePropsDeletePath:null,overridePropsRenamePath:null,setErrorHandler:null,setSuspenseHandler:null,scheduleUpdate:null,currentDispatcherRef:ua.ReactCurrentDispatcher,findHostInstanceByFiber:function(a){a=Zb(a);return null===a?null:a.stateNode},findFiberByHostInstance:ul.findFiberByHostInstance||\nkl,findHostInstancesForRefresh:null,scheduleRefresh:null,scheduleRoot:null,setRefreshHandler:null,getCurrentFiber:null,reconcilerVersion:\"18.2.0-next-9e3b772b8-20220608\"};if(\"undefined\"!==typeof __REACT_DEVTOOLS_GLOBAL_HOOK__){var wl=__REACT_DEVTOOLS_GLOBAL_HOOK__;if(!wl.isDisabled&&wl.supportsFiber)try{kc=wl.inject(vl),lc=wl}catch(a){}}exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=tl;\nexports.createPortal=function(a,b){var c=2<arguments.length&&void 0!==arguments[2]?arguments[2]:null;if(!ol(b))throw Error(p(200));return dl(a,b,null,c)};exports.createRoot=function(a,b){if(!ol(a))throw Error(p(299));var c=!1,d=\"\",e=ll;null!==b&&void 0!==b&&(!0===b.unstable_strictMode&&(c=!0),void 0!==b.identifierPrefix&&(d=b.identifierPrefix),void 0!==b.onRecoverableError&&(e=b.onRecoverableError));b=cl(a,1,!1,null,null,c,!1,d,e);a[uf]=b.current;sf(8===a.nodeType?a.parentNode:a);return new ml(b)};\nexports.findDOMNode=function(a){if(null==a)return null;if(1===a.nodeType)return a;var b=a._reactInternals;if(void 0===b){if(\"function\"===typeof a.render)throw Error(p(188));a=Object.keys(a).join(\",\");throw Error(p(268,a));}a=Zb(b);a=null===a?null:a.stateNode;return a};exports.flushSync=function(a){return Sk(a)};exports.hydrate=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!0,c)};\nexports.hydrateRoot=function(a,b,c){if(!ol(a))throw Error(p(405));var d=null!=c&&c.hydratedSources||null,e=!1,f=\"\",g=ll;null!==c&&void 0!==c&&(!0===c.unstable_strictMode&&(e=!0),void 0!==c.identifierPrefix&&(f=c.identifierPrefix),void 0!==c.onRecoverableError&&(g=c.onRecoverableError));b=fl(b,null,a,1,null!=c?c:null,e,!1,f,g);a[uf]=b.current;sf(a);if(d)for(a=0;a<d.length;a++)c=d[a],e=c._getVersion,e=e(c._source),null==b.mutableSourceEagerHydrationData?b.mutableSourceEagerHydrationData=[c,e]:b.mutableSourceEagerHydrationData.push(c,\ne);return new nl(b)};exports.render=function(a,b,c){if(!pl(b))throw Error(p(200));return sl(null,a,b,!1,c)};exports.unmountComponentAtNode=function(a){if(!pl(a))throw Error(p(40));return a._reactRootContainer?(Sk(function(){sl(null,null,a,!1,function(){a._reactRootContainer=null;a[uf]=null})}),!0):!1};exports.unstable_batchedUpdates=Rk;\nexports.unstable_renderSubtreeIntoContainer=function(a,b,c,d){if(!pl(c))throw Error(p(200));if(null==a||void 0===a._reactInternals)throw Error(p(38));return sl(a,b,c,!1,d)};exports.version=\"18.2.0-next-9e3b772b8-20220608\";\n","'use strict';\n\nvar m = require('react-dom');\nif (process.env.NODE_ENV === 'production') {\n exports.createRoot = m.createRoot;\n exports.hydrateRoot = m.hydrateRoot;\n} else {\n var i = m.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n exports.createRoot = function(c, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.createRoot(c, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n exports.hydrateRoot = function(c, h, o) {\n i.usingClientEntryPoint = true;\n try {\n return m.hydrateRoot(c, h, o);\n } finally {\n i.usingClientEntryPoint = false;\n }\n };\n}\n","'use strict';\n\nfunction checkDCE() {\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\n if (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined' ||\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE !== 'function'\n ) {\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // This branch is unreachable because this function is only called\n // in production, but the condition is true only in development.\n // Therefore if the branch is still here, dead code elimination wasn't\n // properly applied.\n // Don't change the message. React DevTools relies on it. Also make sure\n // this message doesn't occur elsewhere in this function, or it will cause\n // a false positive.\n throw new Error('^_^');\n }\n try {\n // Verify that the code above has been dead code eliminated (DCE'd).\n __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(checkDCE);\n } catch (err) {\n // DevTools shouldn't crash React, no matter what.\n // We should still report in case we break this code.\n console.error(err);\n }\n}\n\nif (process.env.NODE_ENV === 'production') {\n // DCE check should happen before ReactDOM bundle executes so that\n // DevTools can report bad minification during injection.\n checkDCE();\n module.exports = require('./cjs/react-dom.production.min.js');\n} else {\n module.exports = require('./cjs/react-dom.development.js');\n}\n","export default function _extends() {\n _extends = Object.assign || function (target) {\n for (var i = 1; i < arguments.length; i++) {\n var source = arguments[i];\n\n for (var key in source) {\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n\n return target;\n };\n\n return _extends.apply(this, arguments);\n}","/**\n * defines a focus group\n */\nexport var FOCUS_GROUP = 'data-focus-lock';\n/**\n * disables element discovery inside a group marked by key\n */\nexport var FOCUS_DISABLED = 'data-focus-lock-disabled';\n/**\n * allows uncontrolled focus within the marked area, effectively disabling focus lock for it's content\n */\nexport var FOCUS_ALLOW = 'data-no-focus-lock';\n/**\n * instructs autofocus engine to pick default autofocus inside a given node\n * can be set on the element or container\n */\nexport var FOCUS_AUTO = 'data-autofocus-inside';\n/**\n * instructs autofocus to ignore elements within a given node\n * can be set on the element or container\n */\nexport var FOCUS_NO_AUTOFOCUS = 'data-no-autofocus';\n","import { assignRef } from './assignRef';\nimport { useCallbackRef } from './useRef';\n/**\n * Merges two or more refs together providing a single interface to set their value\n * @param {RefObject|Ref} refs\n * @returns {MutableRefObject} - a new ref, which translates all changes to {refs}\n *\n * @see {@link mergeRefs} a version without buit-in memoization\n * @see https://github.com/theKashey/use-callback-ref#usemergerefs\n * @example\n * const Component = React.forwardRef((props, ref) => {\n * const ownRef = useRef();\n * const domRef = useMergeRefs([ref, ownRef]); // 👈 merge together\n * return <div ref={domRef}>...</div>\n * }\n */\nexport function useMergeRefs(refs, defaultValue) {\n return useCallbackRef(defaultValue || null, function (newValue) { return refs.forEach(function (ref) { return assignRef(ref, newValue); }); });\n}\n","import { useState } from 'react';\n/**\n * creates a MutableRef with ref change callback\n * @param initialValue - initial ref value\n * @param {Function} callback - a callback to run when value changes\n *\n * @example\n * const ref = useCallbackRef(0, (newValue, oldValue) => console.log(oldValue, '->', newValue);\n * ref.current = 1;\n * // prints 0 -> 1\n *\n * @see https://reactjs.org/docs/hooks-reference.html#useref\n * @see https://github.com/theKashey/use-callback-ref#usecallbackref---to-replace-reactuseref\n * @returns {MutableRefObject}\n */\nexport function useCallbackRef(initialValue, callback) {\n var ref = useState(function () { return ({\n // value\n value: initialValue,\n // last callback\n callback: callback,\n // \"memoized\" public interface\n facade: {\n get current() {\n return ref.value;\n },\n set current(value) {\n var last = ref.value;\n if (last !== value) {\n ref.value = value;\n ref.callback(value, last);\n }\n },\n },\n }); })[0];\n // update callback\n ref.callback = callback;\n return ref.facade;\n}\n","/**\n * Assigns a value for a given ref, no matter of the ref format\n * @param {RefObject} ref - a callback function or ref object\n * @param value - a new value\n *\n * @see https://github.com/theKashey/use-callback-ref#assignref\n * @example\n * const refObject = useRef();\n * const refFn = (ref) => {....}\n *\n * assignRef(refObject, \"refValue\");\n * assignRef(refFn, \"refValue\");\n */\nexport function assignRef(ref, value) {\n if (typeof ref === 'function') {\n ref(value);\n }\n else if (ref) {\n ref.current = value;\n }\n return ref;\n}\n","import * as React from 'react';\nimport PropTypes from 'prop-types';\nexport var hiddenGuard = {\n width: '1px',\n height: '0px',\n padding: 0,\n overflow: 'hidden',\n position: 'fixed',\n top: '1px',\n left: '1px'\n};\n\nvar InFocusGuard = function InFocusGuard(_ref) {\n var children = _ref.children;\n return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"div\", {\n key: \"guard-first\",\n \"data-focus-guard\": true,\n \"data-focus-auto-guard\": true,\n style: hiddenGuard\n }), children, children && /*#__PURE__*/React.createElement(\"div\", {\n key: \"guard-last\",\n \"data-focus-guard\": true,\n \"data-focus-auto-guard\": true,\n style: hiddenGuard\n }));\n};\n\nInFocusGuard.propTypes = process.env.NODE_ENV !== \"production\" ? {\n children: PropTypes.node\n} : {};\nInFocusGuard.defaultProps = {\n children: null\n};\nexport default InFocusGuard;","/******************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n var desc = Object.getOwnPropertyDescriptor(m, k);\r\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\r\n desc = { enumerable: true, get: function() { return m[k]; } };\r\n }\r\n Object.defineProperty(o, k2, desc);\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n\r\nexport function __classPrivateFieldIn(state, receiver) {\r\n if (receiver === null || (typeof receiver !== \"object\" && typeof receiver !== \"function\")) throw new TypeError(\"Cannot use 'in' operator on non-object\");\r\n return typeof state === \"function\" ? receiver === state : state.has(receiver);\r\n}\r\n","import { __assign } from \"tslib\";\nfunction ItoI(a) {\n return a;\n}\nfunction innerCreateMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n var buffer = [];\n var assigned = false;\n var medium = {\n read: function () {\n if (assigned) {\n throw new Error('Sidecar: could not `read` from an `assigned` medium. `read` could be used only with `useMedium`.');\n }\n if (buffer.length) {\n return buffer[buffer.length - 1];\n }\n return defaults;\n },\n useMedium: function (data) {\n var item = middleware(data, assigned);\n buffer.push(item);\n return function () {\n buffer = buffer.filter(function (x) { return x !== item; });\n };\n },\n assignSyncMedium: function (cb) {\n assigned = true;\n while (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n }\n buffer = {\n push: function (x) { return cb(x); },\n filter: function () { return buffer; },\n };\n },\n assignMedium: function (cb) {\n assigned = true;\n var pendingQueue = [];\n if (buffer.length) {\n var cbs = buffer;\n buffer = [];\n cbs.forEach(cb);\n pendingQueue = buffer;\n }\n var executeQueue = function () {\n var cbs = pendingQueue;\n pendingQueue = [];\n cbs.forEach(cb);\n };\n var cycle = function () { return Promise.resolve().then(executeQueue); };\n cycle();\n buffer = {\n push: function (x) {\n pendingQueue.push(x);\n cycle();\n },\n filter: function (filter) {\n pendingQueue = pendingQueue.filter(filter);\n return buffer;\n },\n };\n },\n };\n return medium;\n}\nexport function createMedium(defaults, middleware) {\n if (middleware === void 0) { middleware = ItoI; }\n return innerCreateMedium(defaults, middleware);\n}\n// eslint-disable-next-line @typescript-eslint/ban-types\nexport function createSidecarMedium(options) {\n if (options === void 0) { options = {}; }\n var medium = innerCreateMedium(null);\n medium.options = __assign({ async: true, ssr: false }, options);\n return medium;\n}\n","import { createMedium, createSidecarMedium } from 'use-sidecar';\nexport var mediumFocus = createMedium({}, function (_ref) {\n var target = _ref.target,\n currentTarget = _ref.currentTarget;\n return {\n target: target,\n currentTarget: currentTarget\n };\n});\nexport var mediumBlur = createMedium();\nexport var mediumEffect = createMedium();\nexport var mediumSidecar = createSidecarMedium({\n async: true\n});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport { node, bool, string, any, arrayOf, oneOfType, object, func } from 'prop-types';\nimport * as constants from 'focus-lock/constants';\nimport { useMergeRefs } from 'use-callback-ref';\nimport { useEffect } from 'react';\nimport { hiddenGuard } from './FocusGuard';\nimport { mediumFocus, mediumBlur, mediumSidecar } from './medium';\nvar emptyArray = [];\nvar FocusLock = /*#__PURE__*/React.forwardRef(function FocusLockUI(props, parentRef) {\n var _extends2;\n\n var _React$useState = React.useState(),\n realObserved = _React$useState[0],\n setObserved = _React$useState[1];\n\n var observed = React.useRef();\n var isActive = React.useRef(false);\n var originalFocusedElement = React.useRef(null);\n var children = props.children,\n disabled = props.disabled,\n noFocusGuards = props.noFocusGuards,\n persistentFocus = props.persistentFocus,\n crossFrame = props.crossFrame,\n autoFocus = props.autoFocus,\n allowTextSelection = props.allowTextSelection,\n group = props.group,\n className = props.className,\n whiteList = props.whiteList,\n hasPositiveIndices = props.hasPositiveIndices,\n _props$shards = props.shards,\n shards = _props$shards === void 0 ? emptyArray : _props$shards,\n _props$as = props.as,\n Container = _props$as === void 0 ? 'div' : _props$as,\n _props$lockProps = props.lockProps,\n containerProps = _props$lockProps === void 0 ? {} : _props$lockProps,\n SideCar = props.sideCar,\n shouldReturnFocus = props.returnFocus,\n focusOptions = props.focusOptions,\n onActivationCallback = props.onActivation,\n onDeactivationCallback = props.onDeactivation;\n\n var _React$useState2 = React.useState({}),\n id = _React$useState2[0]; // SIDE EFFECT CALLBACKS\n\n\n var onActivation = React.useCallback(function () {\n originalFocusedElement.current = originalFocusedElement.current || document && document.activeElement;\n\n if (observed.current && onActivationCallback) {\n onActivationCallback(observed.current);\n }\n\n isActive.current = true;\n }, [onActivationCallback]);\n var onDeactivation = React.useCallback(function () {\n isActive.current = false;\n\n if (onDeactivationCallback) {\n onDeactivationCallback(observed.current);\n }\n }, [onDeactivationCallback]);\n useEffect(function () {\n if (!disabled) {\n // cleanup return focus on trap deactivation\n // sideEffect/returnFocus should happen by this time\n originalFocusedElement.current = null;\n }\n }, []);\n var returnFocus = React.useCallback(function (allowDefer) {\n var returnFocusTo = originalFocusedElement.current;\n\n if (returnFocusTo && returnFocusTo.focus) {\n var howToReturnFocus = typeof shouldReturnFocus === 'function' ? shouldReturnFocus(returnFocusTo) : shouldReturnFocus;\n\n if (howToReturnFocus) {\n var returnFocusOptions = typeof howToReturnFocus === 'object' ? howToReturnFocus : undefined;\n originalFocusedElement.current = null;\n\n if (allowDefer) {\n // React might return focus after update\n // it's safer to defer the action\n Promise.resolve().then(function () {\n return returnFocusTo.focus(returnFocusOptions);\n });\n } else {\n returnFocusTo.focus(returnFocusOptions);\n }\n }\n }\n }, [shouldReturnFocus]); // MEDIUM CALLBACKS\n\n var onFocus = React.useCallback(function (event) {\n if (isActive.current) {\n mediumFocus.useMedium(event);\n }\n }, []);\n var onBlur = mediumBlur.useMedium; // REF PROPAGATION\n // not using real refs due to race conditions\n\n var setObserveNode = React.useCallback(function (newObserved) {\n if (observed.current !== newObserved) {\n observed.current = newObserved;\n setObserved(newObserved);\n }\n }, []);\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof allowTextSelection !== 'undefined') {\n // eslint-disable-next-line no-console\n console.warn('React-Focus-Lock: allowTextSelection is deprecated and enabled by default');\n }\n\n React.useEffect(function () {\n if (!observed.current) {\n // eslint-disable-next-line no-console\n console.error('FocusLock: could not obtain ref to internal node');\n }\n }, []);\n }\n\n var lockProps = _extends((_extends2 = {}, _extends2[constants.FOCUS_DISABLED] = disabled && 'disabled', _extends2[constants.FOCUS_GROUP] = group, _extends2), containerProps);\n\n var hasLeadingGuards = noFocusGuards !== true;\n var hasTailingGuards = hasLeadingGuards && noFocusGuards !== 'tail';\n var mergedRef = useMergeRefs([parentRef, setObserveNode]);\n return /*#__PURE__*/React.createElement(React.Fragment, null, hasLeadingGuards && [\n /*#__PURE__*/\n // nearest focus guard\n React.createElement(\"div\", {\n key: \"guard-first\",\n \"data-focus-guard\": true,\n tabIndex: disabled ? -1 : 0,\n style: hiddenGuard\n }), // first tabbed element guard\n hasPositiveIndices ? /*#__PURE__*/React.createElement(\"div\", {\n key: \"guard-nearest\",\n \"data-focus-guard\": true,\n tabIndex: disabled ? -1 : 1,\n style: hiddenGuard\n }) : null], !disabled && /*#__PURE__*/React.createElement(SideCar, {\n id: id,\n sideCar: mediumSidecar,\n observed: realObserved,\n disabled: disabled,\n persistentFocus: persistentFocus,\n crossFrame: crossFrame,\n autoFocus: autoFocus,\n whiteList: whiteList,\n shards: shards,\n onActivation: onActivation,\n onDeactivation: onDeactivation,\n returnFocus: returnFocus,\n focusOptions: focusOptions\n }), /*#__PURE__*/React.createElement(Container, _extends({\n ref: mergedRef\n }, lockProps, {\n className: className,\n onBlur: onBlur,\n onFocus: onFocus\n }), children), hasTailingGuards && /*#__PURE__*/React.createElement(\"div\", {\n \"data-focus-guard\": true,\n tabIndex: disabled ? -1 : 0,\n style: hiddenGuard\n }));\n});\nFocusLock.propTypes = process.env.NODE_ENV !== \"production\" ? {\n children: node,\n disabled: bool,\n returnFocus: oneOfType([bool, object, func]),\n focusOptions: object,\n noFocusGuards: bool,\n hasPositiveIndices: bool,\n allowTextSelection: bool,\n autoFocus: bool,\n persistentFocus: bool,\n crossFrame: bool,\n group: string,\n className: string,\n whiteList: func,\n shards: arrayOf(any),\n as: oneOfType([string, func, object]),\n lockProps: object,\n onActivation: func,\n onDeactivation: func,\n sideCar: any.isRequired\n} : {};\nFocusLock.defaultProps = {\n children: undefined,\n disabled: false,\n returnFocus: false,\n focusOptions: undefined,\n noFocusGuards: false,\n autoFocus: true,\n persistentFocus: false,\n crossFrame: true,\n hasPositiveIndices: undefined,\n allowTextSelection: undefined,\n group: undefined,\n className: undefined,\n whiteList: undefined,\n shards: undefined,\n as: 'div',\n lockProps: {},\n onActivation: undefined,\n onDeactivation: undefined\n};\nexport default FocusLock;","export default function _setPrototypeOf(o, p) {\n _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n };\n\n return _setPrototypeOf(o, p);\n}","import _inheritsLoose from '@babel/runtime/helpers/esm/inheritsLoose';\nimport _defineProperty from '@babel/runtime/helpers/esm/defineProperty';\nimport React, { PureComponent } from 'react';\n\nfunction withSideEffect(reducePropsToState, handleStateChangeOnClient) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof reducePropsToState !== 'function') {\n throw new Error('Expected reducePropsToState to be a function.');\n }\n\n if (typeof handleStateChangeOnClient !== 'function') {\n throw new Error('Expected handleStateChangeOnClient to be a function.');\n }\n }\n\n function getDisplayName(WrappedComponent) {\n return WrappedComponent.displayName || WrappedComponent.name || 'Component';\n }\n\n return function wrap(WrappedComponent) {\n if (process.env.NODE_ENV !== \"production\") {\n if (typeof WrappedComponent !== 'function') {\n throw new Error('Expected WrappedComponent to be a React component.');\n }\n }\n\n var mountedInstances = [];\n var state;\n\n function emitChange() {\n state = reducePropsToState(mountedInstances.map(function (instance) {\n return instance.props;\n }));\n handleStateChangeOnClient(state);\n }\n\n var SideEffect = /*#__PURE__*/function (_PureComponent) {\n _inheritsLoose(SideEffect, _PureComponent);\n\n function SideEffect() {\n return _PureComponent.apply(this, arguments) || this;\n }\n\n // Try to use displayName of wrapped component\n SideEffect.peek = function peek() {\n return state;\n };\n\n var _proto = SideEffect.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n mountedInstances.push(this);\n emitChange();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate() {\n emitChange();\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n var index = mountedInstances.indexOf(this);\n mountedInstances.splice(index, 1);\n emitChange();\n };\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(WrappedComponent, this.props);\n };\n\n return SideEffect;\n }(PureComponent);\n\n _defineProperty(SideEffect, \"displayName\", \"SideEffect(\" + getDisplayName(WrappedComponent) + \")\");\n\n return SideEffect;\n };\n}\n\nexport default withSideEffect;\n","export default function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}","import setPrototypeOf from \"./setPrototypeOf.js\";\nexport default function _inheritsLoose(subClass, superClass) {\n subClass.prototype = Object.create(superClass.prototype);\n subClass.prototype.constructor = subClass;\n setPrototypeOf(subClass, superClass);\n}","import { FOCUS_NO_AUTOFOCUS } from '../constants';\nvar isElementHidden = function (node) {\n // we can measure only \"elements\"\n // consider others as \"visible\"\n if (node.nodeType !== Node.ELEMENT_NODE) {\n return false;\n }\n var computedStyle = window.getComputedStyle(node, null);\n if (!computedStyle || !computedStyle.getPropertyValue) {\n return false;\n }\n return (computedStyle.getPropertyValue('display') === 'none' || computedStyle.getPropertyValue('visibility') === 'hidden');\n};\nvar getParentNode = function (node) {\n // DOCUMENT_FRAGMENT_NODE can also point on ShadowRoot. In this case .host will point on the next node\n return node.parentNode && node.parentNode.nodeType === Node.DOCUMENT_FRAGMENT_NODE\n ? // eslint-disable-next-line @typescript-eslint/no-explicit-any\n node.parentNode.host\n : node.parentNode;\n};\nvar isTopNode = function (node) {\n // @ts-ignore\n return node === document || (node && node.nodeType === Node.DOCUMENT_NODE);\n};\nvar isVisibleUncached = function (node, checkParent) {\n return !node || isTopNode(node) || (!isElementHidden(node) && checkParent(getParentNode(node)));\n};\nexport var isVisibleCached = function (visibilityCache, node) {\n var cached = visibilityCache.get(node);\n if (cached !== undefined) {\n return cached;\n }\n var result = isVisibleUncached(node, isVisibleCached.bind(undefined, visibilityCache));\n visibilityCache.set(node, result);\n return result;\n};\nvar isAutoFocusAllowedUncached = function (node, checkParent) {\n return node && !isTopNode(node) ? (isAutoFocusAllowed(node) ? checkParent(getParentNode(node)) : false) : true;\n};\nexport var isAutoFocusAllowedCached = function (cache, node) {\n var cached = cache.get(node);\n if (cached !== undefined) {\n return cached;\n }\n var result = isAutoFocusAllowedUncached(node, isAutoFocusAllowedCached.bind(undefined, cache));\n cache.set(node, result);\n return result;\n};\nexport var getDataset = function (node) {\n // @ts-ignore\n return node.dataset;\n};\nexport var isHTMLButtonElement = function (node) { return node.tagName === 'BUTTON'; };\nexport var isHTMLInputElement = function (node) { return node.tagName === 'INPUT'; };\nexport var isRadioElement = function (node) {\n return isHTMLInputElement(node) && node.type === 'radio';\n};\nexport var notHiddenInput = function (node) {\n return !((isHTMLInputElement(node) || isHTMLButtonElement(node)) && (node.type === 'hidden' || node.disabled));\n};\nexport var isAutoFocusAllowed = function (node) {\n var attribute = node.getAttribute(FOCUS_NO_AUTOFOCUS);\n return ![true, 'true', ''].includes(attribute);\n};\nexport var isGuard = function (node) { var _a; return Boolean(node && ((_a = getDataset(node)) === null || _a === void 0 ? void 0 : _a.focusGuard)); };\nexport var isNotAGuard = function (node) { return !isGuard(node); };\nexport var isDefined = function (x) { return Boolean(x); };\n","import { isRadioElement } from './is';\nvar findSelectedRadio = function (node, nodes) {\n return nodes\n .filter(isRadioElement)\n .filter(function (el) { return el.name === node.name; })\n .filter(function (el) { return el.checked; })[0] || node;\n};\nexport var correctNode = function (node, nodes) {\n if (isRadioElement(node) && node.name) {\n return findSelectedRadio(node, nodes);\n }\n return node;\n};\n/**\n * giving a set of radio inputs keeps only selected (tabbable) ones\n * @param nodes\n */\nexport var correctNodes = function (nodes) {\n // IE11 has no Set(array) constructor\n var resultSet = new Set();\n nodes.forEach(function (node) { return resultSet.add(correctNode(node, nodes)); });\n // using filter to support IE11\n return nodes.filter(function (node) { return resultSet.has(node); });\n};\n","import { correctNode } from './correctFocus';\nexport var pickFirstFocus = function (nodes) {\n if (nodes[0] && nodes.length > 1) {\n return correctNode(nodes[0], nodes);\n }\n return nodes[0];\n};\nexport var pickFocusable = function (nodes, index) {\n if (nodes.length > 1) {\n return nodes.indexOf(correctNode(nodes[index], nodes));\n }\n return index;\n};\n","import { correctNodes } from './utils/correctFocus';\nimport { pickFocusable } from './utils/firstFocus';\nimport { isGuard } from './utils/is';\nexport var NEW_FOCUS = 'NEW_FOCUS';\n/**\n * Main solver for the \"find next focus\" question\n * @param innerNodes\n * @param outerNodes\n * @param activeElement\n * @param lastNode\n * @returns {number|string|undefined|*}\n */\nexport var newFocus = function (innerNodes, outerNodes, activeElement, lastNode) {\n var cnt = innerNodes.length;\n var firstFocus = innerNodes[0];\n var lastFocus = innerNodes[cnt - 1];\n var isOnGuard = isGuard(activeElement);\n // focus is inside\n if (activeElement && innerNodes.indexOf(activeElement) >= 0) {\n return undefined;\n }\n var activeIndex = activeElement !== undefined ? outerNodes.indexOf(activeElement) : -1;\n var lastIndex = lastNode ? outerNodes.indexOf(lastNode) : activeIndex;\n var lastNodeInside = lastNode ? innerNodes.indexOf(lastNode) : -1;\n var indexDiff = activeIndex - lastIndex;\n var firstNodeIndex = outerNodes.indexOf(firstFocus);\n var lastNodeIndex = outerNodes.indexOf(lastFocus);\n var correctedNodes = correctNodes(outerNodes);\n var correctedIndex = activeElement !== undefined ? correctedNodes.indexOf(activeElement) : -1;\n var correctedIndexDiff = correctedIndex - (lastNode ? correctedNodes.indexOf(lastNode) : activeIndex);\n var returnFirstNode = pickFocusable(innerNodes, 0);\n var returnLastNode = pickFocusable(innerNodes, cnt - 1);\n // new focus\n if (activeIndex === -1 || lastNodeInside === -1) {\n return NEW_FOCUS;\n }\n // old focus\n if (!indexDiff && lastNodeInside >= 0) {\n return lastNodeInside;\n }\n // first element\n if (activeIndex <= firstNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n return returnLastNode;\n }\n // last element\n if (activeIndex >= lastNodeIndex && isOnGuard && Math.abs(indexDiff) > 1) {\n return returnFirstNode;\n }\n // jump out, but not on the guard\n if (indexDiff && Math.abs(correctedIndexDiff) > 1) {\n return lastNodeInside;\n }\n // focus above lock\n if (activeIndex <= firstNodeIndex) {\n return returnLastNode;\n }\n // focus below lock\n if (activeIndex > lastNodeIndex) {\n return returnFirstNode;\n }\n // index is inside tab order, but outside Lock\n if (indexDiff) {\n if (Math.abs(indexDiff) > 1) {\n return lastNodeInside;\n }\n return (cnt + lastNodeInside + indexDiff) % cnt;\n }\n // do nothing\n return undefined;\n};\n","/*\nIE11 support\n */\nexport var toArray = function (a) {\n var ret = Array(a.length);\n for (var i = 0; i < a.length; ++i) {\n ret[i] = a[i];\n }\n return ret;\n};\nexport var asArray = function (a) { return (Array.isArray(a) ? a : [a]); };\n","import { toArray } from './array';\nexport var tabSort = function (a, b) {\n var tabDiff = a.tabIndex - b.tabIndex;\n var indexDiff = a.index - b.index;\n if (tabDiff) {\n if (!a.tabIndex) {\n return 1;\n }\n if (!b.tabIndex) {\n return -1;\n }\n }\n return tabDiff || indexDiff;\n};\nexport var orderByTabIndex = function (nodes, filterNegative, keepGuards) {\n return toArray(nodes)\n .map(function (node, index) { return ({\n node: node,\n index: index,\n tabIndex: keepGuards && node.tabIndex === -1 ? ((node.dataset || {}).focusGuard ? 0 : -1) : node.tabIndex,\n }); })\n .filter(function (data) { return !filterNegative || data.tabIndex >= 0; })\n .sort(tabSort);\n};\n","import { FOCUS_AUTO } from '../constants';\nimport { toArray } from './array';\nimport { tabbables } from './tabbables';\nvar queryTabbables = tabbables.join(',');\nvar queryGuardTabbables = \"\".concat(queryTabbables, \", [data-focus-guard]\");\nvar getFocusablesWithShadowDom = function (parent, withGuards) {\n var _a;\n return toArray(((_a = parent.shadowRoot) === null || _a === void 0 ? void 0 : _a.children) || parent.children).reduce(function (acc, child) {\n return acc.concat(child.matches(withGuards ? queryGuardTabbables : queryTabbables) ? [child] : [], getFocusablesWithShadowDom(child));\n }, []);\n};\nexport var getFocusables = function (parents, withGuards) {\n return parents.reduce(function (acc, parent) {\n return acc.concat(\n // add all tabbables inside and within shadow DOMs in DOM order\n getFocusablesWithShadowDom(parent, withGuards), \n // add if node is tabbable itself\n parent.parentNode\n ? toArray(parent.parentNode.querySelectorAll(queryTabbables)).filter(function (node) { return node === parent; })\n : []);\n }, []);\n};\n/**\n * return a list of focusable nodes within an area marked as \"auto-focusable\"\n * @param parent\n */\nexport var getParentAutofocusables = function (parent) {\n var parentFocus = parent.querySelectorAll(\"[\".concat(FOCUS_AUTO, \"]\"));\n return toArray(parentFocus)\n .map(function (node) { return getFocusables([node]); })\n .reduce(function (acc, nodes) { return acc.concat(nodes); }, []);\n};\n","/**\n * list of the object to be considered as focusable\n */\nexport var tabbables = [\n 'button:enabled',\n 'select:enabled',\n 'textarea:enabled',\n 'input:enabled',\n // elements with explicit roles will also use explicit tabindex\n // '[role=\"button\"]',\n 'a[href]',\n 'area[href]',\n 'summary',\n 'iframe',\n 'object',\n 'embed',\n 'audio[controls]',\n 'video[controls]',\n '[tabindex]',\n '[contenteditable]',\n '[autofocus]',\n];\n","import { toArray } from './array';\nimport { isAutoFocusAllowedCached, isVisibleCached, notHiddenInput } from './is';\nimport { orderByTabIndex } from './tabOrder';\nimport { getFocusables, getParentAutofocusables } from './tabUtils';\n/**\n * given list of focusable elements keeps the ones user can interact with\n * @param nodes\n * @param visibilityCache\n */\nexport var filterFocusable = function (nodes, visibilityCache) {\n return toArray(nodes)\n .filter(function (node) { return isVisibleCached(visibilityCache, node); })\n .filter(function (node) { return notHiddenInput(node); });\n};\nexport var filterAutoFocusable = function (nodes, cache) {\n if (cache === void 0) { cache = new Map(); }\n return toArray(nodes).filter(function (node) { return isAutoFocusAllowedCached(cache, node); });\n};\n/**\n * only tabbable ones\n * (but with guards which would be ignored)\n */\nexport var getTabbableNodes = function (topNodes, visibilityCache, withGuards) {\n return orderByTabIndex(filterFocusable(getFocusables(topNodes, withGuards), visibilityCache), true, withGuards);\n};\n/**\n * actually anything \"focusable\", not only tabbable\n * (without guards, as long as they are not expected to be focused)\n */\nexport var getAllTabbableNodes = function (topNodes, visibilityCache) {\n return orderByTabIndex(filterFocusable(getFocusables(topNodes), visibilityCache), false);\n};\n/**\n * return list of nodes which are expected to be auto-focused\n * @param topNode\n * @param visibilityCache\n */\nexport var parentAutofocusables = function (topNode, visibilityCache) {\n return filterFocusable(getParentAutofocusables(topNode), visibilityCache);\n};\n/*\n * Determines if element is contained in scope, including nested shadow DOMs\n */\nexport var contains = function (scope, element) {\n return ((scope.shadowRoot\n ? contains(scope.shadowRoot, element)\n : Object.getPrototypeOf(scope).contains.call(scope, element)) ||\n toArray(scope.children).some(function (child) { return contains(child, element); }));\n};\n","import { FOCUS_DISABLED, FOCUS_GROUP } from '../constants';\nimport { asArray, toArray } from './array';\n/**\n * in case of multiple nodes nested inside each other\n * keeps only top ones\n * this is O(nlogn)\n * @param nodes\n * @returns {*}\n */\nvar filterNested = function (nodes) {\n var contained = new Set();\n var l = nodes.length;\n for (var i = 0; i < l; i += 1) {\n for (var j = i + 1; j < l; j += 1) {\n var position = nodes[i].compareDocumentPosition(nodes[j]);\n /* eslint-disable no-bitwise */\n if ((position & Node.DOCUMENT_POSITION_CONTAINED_BY) > 0) {\n contained.add(j);\n }\n if ((position & Node.DOCUMENT_POSITION_CONTAINS) > 0) {\n contained.add(i);\n }\n /* eslint-enable */\n }\n }\n return nodes.filter(function (_, index) { return !contained.has(index); });\n};\n/**\n * finds top most parent for a node\n * @param node\n * @returns {*}\n */\nvar getTopParent = function (node) {\n return node.parentNode ? getTopParent(node.parentNode) : node;\n};\n/**\n * returns all \"focus containers\" inside a given node\n * @param node\n * @returns {T}\n */\nexport var getAllAffectedNodes = function (node) {\n var nodes = asArray(node);\n return nodes.filter(Boolean).reduce(function (acc, currentNode) {\n var group = currentNode.getAttribute(FOCUS_GROUP);\n acc.push.apply(acc, (group\n ? filterNested(toArray(getTopParent(currentNode).querySelectorAll(\"[\".concat(FOCUS_GROUP, \"=\\\"\").concat(group, \"\\\"]:not([\").concat(FOCUS_DISABLED, \"=\\\"disabled\\\"])\"))))\n : [currentNode]));\n return acc;\n }, []);\n};\n","var getNestedShadowActiveElement = function (shadowRoot) {\n return shadowRoot.activeElement\n ? shadowRoot.activeElement.shadowRoot\n ? getNestedShadowActiveElement(shadowRoot.activeElement.shadowRoot)\n : shadowRoot.activeElement\n : undefined;\n};\n/**\n * returns active element from document or from nested shadowdoms\n */\nexport var getActiveElement = function () {\n return (document.activeElement\n ? document.activeElement.shadowRoot\n ? getNestedShadowActiveElement(document.activeElement.shadowRoot)\n : document.activeElement\n : undefined); // eslint-disable-next-line @typescript-eslint/no-explicit-any\n};\n","import { parentAutofocusables } from './DOMutils';\nimport { contains } from './DOMutils';\nimport { asArray } from './array';\nvar getParents = function (node, parents) {\n if (parents === void 0) { parents = []; }\n parents.push(node);\n if (node.parentNode) {\n getParents(node.parentNode.host || node.parentNode, parents);\n }\n return parents;\n};\n/**\n * finds a parent for both nodeA and nodeB\n * @param nodeA\n * @param nodeB\n * @returns {boolean|*}\n */\nexport var getCommonParent = function (nodeA, nodeB) {\n var parentsA = getParents(nodeA);\n var parentsB = getParents(nodeB);\n // tslint:disable-next-line:prefer-for-of\n for (var i = 0; i < parentsA.length; i += 1) {\n var currentParent = parentsA[i];\n if (parentsB.indexOf(currentParent) >= 0) {\n return currentParent;\n }\n }\n return false;\n};\nexport var getTopCommonParent = function (baseActiveElement, leftEntry, rightEntries) {\n var activeElements = asArray(baseActiveElement);\n var leftEntries = asArray(leftEntry);\n var activeElement = activeElements[0];\n var topCommon = false;\n leftEntries.filter(Boolean).forEach(function (entry) {\n topCommon = getCommonParent(topCommon || entry, entry) || topCommon;\n rightEntries.filter(Boolean).forEach(function (subEntry) {\n var common = getCommonParent(activeElement, subEntry);\n if (common) {\n if (!topCommon || contains(common, topCommon)) {\n topCommon = common;\n }\n else {\n topCommon = getCommonParent(common, topCommon);\n }\n }\n });\n });\n // TODO: add assert here?\n return topCommon;\n};\n/**\n * return list of nodes which are expected to be autofocused inside a given top nodes\n * @param entries\n * @param visibilityCache\n */\nexport var allParentAutofocusables = function (entries, visibilityCache) {\n return entries.reduce(function (acc, node) { return acc.concat(parentAutofocusables(node, visibilityCache)); }, []);\n};\n","import { NEW_FOCUS, newFocus } from './solver';\nimport { filterAutoFocusable, getAllTabbableNodes, getTabbableNodes } from './utils/DOMutils';\nimport { getAllAffectedNodes } from './utils/all-affected';\nimport { pickFirstFocus } from './utils/firstFocus';\nimport { getActiveElement } from './utils/getActiveElement';\nimport { getDataset, isDefined, isNotAGuard } from './utils/is';\nimport { allParentAutofocusables, getTopCommonParent } from './utils/parenting';\nvar findAutoFocused = function (autoFocusables) {\n return function (node) { var _a; \n // @ts-expect-error\n return node.autofocus || !!((_a = getDataset(node)) === null || _a === void 0 ? void 0 : _a.autofocus) || autoFocusables.indexOf(node) >= 0; };\n};\nvar reorderNodes = function (srcNodes, dstNodes) {\n var remap = new Map();\n // no Set(dstNodes) for IE11 :(\n dstNodes.forEach(function (entity) { return remap.set(entity.node, entity); });\n // remap to dstNodes\n return srcNodes.map(function (node) { return remap.get(node); }).filter(isDefined);\n};\n/**\n * given top node(s) and the last active element return the element to be focused next\n * @param topNode\n * @param lastNode\n */\nexport var getFocusMerge = function (topNode, lastNode) {\n var activeElement = document && getActiveElement();\n var entries = getAllAffectedNodes(topNode).filter(isNotAGuard);\n var commonParent = getTopCommonParent(activeElement || topNode, topNode, entries);\n var visibilityCache = new Map();\n var anyFocusable = getAllTabbableNodes(entries, visibilityCache);\n var innerElements = getTabbableNodes(entries, visibilityCache).filter(function (_a) {\n var node = _a.node;\n return isNotAGuard(node);\n });\n if (!innerElements[0]) {\n innerElements = anyFocusable;\n if (!innerElements[0]) {\n return undefined;\n }\n }\n var outerNodes = getAllTabbableNodes([commonParent], visibilityCache).map(function (_a) {\n var node = _a.node;\n return node;\n });\n var orderedInnerElements = reorderNodes(outerNodes, innerElements);\n var innerNodes = orderedInnerElements.map(function (_a) {\n var node = _a.node;\n return node;\n });\n var newId = newFocus(innerNodes, outerNodes, activeElement, lastNode);\n if (newId === NEW_FOCUS) {\n var autoFocusable = filterAutoFocusable(anyFocusable.map(function (_a) {\n var node = _a.node;\n return node;\n })).filter(findAutoFocused(allParentAutofocusables(entries, visibilityCache)));\n return {\n node: autoFocusable && autoFocusable.length\n ? pickFirstFocus(autoFocusable)\n : pickFirstFocus(filterAutoFocusable(innerNodes)),\n };\n }\n if (newId === undefined) {\n return newId;\n }\n return orderedInnerElements[newId];\n};\n","import { getFocusMerge } from './focusMerge';\nexport var focusOn = function (target, focusOptions) {\n if ('focus' in target) {\n target.focus(focusOptions);\n }\n if ('contentWindow' in target && target.contentWindow) {\n target.contentWindow.focus();\n }\n};\nvar guardCount = 0;\nvar lockDisabled = false;\n/**\n * Sets focus at a given node. The last focused element will help to determine which element(first or last) should be focused.\n * HTML markers (see {@link import('./constants').FOCUS_AUTO} constants) can control autofocus\n * @param topNode\n * @param lastNode\n * @param options\n */\nexport var setFocus = function (topNode, lastNode, options) {\n if (options === void 0) { options = {}; }\n var focusable = getFocusMerge(topNode, lastNode);\n if (lockDisabled) {\n return;\n }\n if (focusable) {\n if (guardCount > 2) {\n // tslint:disable-next-line:no-console\n console.error('FocusLock: focus-fighting detected. Only one focus management system could be active. ' +\n 'See https://github.com/theKashey/focus-lock/#focus-fighting');\n lockDisabled = true;\n setTimeout(function () {\n lockDisabled = false;\n }, 1);\n return;\n }\n guardCount++;\n focusOn(focusable.node, options.focusOptions);\n guardCount--;\n }\n};\n","import * as constants from './constants';\nimport { focusInside } from './focusInside';\nimport { focusIsHidden } from './focusIsHidden';\nimport { getFocusMerge as focusMerge } from './focusMerge';\nimport { getFocusabledIn, getFocusableIn } from './focusables';\nimport { setFocus } from './setFocus';\nimport { focusNextElement, focusPrevElement } from './sibling';\nimport tabHook from './tabHook';\nimport { getAllAffectedNodes } from './utils/all-affected';\nimport { getActiveElement } from './utils/getActiveElement';\nexport { tabHook, focusInside, focusIsHidden, focusMerge, getFocusableIn, getFocusabledIn, constants, getAllAffectedNodes, focusNextElement, focusPrevElement, getActiveElement, };\nexport default setFocus;\n//\n","import { FOCUS_ALLOW } from './constants';\nimport { contains } from './utils/DOMutils';\nimport { toArray } from './utils/array';\nimport { getActiveElement } from './utils/getActiveElement';\n/**\n * focus is hidden FROM the focus-lock\n * ie contained inside a node focus-lock shall ignore\n * @returns {boolean} focus is currently is in \"allow\" area\n */\nexport var focusIsHidden = function () {\n var activeElement = document && getActiveElement();\n if (!activeElement) {\n return false;\n }\n // this does not support setting FOCUS_ALLOW within shadow dom\n return toArray(document.querySelectorAll(\"[\".concat(FOCUS_ALLOW, \"]\"))).some(function (node) { return contains(node, activeElement); });\n};\n","import { contains } from './utils/DOMutils';\nimport { getAllAffectedNodes } from './utils/all-affected';\nimport { toArray } from './utils/array';\nimport { getActiveElement } from './utils/getActiveElement';\nvar focusInFrame = function (frame) { return frame === document.activeElement; };\nvar focusInsideIframe = function (topNode) {\n return Boolean(toArray(topNode.querySelectorAll('iframe')).some(function (node) { return focusInFrame(node); }));\n};\n/**\n * @returns {Boolean} true, if the current focus is inside given node or nodes\n */\nexport var focusInside = function (topNode) {\n var activeElement = document && getActiveElement();\n if (!activeElement || (activeElement.dataset && activeElement.dataset.focusGuard)) {\n return false;\n }\n return getAllAffectedNodes(topNode).some(function (node) { return contains(node, activeElement) || focusInsideIframe(node); });\n};\n","import { getTabbableNodes } from './utils/DOMutils';\nimport { getAllAffectedNodes } from './utils/all-affected';\nimport { isGuard, isNotAGuard } from './utils/is';\nimport { getTopCommonParent } from './utils/parenting';\n/**\n * return list of focusable elements inside a given top node\n * @deprecated use {@link getFocusableIn}. Yep, there is typo in the function name\n */\nexport var getFocusabledIn = function (topNode) {\n var entries = getAllAffectedNodes(topNode).filter(isNotAGuard);\n var commonParent = getTopCommonParent(topNode, topNode, entries);\n var visibilityCache = new Map();\n var outerNodes = getTabbableNodes([commonParent], visibilityCache, true);\n var innerElements = getTabbableNodes(entries, visibilityCache)\n .filter(function (_a) {\n var node = _a.node;\n return isNotAGuard(node);\n })\n .map(function (_a) {\n var node = _a.node;\n return node;\n });\n return outerNodes.map(function (_a) {\n var node = _a.node, index = _a.index;\n return ({\n node: node,\n index: index,\n lockItem: innerElements.indexOf(node) >= 0,\n guard: isGuard(node),\n });\n });\n};\n/**\n * return list of focusable elements inside a given top node\n */\nexport var getFocusableIn = getFocusabledIn;\n","export function deferAction(action) {\n // Hidding setImmediate from Webpack to avoid inserting polyfill\n var _window = window,\n setImmediate = _window.setImmediate;\n\n if (typeof setImmediate !== 'undefined') {\n setImmediate(action);\n } else {\n setTimeout(action, 1);\n }\n}\nexport var inlineProp = function inlineProp(name, value) {\n var obj = {};\n obj[name] = value;\n return obj;\n};","/* eslint-disable no-mixed-operators */\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport withSideEffect from 'react-clientside-effect';\nimport moveFocusInside, { focusInside, focusIsHidden, getFocusabledIn } from 'focus-lock';\nimport { deferAction } from './util';\nimport { mediumFocus, mediumBlur, mediumEffect } from './medium';\n\nvar focusOnBody = function focusOnBody() {\n return document && document.activeElement === document.body;\n};\n\nvar isFreeFocus = function isFreeFocus() {\n return focusOnBody() || focusIsHidden();\n};\n\nvar lastActiveTrap = null;\nvar lastActiveFocus = null;\nvar lastPortaledElement = null;\nvar focusWasOutsideWindow = false;\n\nvar defaultWhitelist = function defaultWhitelist() {\n return true;\n};\n\nvar focusWhitelisted = function focusWhitelisted(activeElement) {\n return (lastActiveTrap.whiteList || defaultWhitelist)(activeElement);\n};\n\nvar recordPortal = function recordPortal(observerNode, portaledElement) {\n lastPortaledElement = {\n observerNode: observerNode,\n portaledElement: portaledElement\n };\n};\n\nvar focusIsPortaledPair = function focusIsPortaledPair(element) {\n return lastPortaledElement && lastPortaledElement.portaledElement === element;\n};\n\nfunction autoGuard(startIndex, end, step, allNodes) {\n var lastGuard = null;\n var i = startIndex;\n\n do {\n var item = allNodes[i];\n\n if (item.guard) {\n if (item.node.dataset.focusAutoGuard) {\n lastGuard = item;\n }\n } else if (item.lockItem) {\n if (i !== startIndex) {\n // we will tab to the next element\n return;\n }\n\n lastGuard = null;\n } else {\n break;\n }\n } while ((i += step) !== end);\n\n if (lastGuard) {\n lastGuard.node.tabIndex = 0;\n }\n}\n\nvar extractRef = function extractRef(ref) {\n return ref && 'current' in ref ? ref.current : ref;\n};\n\nvar focusWasOutside = function focusWasOutside(crossFrameOption) {\n if (crossFrameOption) {\n // with cross frame return true for any value\n return Boolean(focusWasOutsideWindow);\n } // in other case return only of focus went a while aho\n\n\n return focusWasOutsideWindow === 'meanwhile';\n};\n\nvar checkInHost = function checkInHost(check, el, boundary) {\n return el && ( // find host equal to active element and check nested active element\n el.host === check && (!el.activeElement || boundary.contains(el.activeElement)) // dive up\n || el.parentNode && checkInHost(check, el.parentNode, boundary));\n};\n\nvar withinHost = function withinHost(activeElement, workingArea) {\n return workingArea.some(function (area) {\n return checkInHost(activeElement, area, area);\n });\n};\n\nvar activateTrap = function activateTrap() {\n var result = false;\n\n if (lastActiveTrap) {\n var _lastActiveTrap = lastActiveTrap,\n observed = _lastActiveTrap.observed,\n persistentFocus = _lastActiveTrap.persistentFocus,\n autoFocus = _lastActiveTrap.autoFocus,\n shards = _lastActiveTrap.shards,\n crossFrame = _lastActiveTrap.crossFrame,\n focusOptions = _lastActiveTrap.focusOptions;\n var workingNode = observed || lastPortaledElement && lastPortaledElement.portaledElement;\n var activeElement = document && document.activeElement;\n\n if (workingNode) {\n var workingArea = [workingNode].concat(shards.map(extractRef).filter(Boolean));\n\n if (!activeElement || focusWhitelisted(activeElement)) {\n if (persistentFocus || focusWasOutside(crossFrame) || !isFreeFocus() || !lastActiveFocus && autoFocus) {\n if (workingNode && !( // active element is \"inside\" working area\n focusInside(workingArea) || // check for shadow-dom contained elements\n activeElement && withinHost(activeElement, workingArea) || focusIsPortaledPair(activeElement, workingNode))) {\n if (document && !lastActiveFocus && activeElement && !autoFocus) {\n // Check if blur() exists, which is missing on certain elements on IE\n if (activeElement.blur) {\n activeElement.blur();\n }\n\n document.body.focus();\n } else {\n result = moveFocusInside(workingArea, lastActiveFocus, {\n focusOptions: focusOptions\n });\n lastPortaledElement = {};\n }\n }\n\n focusWasOutsideWindow = false;\n lastActiveFocus = document && document.activeElement;\n }\n }\n\n if (document) {\n var newActiveElement = document && document.activeElement;\n var allNodes = getFocusabledIn(workingArea);\n var focusedIndex = allNodes.map(function (_ref) {\n var node = _ref.node;\n return node;\n }).indexOf(newActiveElement);\n\n if (focusedIndex > -1) {\n // remove old focus\n allNodes.filter(function (_ref2) {\n var guard = _ref2.guard,\n node = _ref2.node;\n return guard && node.dataset.focusAutoGuard;\n }).forEach(function (_ref3) {\n var node = _ref3.node;\n return node.removeAttribute('tabIndex');\n });\n autoGuard(focusedIndex, allNodes.length, +1, allNodes);\n autoGuard(focusedIndex, -1, -1, allNodes);\n }\n }\n }\n }\n\n return result;\n};\n\nvar onTrap = function onTrap(event) {\n if (activateTrap() && event) {\n // prevent scroll jump\n event.stopPropagation();\n event.preventDefault();\n }\n};\n\nvar onBlur = function onBlur() {\n return deferAction(activateTrap);\n};\n\nvar onFocus = function onFocus(event) {\n // detect portal\n var source = event.target;\n var currentNode = event.currentTarget;\n\n if (!currentNode.contains(source)) {\n recordPortal(currentNode, source);\n }\n};\n\nvar FocusWatcher = function FocusWatcher() {\n return null;\n};\n\nvar FocusTrap = function FocusTrap(_ref4) {\n var children = _ref4.children;\n return /*#__PURE__*/React.createElement(\"div\", {\n onBlur: onBlur,\n onFocus: onFocus\n }, children);\n};\n\nFocusTrap.propTypes = process.env.NODE_ENV !== \"production\" ? {\n children: PropTypes.node.isRequired\n} : {};\n\nvar onWindowBlur = function onWindowBlur() {\n focusWasOutsideWindow = 'just'; // using setTimeout to set this variable after React/sidecar reaction\n\n setTimeout(function () {\n focusWasOutsideWindow = 'meanwhile';\n }, 0);\n};\n\nvar attachHandler = function attachHandler() {\n document.addEventListener('focusin', onTrap);\n document.addEventListener('focusout', onBlur);\n window.addEventListener('blur', onWindowBlur);\n};\n\nvar detachHandler = function detachHandler() {\n document.removeEventListener('focusin', onTrap);\n document.removeEventListener('focusout', onBlur);\n window.removeEventListener('blur', onWindowBlur);\n};\n\nfunction reducePropsToState(propsList) {\n return propsList.filter(function (_ref5) {\n var disabled = _ref5.disabled;\n return !disabled;\n });\n}\n\nfunction handleStateChangeOnClient(traps) {\n var trap = traps.slice(-1)[0];\n\n if (trap && !lastActiveTrap) {\n attachHandler();\n }\n\n var lastTrap = lastActiveTrap;\n var sameTrap = lastTrap && trap && trap.id === lastTrap.id;\n lastActiveTrap = trap;\n\n if (lastTrap && !sameTrap) {\n lastTrap.onDeactivation(); // return focus only of last trap was removed\n\n if (!traps.filter(function (_ref6) {\n var id = _ref6.id;\n return id === lastTrap.id;\n }).length) {\n // allow defer is no other trap is awaiting restore\n lastTrap.returnFocus(!trap);\n }\n }\n\n if (trap) {\n lastActiveFocus = null;\n\n if (!sameTrap || lastTrap.observed !== trap.observed) {\n trap.onActivation();\n }\n\n activateTrap(true);\n deferAction(activateTrap);\n } else {\n detachHandler();\n lastActiveFocus = null;\n }\n} // bind medium\n\n\nmediumFocus.assignSyncMedium(onFocus);\nmediumBlur.assignMedium(onBlur);\nmediumEffect.assignMedium(function (cb) {\n return cb({\n moveFocusInside: moveFocusInside,\n focusInside: focusInside\n });\n});\nexport default withSideEffect(reducePropsToState, handleStateChangeOnClient)(FocusWatcher);","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport * as React from 'react';\nimport FocusLockUI from './Lock';\nimport FocusTrap from './Trap';\n/* that would be a BREAKING CHANGE!\n// delaying sidecar execution till the first usage\nconst RequireSideCar = (props) => {\n // eslint-disable-next-line global-require\n const SideCar = require('./Trap').default;\n return <SideCar {...props} />;\n};\n*/\n\nvar FocusLockCombination = /*#__PURE__*/React.forwardRef(function FocusLockUICombination(props, ref) {\n return /*#__PURE__*/React.createElement(FocusLockUI, _extends({\n sideCar: FocusTrap,\n ref: ref\n }, props));\n});\n\nvar _ref = FocusLockUI.propTypes || {},\n sideCar = _ref.sideCar,\n propTypes = _objectWithoutPropertiesLoose(_ref, [\"sideCar\"]);\n\nFocusLockCombination.propTypes = process.env.NODE_ENV !== \"production\" ? propTypes : {};\nexport default FocusLockCombination;","export default function _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n\n return target;\n}","import FocusLock from './Combination';\nexport * from './UI';\nexport default FocusLock;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.I18nextProvider = I18nextProvider;\n\nvar _react = require(\"react\");\n\nvar _context = require(\"./context.js\");\n\nfunction I18nextProvider(_ref) {\n var i18n = _ref.i18n,\n defaultNS = _ref.defaultNS,\n children = _ref.children;\n var value = (0, _react.useMemo)(function () {\n return {\n i18n: i18n,\n defaultNS: defaultNS\n };\n }, [i18n, defaultNS]);\n return (0, _react.createElement)(_context.I18nContext.Provider, {\n value: value\n }, children);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Trans = Trans;\nObject.defineProperty(exports, \"nodesToString\", {\n enumerable: true,\n get: function get() {\n return _TransWithoutContext.nodesToString;\n }\n});\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _react = require(\"react\");\n\nvar _TransWithoutContext = require(\"./TransWithoutContext.js\");\n\nvar _context = require(\"./context.js\");\n\nvar _excluded = [\"children\", \"count\", \"parent\", \"i18nKey\", \"context\", \"tOptions\", \"values\", \"defaults\", \"components\", \"ns\", \"i18n\", \"t\", \"shouldUnescape\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction Trans(_ref) {\n var children = _ref.children,\n count = _ref.count,\n parent = _ref.parent,\n i18nKey = _ref.i18nKey,\n context = _ref.context,\n _ref$tOptions = _ref.tOptions,\n tOptions = _ref$tOptions === void 0 ? {} : _ref$tOptions,\n values = _ref.values,\n defaults = _ref.defaults,\n components = _ref.components,\n ns = _ref.ns,\n i18nFromProps = _ref.i18n,\n tFromProps = _ref.t,\n shouldUnescape = _ref.shouldUnescape,\n additionalProps = (0, _objectWithoutProperties2[\"default\"])(_ref, _excluded);\n\n var _ref2 = (0, _react.useContext)(_context.I18nContext) || {},\n i18nFromContext = _ref2.i18n,\n defaultNSFromContext = _ref2.defaultNS;\n\n var i18n = i18nFromProps || i18nFromContext || (0, _context.getI18n)();\n\n var t = tFromProps || i18n.t.bind(i18n) || function (k) {\n return k;\n };\n\n return (0, _TransWithoutContext.Trans)(_objectSpread({\n children: children,\n count: count,\n parent: parent,\n i18nKey: i18nKey,\n context: context,\n tOptions: tOptions,\n values: values,\n defaults: defaults,\n components: components,\n ns: ns || t.ns || defaultNSFromContext || i18n.options && i18n.options.defaultNS,\n i18n: i18n,\n t: tFromProps,\n shouldUnescape: shouldUnescape\n }, additionalProps));\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.nodesToString = nodesToString;\nexports.Trans = Trans;\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = require(\"react\");\n\nvar _htmlParseStringify = _interopRequireDefault(require(\"html-parse-stringify\"));\n\nvar _utils = require(\"./utils.js\");\n\nvar _defaults = require(\"./defaults.js\");\n\nvar _i18nInstance = require(\"./i18nInstance.js\");\n\nvar _excluded = [\"format\"],\n _excluded2 = [\"children\", \"count\", \"parent\", \"i18nKey\", \"context\", \"tOptions\", \"values\", \"defaults\", \"components\", \"ns\", \"i18n\", \"t\", \"shouldUnescape\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction hasChildren(node, checkLength) {\n if (!node) return false;\n var base = node.props ? node.props.children : node.children;\n if (checkLength) return base.length > 0;\n return !!base;\n}\n\nfunction getChildren(node) {\n if (!node) return [];\n return node.props ? node.props.children : node.children;\n}\n\nfunction hasValidReactChildren(children) {\n if (Object.prototype.toString.call(children) !== '[object Array]') return false;\n return children.every(function (child) {\n return (0, _react.isValidElement)(child);\n });\n}\n\nfunction getAsArray(data) {\n return Array.isArray(data) ? data : [data];\n}\n\nfunction mergeProps(source, target) {\n var newTarget = _objectSpread({}, target);\n\n newTarget.props = Object.assign(source.props, target.props);\n return newTarget;\n}\n\nfunction nodesToString(children, i18nOptions) {\n if (!children) return '';\n var stringNode = '';\n var childrenArray = getAsArray(children);\n var keepArray = i18nOptions.transSupportBasicHtmlNodes && i18nOptions.transKeepBasicHtmlNodesFor ? i18nOptions.transKeepBasicHtmlNodesFor : [];\n childrenArray.forEach(function (child, childIndex) {\n if (typeof child === 'string') {\n stringNode += \"\".concat(child);\n } else if ((0, _react.isValidElement)(child)) {\n var childPropsCount = Object.keys(child.props).length;\n var shouldKeepChild = keepArray.indexOf(child.type) > -1;\n var childChildren = child.props.children;\n\n if (!childChildren && shouldKeepChild && childPropsCount === 0) {\n stringNode += \"<\".concat(child.type, \"/>\");\n } else if (!childChildren && (!shouldKeepChild || childPropsCount !== 0)) {\n stringNode += \"<\".concat(childIndex, \"></\").concat(childIndex, \">\");\n } else if (child.props.i18nIsDynamicList) {\n stringNode += \"<\".concat(childIndex, \"></\").concat(childIndex, \">\");\n } else if (shouldKeepChild && childPropsCount === 1 && typeof childChildren === 'string') {\n stringNode += \"<\".concat(child.type, \">\").concat(childChildren, \"</\").concat(child.type, \">\");\n } else {\n var content = nodesToString(childChildren, i18nOptions);\n stringNode += \"<\".concat(childIndex, \">\").concat(content, \"</\").concat(childIndex, \">\");\n }\n } else if (child === null) {\n (0, _utils.warn)(\"Trans: the passed in value is invalid - seems you passed in a null child.\");\n } else if ((0, _typeof2[\"default\"])(child) === 'object') {\n var format = child.format,\n clone = (0, _objectWithoutProperties2[\"default\"])(child, _excluded);\n var keys = Object.keys(clone);\n\n if (keys.length === 1) {\n var value = format ? \"\".concat(keys[0], \", \").concat(format) : keys[0];\n stringNode += \"{{\".concat(value, \"}}\");\n } else {\n (0, _utils.warn)(\"react-i18next: the passed in object contained more than one variable - the object should look like {{ value, format }} where format is optional.\", child);\n }\n } else {\n (0, _utils.warn)(\"Trans: the passed in value is invalid - seems you passed in a variable like {number} - please pass in variables for interpolation as full objects like {{number}}.\", child);\n }\n });\n return stringNode;\n}\n\nfunction renderNodes(children, targetString, i18n, i18nOptions, combinedTOpts, shouldUnescape) {\n if (targetString === '') return [];\n var keepArray = i18nOptions.transKeepBasicHtmlNodesFor || [];\n var emptyChildrenButNeedsHandling = targetString && new RegExp(keepArray.join('|')).test(targetString);\n if (!children && !emptyChildrenButNeedsHandling) return [targetString];\n var data = {};\n\n function getData(childs) {\n var childrenArray = getAsArray(childs);\n childrenArray.forEach(function (child) {\n if (typeof child === 'string') return;\n if (hasChildren(child)) getData(getChildren(child));else if ((0, _typeof2[\"default\"])(child) === 'object' && !(0, _react.isValidElement)(child)) Object.assign(data, child);\n });\n }\n\n getData(children);\n\n var ast = _htmlParseStringify[\"default\"].parse(\"<0>\".concat(targetString, \"</0>\"));\n\n var opts = _objectSpread(_objectSpread({}, data), combinedTOpts);\n\n function renderInner(child, node, rootReactNode) {\n var childs = getChildren(child);\n var mappedChildren = mapAST(childs, node.children, rootReactNode);\n return hasValidReactChildren(childs) && mappedChildren.length === 0 ? childs : mappedChildren;\n }\n\n function pushTranslatedJSX(child, inner, mem, i, isVoid) {\n if (child.dummy) child.children = inner;\n mem.push((0, _react.cloneElement)(child, _objectSpread(_objectSpread({}, child.props), {}, {\n key: i\n }), isVoid ? undefined : inner));\n }\n\n function mapAST(reactNode, astNode, rootReactNode) {\n var reactNodes = getAsArray(reactNode);\n var astNodes = getAsArray(astNode);\n return astNodes.reduce(function (mem, node, i) {\n var translationContent = node.children && node.children[0] && node.children[0].content && i18n.services.interpolator.interpolate(node.children[0].content, opts, i18n.language);\n\n if (node.type === 'tag') {\n var tmp = reactNodes[parseInt(node.name, 10)];\n if (!tmp && rootReactNode.length === 1 && rootReactNode[0][node.name]) tmp = rootReactNode[0][node.name];\n if (!tmp) tmp = {};\n var child = Object.keys(node.attrs).length !== 0 ? mergeProps({\n props: node.attrs\n }, tmp) : tmp;\n var isElement = (0, _react.isValidElement)(child);\n var isValidTranslationWithChildren = isElement && hasChildren(node, true) && !node.voidElement;\n var isEmptyTransWithHTML = emptyChildrenButNeedsHandling && (0, _typeof2[\"default\"])(child) === 'object' && child.dummy && !isElement;\n var isKnownComponent = (0, _typeof2[\"default\"])(children) === 'object' && children !== null && Object.hasOwnProperty.call(children, node.name);\n\n if (typeof child === 'string') {\n var value = i18n.services.interpolator.interpolate(child, opts, i18n.language);\n mem.push(value);\n } else if (hasChildren(child) || isValidTranslationWithChildren) {\n var inner = renderInner(child, node, rootReactNode);\n pushTranslatedJSX(child, inner, mem, i);\n } else if (isEmptyTransWithHTML) {\n var _inner = mapAST(reactNodes, node.children, rootReactNode);\n\n mem.push((0, _react.cloneElement)(child, _objectSpread(_objectSpread({}, child.props), {}, {\n key: i\n }), _inner));\n } else if (Number.isNaN(parseFloat(node.name))) {\n if (isKnownComponent) {\n var _inner2 = renderInner(child, node, rootReactNode);\n\n pushTranslatedJSX(child, _inner2, mem, i, node.voidElement);\n } else if (i18nOptions.transSupportBasicHtmlNodes && keepArray.indexOf(node.name) > -1) {\n if (node.voidElement) {\n mem.push((0, _react.createElement)(node.name, {\n key: \"\".concat(node.name, \"-\").concat(i)\n }));\n } else {\n var _inner3 = mapAST(reactNodes, node.children, rootReactNode);\n\n mem.push((0, _react.createElement)(node.name, {\n key: \"\".concat(node.name, \"-\").concat(i)\n }, _inner3));\n }\n } else if (node.voidElement) {\n mem.push(\"<\".concat(node.name, \" />\"));\n } else {\n var _inner4 = mapAST(reactNodes, node.children, rootReactNode);\n\n mem.push(\"<\".concat(node.name, \">\").concat(_inner4, \"</\").concat(node.name, \">\"));\n }\n } else if ((0, _typeof2[\"default\"])(child) === 'object' && !isElement) {\n var content = node.children[0] ? translationContent : null;\n if (content) mem.push(content);\n } else if (node.children.length === 1 && translationContent) {\n mem.push((0, _react.cloneElement)(child, _objectSpread(_objectSpread({}, child.props), {}, {\n key: i\n }), translationContent));\n } else {\n mem.push((0, _react.cloneElement)(child, _objectSpread(_objectSpread({}, child.props), {}, {\n key: i\n })));\n }\n } else if (node.type === 'text') {\n var wrapTextNodes = i18nOptions.transWrapTextNodes;\n\n var _content = shouldUnescape ? i18nOptions.unescape(i18n.services.interpolator.interpolate(node.content, opts, i18n.language)) : i18n.services.interpolator.interpolate(node.content, opts, i18n.language);\n\n if (wrapTextNodes) {\n mem.push((0, _react.createElement)(wrapTextNodes, {\n key: \"\".concat(node.name, \"-\").concat(i)\n }, _content));\n } else {\n mem.push(_content);\n }\n }\n\n return mem;\n }, []);\n }\n\n var result = mapAST([{\n dummy: true,\n children: children || []\n }], ast, getAsArray(children || []));\n return getChildren(result[0]);\n}\n\nfunction Trans(_ref) {\n var children = _ref.children,\n count = _ref.count,\n parent = _ref.parent,\n i18nKey = _ref.i18nKey,\n context = _ref.context,\n _ref$tOptions = _ref.tOptions,\n tOptions = _ref$tOptions === void 0 ? {} : _ref$tOptions,\n values = _ref.values,\n defaults = _ref.defaults,\n components = _ref.components,\n ns = _ref.ns,\n i18nFromProps = _ref.i18n,\n tFromProps = _ref.t,\n shouldUnescape = _ref.shouldUnescape,\n additionalProps = (0, _objectWithoutProperties2[\"default\"])(_ref, _excluded2);\n var i18n = i18nFromProps || (0, _i18nInstance.getI18n)();\n\n if (!i18n) {\n (0, _utils.warnOnce)('You will need to pass in an i18next instance by using i18nextReactModule');\n return children;\n }\n\n var t = tFromProps || i18n.t.bind(i18n) || function (k) {\n return k;\n };\n\n if (context) tOptions.context = context;\n\n var reactI18nextOptions = _objectSpread(_objectSpread({}, (0, _defaults.getDefaults)()), i18n.options && i18n.options.react);\n\n var namespaces = ns || t.ns || i18n.options && i18n.options.defaultNS;\n namespaces = typeof namespaces === 'string' ? [namespaces] : namespaces || ['translation'];\n var defaultValue = defaults || nodesToString(children, reactI18nextOptions) || reactI18nextOptions.transEmptyNodeValue || i18nKey;\n var hashTransKey = reactI18nextOptions.hashTransKey;\n var key = i18nKey || (hashTransKey ? hashTransKey(defaultValue) : defaultValue);\n var interpolationOverride = values ? tOptions.interpolation : {\n interpolation: _objectSpread(_objectSpread({}, tOptions.interpolation), {}, {\n prefix: '#$?',\n suffix: '?$#'\n })\n };\n\n var combinedTOpts = _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, tOptions), {}, {\n count: count\n }, values), interpolationOverride), {}, {\n defaultValue: defaultValue,\n ns: namespaces\n });\n\n var translation = key ? t(key, combinedTOpts) : defaultValue;\n var content = renderNodes(components || children, translation, i18n, reactI18nextOptions, combinedTOpts, shouldUnescape);\n var useAsParent = parent !== undefined ? parent : reactI18nextOptions.defaultTransParent;\n return useAsParent ? (0, _react.createElement)(useAsParent, additionalProps, content) : content;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.Translation = Translation;\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _useTranslation3 = require(\"./useTranslation.js\");\n\nvar _excluded = [\"ns\", \"children\"];\n\nfunction Translation(props) {\n var ns = props.ns,\n children = props.children,\n options = (0, _objectWithoutProperties2[\"default\"])(props, _excluded);\n\n var _useTranslation = (0, _useTranslation3.useTranslation)(ns, options),\n _useTranslation2 = (0, _slicedToArray2[\"default\"])(_useTranslation, 3),\n t = _useTranslation2[0],\n i18n = _useTranslation2[1],\n ready = _useTranslation2[2];\n\n return children(t, {\n i18n: i18n,\n lng: i18n.language\n }, ready);\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.composeInitialProps = composeInitialProps;\nexports.getInitialProps = getInitialProps;\nObject.defineProperty(exports, \"getDefaults\", {\n enumerable: true,\n get: function get() {\n return _defaults.getDefaults;\n }\n});\nObject.defineProperty(exports, \"setDefaults\", {\n enumerable: true,\n get: function get() {\n return _defaults.setDefaults;\n }\n});\nObject.defineProperty(exports, \"getI18n\", {\n enumerable: true,\n get: function get() {\n return _i18nInstance.getI18n;\n }\n});\nObject.defineProperty(exports, \"setI18n\", {\n enumerable: true,\n get: function get() {\n return _i18nInstance.setI18n;\n }\n});\nObject.defineProperty(exports, \"initReactI18next\", {\n enumerable: true,\n get: function get() {\n return _initReactI18next.initReactI18next;\n }\n});\nexports.ReportNamespaces = exports.I18nContext = void 0;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _classCallCheck2 = _interopRequireDefault(require(\"@babel/runtime/helpers/classCallCheck\"));\n\nvar _createClass2 = _interopRequireDefault(require(\"@babel/runtime/helpers/createClass\"));\n\nvar _react = require(\"react\");\n\nvar _defaults = require(\"./defaults.js\");\n\nvar _i18nInstance = require(\"./i18nInstance.js\");\n\nvar _initReactI18next = require(\"./initReactI18next.js\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar I18nContext = (0, _react.createContext)();\nexports.I18nContext = I18nContext;\n\nvar ReportNamespaces = function () {\n function ReportNamespaces() {\n (0, _classCallCheck2[\"default\"])(this, ReportNamespaces);\n this.usedNamespaces = {};\n }\n\n (0, _createClass2[\"default\"])(ReportNamespaces, [{\n key: \"addUsedNamespaces\",\n value: function addUsedNamespaces(namespaces) {\n var _this = this;\n\n namespaces.forEach(function (ns) {\n if (!_this.usedNamespaces[ns]) _this.usedNamespaces[ns] = true;\n });\n }\n }, {\n key: \"getUsedNamespaces\",\n value: function getUsedNamespaces() {\n return Object.keys(this.usedNamespaces);\n }\n }]);\n return ReportNamespaces;\n}();\n\nexports.ReportNamespaces = ReportNamespaces;\n\nfunction composeInitialProps(ForComponent) {\n return function (ctx) {\n return new Promise(function (resolve) {\n var i18nInitialProps = getInitialProps();\n\n if (ForComponent.getInitialProps) {\n ForComponent.getInitialProps(ctx).then(function (componentsInitialProps) {\n resolve(_objectSpread(_objectSpread({}, componentsInitialProps), i18nInitialProps));\n });\n } else {\n resolve(i18nInitialProps);\n }\n });\n };\n}\n\nfunction getInitialProps() {\n var i18n = (0, _i18nInstance.getI18n)();\n var namespaces = i18n.reportNamespaces ? i18n.reportNamespaces.getUsedNamespaces() : [];\n var ret = {};\n var initialI18nStore = {};\n i18n.languages.forEach(function (l) {\n initialI18nStore[l] = {};\n namespaces.forEach(function (ns) {\n initialI18nStore[l][ns] = i18n.getResourceBundle(l, ns) || {};\n });\n });\n ret.initialI18nStore = initialI18nStore;\n ret.initialLanguage = i18n.language;\n return ret;\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setDefaults = setDefaults;\nexports.getDefaults = getDefaults;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _unescape = require(\"./unescape.js\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar defaultOptions = {\n bindI18n: 'languageChanged',\n bindI18nStore: '',\n transEmptyNodeValue: '',\n transSupportBasicHtmlNodes: true,\n transWrapTextNodes: '',\n transKeepBasicHtmlNodesFor: ['br', 'strong', 'i', 'p'],\n useSuspense: true,\n unescape: _unescape.unescape\n};\n\nfunction setDefaults() {\n var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n defaultOptions = _objectSpread(_objectSpread({}, defaultOptions), options);\n}\n\nfunction getDefaults() {\n return defaultOptions;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.setI18n = setI18n;\nexports.getI18n = getI18n;\nvar i18nInstance;\n\nfunction setI18n(instance) {\n i18nInstance = instance;\n}\n\nfunction getI18n() {\n return i18nInstance;\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nObject.defineProperty(exports, \"Trans\", {\n enumerable: true,\n get: function get() {\n return _Trans.Trans;\n }\n});\nObject.defineProperty(exports, \"TransWithoutContext\", {\n enumerable: true,\n get: function get() {\n return _TransWithoutContext.Trans;\n }\n});\nObject.defineProperty(exports, \"useTranslation\", {\n enumerable: true,\n get: function get() {\n return _useTranslation.useTranslation;\n }\n});\nObject.defineProperty(exports, \"withTranslation\", {\n enumerable: true,\n get: function get() {\n return _withTranslation.withTranslation;\n }\n});\nObject.defineProperty(exports, \"Translation\", {\n enumerable: true,\n get: function get() {\n return _Translation.Translation;\n }\n});\nObject.defineProperty(exports, \"I18nextProvider\", {\n enumerable: true,\n get: function get() {\n return _I18nextProvider.I18nextProvider;\n }\n});\nObject.defineProperty(exports, \"withSSR\", {\n enumerable: true,\n get: function get() {\n return _withSSR.withSSR;\n }\n});\nObject.defineProperty(exports, \"useSSR\", {\n enumerable: true,\n get: function get() {\n return _useSSR.useSSR;\n }\n});\nObject.defineProperty(exports, \"I18nContext\", {\n enumerable: true,\n get: function get() {\n return _context.I18nContext;\n }\n});\nObject.defineProperty(exports, \"initReactI18next\", {\n enumerable: true,\n get: function get() {\n return _context.initReactI18next;\n }\n});\nObject.defineProperty(exports, \"setDefaults\", {\n enumerable: true,\n get: function get() {\n return _context.setDefaults;\n }\n});\nObject.defineProperty(exports, \"getDefaults\", {\n enumerable: true,\n get: function get() {\n return _context.getDefaults;\n }\n});\nObject.defineProperty(exports, \"setI18n\", {\n enumerable: true,\n get: function get() {\n return _context.setI18n;\n }\n});\nObject.defineProperty(exports, \"getI18n\", {\n enumerable: true,\n get: function get() {\n return _context.getI18n;\n }\n});\nObject.defineProperty(exports, \"composeInitialProps\", {\n enumerable: true,\n get: function get() {\n return _context.composeInitialProps;\n }\n});\nObject.defineProperty(exports, \"getInitialProps\", {\n enumerable: true,\n get: function get() {\n return _context.getInitialProps;\n }\n});\nexports.selectOrdinal = exports.plural = exports.select = exports.number = exports.time = exports.date = void 0;\n\nvar _Trans = require(\"./Trans.js\");\n\nvar _TransWithoutContext = require(\"./TransWithoutContext.js\");\n\nvar _useTranslation = require(\"./useTranslation.js\");\n\nvar _withTranslation = require(\"./withTranslation.js\");\n\nvar _Translation = require(\"./Translation.js\");\n\nvar _I18nextProvider = require(\"./I18nextProvider.js\");\n\nvar _withSSR = require(\"./withSSR.js\");\n\nvar _useSSR = require(\"./useSSR.js\");\n\nvar _context = require(\"./context.js\");\n\nvar date = function date() {\n return '';\n};\n\nexports.date = date;\n\nvar time = function time() {\n return '';\n};\n\nexports.time = time;\n\nvar number = function number() {\n return '';\n};\n\nexports.number = number;\n\nvar select = function select() {\n return '';\n};\n\nexports.select = select;\n\nvar plural = function plural() {\n return '';\n};\n\nexports.plural = plural;\n\nvar selectOrdinal = function selectOrdinal() {\n return '';\n};\n\nexports.selectOrdinal = selectOrdinal;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.initReactI18next = void 0;\n\nvar _defaults = require(\"./defaults.js\");\n\nvar _i18nInstance = require(\"./i18nInstance.js\");\n\nvar initReactI18next = {\n type: '3rdParty',\n init: function init(instance) {\n (0, _defaults.setDefaults)(instance.options.react);\n (0, _i18nInstance.setI18n)(instance);\n }\n};\nexports.initReactI18next = initReactI18next;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.unescape = void 0;\nvar matchHtmlEntity = /&(?:amp|#38|lt|#60|gt|#62|apos|#39|quot|#34|nbsp|#160|copy|#169|reg|#174|hellip|#8230|#x2F|#47);/g;\nvar htmlEntities = {\n '&': '&',\n '&': '&',\n '<': '<',\n '<': '<',\n '>': '>',\n '>': '>',\n ''': \"'\",\n ''': \"'\",\n '"': '\"',\n '"': '\"',\n ' ': ' ',\n ' ': ' ',\n '©': '©',\n '©': '©',\n '®': '®',\n '®': '®',\n '…': '…',\n '…': '…',\n '/': '/',\n '/': '/'\n};\n\nvar unescapeHtmlEntity = function unescapeHtmlEntity(m) {\n return htmlEntities[m];\n};\n\nvar unescape = function unescape(text) {\n return text.replace(matchHtmlEntity, unescapeHtmlEntity);\n};\n\nexports.unescape = unescape;","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useSSR = useSSR;\n\nvar _react = require(\"react\");\n\nvar _context = require(\"./context.js\");\n\nfunction useSSR(initialI18nStore, initialLanguage) {\n var props = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var i18nFromProps = props.i18n;\n\n var _ref = (0, _react.useContext)(_context.I18nContext) || {},\n i18nFromContext = _ref.i18n;\n\n var i18n = i18nFromProps || i18nFromContext || (0, _context.getI18n)();\n if (i18n.options && i18n.options.isClone) return;\n\n if (initialI18nStore && !i18n.initializedStoreOnce) {\n i18n.services.resourceStore.data = initialI18nStore;\n i18n.options.ns = Object.values(initialI18nStore).reduce(function (mem, lngResources) {\n Object.keys(lngResources).forEach(function (ns) {\n if (mem.indexOf(ns) < 0) mem.push(ns);\n });\n return mem;\n }, i18n.options.ns);\n i18n.initializedStoreOnce = true;\n i18n.isInitialized = true;\n }\n\n if (initialLanguage && !i18n.initializedLanguageOnce) {\n i18n.changeLanguage(initialLanguage);\n i18n.initializedLanguageOnce = true;\n }\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.useTranslation = useTranslation;\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _react = require(\"react\");\n\nvar _context = require(\"./context.js\");\n\nvar _utils = require(\"./utils.js\");\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nvar usePrevious = function usePrevious(value, ignore) {\n var ref = (0, _react.useRef)();\n (0, _react.useEffect)(function () {\n ref.current = ignore ? ref.current : value;\n }, [value, ignore]);\n return ref.current;\n};\n\nfunction useTranslation(ns) {\n var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var i18nFromProps = props.i18n;\n\n var _ref = (0, _react.useContext)(_context.I18nContext) || {},\n i18nFromContext = _ref.i18n,\n defaultNSFromContext = _ref.defaultNS;\n\n var i18n = i18nFromProps || i18nFromContext || (0, _context.getI18n)();\n if (i18n && !i18n.reportNamespaces) i18n.reportNamespaces = new _context.ReportNamespaces();\n\n if (!i18n) {\n (0, _utils.warnOnce)('You will need to pass in an i18next instance by using initReactI18next');\n\n var notReadyT = function notReadyT(k) {\n return Array.isArray(k) ? k[k.length - 1] : k;\n };\n\n var retNotReady = [notReadyT, {}, false];\n retNotReady.t = notReadyT;\n retNotReady.i18n = {};\n retNotReady.ready = false;\n return retNotReady;\n }\n\n if (i18n.options.react && i18n.options.react.wait !== undefined) (0, _utils.warnOnce)('It seems you are still using the old wait option, you may migrate to the new useSuspense behaviour.');\n\n var i18nOptions = _objectSpread(_objectSpread(_objectSpread({}, (0, _context.getDefaults)()), i18n.options.react), props);\n\n var useSuspense = i18nOptions.useSuspense,\n keyPrefix = i18nOptions.keyPrefix;\n var namespaces = ns || defaultNSFromContext || i18n.options && i18n.options.defaultNS;\n namespaces = typeof namespaces === 'string' ? [namespaces] : namespaces || ['translation'];\n if (i18n.reportNamespaces.addUsedNamespaces) i18n.reportNamespaces.addUsedNamespaces(namespaces);\n var ready = (i18n.isInitialized || i18n.initializedStoreOnce) && namespaces.every(function (n) {\n return (0, _utils.hasLoadedNamespace)(n, i18n, i18nOptions);\n });\n\n function getT() {\n return i18n.getFixedT(null, i18nOptions.nsMode === 'fallback' ? namespaces : namespaces[0], keyPrefix);\n }\n\n var _useState = (0, _react.useState)(getT),\n _useState2 = (0, _slicedToArray2[\"default\"])(_useState, 2),\n t = _useState2[0],\n setT = _useState2[1];\n\n var joinedNS = namespaces.join();\n var previousJoinedNS = usePrevious(joinedNS);\n var isMounted = (0, _react.useRef)(true);\n (0, _react.useEffect)(function () {\n var bindI18n = i18nOptions.bindI18n,\n bindI18nStore = i18nOptions.bindI18nStore;\n isMounted.current = true;\n\n if (!ready && !useSuspense) {\n (0, _utils.loadNamespaces)(i18n, namespaces, function () {\n if (isMounted.current) setT(getT);\n });\n }\n\n if (ready && previousJoinedNS && previousJoinedNS !== joinedNS && isMounted.current) {\n setT(getT);\n }\n\n function boundReset() {\n if (isMounted.current) setT(getT);\n }\n\n if (bindI18n && i18n) i18n.on(bindI18n, boundReset);\n if (bindI18nStore && i18n) i18n.store.on(bindI18nStore, boundReset);\n return function () {\n isMounted.current = false;\n if (bindI18n && i18n) bindI18n.split(' ').forEach(function (e) {\n return i18n.off(e, boundReset);\n });\n if (bindI18nStore && i18n) bindI18nStore.split(' ').forEach(function (e) {\n return i18n.store.off(e, boundReset);\n });\n };\n }, [i18n, joinedNS]);\n var isInitial = (0, _react.useRef)(true);\n (0, _react.useEffect)(function () {\n if (isMounted.current && !isInitial.current) {\n setT(getT);\n }\n\n isInitial.current = false;\n }, [i18n, keyPrefix]);\n var ret = [t, i18n, ready];\n ret.t = t;\n ret.i18n = i18n;\n ret.ready = ready;\n if (ready) return ret;\n if (!ready && !useSuspense) return ret;\n throw new Promise(function (resolve) {\n (0, _utils.loadNamespaces)(i18n, namespaces, function () {\n resolve();\n });\n });\n}","\"use strict\";\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.warn = warn;\nexports.warnOnce = warnOnce;\nexports.loadNamespaces = loadNamespaces;\nexports.hasLoadedNamespace = hasLoadedNamespace;\nexports.getDisplayName = getDisplayName;\n\nfunction warn() {\n if (console && console.warn) {\n var _console;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n if (typeof args[0] === 'string') args[0] = \"react-i18next:: \".concat(args[0]);\n\n (_console = console).warn.apply(_console, args);\n }\n}\n\nvar alreadyWarned = {};\n\nfunction warnOnce() {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n if (typeof args[0] === 'string' && alreadyWarned[args[0]]) return;\n if (typeof args[0] === 'string') alreadyWarned[args[0]] = new Date();\n warn.apply(void 0, args);\n}\n\nfunction loadNamespaces(i18n, ns, cb) {\n i18n.loadNamespaces(ns, function () {\n if (i18n.isInitialized) {\n cb();\n } else {\n var initialized = function initialized() {\n setTimeout(function () {\n i18n.off('initialized', initialized);\n }, 0);\n cb();\n };\n\n i18n.on('initialized', initialized);\n }\n });\n}\n\nfunction oldI18nextHasLoadedNamespace(ns, i18n) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var lng = i18n.languages[0];\n var fallbackLng = i18n.options ? i18n.options.fallbackLng : false;\n var lastLng = i18n.languages[i18n.languages.length - 1];\n if (lng.toLowerCase() === 'cimode') return true;\n\n var loadNotPending = function loadNotPending(l, n) {\n var loadState = i18n.services.backendConnector.state[\"\".concat(l, \"|\").concat(n)];\n return loadState === -1 || loadState === 2;\n };\n\n if (options.bindI18n && options.bindI18n.indexOf('languageChanging') > -1 && i18n.services.backendConnector.backend && i18n.isLanguageChangingTo && !loadNotPending(i18n.isLanguageChangingTo, ns)) return false;\n if (i18n.hasResourceBundle(lng, ns)) return true;\n if (!i18n.services.backendConnector.backend || i18n.options.resources && !i18n.options.partialBundledLanguages) return true;\n if (loadNotPending(lng, ns) && (!fallbackLng || loadNotPending(lastLng, ns))) return true;\n return false;\n}\n\nfunction hasLoadedNamespace(ns, i18n) {\n var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n\n if (!i18n.languages || !i18n.languages.length) {\n warnOnce('i18n.languages were undefined or empty', i18n.languages);\n return true;\n }\n\n var isNewerI18next = i18n.options.ignoreJSONStructure !== undefined;\n\n if (!isNewerI18next) {\n return oldI18nextHasLoadedNamespace(ns, i18n, options);\n }\n\n return i18n.hasLoadedNamespace(ns, {\n precheck: function precheck(i18nInstance, loadNotPending) {\n if (options.bindI18n && options.bindI18n.indexOf('languageChanging') > -1 && i18nInstance.services.backendConnector.backend && i18nInstance.isLanguageChangingTo && !loadNotPending(i18nInstance.isLanguageChangingTo, ns)) return false;\n }\n });\n}\n\nfunction getDisplayName(Component) {\n return Component.displayName || Component.name || (typeof Component === 'string' && Component.length > 0 ? Component : 'Unknown');\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withSSR = withSSR;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _react = require(\"react\");\n\nvar _useSSR = require(\"./useSSR.js\");\n\nvar _context = require(\"./context.js\");\n\nvar _utils = require(\"./utils.js\");\n\nvar _excluded = [\"initialI18nStore\", \"initialLanguage\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction withSSR() {\n return function Extend(WrappedComponent) {\n function I18nextWithSSR(_ref) {\n var initialI18nStore = _ref.initialI18nStore,\n initialLanguage = _ref.initialLanguage,\n rest = (0, _objectWithoutProperties2[\"default\"])(_ref, _excluded);\n (0, _useSSR.useSSR)(initialI18nStore, initialLanguage);\n return (0, _react.createElement)(WrappedComponent, _objectSpread({}, rest));\n }\n\n I18nextWithSSR.getInitialProps = (0, _context.composeInitialProps)(WrappedComponent);\n I18nextWithSSR.displayName = \"withI18nextSSR(\".concat((0, _utils.getDisplayName)(WrappedComponent), \")\");\n I18nextWithSSR.WrappedComponent = WrappedComponent;\n return I18nextWithSSR;\n };\n}","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.withTranslation = withTranslation;\n\nvar _defineProperty2 = _interopRequireDefault(require(\"@babel/runtime/helpers/defineProperty\"));\n\nvar _slicedToArray2 = _interopRequireDefault(require(\"@babel/runtime/helpers/slicedToArray\"));\n\nvar _objectWithoutProperties2 = _interopRequireDefault(require(\"@babel/runtime/helpers/objectWithoutProperties\"));\n\nvar _react = require(\"react\");\n\nvar _useTranslation3 = require(\"./useTranslation.js\");\n\nvar _utils = require(\"./utils.js\");\n\nvar _excluded = [\"forwardedRef\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2[\"default\"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction withTranslation(ns) {\n var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n return function Extend(WrappedComponent) {\n function I18nextWithTranslation(_ref) {\n var forwardedRef = _ref.forwardedRef,\n rest = (0, _objectWithoutProperties2[\"default\"])(_ref, _excluded);\n\n var _useTranslation = (0, _useTranslation3.useTranslation)(ns, _objectSpread(_objectSpread({}, rest), {}, {\n keyPrefix: options.keyPrefix\n })),\n _useTranslation2 = (0, _slicedToArray2[\"default\"])(_useTranslation, 3),\n t = _useTranslation2[0],\n i18n = _useTranslation2[1],\n ready = _useTranslation2[2];\n\n var passDownProps = _objectSpread(_objectSpread({}, rest), {}, {\n t: t,\n i18n: i18n,\n tReady: ready\n });\n\n if (options.withRef && forwardedRef) {\n passDownProps.ref = forwardedRef;\n } else if (!options.withRef && forwardedRef) {\n passDownProps.forwardedRef = forwardedRef;\n }\n\n return (0, _react.createElement)(WrappedComponent, passDownProps);\n }\n\n I18nextWithTranslation.displayName = \"withI18nextTranslation(\".concat((0, _utils.getDisplayName)(WrappedComponent), \")\");\n I18nextWithTranslation.WrappedComponent = WrappedComponent;\n\n var forwardRef = function forwardRef(props, ref) {\n return (0, _react.createElement)(I18nextWithTranslation, Object.assign({}, props, {\n forwardedRef: ref\n }));\n };\n\n return options.withRef ? (0, _react.forwardRef)(forwardRef) : I18nextWithTranslation;\n };\n}","/**\n * @license React\n * react-is.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var b=Symbol.for(\"react.element\"),c=Symbol.for(\"react.portal\"),d=Symbol.for(\"react.fragment\"),e=Symbol.for(\"react.strict_mode\"),f=Symbol.for(\"react.profiler\"),g=Symbol.for(\"react.provider\"),h=Symbol.for(\"react.context\"),k=Symbol.for(\"react.server_context\"),l=Symbol.for(\"react.forward_ref\"),m=Symbol.for(\"react.suspense\"),n=Symbol.for(\"react.suspense_list\"),p=Symbol.for(\"react.memo\"),q=Symbol.for(\"react.lazy\"),t=Symbol.for(\"react.offscreen\"),u;u=Symbol.for(\"react.module.reference\");\nfunction v(a){if(\"object\"===typeof a&&null!==a){var r=a.$$typeof;switch(r){case b:switch(a=a.type,a){case d:case f:case e:case m:case n:return a;default:switch(a=a&&a.$$typeof,a){case k:case h:case l:case q:case p:case g:return a;default:return r}}case c:return r}}}exports.ContextConsumer=h;exports.ContextProvider=g;exports.Element=b;exports.ForwardRef=l;exports.Fragment=d;exports.Lazy=q;exports.Memo=p;exports.Portal=c;exports.Profiler=f;exports.StrictMode=e;exports.Suspense=m;\nexports.SuspenseList=n;exports.isAsyncMode=function(){return!1};exports.isConcurrentMode=function(){return!1};exports.isContextConsumer=function(a){return v(a)===h};exports.isContextProvider=function(a){return v(a)===g};exports.isElement=function(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===b};exports.isForwardRef=function(a){return v(a)===l};exports.isFragment=function(a){return v(a)===d};exports.isLazy=function(a){return v(a)===q};exports.isMemo=function(a){return v(a)===p};\nexports.isPortal=function(a){return v(a)===c};exports.isProfiler=function(a){return v(a)===f};exports.isStrictMode=function(a){return v(a)===e};exports.isSuspense=function(a){return v(a)===m};exports.isSuspenseList=function(a){return v(a)===n};\nexports.isValidElementType=function(a){return\"string\"===typeof a||\"function\"===typeof a||a===d||a===f||a===e||a===m||a===n||a===t||\"object\"===typeof a&&null!==a&&(a.$$typeof===q||a.$$typeof===p||a.$$typeof===g||a.$$typeof===h||a.$$typeof===l||a.$$typeof===u||void 0!==a.getModuleId)?!0:!1};exports.typeOf=v;\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react-is.production.min.js');\n} else {\n module.exports = require('./cjs/react-is.development.js');\n}\n","/**\n * @license React\n * react.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1<g){for(var f=Array(g),m=0;m<g;m++)f[m]=arguments[m+2];c.children=f}if(a&&a.defaultProps)for(d in g=a.defaultProps,g)void 0===c[d]&&(c[d]=g[d]);return{$$typeof:l,type:a,key:k,ref:h,props:c,_owner:K.current}}\nfunction N(a,b){return{$$typeof:l,type:a.type,key:b,ref:a.ref,props:a.props,_owner:a._owner}}function O(a){return\"object\"===typeof a&&null!==a&&a.$$typeof===l}function escape(a){var b={\"=\":\"=0\",\":\":\"=2\"};return\"$\"+a.replace(/[=:]/g,function(a){return b[a]})}var P=/\\/+/g;function Q(a,b){return\"object\"===typeof a&&null!==a&&null!=a.key?escape(\"\"+a.key):b.toString(36)}\nfunction R(a,b,e,d,c){var k=typeof a;if(\"undefined\"===k||\"boolean\"===k)a=null;var h=!1;if(null===a)h=!0;else switch(k){case \"string\":case \"number\":h=!0;break;case \"object\":switch(a.$$typeof){case l:case n:h=!0}}if(h)return h=a,c=c(h),a=\"\"===d?\".\"+Q(h,0):d,I(c)?(e=\"\",null!=a&&(e=a.replace(P,\"$&/\")+\"/\"),R(c,b,e,\"\",function(a){return a})):null!=c&&(O(c)&&(c=N(c,e+(!c.key||h&&h.key===c.key?\"\":(\"\"+c.key).replace(P,\"$&/\")+\"/\")+a)),b.push(c)),1;h=0;d=\"\"===d?\".\":d+\":\";if(I(a))for(var g=0;g<a.length;g++){k=\na[g];var f=d+Q(k,g);h+=R(k,b,e,f,c)}else if(f=A(a),\"function\"===typeof f)for(a=f.call(a),g=0;!(k=a.next()).done;)k=k.value,f=d+Q(k,g++),h+=R(k,b,e,f,c);else if(\"object\"===k)throw b=String(a),Error(\"Objects are not valid as a React child (found: \"+(\"[object Object]\"===b?\"object with keys {\"+Object.keys(a).join(\", \")+\"}\":b)+\"). If you meant to render a collection of children, use an array instead.\");return h}\nfunction S(a,b,e){if(null==a)return a;var d=[],c=0;R(a,d,\"\",\"\",function(a){return b.call(e,a,c++)});return d}function T(a){if(-1===a._status){var b=a._result;b=b();b.then(function(b){if(0===a._status||-1===a._status)a._status=1,a._result=b},function(b){if(0===a._status||-1===a._status)a._status=2,a._result=b});-1===a._status&&(a._status=0,a._result=b)}if(1===a._status)return a._result.default;throw a._result;}\nvar U={current:null},V={transition:null},W={ReactCurrentDispatcher:U,ReactCurrentBatchConfig:V,ReactCurrentOwner:K};exports.Children={map:S,forEach:function(a,b,e){S(a,function(){b.apply(this,arguments)},e)},count:function(a){var b=0;S(a,function(){b++});return b},toArray:function(a){return S(a,function(a){return a})||[]},only:function(a){if(!O(a))throw Error(\"React.Children.only expected to receive a single React element child.\");return a}};exports.Component=E;exports.Fragment=p;\nexports.Profiler=r;exports.PureComponent=G;exports.StrictMode=q;exports.Suspense=w;exports.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED=W;\nexports.cloneElement=function(a,b,e){if(null===a||void 0===a)throw Error(\"React.cloneElement(...): The argument must be a React element, but you passed \"+a+\".\");var d=C({},a.props),c=a.key,k=a.ref,h=a._owner;if(null!=b){void 0!==b.ref&&(k=b.ref,h=K.current);void 0!==b.key&&(c=\"\"+b.key);if(a.type&&a.type.defaultProps)var g=a.type.defaultProps;for(f in b)J.call(b,f)&&!L.hasOwnProperty(f)&&(d[f]=void 0===b[f]&&void 0!==g?g[f]:b[f])}var f=arguments.length-2;if(1===f)d.children=e;else if(1<f){g=Array(f);\nfor(var m=0;m<f;m++)g[m]=arguments[m+2];d.children=g}return{$$typeof:l,type:a.type,key:c,ref:k,props:d,_owner:h}};exports.createContext=function(a){a={$$typeof:u,_currentValue:a,_currentValue2:a,_threadCount:0,Provider:null,Consumer:null,_defaultValue:null,_globalName:null};a.Provider={$$typeof:t,_context:a};return a.Consumer=a};exports.createElement=M;exports.createFactory=function(a){var b=M.bind(null,a);b.type=a;return b};exports.createRef=function(){return{current:null}};\nexports.forwardRef=function(a){return{$$typeof:v,render:a}};exports.isValidElement=O;exports.lazy=function(a){return{$$typeof:y,_payload:{_status:-1,_result:a},_init:T}};exports.memo=function(a,b){return{$$typeof:x,type:a,compare:void 0===b?null:b}};exports.startTransition=function(a){var b=V.transition;V.transition={};try{a()}finally{V.transition=b}};exports.unstable_act=function(){throw Error(\"act(...) is not supported in production builds of React.\");};\nexports.useCallback=function(a,b){return U.current.useCallback(a,b)};exports.useContext=function(a){return U.current.useContext(a)};exports.useDebugValue=function(){};exports.useDeferredValue=function(a){return U.current.useDeferredValue(a)};exports.useEffect=function(a,b){return U.current.useEffect(a,b)};exports.useId=function(){return U.current.useId()};exports.useImperativeHandle=function(a,b,e){return U.current.useImperativeHandle(a,b,e)};\nexports.useInsertionEffect=function(a,b){return U.current.useInsertionEffect(a,b)};exports.useLayoutEffect=function(a,b){return U.current.useLayoutEffect(a,b)};exports.useMemo=function(a,b){return U.current.useMemo(a,b)};exports.useReducer=function(a,b,e){return U.current.useReducer(a,b,e)};exports.useRef=function(a){return U.current.useRef(a)};exports.useState=function(a){return U.current.useState(a)};exports.useSyncExternalStore=function(a,b,e){return U.current.useSyncExternalStore(a,b,e)};\nexports.useTransition=function(){return U.current.useTransition()};exports.version=\"18.2.0\";\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/react.production.min.js');\n} else {\n module.exports = require('./cjs/react.development.js');\n}\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; };\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n defineProperty(generator, \"_invoke\", { value: makeInvokeMethod(innerFn, self, context) });\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n defineProperty(Gp, \"constructor\", { value: GeneratorFunctionPrototype, configurable: true });\n defineProperty(\n GeneratorFunctionPrototype,\n \"constructor\",\n { value: GeneratorFunction, configurable: true }\n );\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n defineProperty(this, \"_invoke\", { value: enqueue });\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var methodName = context.method;\n var method = delegate.iterator[methodName];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method, or a missing .next mehtod, always terminate the\n // yield* loop.\n context.delegate = null;\n\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (methodName === \"throw\" && delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n if (methodName !== \"return\") {\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a '\" + methodName + \"' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(val) {\n var object = Object(val);\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n","/**\n * @license React\n * scheduler.production.min.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n'use strict';function f(a,b){var c=a.length;a.push(b);a:for(;0<c;){var d=c-1>>>1,e=a[d];if(0<g(e,b))a[d]=b,a[c]=e,c=d;else break a}}function h(a){return 0===a.length?null:a[0]}function k(a){if(0===a.length)return null;var b=a[0],c=a.pop();if(c!==b){a[0]=c;a:for(var d=0,e=a.length,w=e>>>1;d<w;){var m=2*(d+1)-1,C=a[m],n=m+1,x=a[n];if(0>g(C,c))n<e&&0>g(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(n<e&&0>g(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Q<P?!1:!0}function R(){if(null!==O){var a=exports.unstable_now();Q=a;var b=!0;try{b=O(!0,a)}finally{b?S():(N=!1,O=null)}}else N=!1}var S;if(\"function\"===typeof F)S=function(){F(R)};else if(\"undefined\"!==typeof MessageChannel){var T=new MessageChannel,U=T.port2;T.port1.onmessage=R;S=function(){U.postMessage(null)}}else S=function(){D(R,0)};function I(a){O=a;N||(N=!0,S())}function K(a,b){L=D(function(){a(exports.unstable_now())},b)}\nexports.unstable_IdlePriority=5;exports.unstable_ImmediatePriority=1;exports.unstable_LowPriority=4;exports.unstable_NormalPriority=3;exports.unstable_Profiling=null;exports.unstable_UserBlockingPriority=2;exports.unstable_cancelCallback=function(a){a.callback=null};exports.unstable_continueExecution=function(){A||z||(A=!0,I(J))};\nexports.unstable_forceFrameRate=function(a){0>a||125<a?console.error(\"forceFrameRate takes a positive int between 0 and 125, forcing frame rates higher than 125 fps is not supported\"):P=0<a?Math.floor(1E3/a):5};exports.unstable_getCurrentPriorityLevel=function(){return y};exports.unstable_getFirstCallbackNode=function(){return h(r)};exports.unstable_next=function(a){switch(y){case 1:case 2:case 3:var b=3;break;default:b=y}var c=y;y=b;try{return a()}finally{y=c}};exports.unstable_pauseExecution=function(){};\nexports.unstable_requestPaint=function(){};exports.unstable_runWithPriority=function(a,b){switch(a){case 1:case 2:case 3:case 4:case 5:break;default:a=3}var c=y;y=a;try{return b()}finally{y=c}};\nexports.unstable_scheduleCallback=function(a,b,c){var d=exports.unstable_now();\"object\"===typeof c&&null!==c?(c=c.delay,c=\"number\"===typeof c&&0<c?d+c:d):c=d;switch(a){case 1:var e=-1;break;case 2:e=250;break;case 5:e=1073741823;break;case 4:e=1E4;break;default:e=5E3}e=c+e;a={id:u++,callback:b,priorityLevel:a,startTime:c,expirationTime:e,sortIndex:-1};c>d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","'use strict';\n\nvar isArrayish = require('is-arrayish');\n\nvar concat = Array.prototype.concat;\nvar slice = Array.prototype.slice;\n\nvar swizzle = module.exports = function swizzle(args) {\n\tvar results = [];\n\n\tfor (var i = 0, len = args.length; i < len; i++) {\n\t\tvar arg = args[i];\n\n\t\tif (isArrayish(arg)) {\n\t\t\t// http://jsperf.com/javascript-array-concat-vs-push/98\n\t\t\tresults = concat.call(results, slice.call(arg));\n\t\t} else {\n\t\t\tresults.push(arg);\n\t\t}\n\t}\n\n\treturn results;\n};\n\nswizzle.wrap = function (fn) {\n\treturn function () {\n\t\treturn fn(swizzle(arguments));\n\t};\n};\n","module.exports = function isArrayish(obj) {\n\tif (!obj || typeof obj === 'string') {\n\t\treturn false;\n\t}\n\n\treturn obj instanceof Array || Array.isArray(obj) ||\n\t\t(obj.length >= 0 && (obj.splice instanceof Function ||\n\t\t\t(Object.getOwnPropertyDescriptor(obj, (obj.length - 1)) && obj.constructor.name !== 'String')));\n};\n","/* Spatial Navigation Polyfill\n *\n * It follows W3C official specification\n * https://drafts.csswg.org/css-nav-1/\n *\n * Copyright (c) 2018-2019 LG Electronics Inc.\n * https://github.com/WICG/spatial-navigation/polyfill\n *\n * Licensed under the MIT license (MIT)\n */\n\n(function () {\n\n // The polyfill must not be executed, if it's already enabled via browser engine or browser extensions.\n if (window.navigate !== undefined) {\n return;\n }\n\n const ARROW_KEY_CODE = {37: 'left', 38: 'up', 39: 'right', 40: 'down'};\n const TAB_KEY_CODE = 9;\n let mapOfBoundRect = null;\n let startingPoint = null; // Indicates global variables for spatnav (starting position)\n\n /**\n * Initiate the spatial navigation features of the polyfill.\n * This function defines which input methods trigger the spatial navigation behavior.\n * @function initiateSpatialNavigation\n */\n function initiateSpatialNavigation() {\n /*\n * Bind the standards APIs to be exposed to the window object for authors\n */\n window.navigate = navigate;\n window.Element.prototype.spatialNavigationSearch = spatialNavigationSearch;\n window.Element.prototype.focusableAreas = focusableAreas;\n window.Element.prototype.getSpatialNavigationContainer = getSpatialNavigationContainer;\n\n /*\n * CSS.registerProperty() from the Properties and Values API\n * Reference: https://drafts.css-houdini.org/css-properties-values-api/#the-registerproperty-function\n */\n if (window.CSS && CSS.registerProperty) {\n if (window.getComputedStyle(document.documentElement).getPropertyValue('--spatial-navigation-contain') === '') {\n CSS.registerProperty({\n name: '--spatial-navigation-contain',\n syntax: 'auto | contain',\n inherits: false,\n initialValue: 'auto'\n });\n }\n\n if (window.getComputedStyle(document.documentElement).getPropertyValue('--spatial-navigation-action') === '') {\n CSS.registerProperty({\n name: '--spatial-navigation-action',\n syntax: 'auto | focus | scroll',\n inherits: false,\n initialValue: 'auto'\n });\n }\n\n if (window.getComputedStyle(document.documentElement).getPropertyValue('--spatial-navigation-function') === '') {\n CSS.registerProperty({\n name: '--spatial-navigation-function',\n syntax: 'normal | euclidean | grid',\n inherits: true,\n initialValue: 'normal'\n });\n }\n }\n\n /*\n * keydown EventListener :\n * If arrow key pressed, get the next focusing element and send it to focusing controller\n */\n window.addEventListener('keydown', e => {\n const currentKeyMode = (parent && parent.__spatialNavigation__.keyMode) || window.__spatialNavigation__.keyMode;\n const eventTarget = document.activeElement;\n const dir = ARROW_KEY_CODE[e.keyCode];\n\n if (e.keyCode === TAB_KEY_CODE)\n startingPoint = null;\n\n if (!currentKeyMode ||\n (currentKeyMode === 'NONE') ||\n ((currentKeyMode === 'SHIFTARROW') && !e.shiftKey) ||\n ((currentKeyMode === 'ARROW') && e.shiftKey))\n return;\n\n if (!e.defaultPrevented && !e.spatialNavigationPrevented) {\n let focusNavigableArrowKey = {left: true, up: true, right: true, down: true};\n\n // Edge case (text input, area) : Don't move focus, just navigate cursor in text area\n if ((eventTarget.nodeName === 'INPUT') || eventTarget.nodeName === 'TEXTAREA')\n focusNavigableArrowKey = handlingEditableElement(e);\n\n if (focusNavigableArrowKey[dir]) {\n e.preventDefault();\n mapOfBoundRect = new Map();\n\n navigate(dir);\n\n mapOfBoundRect = null;\n startingPoint = null;\n }\n }\n });\n\n /*\n * mouseup EventListener :\n * If the mouse click a point in the page, the point will be the starting point.\n * NOTE: Let UA set the spatial navigation starting point based on click\n */\n // document.addEventListener('mouseup', e => {\n // startingPoint = {x: e.clientX, y: e.clientY};\n // });\n }\n\n /**\n * Enable the author to trigger spatial navigation programmatically, as if the user had done so manually.\n * @see {@link https://drafts.csswg.org/css-nav-1/#dom-window-navigate}\n * @function navigate\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n */\n function navigate(dir) {\n // spatial navigation steps\n\n // 1\n const searchOrigin = findSearchOrigin();\n let eventTarget = searchOrigin;\n\n let elementFromPosition = null;\n\n // 2 Optional step, UA defined starting point\n if (startingPoint) {\n // if there is a starting point, set eventTarget as the element from position for getting the spatnav container\n elementFromPosition = document.elementFromPoint(startingPoint.x, startingPoint.y);\n\n // Use starting point if the starting point isn't inside the focusable element (but not container)\n // * Starting point is meaningfull when:\n // 1) starting point is inside the spatnav container\n // 2) starting point is inside the non-focusable element\n if(elementFromPosition === null) {\n elementFromPosition = document.body;\n }\n if (isFocusable(elementFromPosition) && !isContainer(elementFromPosition)) {\n startingPoint = null;\n } else if (isContainer(elementFromPosition)) {\n eventTarget = elementFromPosition;\n } else {\n eventTarget = elementFromPosition.getSpatialNavigationContainer();\n }\n }\n\n // 4\n if (eventTarget === document || eventTarget === document.documentElement) {\n eventTarget = document.body || document.documentElement;\n }\n\n // 5\n // At this point, spatialNavigationSearch can be applied.\n // If startingPoint is either a scroll container or the document,\n // find the best candidate within startingPoint\n let container = null;\n if ((isContainer(eventTarget) || eventTarget.nodeName === 'BODY') && !(eventTarget.nodeName === 'INPUT')) {\n container = eventTarget;\n\n if (eventTarget.nodeName === 'IFRAME')\n eventTarget = eventTarget.contentDocument.documentElement;\n\n let bestInsideCandidate = null;\n\n // 5-2\n if (getCSSSpatNavAction(eventTarget) === 'scroll') {\n if (scrollingController(eventTarget, dir)) return;\n } else if (getCSSSpatNavAction(eventTarget) === 'focus') {\n bestInsideCandidate = eventTarget.spatialNavigationSearch(dir, {container: eventTarget, candidates: getSpatialNavigationCandidates(eventTarget, {mode: 'all'}), inside: true});\n if (focusingController(bestInsideCandidate, dir)) return;\n } else if (getCSSSpatNavAction(eventTarget) === 'auto') {\n bestInsideCandidate = eventTarget.spatialNavigationSearch(dir, {container: eventTarget, inside: true});\n if (focusingController(bestInsideCandidate, dir) || scrollingController(eventTarget, dir)) return;\n }\n }\n\n // 6\n // Let container be the nearest ancestor of eventTarget\n container = container || eventTarget.getSpatialNavigationContainer();\n let parentContainer = (container.parentElement) ? container.getSpatialNavigationContainer() : null;\n\n // When the container is the viewport of a browsing context\n if (!parentContainer && ( window.location !== window.parent.location)) {\n parentContainer = window.parent.document.documentElement;\n }\n\n if (getCSSSpatNavAction(eventTarget) === 'scroll') {\n if (scrollingController(container, dir)) return;\n }\n else if (getCSSSpatNavAction(eventTarget) === 'focus') {\n navigateChain(eventTarget, container, parentContainer, dir, 'all');\n }\n else if (getCSSSpatNavAction(eventTarget) === 'auto') {\n navigateChain(eventTarget, container, parentContainer, dir, 'visible');\n }\n }\n\n /**\n * Move the focus to the best candidate or do nothing.\n * @function focusingController\n * @param bestCandidate {Node} - The best candidate of the spatial navigation\n * @param dir {SpatialNavigationDirection}- The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function focusingController(bestCandidate, dir) {\n // 10 & 11\n // When bestCandidate is found\n if (bestCandidate) {\n const container = bestCandidate.getSpatialNavigationContainer();\n const elementStyle = window.getComputedStyle(container, null);\n const overflowX = elementStyle.getPropertyValue('overflow-x');\n const overflowY = elementStyle.getPropertyValue('overflow-y');\n\n // Scrolling container or document when the next focusing element isn't entirely visible\n // This is for the browser compatability\n if (isScrollable(container, dir) && !isEntirelyVisible(bestCandidate));\n bestCandidate.scrollIntoView();\n\n // When bestCandidate is a focusable element and not a container : move focus\n /*\n * [event] navbeforefocus : Fired before spatial or sequential navigation changes the focus.\n */\n if (!createSpatNavEvents('beforefocus', bestCandidate, null, dir))\n return true;\n\n bestCandidate.focus();\n return true;\n }\n\n // When bestCandidate is not found within the scrollport of a container: Nothing\n return false;\n }\n\n /**\n * Directionally scroll the scrollable spatial navigation container if it can be manually scrolled more.\n * @function scrollingController\n * @param container {Node} - The spatial navigation container which can scroll\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function scrollingController(container, dir) {\n\n // If there is any scrollable area among parent elements and it can be manually scrolled, scroll the document\n if (isScrollable(container, dir) && !isScrollBoundary(container, dir)) {\n moveScroll(container, dir);\n return true;\n }\n\n // If the spatnav container is document and it can be scrolled, scroll the document\n if (!container.parentElement && !isHTMLScrollBoundary(container, dir)) {\n moveScroll(document.documentElement, dir);\n return true;\n }\n return false;\n }\n\n /**\n * Find the candidates within a spatial navigation container include delegable container.\n * This function does not search inside delegable container or focusable container.\n * In other words, this return candidates set is not included focusable elements inside delegable container or focusable container.\n *\n * @function getSpatialNavigationCandidates\n * @param container {Node} - The spatial navigation container\n * @param option {FocusableAreasOptions} - 'mode' attribute takes 'visible' or 'all' for searching the boundary of focusable elements.\n * Default value is 'visible'.\n * @returns {sequence<Node>} candidate elements within the container\n */\n function getSpatialNavigationCandidates (container, option = {mode: 'visible'}) {\n let candidates = [];\n\n if (container.childElementCount > 0) {\n if (!container.parentElement) {\n container = container.getElementsByTagName('body')[0] || document.body;\n }\n const children = container.children;\n for (const elem of children) {\n if (isDelegableContainer(elem)) {\n candidates.push(elem);\n } else if(isFocusable(elem)) {\n candidates.push(elem);\n\n if(!isContainer(elem) && elem.childElementCount) {\n candidates = candidates.concat(getSpatialNavigationCandidates(elem, {mode: 'all'}));\n }\n } else if (elem.childElementCount) {\n candidates = candidates.concat(getSpatialNavigationCandidates(elem, {mode: 'all'}));\n }\n }\n }\n return (option.mode === 'all') ? candidates : candidates.filter(isVisible);\n }\n\n /**\n * Find the candidates among focusable elements within a spatial navigation container from the search origin (currently focused element)\n * depending on the directional information.\n * @function getFilteredSpatialNavigationCandidates\n * @param element {Node} - The currently focused element which is defined as 'search origin' in the spec\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @param candidates {sequence<Node>} - The candidates for spatial navigation without the directional information\n * @param container {Node} - The spatial navigation container\n * @returns {Node} The candidates for spatial navigation considering the directional information\n */\n function getFilteredSpatialNavigationCandidates (element, dir, candidates, container) {\n const targetElement = element;\n // Removed below line due to a bug. (iframe body rect is sometime weird.)\n // const targetElement = (element.nodeName === 'IFRAME') ? element.contentDocument.body : element;\n // If the container is unknown, get the closest container from the element\n container = container || targetElement.getSpatialNavigationContainer();\n\n // If the candidates is unknown, find candidates\n // 5-1\n candidates = (!candidates || candidates.length <= 0) ? getSpatialNavigationCandidates(container) : candidates;\n return filteredCandidates(targetElement, candidates, dir, container);\n }\n\n /**\n * Find the best candidate among the candidates within the container from the search origin (currently focused element)\n * @see {@link https://drafts.csswg.org/css-nav-1/#dom-element-spatialnavigationsearch}\n * @function spatialNavigationSearch\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @param candidates {sequence<Node>} - The candidates for spatial navigation\n * @param container {Node} - The spatial navigation container\n * @param inside {boolean} - Whether candidates should be elements outside of the target element or not.\n * @returns {Node} The best candidate which will gain the focus\n */\n function spatialNavigationSearch (dir, args) {\n const targetElement = this;\n let internalCandidates = [];\n let externalCandidates = [];\n let bestTarget;\n\n // Set default parameter value\n if (!args)\n args = {};\n const container = args.container || targetElement.getSpatialNavigationContainer();\n const candidates = (args.candidates && args.candidates.length > 0) ?\n args.candidates.filter((candidate) => container.contains(candidate)) : getSpatialNavigationCandidates(container);\n const inside = args.inside || false;\n\n // Find the best candidate\n // 5\n // If startingPoint is either a scroll container or the document,\n // find the best candidate within startingPoint\n if (candidates && candidates.length > 0) {\n\n // Divide internal or external candidates\n candidates.forEach(candidate => {\n (targetElement.contains(candidate) && targetElement !== candidate ? internalCandidates : externalCandidates).push(candidate);\n });\n if (!(args.candidates && args.candidates.length > 0) && (internalCandidates.length === 0)) {\n // If targetElement is focusable container or delegable container,\n // getFilteredSpatialNavigationCandidates not return internal candidate.\n internalCandidates = getSpatialNavigationCandidates(targetElement);\n }\n // Filter external Candidates\n if (externalCandidates.length > 0) {\n externalCandidates = getFilteredSpatialNavigationCandidates (targetElement, dir, externalCandidates, container);\n }\n\n if (inside && (isContainer(targetElement) || targetElement.nodeName === 'BODY') && !(targetElement.nodeName === 'INPUT')) {\n bestTarget = selectBestCandidateFromEdge(targetElement, internalCandidates, dir);\n }\n bestTarget = bestTarget || selectBestCandidate(targetElement, externalCandidates, dir);\n\n if (bestTarget && isDelegableContainer(bestTarget)) {\n // if best target is delegable container, then find descendants candidate inside delegable container.\n const innerTarget = getSpatialNavigationCandidates(bestTarget, {mode: 'all'});\n const descendantsBest = innerTarget.length > 0 ? targetElement.spatialNavigationSearch(dir, {candidates: innerTarget, container: bestTarget}) : null;\n if (descendantsBest) {\n bestTarget = descendantsBest;\n } else if (!isFocusable(bestTarget)) {\n // if there is no target inside bestTarget and delegable container is not focusable,\n // then try to find another best target without curren best target.\n candidates.splice(candidates.indexOf(bestTarget), 1);\n bestTarget = candidates.length ? targetElement.spatialNavigationSearch(dir, {candidates: candidates, container: container}) : null;\n }\n }\n return bestTarget;\n }\n\n return null;\n }\n\n /**\n * Get the filtered candidate among candidates.\n * @see {@link https://drafts.csswg.org/css-nav-1/#select-the-best-candidate}\n * @function filteredCandidates\n * @param currentElm {Node} - The currently focused element which is defined as 'search origin' in the spec\n * @param candidates {sequence<Node>} - The candidates for spatial navigation\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @param container {Node} - The spatial navigation container\n * @returns {sequence<Node>} The filtered candidates which are not the search origin and not in the given spatial navigation direction from the search origin\n */\n function filteredCandidates(currentElm, candidates, dir, container) {\n const originalContainer = currentElm.getSpatialNavigationContainer();\n let eventTargetRect;\n\n // If D(dir) is null, let candidates be the same as visibles\n if (dir === undefined)\n return candidates;\n\n // to do\n // Offscreen handling when originalContainer is not <HTML>\n if (originalContainer.parentElement && container !== originalContainer && !isVisible(currentElm))\n eventTargetRect = getBoundingClientRect(originalContainer);\n else eventTargetRect = getBoundingClientRect(currentElm);\n\n /*\n * Else, let candidates be the subset of the elements in visibles\n * whose principal box’s geometric center is within the closed half plane\n * whose boundary goes through the geometric center of starting point and is perpendicular to D.\n */\n if ((isContainer(currentElm) || currentElm.nodeName === 'BODY') && !(currentElm.nodeName === 'INPUT')) {\n return candidates.filter(candidate => {\n const candidateRect = getBoundingClientRect(candidate);\n return container.contains(candidate) &&\n ((currentElm.contains(candidate) && isInside(eventTargetRect, candidateRect) && candidate !== currentElm) ||\n isOutside(candidateRect, eventTargetRect, dir));\n });\n } else {\n return candidates.filter(candidate => {\n const candidateRect = getBoundingClientRect(candidate);\n const candidateBody = (candidate.nodeName === 'IFRAME') ? candidate.contentDocument.body : null;\n return container.contains(candidate) &&\n candidate !== currentElm && candidateBody !== currentElm &&\n isOutside(candidateRect, eventTargetRect, dir);\n });\n }\n }\n\n /**\n * Select the best candidate among given candidates.\n * @see {@link https://drafts.csswg.org/css-nav-1/#select-the-best-candidate}\n * @function selectBestCandidate\n * @param currentElm {Node} - The currently focused element which is defined as 'search origin' in the spec\n * @param candidates {sequence<Node>} - The candidates for spatial navigation\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Node} The best candidate which will gain the focus\n */\n function selectBestCandidate(currentElm, candidates, dir) {\n const spatialNavigationFunction = getComputedStyle(currentElm).getPropertyValue('--spatial-navigation-function');\n const currentElmRect = getBoundingClientRect(currentElm);\n let distanceFunction;\n let alignedCandidates;\n\n switch (spatialNavigationFunction) {\n case 'grid':\n alignedCandidates = candidates.filter(elm => isAligned(currentElmRect, getBoundingClientRect(elm), dir));\n if (alignedCandidates.length > 0) {\n candidates = alignedCandidates;\n }\n distanceFunction = getAbsoluteDistance;\n break;\n case 'euclidean':\n distanceFunction = getEuclideanDistance;\n break;\n default:\n distanceFunction = getDistance;\n break;\n }\n return getClosestElement(currentElm, candidates, dir, distanceFunction);\n }\n\n /**\n * Select the best candidate among candidates by finding the closet candidate from the edge of the currently focused element (search origin).\n * @see {@link https://drafts.csswg.org/css-nav-1/#select-the-best-candidate (Step 5)}\n * @function selectBestCandidateFromEdge\n * @param currentElm {Node} - The currently focused element which is defined as 'search origin' in the spec\n * @param candidates {sequence<Node>} - The candidates for spatial navigation\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Node} The best candidate which will gain the focus\n */\n function selectBestCandidateFromEdge(currentElm, candidates, dir) {\n if (startingPoint)\n return getClosestElement(currentElm, candidates, dir, getDistanceFromPoint);\n else\n return getClosestElement(currentElm, candidates, dir, getInnerDistance);\n }\n\n /**\n * Select the closest candidate from the currently focused element (search origin) among candidates by using the distance function.\n * @function getClosestElement\n * @param currentElm {Node} - The currently focused element which is defined as 'search origin' in the spec\n * @param candidates {sequence<Node>} - The candidates for spatial navigation\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @param distanceFunction {function} - The distance function which measures the distance from the search origin to each candidate\n * @returns {Node} The candidate which is the closest one from the search origin\n */\n function getClosestElement(currentElm, candidates, dir, distanceFunction) {\n let eventTargetRect = null;\n if (( window.location !== window.parent.location ) && (currentElm.nodeName === 'BODY' || currentElm.nodeName === 'HTML')) {\n // If the eventTarget is iframe, then get rect of it based on its containing document\n // Set the iframe's position as (0,0) because the rects of elements inside the iframe don't know the real iframe's position.\n eventTargetRect = window.frameElement.getBoundingClientRect();\n eventTargetRect.x = 0;\n eventTargetRect.y = 0;\n }\n else \n eventTargetRect = currentElm.getBoundingClientRect();\n\n let minDistance = Number.POSITIVE_INFINITY;\n let minDistanceElements = [];\n\n if (candidates) {\n for (let i = 0; i < candidates.length; i++) {\n const distance = distanceFunction(eventTargetRect, getBoundingClientRect(candidates[i]), dir);\n\n // If the same distance, the candidate will be selected in the DOM order\n if (distance < minDistance) {\n minDistance = distance;\n minDistanceElements = [candidates[i]];\n } else if (distance === minDistance) {\n minDistanceElements.push(candidates[i]);\n }\n }\n }\n if (minDistanceElements.length === 0)\n return null;\n\n return (minDistanceElements.length > 1 && distanceFunction === getAbsoluteDistance) ?\n getClosestElement(currentElm, minDistanceElements, dir, getEuclideanDistance) : minDistanceElements[0];\n }\n\n /**\n * Get container of an element.\n * @see {@link https://drafts.csswg.org/css-nav-1/#dom-element-getspatialnavigationcontainer}\n * @module Element\n * @function getSpatialNavigationContainer\n * @returns {Node} The spatial navigation container\n */\n function getSpatialNavigationContainer() {\n let container = this;\n\n do {\n if (!container.parentElement) {\n if (window.location !== window.parent.location)\n container = window.parent.document.documentElement;\n else\n container = window.document.documentElement;\n break;\n }\n else {\n container = container.parentElement;\n }\n } while (!isContainer(container));\n return container;\n }\n\n /**\n * Find focusable elements within the spatial navigation container.\n * @see {@link https://drafts.csswg.org/css-nav-1/#dom-element-focusableareas}\n * @function focusableAreas\n * @param option {FocusableAreasOptions} - 'mode' attribute takes 'visible' or 'all' for searching the boundary of focusable elements.\n * Default value is 'visible'.\n * @returns {sequence<Node>} All focusable elements or only visible focusable elements within the container\n */\n function focusableAreas(option = {mode: 'visible'}) {\n const container = this.parentElement ? this : document.body;\n const focusables = Array.prototype.filter.call(container.getElementsByTagName('*'), isFocusable);\n return (option.mode === 'all') ? focusables : focusables.filter(isVisible);\n }\n\n /**\n * Create the NavigationEvent: navbeforefocus, navnotarget\n * @see {@link https://drafts.csswg.org/css-nav-1/#events-navigationevent}\n * @function createSpatNavEvents\n * @param option {string} - Type of the navigation event (beforefocus, notarget)\n * @param element {Node} - The target element of the event\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n */\n function createSpatNavEvents(eventType, containerElement, currentElement, direction) {\n if(['beforefocus', 'notarget'].includes(eventType)) {\n const data = {\n causedTarget: currentElement,\n dir: direction\n };\n const triggeredEvent = new CustomEvent('nav' + eventType, {bubbles: true, cancelable: true, detail: data});\n return containerElement.dispatchEvent(triggeredEvent);\n }\n }\n\n /**\n * Get the value of the CSS custom property of the element\n * @function readCssVar\n * @param element {Node}\n * @param varName {string} - The name of the css custom property without '--'\n * @returns {string} The value of the css custom property\n */\n function readCssVar(element, varName) {\n return window.getComputedStyle(element).getPropertyValue(`--${varName}`).trim();\n }\n\n /**\n * Decide whether or not the 'contain' value is given to 'spatial-navigation-contain' css property of an element\n * @function isCSSSpatNavContain\n * @param element {Node}\n * @returns {boolean}\n */\n function isCSSSpatNavContain(element) {\n return readCssVar(element, 'spatial-navigation-contain') === 'contain';\n }\n\n /**\n * Return the value of 'spatial-navigation-action' css property of an element\n * @function getCSSSpatNavAction\n * @param element {Node} - would be the spatial navigation container\n * @returns {string} auto | focus | scroll\n */\n function getCSSSpatNavAction(element) {\n return readCssVar(element, 'spatial-navigation-action') || 'auto';\n }\n\n /**\n * Only move the focus with spatial navigation. Manually scrolling isn't available.\n * @function navigateChain\n * @param eventTarget {Node} - currently focused element\n * @param container {SpatialNavigationContainer} - container\n * @param parentContainer {SpatialNavigationContainer} - parent container\n * @param option - visible || all\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n */\n function navigateChain(eventTarget, container, parentContainer, dir, option) {\n let currentOption = {candidates: getSpatialNavigationCandidates(container, {mode: option}), container};\n\n while (parentContainer) {\n if (focusingController(eventTarget.spatialNavigationSearch(dir, currentOption), dir)) {\n return;\n }\n else {\n if ((option === 'visible') && scrollingController(container, dir)) return;\n else {\n if (!createSpatNavEvents('notarget', container, eventTarget, dir)) return;\n\n // find the container\n if (container === document || container === document.documentElement) {\n if ( window.location !== window.parent.location ) {\n // The page is in an iframe. eventTarget needs to be reset because the position of the element in the iframe\n eventTarget = window.frameElement;\n container = window.parent.document.documentElement;\n\n if (container.parentElement)\n parentContainer = container.getSpatialNavigationContainer();\n else {\n parentContainer = null;\n break;\n }\n }\n }\n else {\n container = parentContainer;\n currentOption = {candidates: getSpatialNavigationCandidates(container, {mode: option}), container};\n\n if (container.parentElement)\n parentContainer = container.getSpatialNavigationContainer();\n else {\n parentContainer = null;\n break;\n }\n }\n }\n }\n }\n\n currentOption = {candidates: getSpatialNavigationCandidates(container, {mode: option}), container};\n\n // Behavior after 'navnotarget' - Getting out from the current spatnav container\n if ((!parentContainer && container) && focusingController(eventTarget.spatialNavigationSearch(dir, currentOption), dir)) return;\n\n if (!createSpatNavEvents('notarget', currentOption.container, eventTarget, dir)) return;\n\n if ((getCSSSpatNavAction(container) === 'auto') && (option === 'visible'))\n if (scrollingController(container, dir)) return;\n }\n\n /**\n * Find search origin\n * @see {@link https://drafts.csswg.org/css-nav-1/#nav}\n * @function findSearchOrigin\n * @returns {Node} The search origin for the spatial navigation\n */\n function findSearchOrigin() {\n let searchOrigin = document.activeElement;\n if (!searchOrigin ||\n (searchOrigin === document.body && !document.querySelector(':focus')) /* body isn't actually focused*/\n ) {\n searchOrigin = document;\n }\n return searchOrigin;\n }\n\n /**\n * Move the scroll of an element depending on the given spatial navigation directrion\n * (Assume that User Agent defined distance is '40px')\n * @see {@link https://drafts.csswg.org/css-nav-1/#directionally-scroll-an-element}\n * @function moveScroll\n * @param element {Node} - The scrollable element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @param offset {Number} - The explicit amount of offset for scrolling. Default value is 0.\n */\n function moveScroll(element, dir, offset = 0) {\n if (element) {\n switch (dir) {\n case 'left': element.scrollLeft -= (40 + offset); break;\n case 'right': element.scrollLeft += (40 + offset); break;\n case 'up': element.scrollTop -= (40 + offset); break;\n case 'down': element.scrollTop += (40 + offset); break;\n }\n }\n }\n\n /**\n * Decide whether an element is container or not.\n * @function isContainer\n * @param element {Node} element\n * @returns {boolean}\n */\n function isContainer(element) {\n return (!element.parentElement) ||\n (element.nodeName === 'IFRAME') ||\n (isScrollContainer(element)) ||\n (isCSSSpatNavContain(element));\n }\n\n /**\n * Decide whether an element is delegable container or not.\n * NOTE: THIS IS NON-NORMATIVE API. \n * @function isDelegableContainer\n * @param element {Node} element\n * @returns {boolean}\n */\n function isDelegableContainer(element) {\n return readCssVar(element, 'spatial-navigation-contain') === 'delegable';\n }\n\n /**\n * Decide whether an element is a scrollable container or not.\n * @see {@link https://drafts.csswg.org/css-overflow-3/#scroll-container}\n * @function isScrollContainer\n * @param element {Node}\n * @returns {boolean}\n */\n function isScrollContainer(element) {\n const elementStyle = window.getComputedStyle(element, null);\n const overflowX = elementStyle.getPropertyValue('overflow-x');\n const overflowY = elementStyle.getPropertyValue('overflow-y');\n\n return ((overflowX !== 'visible' && overflowX !== 'clip' && isOverflow(element, 'left')) ||\n (overflowY !== 'visible' && overflowY !== 'clip' && isOverflow(element, 'down'))) ?\n true : false;\n }\n\n /**\n * Decide whether this element is scrollable or not.\n * NOTE: If the value of 'overflow' is given to either 'visible', 'clip', or 'hidden', the element isn't scrollable.\n * If the value is 'hidden', the element can be only programmically scrollable. (https://drafts.csswg.org/css-overflow-3/#valdef-overflow-hidden)\n * @function isScrollable\n * @param element {Node}\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function isScrollable(element, dir) { // element, dir\n if (element && typeof element === 'object') {\n if (dir && typeof dir === 'string') { // parameter: dir, element\n if (isOverflow(element, dir)) {\n // style property\n const elementStyle = window.getComputedStyle(element, null);\n const overflowX = elementStyle.getPropertyValue('overflow-x');\n const overflowY = elementStyle.getPropertyValue('overflow-y');\n\n switch (dir) {\n case 'left':\n /* falls through */\n case 'right':\n return (overflowX !== 'visible' && overflowX !== 'clip' && overflowX !== 'hidden');\n case 'up':\n /* falls through */\n case 'down':\n return (overflowY !== 'visible' && overflowY !== 'clip' && overflowY !== 'hidden');\n }\n }\n return false;\n } else { // parameter: element\n return (element.nodeName === 'HTML' || element.nodeName === 'BODY') ||\n (isScrollContainer(element) && isOverflow(element));\n }\n }\n }\n\n /**\n * Decide whether an element is overflow or not.\n * @function isOverflow\n * @param element {Node}\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function isOverflow(element, dir) {\n if (element && typeof element === 'object') {\n if (dir && typeof dir === 'string') { // parameter: element, dir\n switch (dir) {\n case 'left':\n /* falls through */\n case 'right':\n return (element.scrollWidth > element.clientWidth);\n case 'up':\n /* falls through */\n case 'down':\n return (element.scrollHeight > element.clientHeight);\n }\n } else { // parameter: element\n return (element.scrollWidth > element.clientWidth || element.scrollHeight > element.clientHeight);\n }\n return false;\n }\n }\n\n /**\n * Decide whether the scrollbar of the browsing context reaches to the end or not.\n * @function isHTMLScrollBoundary\n * @param element {Node} - The top browsing context\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function isHTMLScrollBoundary(element, dir) {\n let result = false;\n switch (dir) {\n case 'left':\n result = window.scrollX === 0;\n break;\n case 'right':\n result = (element.scrollWidth - element.scrollLeft - element.clientWidth) === 0;\n break;\n case 'up':\n result = window.scrollY === 0;\n break;\n case 'down':\n result = (element.scrollHeight - element.scrollTop - element.clientHeight) === 0;\n break;\n }\n return result;\n }\n\n /**\n * Decide whether the scrollbar of an element reaches to the end or not.\n * @function isScrollBoundary\n * @param element {Node}\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function isScrollBoundary(element, dir) {\n if (isScrollable(element, dir)) {\n const winScrollY = element.scrollTop;\n const winScrollX = element.scrollLeft;\n\n const height = element.scrollHeight - element.clientHeight;\n const width = element.scrollWidth - element.clientWidth;\n\n switch (dir) {\n case 'left': return (winScrollX === 0);\n case 'right': return (Math.abs(winScrollX - width) <= 1);\n case 'up': return (winScrollY === 0);\n case 'down': return (Math.abs(winScrollY - height) <= 1);\n }\n }\n return false;\n }\n\n /**\n * Decide whether an element is focusable for spatial navigation.\n * 1. If element is the browsing context (document, iframe), then it's focusable,\n * 2. If the element is scrollable container (regardless of scrollable axis), then it's focusable,\n * 3. The value of tabIndex >= 0, then it's focusable,\n * 4. If the element is disabled, it isn't focusable,\n * 5. If the element is expressly inert, it isn't focusable,\n * 6. Whether the element is being rendered or not.\n *\n * @function isFocusable\n * @param element {Node}\n * @returns {boolean}\n *\n * @see {@link https://html.spec.whatwg.org/multipage/interaction.html#focusable-area}\n */\n function isFocusable(element) {\n if ((element.tabIndex < 0) || isAtagWithoutHref(element) || isActuallyDisabled(element) || isExpresslyInert(element) || !isBeingRendered(element))\n return false;\n else if ((!element.parentElement) || (isScrollable(element) && isOverflow(element)) || (element.tabIndex >= 0))\n return true;\n }\n\n /**\n * Decide whether an element is a tag without href attribute or not.\n *\n * @function isAtagWithoutHref\n * @param element {Node}\n * @returns {boolean}\n */\n function isAtagWithoutHref(element) {\n return (element.tagName === 'A' && element.getAttribute('href') === null && element.getAttribute('tabIndex') === null);\n }\n\n /**\n * Decide whether an element is actually disabled or not.\n *\n * @function isActuallyDisabled\n * @param element {Node}\n * @returns {boolean}\n *\n * @see {@link https://html.spec.whatwg.org/multipage/semantics-other.html#concept-element-disabled}\n */\n function isActuallyDisabled(element) {\n if (['BUTTON', 'INPUT', 'SELECT', 'TEXTAREA', 'OPTGROUP', 'OPTION', 'FIELDSET'].includes(element.tagName))\n return (element.disabled);\n else\n return false;\n }\n\n /**\n * Decide whether the element is expressly inert or not.\n * @see {@link https://html.spec.whatwg.org/multipage/interaction.html#expressly-inert}\n * @function isExpresslyInert\n * @param element {Node}\n * @returns {boolean}\n */\n function isExpresslyInert(element) {\n return ((element.inert) && (!element.ownerDocument.documentElement.inert));\n }\n\n /**\n * Decide whether the element is being rendered or not.\n * 1. If an element has the style as \"visibility: hidden | collapse\" or \"display: none\", it is not being rendered.\n * 2. If an element has the style as \"opacity: 0\", it is not being rendered.(that is, invisible).\n * 3. If width and height of an element are explicitly set to 0, it is not being rendered.\n * 4. If a parent element is hidden, an element itself is not being rendered.\n * (CSS visibility property and display property are inherited.)\n * @see {@link https://html.spec.whatwg.org/multipage/rendering.html#being-rendered}\n * @function isBeingRendered\n * @param element {Node}\n * @returns {boolean}\n */\n function isBeingRendered(element) {\n if (!isVisibleStyleProperty(element.parentElement))\n return false;\n if (!isVisibleStyleProperty(element) || (element.style.opacity === 0) ||\n ((element.style.width === '0px' || element.style.width === 0) && (element.style.height === '0px' || element.style.height === 0)))\n return false;\n return true;\n }\n\n /**\n * Decide whether this element is partially or completely visible to user agent.\n * @function isVisible\n * @param element {Node}\n * @returns {boolean}\n */\n function isVisible(element) {\n return (!element.parentElement) || (isVisibleStyleProperty(element) && hitTest(element));\n }\n\n /**\n * Decide whether this element is completely visible in this viewport for the arrow direction.\n * @function isEntirelyVisible\n * @param element {Node}\n * @returns {boolean}\n */\n function isEntirelyVisible(element) {\n const rect = getBoundingClientRect(element);\n const containerRect = getBoundingClientRect(element.getSpatialNavigationContainer());\n\n // FIXME: when element is bigger than container?\n const entirelyVisible = !((rect.left < containerRect.left) ||\n (rect.right > containerRect.right) ||\n (rect.top < containerRect.top) ||\n (rect.bottom > containerRect.bottom));\n\n return entirelyVisible;\n }\n\n /**\n * Decide the style property of this element is specified whether it's visible or not.\n * @function isVisibleStyleProperty\n * @param element {CSSStyleDeclaration}\n * @returns {boolean}\n */\n function isVisibleStyleProperty(element) {\n const elementStyle = window.getComputedStyle(element, null);\n const thisVisibility = elementStyle.getPropertyValue('visibility');\n const thisDisplay = elementStyle.getPropertyValue('display');\n const invisibleStyle = ['hidden', 'collapse'];\n\n return (thisDisplay !== 'none' && !invisibleStyle.includes(thisVisibility));\n }\n\n /**\n * Decide whether this element is entirely or partially visible within the viewport.\n * @function hitTest\n * @param element {Node}\n * @returns {boolean}\n */\n function hitTest(element) {\n const elementRect = getBoundingClientRect(element);\n if (element.nodeName !== 'IFRAME' && (elementRect.top < 0 || elementRect.left < 0 ||\n elementRect.top > window.innerHeight || elementRect.left > window.innerWidth))\n return false;\n\n let offsetX = parseInt(element.offsetWidth) / 10;\n let offsetY = parseInt(element.offsetHeight) / 10;\n\n offsetX = isNaN(offsetX) ? 1 : offsetX;\n offsetY = isNaN(offsetY) ? 1 : offsetY;\n\n const hitTestPoint = {\n middle: [(elementRect.left + elementRect.right) / 2, (elementRect.top + elementRect.bottom) / 2],\n leftTop: [elementRect.left + offsetX, elementRect.top + offsetY],\n // For performance\n // leftBoottom: [elementRect.left + offsetX, elementRect.bottom - offsetY],\n // rightTop: [elementRect.right - offsetX, elementRect.top + offsetY],\n rightBottom: [elementRect.right - offsetX, elementRect.bottom - offsetY]\n };\n\n for(const point in hitTestPoint) {\n const elemFromPoint = document.elementFromPoint(...hitTestPoint[point]);\n if (element === elemFromPoint || element.contains(elemFromPoint)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Decide whether a child element is entirely or partially Included within container visually.\n * @function isInside\n * @param containerRect {DOMRect}\n * @param childRect {DOMRect}\n * @returns {boolean}\n */\n function isInside(containerRect, childRect) {\n const rightEdgeCheck = (containerRect.left <= childRect.right && containerRect.right >= childRect.right);\n const leftEdgeCheck = (containerRect.left <= childRect.left && containerRect.right >= childRect.left);\n const topEdgeCheck = (containerRect.top <= childRect.top && containerRect.bottom >= childRect.top);\n const bottomEdgeCheck = (containerRect.top <= childRect.bottom && containerRect.bottom >= childRect.bottom);\n return (rightEdgeCheck || leftEdgeCheck) && (topEdgeCheck || bottomEdgeCheck);\n }\n\n /**\n * Decide whether this element is entirely or partially visible within the viewport.\n * Note: rect1 is outside of rect2 for the dir\n * @function isOutside\n * @param rect1 {DOMRect}\n * @param rect2 {DOMRect}\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {boolean}\n */\n function isOutside(rect1, rect2, dir) {\n switch (dir) {\n case 'left':\n return isRightSide(rect2, rect1);\n case 'right':\n return isRightSide(rect1, rect2);\n case 'up':\n return isBelow(rect2, rect1);\n case 'down':\n return isBelow(rect1, rect2);\n default:\n return false;\n }\n }\n\n /* rect1 is right of rect2 */\n function isRightSide(rect1, rect2) {\n return rect1.left >= rect2.right || (rect1.left >= rect2.left && rect1.right > rect2.right && rect1.bottom > rect2.top && rect1.top < rect2.bottom);\n }\n\n /* rect1 is below of rect2 */\n function isBelow(rect1, rect2) {\n return rect1.top >= rect2.bottom || (rect1.top >= rect2.top && rect1.bottom > rect2.bottom && rect1.left < rect2.right && rect1.right > rect2.left);\n }\n\n /* rect1 is completely aligned or partially aligned for the direction */\n function isAligned(rect1, rect2, dir) {\n switch (dir) {\n case 'left' :\n /* falls through */\n case 'right' :\n return rect1.bottom > rect2.top && rect1.top < rect2.bottom;\n case 'up' :\n /* falls through */\n case 'down' :\n return rect1.right > rect2.left && rect1.left < rect2.right;\n default:\n return false;\n }\n }\n\n /**\n * Get distance between the search origin and a candidate element along the direction when candidate element is inside the search origin.\n * @see {@link https://drafts.csswg.org/css-nav-1/#find-the-shortest-distance}\n * @function getDistanceFromPoint\n * @param point {Point} - The search origin\n * @param element {DOMRect} - A candidate element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Number} The euclidian distance between the spatial navigation container and an element inside it\n */\n function getDistanceFromPoint(point, element, dir) {\n point = startingPoint;\n // Get exit point, entry point -> {x: '', y: ''};\n const points = getEntryAndExitPoints(dir, point, element);\n\n // Find the points P1 inside the border box of starting point and P2 inside the border box of candidate\n // that minimize the distance between these two points\n const P1 = Math.abs(points.entryPoint.x - points.exitPoint.x);\n const P2 = Math.abs(points.entryPoint.y - points.exitPoint.y);\n\n // The result is euclidian distance between P1 and P2.\n return Math.sqrt(Math.pow(P1, 2) + Math.pow(P2, 2));\n }\n\n /**\n * Get distance between the search origin and a candidate element along the direction when candidate element is inside the search origin.\n * @see {@link https://drafts.csswg.org/css-nav-1/#find-the-shortest-distance}\n * @function getInnerDistance\n * @param rect1 {DOMRect} - The search origin\n * @param rect2 {DOMRect} - A candidate element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Number} The euclidean distance between the spatial navigation container and an element inside it\n */\n function getInnerDistance(rect1, rect2, dir) {\n const baseEdgeForEachDirection = {left: 'right', right: 'left', up: 'bottom', down: 'top'};\n const baseEdge = baseEdgeForEachDirection[dir];\n\n return Math.abs(rect1[baseEdge] - rect2[baseEdge]);\n }\n\n /**\n * Get the distance between the search origin and a candidate element considering the direction.\n * @see {@link https://drafts.csswg.org/css-nav-1/#calculating-the-distance}\n * @function getDistance\n * @param searchOrigin {DOMRect || Point} - The search origin\n * @param candidateRect {DOMRect} - A candidate element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Number} The distance scoring between two elements\n */\n function getDistance(searchOrigin, candidateRect, dir) {\n const kOrthogonalWeightForLeftRight = 30;\n const kOrthogonalWeightForUpDown = 2;\n\n let orthogonalBias = 0;\n let alignBias = 0;\n const alignWeight = 5.0;\n\n // Get exit point, entry point -> {x: '', y: ''};\n const points = getEntryAndExitPoints(dir, searchOrigin, candidateRect);\n\n // Find the points P1 inside the border box of starting point and P2 inside the border box of candidate\n // that minimize the distance between these two points\n const P1 = Math.abs(points.entryPoint.x - points.exitPoint.x);\n const P2 = Math.abs(points.entryPoint.y - points.exitPoint.y);\n\n // A: The euclidean distance between P1 and P2.\n const A = Math.sqrt(Math.pow(P1, 2) + Math.pow(P2, 2));\n let B, C;\n\n // B: The absolute distance in the direction which is orthogonal to dir between P1 and P2, or 0 if dir is null.\n // C: The intersection edges between a candidate and the starting point.\n\n // D: The square root of the area of intersection between the border boxes of candidate and starting point\n const intersectionRect = getIntersectionRect(searchOrigin, candidateRect);\n const D = intersectionRect.area;\n\n switch (dir) {\n case 'left':\n /* falls through */\n case 'right' :\n // If two elements are aligned, add align bias\n // else, add orthogonal bias\n if (isAligned(searchOrigin, candidateRect, dir))\n alignBias = Math.min(intersectionRect.height / searchOrigin.height , 1);\n else\n orthogonalBias = (searchOrigin.height / 2);\n\n B = (P2 + orthogonalBias) * kOrthogonalWeightForLeftRight;\n C = alignWeight * alignBias;\n break;\n\n case 'up' :\n /* falls through */\n case 'down' :\n // If two elements are aligned, add align bias\n // else, add orthogonal bias\n if (isAligned(searchOrigin, candidateRect, dir))\n alignBias = Math.min(intersectionRect.width / searchOrigin.width , 1);\n else\n orthogonalBias = (searchOrigin.width / 2);\n\n B = (P1 + orthogonalBias) * kOrthogonalWeightForUpDown;\n C = alignWeight * alignBias;\n break;\n\n default:\n B = 0;\n C = 0;\n break;\n }\n\n return (A + B - C - D);\n }\n\n /**\n * Get the euclidean distance between the search origin and a candidate element considering the direction.\n * @function getEuclideanDistance\n * @param rect1 {DOMRect} - The search origin\n * @param rect2 {DOMRect} - A candidate element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Number} The distance scoring between two elements\n */\n function getEuclideanDistance(rect1, rect2, dir) {\n // Get exit point, entry point\n const points = getEntryAndExitPoints(dir, rect1, rect2);\n\n // Find the points P1 inside the border box of starting point and P2 inside the border box of candidate\n // that minimize the distance between these two points\n const P1 = Math.abs(points.entryPoint.x - points.exitPoint.x);\n const P2 = Math.abs(points.entryPoint.y - points.exitPoint.y);\n\n // Return the euclidean distance between P1 and P2.\n return Math.sqrt(Math.pow(P1, 2) + Math.pow(P2, 2));\n }\n\n /**\n * Get the absolute distance between the search origin and a candidate element considering the direction.\n * @function getAbsoluteDistance\n * @param rect1 {DOMRect} - The search origin\n * @param rect2 {DOMRect} - A candidate element\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD)\n * @returns {Number} The distance scoring between two elements\n */\n function getAbsoluteDistance(rect1, rect2, dir) {\n // Get exit point, entry point\n const points = getEntryAndExitPoints(dir, rect1, rect2);\n\n // Return the absolute distance in the dir direction between P1 and P.\n return ((dir === 'left') || (dir === 'right')) ?\n Math.abs(points.entryPoint.x - points.exitPoint.x) : Math.abs(points.entryPoint.y - points.exitPoint.y);\n }\n\n /**\n * Get entry point and exit point of two elements considering the direction.\n * @function getEntryAndExitPoints\n * @param dir {SpatialNavigationDirection} - The directional information for the spatial navigation (e.g. LRUD). Default value for dir is 'down'.\n * @param searchOrigin {DOMRect | Point} - The search origin which contains the exit point\n * @param candidateRect {DOMRect} - One of candidates which contains the entry point\n * @returns {Points} The exit point from the search origin and the entry point from a candidate\n */\n function getEntryAndExitPoints(dir = 'down', searchOrigin, candidateRect) {\n /**\n * User type definition for Point\n * @typeof {Object} Points\n * @property {Point} Points.entryPoint\n * @property {Point} Points.exitPoint\n */\n const points = {entryPoint: {x: 0, y: 0}, exitPoint:{x: 0, y: 0}};\n\n if (startingPoint) {\n points.exitPoint = searchOrigin;\n\n switch (dir) {\n case 'left':\n points.entryPoint.x = candidateRect.right;\n break;\n case 'up':\n points.entryPoint.y = candidateRect.bottom;\n break;\n case 'right':\n points.entryPoint.x = candidateRect.left;\n break;\n case 'down':\n points.entryPoint.y = candidateRect.top;\n break;\n }\n\n // Set orthogonal direction\n switch (dir) {\n case 'left':\n case 'right':\n if (startingPoint.y <= candidateRect.top) {\n points.entryPoint.y = candidateRect.top;\n } else if (startingPoint.y < candidateRect.bottom) {\n points.entryPoint.y = startingPoint.y;\n } else {\n points.entryPoint.y = candidateRect.bottom;\n }\n break;\n\n case 'up':\n case 'down':\n if (startingPoint.x <= candidateRect.left) {\n points.entryPoint.x = candidateRect.left;\n } else if (startingPoint.x < candidateRect.right) {\n points.entryPoint.x = startingPoint.x;\n } else {\n points.entryPoint.x = candidateRect.right;\n }\n break;\n }\n }\n else {\n // Set direction\n switch (dir) {\n case 'left':\n points.exitPoint.x = searchOrigin.left;\n points.entryPoint.x = (candidateRect.right < searchOrigin.left) ? candidateRect.right : searchOrigin.left;\n break;\n case 'up':\n points.exitPoint.y = searchOrigin.top;\n points.entryPoint.y = (candidateRect.bottom < searchOrigin.top) ? candidateRect.bottom : searchOrigin.top;\n break;\n case 'right':\n points.exitPoint.x = searchOrigin.right;\n points.entryPoint.x = (candidateRect.left > searchOrigin.right) ? candidateRect.left : searchOrigin.right;\n break;\n case 'down':\n points.exitPoint.y = searchOrigin.bottom;\n points.entryPoint.y = (candidateRect.top > searchOrigin.bottom) ? candidateRect.top : searchOrigin.bottom;\n break;\n }\n\n // Set orthogonal direction\n switch (dir) {\n case 'left':\n case 'right':\n if (isBelow(searchOrigin, candidateRect)) {\n points.exitPoint.y = searchOrigin.top;\n points.entryPoint.y = (candidateRect.bottom < searchOrigin.top) ? candidateRect.bottom : searchOrigin.top;\n } else if (isBelow(candidateRect, searchOrigin)) {\n points.exitPoint.y = searchOrigin.bottom;\n points.entryPoint.y = (candidateRect.top > searchOrigin.bottom) ? candidateRect.top : searchOrigin.bottom;\n } else {\n points.exitPoint.y = Math.max(searchOrigin.top, candidateRect.top);\n points.entryPoint.y = points.exitPoint.y;\n }\n break;\n\n case 'up':\n case 'down':\n if (isRightSide(searchOrigin, candidateRect)) {\n points.exitPoint.x = searchOrigin.left;\n points.entryPoint.x = (candidateRect.right < searchOrigin.left) ? candidateRect.right : searchOrigin.left;\n } else if (isRightSide(candidateRect, searchOrigin)) {\n points.exitPoint.x = searchOrigin.right;\n points.entryPoint.x = (candidateRect.left > searchOrigin.right) ? candidateRect.left : searchOrigin.right;\n } else {\n points.exitPoint.x = Math.max(searchOrigin.left, candidateRect.left);\n points.entryPoint.x = points.exitPoint.x;\n }\n break;\n }\n }\n\n return points;\n }\n\n /**\n * Find focusable elements within the container\n * @see {@link https://drafts.csswg.org/css-nav-1/#find-the-shortest-distance}\n * @function getIntersectionRect\n * @param rect1 {DOMRect} - The search origin which contains the exit point\n * @param rect2 {DOMRect} - One of candidates which contains the entry point\n * @returns {IntersectionArea} The intersection area between two elements.\n *\n * @typeof {Object} IntersectionArea\n * @property {Number} IntersectionArea.width\n * @property {Number} IntersectionArea.height\n */\n function getIntersectionRect(rect1, rect2) {\n const intersection_rect = {width: 0, height: 0, area: 0};\n\n const new_location = [Math.max(rect1.left, rect2.left), Math.max(rect1.top, rect2.top)];\n const new_max_point = [Math.min(rect1.right, rect2.right), Math.min(rect1.bottom, rect2.bottom)];\n\n intersection_rect.width = Math.abs(new_location[0] - new_max_point[0]);\n intersection_rect.height = Math.abs(new_location[1] - new_max_point[1]);\n\n if (!(new_location[0] >= new_max_point[0] || new_location[1] >= new_max_point[1])) {\n // intersecting-cases\n intersection_rect.area = Math.sqrt(intersection_rect.width * intersection_rect.height);\n }\n\n return intersection_rect;\n }\n\n /**\n * Handle the spatial navigation behavior for HTMLInputElement, HTMLTextAreaElement\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input|HTMLInputElement (MDN)}\n * @function handlingEditableElement\n * @param e {Event} - keydownEvent\n * @returns {boolean}\n */\n function handlingEditableElement(e) {\n const SPINNABLE_INPUT_TYPES = ['email', 'date', 'month', 'number', 'time', 'week'],\n TEXT_INPUT_TYPES = ['password', 'text', 'search', 'tel', 'url', null];\n const eventTarget = document.activeElement;\n const startPosition = eventTarget.selectionStart;\n const endPosition = eventTarget.selectionEnd;\n const focusNavigableArrowKey = {left: false, up: false, right: false, down: false};\n\n const dir = ARROW_KEY_CODE[e.keyCode];\n if (dir === undefined) {\n return focusNavigableArrowKey;\n }\n\n if (SPINNABLE_INPUT_TYPES.includes(eventTarget.getAttribute('type')) &&\n (dir === 'up' || dir === 'down')) {\n focusNavigableArrowKey[dir] = true;\n } else if (TEXT_INPUT_TYPES.includes(eventTarget.getAttribute('type')) || eventTarget.nodeName === 'TEXTAREA') {\n if (startPosition === endPosition) { // if there isn't any selected text\n if (startPosition === 0) {\n focusNavigableArrowKey.left = true;\n focusNavigableArrowKey.up = true;\n }\n if (endPosition === eventTarget.value.length) {\n focusNavigableArrowKey.right = true;\n focusNavigableArrowKey.down = true;\n }\n }\n } else { // HTMLDataListElement, HTMLSelectElement, HTMLOptGroup\n focusNavigableArrowKey[dir] = true;\n }\n\n return focusNavigableArrowKey;\n }\n\n /**\n * Get the DOMRect of an element\n * @function getBoundingClientRect\n * @param element {Node}\n * @returns {DOMRect}\n */\n function getBoundingClientRect(element) {\n // memoization\n let rect = mapOfBoundRect && mapOfBoundRect.get(element);\n if (!rect) {\n const boundingClientRect = element.getBoundingClientRect();\n rect = {\n top: Number(boundingClientRect.top.toFixed(2)),\n right: Number(boundingClientRect.right.toFixed(2)),\n bottom: Number(boundingClientRect.bottom.toFixed(2)),\n left: Number(boundingClientRect.left.toFixed(2)),\n width: Number(boundingClientRect.width.toFixed(2)),\n height: Number(boundingClientRect.height.toFixed(2))\n };\n mapOfBoundRect && mapOfBoundRect.set(element, rect);\n }\n return rect;\n }\n\n /**\n * Get the list of the experimental APIs\n * @function getExperimentalAPI\n */\n function getExperimentalAPI() {\n function canScroll(container, dir) {\n return (isScrollable(container, dir) && !isScrollBoundary(container, dir)) ||\n (!container.parentElement && !isHTMLScrollBoundary(container, dir));\n }\n\n function findTarget(findCandidate, element, dir, option) {\n let eventTarget = element;\n let bestNextTarget = null;\n\n // 4\n if (eventTarget === document || eventTarget === document.documentElement) {\n eventTarget = document.body || document.documentElement;\n }\n\n // 5\n // At this point, spatialNavigationSearch can be applied.\n // If startingPoint is either a scroll container or the document,\n // find the best candidate within startingPoint\n if ((isContainer(eventTarget) || eventTarget.nodeName === 'BODY') && !(eventTarget.nodeName === 'INPUT')) {\n if (eventTarget.nodeName === 'IFRAME')\n eventTarget = eventTarget.contentDocument.body;\n\n const candidates = getSpatialNavigationCandidates(eventTarget, option);\n\n // 5-2\n if (Array.isArray(candidates) && candidates.length > 0) {\n return findCandidate ? getFilteredSpatialNavigationCandidates(eventTarget, dir, candidates) : eventTarget.spatialNavigationSearch(dir, {candidates});\n }\n if (canScroll(eventTarget, dir)) {\n return findCandidate ? [] : eventTarget;\n }\n }\n\n // 6\n // Let container be the nearest ancestor of eventTarget\n let container = eventTarget.getSpatialNavigationContainer();\n let parentContainer = (container.parentElement) ? container.getSpatialNavigationContainer() : null;\n\n // When the container is the viewport of a browsing context\n if (!parentContainer && ( window.location !== window.parent.location)) {\n parentContainer = window.parent.document.documentElement;\n }\n\n // 7\n while (parentContainer) {\n const candidates = filteredCandidates(eventTarget, getSpatialNavigationCandidates(container, option), dir, container);\n\n if (Array.isArray(candidates) && candidates.length > 0) {\n bestNextTarget = eventTarget.spatialNavigationSearch(dir, {candidates, container});\n if (bestNextTarget) {\n return findCandidate ? candidates : bestNextTarget;\n }\n }\n\n // If there isn't any candidate and the best candidate among candidate:\n // 1) Scroll or 2) Find candidates of the ancestor container\n // 8 - if\n else if (canScroll(container, dir)) {\n return findCandidate ? [] : eventTarget;\n } else if (container === document || container === document.documentElement) {\n container = window.document.documentElement;\n\n // The page is in an iframe\n if ( window.location !== window.parent.location ) {\n\n // eventTarget needs to be reset because the position of the element in the IFRAME\n // is unuseful when the focus moves out of the iframe\n eventTarget = window.frameElement;\n container = window.parent.document.documentElement;\n if (container.parentElement)\n parentContainer = container.getSpatialNavigationContainer();\n else {\n parentContainer = null;\n break;\n }\n }\n } else {\n // avoiding when spatnav container with tabindex=-1\n if (isFocusable(container)) {\n eventTarget = container;\n }\n\n container = parentContainer;\n if (container.parentElement)\n parentContainer = container.getSpatialNavigationContainer();\n else {\n parentContainer = null;\n break;\n }\n }\n }\n\n if (!parentContainer && container) {\n // Getting out from the current spatnav container\n const candidates = filteredCandidates(eventTarget, getSpatialNavigationCandidates(container, option), dir, container);\n\n // 9\n if (Array.isArray(candidates) && candidates.length > 0) {\n bestNextTarget = eventTarget.spatialNavigationSearch(dir, {candidates, container});\n if (bestNextTarget) {\n return findCandidate ? candidates : bestNextTarget;\n }\n }\n }\n\n if (canScroll(container, dir)) {\n bestNextTarget = eventTarget;\n return bestNextTarget;\n }\n }\n\n return {\n isContainer,\n isScrollContainer,\n findCandidates: findTarget.bind(null, true),\n findNextTarget: findTarget.bind(null, false),\n getDistanceFromTarget: (element, candidateElement, dir) => {\n if ((isContainer(element) || element.nodeName === 'BODY') && !(element.nodeName === 'INPUT')) {\n if (getSpatialNavigationCandidates(element).includes(candidateElement)) {\n return getInnerDistance(getBoundingClientRect(element), getBoundingClientRect(candidateElement), dir);\n }\n }\n return getDistance(getBoundingClientRect(element), getBoundingClientRect(candidateElement), dir);\n }\n };\n }\n\n /**\n * Makes to use the experimental APIs.\n * @function enableExperimentalAPIs\n * @param option {boolean} - If it is true, the experimental APIs can be used or it cannot.\n */\n function enableExperimentalAPIs (option) {\n const currentKeyMode = window.__spatialNavigation__ && window.__spatialNavigation__.keyMode;\n window.__spatialNavigation__ = (option === false) ? getInitialAPIs() : Object.assign(getInitialAPIs(), getExperimentalAPI());\n window.__spatialNavigation__.keyMode = currentKeyMode;\n Object.seal(window.__spatialNavigation__);\n }\n\n /**\n * Set the environment for using the spatial navigation polyfill.\n * @function getInitialAPIs\n */\n function getInitialAPIs() {\n return {\n enableExperimentalAPIs,\n get keyMode() { return this._keymode ? this._keymode : 'ARROW'; },\n set keyMode(mode) { this._keymode = (['SHIFTARROW', 'ARROW', 'NONE'].includes(mode)) ? mode : 'ARROW'; },\n setStartingPoint: function (x, y) {startingPoint = (x && y) ? {x, y} : null;}\n };\n }\n\n window.addEventListener('load', () => {\n initiateSpatialNavigation();\n enableExperimentalAPIs(false);\n });\n})();\n","// No automatic generation: we don't want to depend on fs, as we want to keep this universal\n// ls *-*.json | while read line; do printf \"\\\"`printf $line | cut -d '.' -f1`\\\": require(\\\"./$line\\\"),\\n\"; done\nmodule.exports = function() {\n\treturn {\n\t\t\"ar-AR\": require(\"./ar-AR.json\"),\n\t\t\"id-ID\": require(\"./id-ID.json\"),\n\t\t\"bg-BG\": require(\"./bg-BG.json\"),\n\t\t\"ca-CA\": require(\"./ca-CA.json\"),\n\t\t\"da-DK\": require(\"./da-DK.json\"),\n\t\t\"de-DE\": require(\"./de-DE.json\"),\n\t\t\"el-GR\": require(\"./el-GR.json\"),\n\t\t\"en-US\": require(\"./en-US.json\"),\n\t\t\"eo-EO\": require(\"./eo-EO.json\"),\n\t\t\"es-ES\": require(\"./es-ES.json\"),\n\t\t\"eu-ES\": require(\"./eu-ES.json\"),\n\t\t\"fa-IR\": require(\"./fa-IR.json\"),\n\t\t\"fr-FR\": require(\"./fr-FR.json\"),\n\t\t\"he-IL\": require(\"./he-IL.json\"),\n\t\t\"hi-IN\": require(\"./hi-IN.json\"),\n\t\t\"hr-HR\": require(\"./hr-HR.json\"),\n\t\t\"hu-HU\": require(\"./hu-HU.json\"),\n\t\t\"it-IT\": require(\"./it-IT.json\"),\n\t\t\"mk-MK\": require(\"./mk-MK.json\"),\n\t\t\"my-BM\": require(\"./my-BM.json\"),\n\t\t\"nb-NO\": require(\"./nb-NO.json\"),\n\t\t\"nl-NL\": require(\"./nl-NL.json\"),\n\t\t\"nn-NO\": require(\"./nn-NO.json\"),\n\t\t\"pl-PL\": require(\"./pl-PL.json\"),\n\t\t\"pt-BR\": require(\"./pt-BR.json\"),\n\t\t\"pt-PT\": require(\"./pt-PT.json\"),\n\t\t\"ru-RU\": require(\"./ru-RU.json\"),\n\t\t\"sv-SE\": require(\"./sv-SE.json\"),\n\t\t\"sr-RS\": require(\"./sr-RS.json\"),\n\t\t\"tr-TR\": require(\"./tr-TR.json\"),\n\t\t\"zh-CN\": require(\"./zh-CN.json\"),\n\t\t\"zh-HK\": require(\"./zh-HK.json\"),\n\t\t\"sl-SL\": require(\"./sl-SL.json\"),\n\t\t\"cs-CZ\": require(\"./cs-CZ.json\"),\n\t\t\"te-IN\": require(\"./te-IN.json\"),\n\t\t\"zh-TW\": require(\"./zh-TW.json\"),\n\t}\n};\n\n// ls *-*.json | while read line; do printf \"\\\"`printf $line | cut -d '.' -f1`\\\",\\n\"; done\nmodule.exports.all = [\n\t\"ar-AR\",\n\t\"id-ID\",\n\t\"bg-BG\",\n\t\"ca-CA\",\n\t\"da-DK\",\n\t\"de-DE\",\n\t\"el-GR\",\n\t\"en-US\",\n\t\"eo-EO\",\n\t\"es-ES\",\n\t\"eu-ES\",\n\t\"fa-IR\",\n\t\"fr-FR\",\n\t\"he-IL\",\n\t\"hi-IN\",\n\t\"hr-HR\",\n\t\"hu-HU\",\n\t\"it-IT\",\n\t\"mk-MK\",\n\t\"my-BM\",\n\t\"nb-NO\",\n\t\"nl-NL\",\n\t\"nn-NO\",\n\t\"pl-PL\",\n\t\"pt-BR\",\n\t\"pt-PT\",\n\t\"ru-RU\",\n\t\"sv-SE\",\n\t\"sr-RS\",\n\t\"tr-TR\",\n\t\"zh-CN\",\n\t\"zh-HK\",\n\t\"sl-SL\",\n\t\"cs-CZ\",\n\t\"te-IN\",\n\t\"zh-TW\"\n];\n","/* \nCopyright (c) 2011, Chris Umbel\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in \nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN \nTHE SOFTWARE.\n*/\n\nvar base32 = require('./thirty-two');\n\nexports.encode = base32.encode;\nexports.decode = base32.decode;\n","/*\nCopyright (c) 2011, Chris Umbel\n\nPermission is hereby granted, free of charge, to any person obtaining a copy\nof this software and associated documentation files (the \"Software\"), to deal\nin the Software without restriction, including without limitation the rights\nto use, copy, modify, merge, publish, distribute, sublicense, and/or sell\ncopies of the Software, and to permit persons to whom the Software is\nfurnished to do so, subject to the following conditions:\n\nThe above copyright notice and this permission notice shall be included in\nall copies or substantial portions of the Software.\n\nTHE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\nIMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\nFITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\nAUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\nLIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\nOUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\nTHE SOFTWARE.\n*/\n'use strict';\n\nvar charTable = \"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567\";\nvar byteTable = [\n 0xff, 0xff, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f,\n 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff,\n 0xff, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06,\n 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e,\n 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n 0x17, 0x18, 0x19, 0xff, 0xff, 0xff, 0xff, 0xff,\n 0xff, 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06,\n 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e,\n 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16,\n 0x17, 0x18, 0x19, 0xff, 0xff, 0xff, 0xff, 0xff\n];\n\nfunction quintetCount(buff) {\n var quintets = Math.floor(buff.length / 5);\n return buff.length % 5 === 0 ? quintets: quintets + 1;\n}\n\nexports.encode = function(plain) {\n if(!Buffer.isBuffer(plain)){\n \tplain = new Buffer(plain);\n }\n var i = 0;\n var j = 0;\n var shiftIndex = 0;\n var digit = 0;\n var encoded = new Buffer(quintetCount(plain) * 8);\n\n /* byte by byte isn't as pretty as quintet by quintet but tests a bit\n faster. will have to revisit. */\n while(i < plain.length) {\n var current = plain[i];\n\n if(shiftIndex > 3) {\n digit = current & (0xff >> shiftIndex);\n shiftIndex = (shiftIndex + 5) % 8;\n digit = (digit << shiftIndex) | ((i + 1 < plain.length) ?\n plain[i + 1] : 0) >> (8 - shiftIndex);\n i++;\n } else {\n digit = (current >> (8 - (shiftIndex + 5))) & 0x1f;\n shiftIndex = (shiftIndex + 5) % 8;\n if(shiftIndex === 0) i++;\n }\n\n encoded[j] = charTable.charCodeAt(digit);\n j++;\n }\n\n for(i = j; i < encoded.length; i++) {\n encoded[i] = 0x3d; //'='.charCodeAt(0)\n }\n\n return encoded;\n};\n\nexports.decode = function(encoded) {\n var shiftIndex = 0;\n var plainDigit = 0;\n var plainChar;\n var plainPos = 0;\n if(!Buffer.isBuffer(encoded)){\n \tencoded = new Buffer(encoded);\n }\n var decoded = new Buffer(Math.ceil(encoded.length * 5 / 8));\n\n /* byte by byte isn't as pretty as octet by octet but tests a bit\n faster. will have to revisit. */\n for(var i = 0; i < encoded.length; i++) {\n \tif(encoded[i] === 0x3d){ //'='\n \t\tbreak;\n \t}\n\n var encodedByte = encoded[i] - 0x30;\n\n if(encodedByte < byteTable.length) {\n plainDigit = byteTable[encodedByte];\n\n if(shiftIndex <= 3) {\n shiftIndex = (shiftIndex + 5) % 8;\n\n if(shiftIndex === 0) {\n plainChar |= plainDigit;\n decoded[plainPos] = plainChar;\n plainPos++;\n plainChar = 0;\n } else {\n plainChar |= 0xff & (plainDigit << (8 - shiftIndex));\n }\n } else {\n shiftIndex = (shiftIndex + 5) % 8;\n plainChar |= 0xff & (plainDigit >>> shiftIndex);\n decoded[plainPos] = plainChar;\n plainPos++;\n\n plainChar = 0xff & (plainDigit << (8 - shiftIndex));\n }\n } else {\n \tthrow new Error('Invalid input - it is not base32 encoded string');\n }\n }\n\n return decoded.slice(0, plainPos);\n};\n","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n'use strict';\n\nvar punycode = require('punycode');\nvar util = require('./util');\n\nexports.parse = urlParse;\nexports.resolve = urlResolve;\nexports.resolveObject = urlResolveObject;\nexports.format = urlFormat;\n\nexports.Url = Url;\n\nfunction Url() {\n this.protocol = null;\n this.slashes = null;\n this.auth = null;\n this.host = null;\n this.port = null;\n this.hostname = null;\n this.hash = null;\n this.search = null;\n this.query = null;\n this.pathname = null;\n this.path = null;\n this.href = null;\n}\n\n// Reference: RFC 3986, RFC 1808, RFC 2396\n\n// define these here so at least they only have to be\n// compiled once on the first module load.\nvar protocolPattern = /^([a-z0-9.+-]+:)/i,\n portPattern = /:[0-9]*$/,\n\n // Special case for a simple path URL\n simplePathPattern = /^(\\/\\/?(?!\\/)[^\\?\\s]*)(\\?[^\\s]*)?$/,\n\n // RFC 2396: characters reserved for delimiting URLs.\n // We actually just auto-escape these.\n delims = ['<', '>', '\"', '`', ' ', '\\r', '\\n', '\\t'],\n\n // RFC 2396: characters not allowed for various reasons.\n unwise = ['{', '}', '|', '\\\\', '^', '`'].concat(delims),\n\n // Allowed by RFCs, but cause of XSS attacks. Always escape these.\n autoEscape = ['\\''].concat(unwise),\n // Characters that are never ever allowed in a hostname.\n // Note that any invalid chars are also handled, but these\n // are the ones that are *expected* to be seen, so we fast-path\n // them.\n nonHostChars = ['%', '/', '?', ';', '#'].concat(autoEscape),\n hostEndingChars = ['/', '?', '#'],\n hostnameMaxLen = 255,\n hostnamePartPattern = /^[+a-z0-9A-Z_-]{0,63}$/,\n hostnamePartStart = /^([+a-z0-9A-Z_-]{0,63})(.*)$/,\n // protocols that can allow \"unsafe\" and \"unwise\" chars.\n unsafeProtocol = {\n 'javascript': true,\n 'javascript:': true\n },\n // protocols that never have a hostname.\n hostlessProtocol = {\n 'javascript': true,\n 'javascript:': true\n },\n // protocols that always contain a // bit.\n slashedProtocol = {\n 'http': true,\n 'https': true,\n 'ftp': true,\n 'gopher': true,\n 'file': true,\n 'http:': true,\n 'https:': true,\n 'ftp:': true,\n 'gopher:': true,\n 'file:': true\n },\n querystring = require('querystring');\n\nfunction urlParse(url, parseQueryString, slashesDenoteHost) {\n if (url && util.isObject(url) && url instanceof Url) return url;\n\n var u = new Url;\n u.parse(url, parseQueryString, slashesDenoteHost);\n return u;\n}\n\nUrl.prototype.parse = function(url, parseQueryString, slashesDenoteHost) {\n if (!util.isString(url)) {\n throw new TypeError(\"Parameter 'url' must be a string, not \" + typeof url);\n }\n\n // Copy chrome, IE, opera backslash-handling behavior.\n // Back slashes before the query string get converted to forward slashes\n // See: https://code.google.com/p/chromium/issues/detail?id=25916\n var queryIndex = url.indexOf('?'),\n splitter =\n (queryIndex !== -1 && queryIndex < url.indexOf('#')) ? '?' : '#',\n uSplit = url.split(splitter),\n slashRegex = /\\\\/g;\n uSplit[0] = uSplit[0].replace(slashRegex, '/');\n url = uSplit.join(splitter);\n\n var rest = url;\n\n // trim before proceeding.\n // This is to support parse stuff like \" http://foo.com \\n\"\n rest = rest.trim();\n\n if (!slashesDenoteHost && url.split('#').length === 1) {\n // Try fast path regexp\n var simplePath = simplePathPattern.exec(rest);\n if (simplePath) {\n this.path = rest;\n this.href = rest;\n this.pathname = simplePath[1];\n if (simplePath[2]) {\n this.search = simplePath[2];\n if (parseQueryString) {\n this.query = querystring.parse(this.search.substr(1));\n } else {\n this.query = this.search.substr(1);\n }\n } else if (parseQueryString) {\n this.search = '';\n this.query = {};\n }\n return this;\n }\n }\n\n var proto = protocolPattern.exec(rest);\n if (proto) {\n proto = proto[0];\n var lowerProto = proto.toLowerCase();\n this.protocol = lowerProto;\n rest = rest.substr(proto.length);\n }\n\n // figure out if it's got a host\n // user@server is *always* interpreted as a hostname, and url\n // resolution will treat //foo/bar as host=foo,path=bar because that's\n // how the browser resolves relative URLs.\n if (slashesDenoteHost || proto || rest.match(/^\\/\\/[^@\\/]+@[^@\\/]+/)) {\n var slashes = rest.substr(0, 2) === '//';\n if (slashes && !(proto && hostlessProtocol[proto])) {\n rest = rest.substr(2);\n this.slashes = true;\n }\n }\n\n if (!hostlessProtocol[proto] &&\n (slashes || (proto && !slashedProtocol[proto]))) {\n\n // there's a hostname.\n // the first instance of /, ?, ;, or # ends the host.\n //\n // If there is an @ in the hostname, then non-host chars *are* allowed\n // to the left of the last @ sign, unless some host-ending character\n // comes *before* the @-sign.\n // URLs are obnoxious.\n //\n // ex:\n // http://a@b@c/ => user:a@b host:c\n // http://a@b?@c => user:a host:c path:/?@c\n\n // v0.12 TODO(isaacs): This is not quite how Chrome does things.\n // Review our test case against browsers more comprehensively.\n\n // find the first instance of any hostEndingChars\n var hostEnd = -1;\n for (var i = 0; i < hostEndingChars.length; i++) {\n var hec = rest.indexOf(hostEndingChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n hostEnd = hec;\n }\n\n // at this point, either we have an explicit point where the\n // auth portion cannot go past, or the last @ char is the decider.\n var auth, atSign;\n if (hostEnd === -1) {\n // atSign can be anywhere.\n atSign = rest.lastIndexOf('@');\n } else {\n // atSign must be in auth portion.\n // http://a@b/c@d => host:b auth:a path:/c@d\n atSign = rest.lastIndexOf('@', hostEnd);\n }\n\n // Now we have a portion which is definitely the auth.\n // Pull that off.\n if (atSign !== -1) {\n auth = rest.slice(0, atSign);\n rest = rest.slice(atSign + 1);\n this.auth = decodeURIComponent(auth);\n }\n\n // the host is the remaining to the left of the first non-host char\n hostEnd = -1;\n for (var i = 0; i < nonHostChars.length; i++) {\n var hec = rest.indexOf(nonHostChars[i]);\n if (hec !== -1 && (hostEnd === -1 || hec < hostEnd))\n hostEnd = hec;\n }\n // if we still have not hit it, then the entire thing is a host.\n if (hostEnd === -1)\n hostEnd = rest.length;\n\n this.host = rest.slice(0, hostEnd);\n rest = rest.slice(hostEnd);\n\n // pull out port.\n this.parseHost();\n\n // we've indicated that there is a hostname,\n // so even if it's empty, it has to be present.\n this.hostname = this.hostname || '';\n\n // if hostname begins with [ and ends with ]\n // assume that it's an IPv6 address.\n var ipv6Hostname = this.hostname[0] === '[' &&\n this.hostname[this.hostname.length - 1] === ']';\n\n // validate a little.\n if (!ipv6Hostname) {\n var hostparts = this.hostname.split(/\\./);\n for (var i = 0, l = hostparts.length; i < l; i++) {\n var part = hostparts[i];\n if (!part) continue;\n if (!part.match(hostnamePartPattern)) {\n var newpart = '';\n for (var j = 0, k = part.length; j < k; j++) {\n if (part.charCodeAt(j) > 127) {\n // we replace non-ASCII char with a temporary placeholder\n // we need this to make sure size of hostname is not\n // broken by replacing non-ASCII by nothing\n newpart += 'x';\n } else {\n newpart += part[j];\n }\n }\n // we test again with ASCII char only\n if (!newpart.match(hostnamePartPattern)) {\n var validParts = hostparts.slice(0, i);\n var notHost = hostparts.slice(i + 1);\n var bit = part.match(hostnamePartStart);\n if (bit) {\n validParts.push(bit[1]);\n notHost.unshift(bit[2]);\n }\n if (notHost.length) {\n rest = '/' + notHost.join('.') + rest;\n }\n this.hostname = validParts.join('.');\n break;\n }\n }\n }\n }\n\n if (this.hostname.length > hostnameMaxLen) {\n this.hostname = '';\n } else {\n // hostnames are always lower case.\n this.hostname = this.hostname.toLowerCase();\n }\n\n if (!ipv6Hostname) {\n // IDNA Support: Returns a punycoded representation of \"domain\".\n // It only converts parts of the domain name that\n // have non-ASCII characters, i.e. it doesn't matter if\n // you call it with a domain that already is ASCII-only.\n this.hostname = punycode.toASCII(this.hostname);\n }\n\n var p = this.port ? ':' + this.port : '';\n var h = this.hostname || '';\n this.host = h + p;\n this.href += this.host;\n\n // strip [ and ] from the hostname\n // the host field still retains them, though\n if (ipv6Hostname) {\n this.hostname = this.hostname.substr(1, this.hostname.length - 2);\n if (rest[0] !== '/') {\n rest = '/' + rest;\n }\n }\n }\n\n // now rest is set to the post-host stuff.\n // chop off any delim chars.\n if (!unsafeProtocol[lowerProto]) {\n\n // First, make 100% sure that any \"autoEscape\" chars get\n // escaped, even if encodeURIComponent doesn't think they\n // need to be.\n for (var i = 0, l = autoEscape.length; i < l; i++) {\n var ae = autoEscape[i];\n if (rest.indexOf(ae) === -1)\n continue;\n var esc = encodeURIComponent(ae);\n if (esc === ae) {\n esc = escape(ae);\n }\n rest = rest.split(ae).join(esc);\n }\n }\n\n\n // chop off from the tail first.\n var hash = rest.indexOf('#');\n if (hash !== -1) {\n // got a fragment string.\n this.hash = rest.substr(hash);\n rest = rest.slice(0, hash);\n }\n var qm = rest.indexOf('?');\n if (qm !== -1) {\n this.search = rest.substr(qm);\n this.query = rest.substr(qm + 1);\n if (parseQueryString) {\n this.query = querystring.parse(this.query);\n }\n rest = rest.slice(0, qm);\n } else if (parseQueryString) {\n // no query string, but parseQueryString still requested\n this.search = '';\n this.query = {};\n }\n if (rest) this.pathname = rest;\n if (slashedProtocol[lowerProto] &&\n this.hostname && !this.pathname) {\n this.pathname = '/';\n }\n\n //to support http.request\n if (this.pathname || this.search) {\n var p = this.pathname || '';\n var s = this.search || '';\n this.path = p + s;\n }\n\n // finally, reconstruct the href based on what has been validated.\n this.href = this.format();\n return this;\n};\n\n// format a parsed object into a url string\nfunction urlFormat(obj) {\n // ensure it's an object, and not a string url.\n // If it's an obj, this is a no-op.\n // this way, you can call url_format() on strings\n // to clean up potentially wonky urls.\n if (util.isString(obj)) obj = urlParse(obj);\n if (!(obj instanceof Url)) return Url.prototype.format.call(obj);\n return obj.format();\n}\n\nUrl.prototype.format = function() {\n var auth = this.auth || '';\n if (auth) {\n auth = encodeURIComponent(auth);\n auth = auth.replace(/%3A/i, ':');\n auth += '@';\n }\n\n var protocol = this.protocol || '',\n pathname = this.pathname || '',\n hash = this.hash || '',\n host = false,\n query = '';\n\n if (this.host) {\n host = auth + this.host;\n } else if (this.hostname) {\n host = auth + (this.hostname.indexOf(':') === -1 ?\n this.hostname :\n '[' + this.hostname + ']');\n if (this.port) {\n host += ':' + this.port;\n }\n }\n\n if (this.query &&\n util.isObject(this.query) &&\n Object.keys(this.query).length) {\n query = querystring.stringify(this.query);\n }\n\n var search = this.search || (query && ('?' + query)) || '';\n\n if (protocol && protocol.substr(-1) !== ':') protocol += ':';\n\n // only the slashedProtocols get the //. Not mailto:, xmpp:, etc.\n // unless they had them to begin with.\n if (this.slashes ||\n (!protocol || slashedProtocol[protocol]) && host !== false) {\n host = '//' + (host || '');\n if (pathname && pathname.charAt(0) !== '/') pathname = '/' + pathname;\n } else if (!host) {\n host = '';\n }\n\n if (hash && hash.charAt(0) !== '#') hash = '#' + hash;\n if (search && search.charAt(0) !== '?') search = '?' + search;\n\n pathname = pathname.replace(/[?#]/g, function(match) {\n return encodeURIComponent(match);\n });\n search = search.replace('#', '%23');\n\n return protocol + host + pathname + search + hash;\n};\n\nfunction urlResolve(source, relative) {\n return urlParse(source, false, true).resolve(relative);\n}\n\nUrl.prototype.resolve = function(relative) {\n return this.resolveObject(urlParse(relative, false, true)).format();\n};\n\nfunction urlResolveObject(source, relative) {\n if (!source) return relative;\n return urlParse(source, false, true).resolveObject(relative);\n}\n\nUrl.prototype.resolveObject = function(relative) {\n if (util.isString(relative)) {\n var rel = new Url();\n rel.parse(relative, false, true);\n relative = rel;\n }\n\n var result = new Url();\n var tkeys = Object.keys(this);\n for (var tk = 0; tk < tkeys.length; tk++) {\n var tkey = tkeys[tk];\n result[tkey] = this[tkey];\n }\n\n // hash is always overridden, no matter what.\n // even href=\"\" will remove it.\n result.hash = relative.hash;\n\n // if the relative url is empty, then there's nothing left to do here.\n if (relative.href === '') {\n result.href = result.format();\n return result;\n }\n\n // hrefs like //foo/bar always cut to the protocol.\n if (relative.slashes && !relative.protocol) {\n // take everything except the protocol from relative\n var rkeys = Object.keys(relative);\n for (var rk = 0; rk < rkeys.length; rk++) {\n var rkey = rkeys[rk];\n if (rkey !== 'protocol')\n result[rkey] = relative[rkey];\n }\n\n //urlParse appends trailing / to urls like http://www.example.com\n if (slashedProtocol[result.protocol] &&\n result.hostname && !result.pathname) {\n result.path = result.pathname = '/';\n }\n\n result.href = result.format();\n return result;\n }\n\n if (relative.protocol && relative.protocol !== result.protocol) {\n // if it's a known url protocol, then changing\n // the protocol does weird things\n // first, if it's not file:, then we MUST have a host,\n // and if there was a path\n // to begin with, then we MUST have a path.\n // if it is file:, then the host is dropped,\n // because that's known to be hostless.\n // anything else is assumed to be absolute.\n if (!slashedProtocol[relative.protocol]) {\n var keys = Object.keys(relative);\n for (var v = 0; v < keys.length; v++) {\n var k = keys[v];\n result[k] = relative[k];\n }\n result.href = result.format();\n return result;\n }\n\n result.protocol = relative.protocol;\n if (!relative.host && !hostlessProtocol[relative.protocol]) {\n var relPath = (relative.pathname || '').split('/');\n while (relPath.length && !(relative.host = relPath.shift()));\n if (!relative.host) relative.host = '';\n if (!relative.hostname) relative.hostname = '';\n if (relPath[0] !== '') relPath.unshift('');\n if (relPath.length < 2) relPath.unshift('');\n result.pathname = relPath.join('/');\n } else {\n result.pathname = relative.pathname;\n }\n result.search = relative.search;\n result.query = relative.query;\n result.host = relative.host || '';\n result.auth = relative.auth;\n result.hostname = relative.hostname || relative.host;\n result.port = relative.port;\n // to support http.request\n if (result.pathname || result.search) {\n var p = result.pathname || '';\n var s = result.search || '';\n result.path = p + s;\n }\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n }\n\n var isSourceAbs = (result.pathname && result.pathname.charAt(0) === '/'),\n isRelAbs = (\n relative.host ||\n relative.pathname && relative.pathname.charAt(0) === '/'\n ),\n mustEndAbs = (isRelAbs || isSourceAbs ||\n (result.host && relative.pathname)),\n removeAllDots = mustEndAbs,\n srcPath = result.pathname && result.pathname.split('/') || [],\n relPath = relative.pathname && relative.pathname.split('/') || [],\n psychotic = result.protocol && !slashedProtocol[result.protocol];\n\n // if the url is a non-slashed url, then relative\n // links like ../.. should be able\n // to crawl up to the hostname, as well. This is strange.\n // result.protocol has already been set by now.\n // Later on, put the first path part into the host field.\n if (psychotic) {\n result.hostname = '';\n result.port = null;\n if (result.host) {\n if (srcPath[0] === '') srcPath[0] = result.host;\n else srcPath.unshift(result.host);\n }\n result.host = '';\n if (relative.protocol) {\n relative.hostname = null;\n relative.port = null;\n if (relative.host) {\n if (relPath[0] === '') relPath[0] = relative.host;\n else relPath.unshift(relative.host);\n }\n relative.host = null;\n }\n mustEndAbs = mustEndAbs && (relPath[0] === '' || srcPath[0] === '');\n }\n\n if (isRelAbs) {\n // it's absolute.\n result.host = (relative.host || relative.host === '') ?\n relative.host : result.host;\n result.hostname = (relative.hostname || relative.hostname === '') ?\n relative.hostname : result.hostname;\n result.search = relative.search;\n result.query = relative.query;\n srcPath = relPath;\n // fall through to the dot-handling below.\n } else if (relPath.length) {\n // it's relative\n // throw away the existing file, and take the new path instead.\n if (!srcPath) srcPath = [];\n srcPath.pop();\n srcPath = srcPath.concat(relPath);\n result.search = relative.search;\n result.query = relative.query;\n } else if (!util.isNullOrUndefined(relative.search)) {\n // just pull out the search.\n // like href='?foo'.\n // Put this after the other two cases because it simplifies the booleans\n if (psychotic) {\n result.hostname = result.host = srcPath.shift();\n //occationaly the auth can get stuck only in host\n //this especially happens in cases like\n //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n var authInHost = result.host && result.host.indexOf('@') > 0 ?\n result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.host = result.hostname = authInHost.shift();\n }\n }\n result.search = relative.search;\n result.query = relative.query;\n //to support http.request\n if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n result.path = (result.pathname ? result.pathname : '') +\n (result.search ? result.search : '');\n }\n result.href = result.format();\n return result;\n }\n\n if (!srcPath.length) {\n // no path at all. easy.\n // we've already handled the other stuff above.\n result.pathname = null;\n //to support http.request\n if (result.search) {\n result.path = '/' + result.search;\n } else {\n result.path = null;\n }\n result.href = result.format();\n return result;\n }\n\n // if a url ENDs in . or .., then it must get a trailing slash.\n // however, if it ends in anything else non-slashy,\n // then it must NOT get a trailing slash.\n var last = srcPath.slice(-1)[0];\n var hasTrailingSlash = (\n (result.host || relative.host || srcPath.length > 1) &&\n (last === '.' || last === '..') || last === '');\n\n // strip single dots, resolve double dots to parent dir\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = srcPath.length; i >= 0; i--) {\n last = srcPath[i];\n if (last === '.') {\n srcPath.splice(i, 1);\n } else if (last === '..') {\n srcPath.splice(i, 1);\n up++;\n } else if (up) {\n srcPath.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (!mustEndAbs && !removeAllDots) {\n for (; up--; up) {\n srcPath.unshift('..');\n }\n }\n\n if (mustEndAbs && srcPath[0] !== '' &&\n (!srcPath[0] || srcPath[0].charAt(0) !== '/')) {\n srcPath.unshift('');\n }\n\n if (hasTrailingSlash && (srcPath.join('/').substr(-1) !== '/')) {\n srcPath.push('');\n }\n\n var isAbsolute = srcPath[0] === '' ||\n (srcPath[0] && srcPath[0].charAt(0) === '/');\n\n // put the host back\n if (psychotic) {\n result.hostname = result.host = isAbsolute ? '' :\n srcPath.length ? srcPath.shift() : '';\n //occationaly the auth can get stuck only in host\n //this especially happens in cases like\n //url.resolveObject('mailto:local1@domain1', 'local2@domain2')\n var authInHost = result.host && result.host.indexOf('@') > 0 ?\n result.host.split('@') : false;\n if (authInHost) {\n result.auth = authInHost.shift();\n result.host = result.hostname = authInHost.shift();\n }\n }\n\n mustEndAbs = mustEndAbs || (result.host && srcPath.length);\n\n if (mustEndAbs && !isAbsolute) {\n srcPath.unshift('');\n }\n\n if (!srcPath.length) {\n result.pathname = null;\n result.path = null;\n } else {\n result.pathname = srcPath.join('/');\n }\n\n //to support request.http\n if (!util.isNull(result.pathname) || !util.isNull(result.search)) {\n result.path = (result.pathname ? result.pathname : '') +\n (result.search ? result.search : '');\n }\n result.auth = relative.auth || result.auth;\n result.slashes = result.slashes || relative.slashes;\n result.href = result.format();\n return result;\n};\n\nUrl.prototype.parseHost = function() {\n var host = this.host;\n var port = portPattern.exec(host);\n if (port) {\n port = port[0];\n if (port !== ':') {\n this.port = port.substr(1);\n }\n host = host.substr(0, host.length - port.length);\n }\n if (host) this.hostname = host;\n};\n","'use strict';\n\nmodule.exports = {\n isString: function(arg) {\n return typeof(arg) === 'string';\n },\n isObject: function(arg) {\n return typeof(arg) === 'object' && arg !== null;\n },\n isNull: function(arg) {\n return arg === null;\n },\n isNullOrUndefined: function(arg) {\n return arg == null;\n }\n};\n","/**\n * This file automatically generated from `pre-publish.js`.\n * Do not manually edit.\n */\n\nmodule.exports = {\n \"area\": true,\n \"base\": true,\n \"br\": true,\n \"col\": true,\n \"embed\": true,\n \"hr\": true,\n \"img\": true,\n \"input\": true,\n \"link\": true,\n \"meta\": true,\n \"param\": true,\n \"source\": true,\n \"track\": true,\n \"wbr\": true\n};\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// Default exports for Node. Export the extended versions of VTTCue and\n// VTTRegion in Node since we likely want the capability to convert back and\n// forth between JSON. If we don't then it's not that big of a deal since we're\n// off browser.\nmodule.exports = {\n WebVTT: require(\"./vtt.js\").WebVTT,\n VTTCue: require(\"./vttcue-extended.js\").VTTCue,\n VTTRegion: require(\"./vttregion-extended.js\").VTTRegion\n};\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n/* -*- Mode: Java; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */\n/* vim: set shiftwidth=2 tabstop=2 autoindent cindent expandtab: */\n\n(function(global) {\n function makeColorSet(color, opacity) {\n if(opacity === undefined) {\n opacity = 1;\n }\n return \"rgba(\" + [parseInt(color.substring(0, 2), 16),\n parseInt(color.substring(2, 4), 16),\n parseInt(color.substring(4, 6), 16),\n opacity].join(\",\") + \")\";\n }\n\n var WebVTTPrefs = ['webvtt.font.color', 'webvtt.font.opacity', 'webvtt.font.scale',\n 'webvtt.bg.color', 'webvtt.bg.opacity',\n 'webvtt.edge.color', 'webvtt.edge.type'];\n\n var fontScale = 1;\n\n function observe(subject, topic, data) {\n switch (data) {\n case \"webvtt.font.color\":\n case \"webvtt.font.opacity\":\n var fontColor = Services.prefs.getCharPref(\"webvtt.font.color\");\n var fontOpacity = Services.prefs.getIntPref(\"webvtt.font.opacity\") / 100;\n WebVTTSet.fontSet = makeColorSet(fontColor, fontOpacity);\n break;\n case \"webvtt.font.scale\":\n fontScale = Services.prefs.getIntPref(\"webvtt.font.scale\") / 100;\n break;\n case \"webvtt.bg.color\":\n case \"webvtt.bg.opacity\":\n var backgroundColor = Services.prefs.getCharPref(\"webvtt.bg.color\");\n var backgroundOpacity = Services.prefs.getIntPref(\"webvtt.bg.opacity\") / 100;\n WebVTTSet.backgroundSet = makeColorSet(backgroundColor, backgroundOpacity);\n break;\n case \"webvtt.edge.color\":\n case \"webvtt.edge.type\":\n var edgeTypeList = [\"\", \"0px 0px \", \"4px 4px 4px \", \"-2px -2px \", \"2px 2px \"];\n var edgeType = Services.prefs.getIntPref(\"webvtt.edge.type\");\n var edgeColor = Services.prefs.getCharPref(\"webvtt.edge.color\");\n WebVTTSet.edgeSet = edgeTypeList[edgeType] + makeColorSet(edgeColor);\n break;\n }\n }\n\n if(typeof Services !== \"undefined\") {\n var WebVTTSet = {};\n WebVTTPrefs.forEach(function (pref) {\n observe(undefined, undefined, pref);\n Services.prefs.addObserver(pref, observe, false);\n });\n }\n\n var _objCreate = Object.create || (function() {\n function F() {}\n return function(o) {\n if (arguments.length !== 1) {\n throw new Error('Object.create shim only accepts one parameter.');\n }\n F.prototype = o;\n return new F();\n };\n })();\n\n // Creates a new ParserError object from an errorData object. The errorData\n // object should have default code and message properties. The default message\n // property can be overriden by passing in a message parameter.\n // See ParsingError.Errors below for acceptable errors.\n function ParsingError(errorData, message) {\n this.name = \"ParsingError\";\n this.code = errorData.code;\n this.message = message || errorData.message;\n }\n ParsingError.prototype = _objCreate(Error.prototype);\n ParsingError.prototype.constructor = ParsingError;\n\n // ParsingError metadata for acceptable ParsingErrors.\n ParsingError.Errors = {\n BadSignature: {\n code: 0,\n message: \"Malformed WebVTT signature.\"\n },\n BadTimeStamp: {\n code: 1,\n message: \"Malformed time stamp.\"\n }\n };\n\n // Try to parse input as a time stamp.\n function parseTimeStamp(input) {\n\n function computeSeconds(h, m, s, f) {\n return (h | 0) * 3600 + (m | 0) * 60 + (s | 0) + (f | 0) / 1000;\n }\n\n var m = input.match(/^(\\d+):(\\d{2})(:\\d{2})?\\.(\\d{3})/);\n if (!m) {\n return null;\n }\n\n if (m[3]) {\n // Timestamp takes the form of [hours]:[minutes]:[seconds].[milliseconds]\n return computeSeconds(m[1], m[2], m[3].replace(\":\", \"\"), m[4]);\n } else if (m[1] > 59) {\n // Timestamp takes the form of [hours]:[minutes].[milliseconds]\n // First position is hours as it's over 59.\n return computeSeconds(m[1], m[2], 0, m[4]);\n } else {\n // Timestamp takes the form of [minutes]:[seconds].[milliseconds]\n return computeSeconds(0, m[1], m[2], m[4]);\n }\n }\n\n // A settings object holds key/value pairs and will ignore anything but the first\n // assignment to a specific key.\n function Settings() {\n this.values = _objCreate(null);\n }\n\n Settings.prototype = {\n // Only accept the first assignment to any key.\n set: function(k, v) {\n if (!this.get(k) && v !== \"\") {\n this.values[k] = v;\n }\n },\n // Return the value for a key, or a default value.\n // If 'defaultKey' is passed then 'dflt' is assumed to be an object with\n // a number of possible default values as properties where 'defaultKey' is\n // the key of the property that will be chosen; otherwise it's assumed to be\n // a single value.\n get: function(k, dflt, defaultKey) {\n if (defaultKey) {\n return this.has(k) ? this.values[k] : dflt[defaultKey];\n }\n return this.has(k) ? this.values[k] : dflt;\n },\n // Check whether we have a value for a key.\n has: function(k) {\n return k in this.values;\n },\n // Accept a setting if its one of the given alternatives.\n alt: function(k, v, a) {\n for (var n = 0; n < a.length; ++n) {\n if (v === a[n]) {\n this.set(k, v);\n break;\n }\n }\n },\n // Accept a setting if its a valid (signed) integer.\n integer: function(k, v) {\n if (/^-?\\d+$/.test(v)) { // integer\n this.set(k, parseInt(v, 10));\n }\n },\n // Accept a setting if its a valid percentage.\n percent: function(k, v) {\n var m;\n if ((m = v.match(/^([\\d]{1,3})(\\.[\\d]*)?%$/))) {\n v = parseFloat(v);\n if (v >= 0 && v <= 100) {\n this.set(k, v);\n return true;\n }\n }\n return false;\n }\n };\n\n // Helper function to parse input into groups separated by 'groupDelim', and\n // interprete each group as a key/value pair separated by 'keyValueDelim'.\n function parseOptions(input, callback, keyValueDelim, groupDelim) {\n var groups = groupDelim ? input.split(groupDelim) : [input];\n for (var i in groups) {\n if (typeof groups[i] !== \"string\") {\n continue;\n }\n var kv = groups[i].split(keyValueDelim);\n if (kv.length !== 2) {\n continue;\n }\n var k = kv[0];\n var v = kv[1];\n callback(k, v);\n }\n }\n\n function parseCue(input, cue, regionList, successCb, errCb) {\n // Remember the original input if we need to throw an error.\n var oInput = input;\n // 4.1 WebVTT timestamp\n function consumeTimeStamp() {\n var ts = parseTimeStamp(input);\n if (ts === null) {\n if (errCb) {\n errCb(new ParsingError(ParsingError.Errors.BadTimeStamp,\n \"Malformed timestamp: \" + oInput));\n return;\n }\n }\n // Remove time stamp from input.\n input = input.replace(/^[^\\sa-zA-Z-]+/, \"\");\n return ts;\n }\n\n // 4.4.2 WebVTT cue settings\n function consumeCueSettings(input, cue) {\n var settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"region\":\n // Find the last region we parsed with the same region id.\n for (var i = regionList.length - 1; i >= 0; i--) {\n if (regionList[i].id === v) {\n settings.set(k, regionList[i].region);\n break;\n }\n }\n break;\n case \"vertical\":\n settings.alt(k, v, [\"rl\", \"lr\"]);\n break;\n case \"line\":\n var vals = v.split(\",\"),\n vals0 = vals[0];\n settings.integer(k, vals0);\n settings.percent(k, vals0) ? settings.set(\"snapToLines\", false) : null;\n settings.alt(k, vals0, [\"auto\"]);\n if (vals.length === 2) {\n settings.alt(\"lineAlign\", vals[1], [\"start\", \"middle\", \"end\"]);\n }\n break;\n case \"position\":\n vals = v.split(\",\");\n settings.percent(k, vals[0]);\n if (vals.length === 2) {\n settings.alt(\"positionAlign\", vals[1], [\"start\", \"middle\", \"end\"]);\n }\n break;\n case \"size\":\n settings.percent(k, v);\n break;\n case \"align\":\n settings.alt(k, v, [\"start\", \"middle\", \"end\", \"left\", \"right\"]);\n break;\n }\n }, /:/, /\\s/);\n\n // Apply default values for any missing fields.\n cue.region = settings.get(\"region\", null);\n cue.vertical = settings.get(\"vertical\", \"\");\n cue.line = settings.get(\"line\", \"auto\");\n cue.lineAlign = settings.get(\"lineAlign\", \"start\");\n cue.snapToLines = settings.get(\"snapToLines\", true);\n cue.size = settings.get(\"size\", 100);\n cue.align = settings.get(\"align\", \"center\");\n cue.position = settings.get(\"position\", \"auto\");\n cue.positionAlign = settings.get(\"positionAlign\", {\n start: \"start\",\n left: \"start\",\n middle: \"middle\",\n end: \"end\",\n right: \"end\"\n }, cue.align);\n\n successCb();\n }\n\n function skipWhitespace() {\n input = input.replace(/^\\s+/, \"\");\n }\n\n // 4.1 WebVTT cue timings.\n skipWhitespace();\n\n var timestamp = consumeTimeStamp()\n if (timestamp === undefined) return\n cue.startTime = timestamp; // (1) collect cue start time\n skipWhitespace();\n if (input.substr(0, 3) !== \"-->\") {\n // (3) next characters must match \"-->\"\n errCb(new ParsingError(ParsingError.Errors.BadTimeStamp,\n \"Malformed time stamp (time stamps must be separated by '-->'): \" +\n oInput));\n return;\n }\n input = input.substr(3);\n skipWhitespace();\n var timestamp = consumeTimeStamp()\n if (timestamp === undefined) return\n cue.endTime = timestamp; // (5) collect cue end time\n\n // 4.1 WebVTT cue settings list.\n skipWhitespace();\n consumeCueSettings(input, cue);\n }\n\n var ESCAPE = {\n \"&\": \"&\",\n \"<\": \"<\",\n \">\": \">\",\n \"‎\": \"\\u200e\",\n \"‏\": \"\\u200f\",\n \" \": \"\\u00a0\"\n };\n\n var TAG_NAME = {\n c: \"span\",\n i: \"i\",\n b: \"b\",\n u: \"u\",\n ruby: \"ruby\",\n rt: \"rt\",\n v: \"span\",\n lang: \"span\"\n };\n\n var TAG_ANNOTATION = {\n v: \"title\",\n lang: \"lang\"\n };\n\n var NEEDS_PARENT = {\n rt: \"ruby\"\n };\n\n // Parse content into a document fragment.\n function parseContent(window, input) {\n function nextToken() {\n // Check for end-of-string.\n if (!input) {\n return null;\n }\n\n // Consume 'n' characters from the input.\n function consume(result) {\n input = input.substr(result.length);\n return result;\n }\n\n var m = input.match(/^([^<]*)(<[^>]+>?)?/);\n // If there is some text before the next tag, return it, otherwise return\n // the tag.\n return consume(m[1] ? m[1] : m[2]);\n }\n\n // Unescape a string 's'.\n function unescape1(e) {\n return ESCAPE[e];\n }\n function unescape(s) {\n while ((m = s.match(/&(amp|lt|gt|lrm|rlm|nbsp);/))) {\n s = s.replace(m[0], unescape1);\n }\n return s;\n }\n\n function shouldAdd(current, element) {\n return !NEEDS_PARENT[element.localName] ||\n NEEDS_PARENT[element.localName] === current.localName;\n }\n\n // Create an element for this tag.\n function createElement(type, annotation) {\n var tagName = TAG_NAME[type];\n if (!tagName) {\n return null;\n }\n var element = window.document.createElement(tagName);\n element.localName = tagName;\n var name = TAG_ANNOTATION[type];\n if (name && annotation) {\n element[name] = annotation.trim();\n }\n return element;\n }\n\n var rootDiv = window.document.createElement(\"div\"),\n current = rootDiv,\n t,\n tagStack = [];\n\n while ((t = nextToken()) !== null) {\n if (t[0] === '<') {\n if (t[1] === \"/\") {\n // If the closing tag matches, move back up to the parent node.\n if (tagStack.length &&\n tagStack[tagStack.length - 1] === t.substr(2).replace(\">\", \"\")) {\n tagStack.pop();\n current = current.parentNode;\n }\n // Otherwise just ignore the end tag.\n continue;\n }\n var ts = parseTimeStamp(t.substr(1, t.length - 2));\n var node;\n if (ts) {\n // Timestamps are lead nodes as well.\n node = window.document.createProcessingInstruction(\"timestamp\", ts);\n current.appendChild(node);\n continue;\n }\n var m = t.match(/^<([^.\\s/0-9>]+)(\\.[^\\s\\\\>]+)?([^>\\\\]+)?(\\\\?)>?$/);\n // If we can't parse the tag, skip to the next tag.\n if (!m) {\n continue;\n }\n // Try to construct an element, and ignore the tag if we couldn't.\n node = createElement(m[1], m[3]);\n if (!node) {\n continue;\n }\n // Determine if the tag should be added based on the context of where it\n // is placed in the cuetext.\n if (!shouldAdd(current, node)) {\n continue;\n }\n // Set the class list (as a list of classes, separated by space).\n if (m[2]) {\n node.className = m[2].substr(1).replace('.', ' ');\n }\n // Append the node to the current node, and enter the scope of the new\n // node.\n tagStack.push(m[1]);\n current.appendChild(node);\n current = node;\n continue;\n }\n\n // Text nodes are leaf nodes.\n current.appendChild(window.document.createTextNode(unescape(t)));\n }\n\n return rootDiv;\n }\n\n // This is a list of all the Unicode characters that have a strong\n // right-to-left category. What this means is that these characters are\n // written right-to-left for sure. It was generated by pulling all the strong\n // right-to-left characters out of the Unicode data table. That table can\n // found at: http://www.unicode.org/Public/UNIDATA/UnicodeData.txt\n var strongRTLRanges = [[0x5be, 0x5be], [0x5c0, 0x5c0], [0x5c3, 0x5c3], [0x5c6, 0x5c6],\n [0x5d0, 0x5ea], [0x5f0, 0x5f4], [0x608, 0x608], [0x60b, 0x60b], [0x60d, 0x60d],\n [0x61b, 0x61b], [0x61e, 0x64a], [0x66d, 0x66f], [0x671, 0x6d5], [0x6e5, 0x6e6],\n [0x6ee, 0x6ef], [0x6fa, 0x70d], [0x70f, 0x710], [0x712, 0x72f], [0x74d, 0x7a5],\n [0x7b1, 0x7b1], [0x7c0, 0x7ea], [0x7f4, 0x7f5], [0x7fa, 0x7fa], [0x800, 0x815],\n [0x81a, 0x81a], [0x824, 0x824], [0x828, 0x828], [0x830, 0x83e], [0x840, 0x858],\n [0x85e, 0x85e], [0x8a0, 0x8a0], [0x8a2, 0x8ac], [0x200f, 0x200f],\n [0xfb1d, 0xfb1d], [0xfb1f, 0xfb28], [0xfb2a, 0xfb36], [0xfb38, 0xfb3c],\n [0xfb3e, 0xfb3e], [0xfb40, 0xfb41], [0xfb43, 0xfb44], [0xfb46, 0xfbc1],\n [0xfbd3, 0xfd3d], [0xfd50, 0xfd8f], [0xfd92, 0xfdc7], [0xfdf0, 0xfdfc],\n [0xfe70, 0xfe74], [0xfe76, 0xfefc], [0x10800, 0x10805], [0x10808, 0x10808],\n [0x1080a, 0x10835], [0x10837, 0x10838], [0x1083c, 0x1083c], [0x1083f, 0x10855],\n [0x10857, 0x1085f], [0x10900, 0x1091b], [0x10920, 0x10939], [0x1093f, 0x1093f],\n [0x10980, 0x109b7], [0x109be, 0x109bf], [0x10a00, 0x10a00], [0x10a10, 0x10a13],\n [0x10a15, 0x10a17], [0x10a19, 0x10a33], [0x10a40, 0x10a47], [0x10a50, 0x10a58],\n [0x10a60, 0x10a7f], [0x10b00, 0x10b35], [0x10b40, 0x10b55], [0x10b58, 0x10b72],\n [0x10b78, 0x10b7f], [0x10c00, 0x10c48], [0x1ee00, 0x1ee03], [0x1ee05, 0x1ee1f],\n [0x1ee21, 0x1ee22], [0x1ee24, 0x1ee24], [0x1ee27, 0x1ee27], [0x1ee29, 0x1ee32],\n [0x1ee34, 0x1ee37], [0x1ee39, 0x1ee39], [0x1ee3b, 0x1ee3b], [0x1ee42, 0x1ee42],\n [0x1ee47, 0x1ee47], [0x1ee49, 0x1ee49], [0x1ee4b, 0x1ee4b], [0x1ee4d, 0x1ee4f],\n [0x1ee51, 0x1ee52], [0x1ee54, 0x1ee54], [0x1ee57, 0x1ee57], [0x1ee59, 0x1ee59],\n [0x1ee5b, 0x1ee5b], [0x1ee5d, 0x1ee5d], [0x1ee5f, 0x1ee5f], [0x1ee61, 0x1ee62],\n [0x1ee64, 0x1ee64], [0x1ee67, 0x1ee6a], [0x1ee6c, 0x1ee72], [0x1ee74, 0x1ee77],\n [0x1ee79, 0x1ee7c], [0x1ee7e, 0x1ee7e], [0x1ee80, 0x1ee89], [0x1ee8b, 0x1ee9b],\n [0x1eea1, 0x1eea3], [0x1eea5, 0x1eea9], [0x1eeab, 0x1eebb], [0x10fffd, 0x10fffd]];\n\n function isStrongRTLChar(charCode) {\n for (var i = 0; i < strongRTLRanges.length; i++) {\n var currentRange = strongRTLRanges[i];\n if (charCode >= currentRange[0] && charCode <= currentRange[1]) {\n return true;\n }\n }\n\n return false;\n }\n\n function determineBidi(cueDiv) {\n var nodeStack = [],\n text = \"\",\n charCode;\n\n if (!cueDiv || !cueDiv.childNodes) {\n return \"ltr\";\n }\n\n function pushNodes(nodeStack, node) {\n for (var i = node.childNodes.length - 1; i >= 0; i--) {\n nodeStack.push(node.childNodes[i]);\n }\n }\n\n function nextTextNode(nodeStack) {\n if (!nodeStack || !nodeStack.length) {\n return null;\n }\n\n var node = nodeStack.pop(),\n text = node.textContent || node.innerText;\n if (text) {\n // TODO: This should match all unicode type B characters (paragraph\n // separator characters). See issue #115.\n var m = text.match(/^.*(\\n|\\r)/);\n if (m) {\n nodeStack.length = 0;\n return m[0];\n }\n return text;\n }\n if (node.tagName === \"ruby\") {\n return nextTextNode(nodeStack);\n }\n if (node.childNodes) {\n pushNodes(nodeStack, node);\n return nextTextNode(nodeStack);\n }\n }\n\n pushNodes(nodeStack, cueDiv);\n while ((text = nextTextNode(nodeStack))) {\n for (var i = 0; i < text.length; i++) {\n charCode = text.charCodeAt(i);\n if (isStrongRTLChar(charCode)) {\n return \"rtl\";\n }\n }\n }\n return \"ltr\";\n }\n\n function computeLinePos(cue) {\n if (typeof cue.line === \"number\" &&\n (cue.snapToLines || (cue.line >= 0 && cue.line <= 100))) {\n return cue.line;\n }\n if (!cue.track || !cue.track.textTrackList ||\n !cue.track.textTrackList.mediaElement) {\n return -1;\n }\n var track = cue.track,\n trackList = track.textTrackList,\n count = 0;\n for (var i = 0; i < trackList.length && trackList[i] !== track; i++) {\n if (trackList[i].mode === \"showing\") {\n count++;\n }\n }\n return ++count * -1;\n }\n\n function StyleBox() {\n }\n\n // Apply styles to a div. If there is no div passed then it defaults to the\n // div on 'this'.\n StyleBox.prototype.applyStyles = function(styles, div) {\n div = div || this.div;\n for (var prop in styles) {\n if (styles.hasOwnProperty(prop)) {\n div.style[prop] = styles[prop];\n }\n }\n };\n\n StyleBox.prototype.formatStyle = function(val, unit) {\n return val === 0 ? 0 : val + unit;\n };\n\n // Constructs the computed display state of the cue (a div). Places the div\n // into the overlay which should be a block level element (usually a div).\n function CueStyleBox(window, cue, styleOptions) {\n var isIE8 = (typeof navigator !== \"undefined\") &&\n (/MSIE\\s8\\.0/).test(navigator.userAgent);\n var color = \"rgba(255, 255, 255, 1)\";\n var backgroundColor = \"rgba(0, 0, 0, 0.8)\";\n var textShadow = \"\";\n\n if(typeof WebVTTSet !== \"undefined\") {\n color = WebVTTSet.fontSet;\n backgroundColor = WebVTTSet.backgroundSet;\n textShadow = WebVTTSet.edgeSet;\n }\n\n if (isIE8) {\n color = \"rgb(255, 255, 255)\";\n backgroundColor = \"rgb(0, 0, 0)\";\n }\n\n StyleBox.call(this);\n this.cue = cue;\n\n // Parse our cue's text into a DOM tree rooted at 'cueDiv'. This div will\n // have inline positioning and will function as the cue background box.\n this.cueDiv = parseContent(window, cue.text);\n var styles = {\n color: color,\n backgroundColor: backgroundColor,\n textShadow: textShadow,\n position: \"relative\",\n left: 0,\n right: 0,\n top: 0,\n bottom: 0,\n display: \"inline\"\n };\n\n if (!isIE8) {\n styles.writingMode = cue.vertical === \"\" ? \"horizontal-tb\"\n : cue.vertical === \"lr\" ? \"vertical-lr\"\n : \"vertical-rl\";\n styles.unicodeBidi = \"plaintext\";\n }\n this.applyStyles(styles, this.cueDiv);\n\n // Create an absolutely positioned div that will be used to position the cue\n // div. Note, all WebVTT cue-setting alignments are equivalent to the CSS\n // mirrors of them except \"middle\" which is \"center\" in CSS.\n this.div = window.document.createElement(\"div\");\n styles = {\n textAlign: cue.align === \"middle\" ? \"center\" : cue.align,\n font: styleOptions.font,\n whiteSpace: \"pre-line\",\n position: \"absolute\"\n };\n\n if (!isIE8) {\n styles.direction = determineBidi(this.cueDiv);\n styles.writingMode = cue.vertical === \"\" ? \"horizontal-tb\"\n : cue.vertical === \"lr\" ? \"vertical-lr\"\n : \"vertical-rl\".\n stylesunicodeBidi = \"plaintext\";\n }\n\n this.applyStyles(styles);\n\n this.div.appendChild(this.cueDiv);\n\n // Calculate the distance from the reference edge of the viewport to the text\n // position of the cue box. The reference edge will be resolved later when\n // the box orientation styles are applied.\n var textPos = 0;\n switch (cue.positionAlign) {\n case \"start\":\n textPos = cue.position;\n break;\n case \"middle\":\n textPos = cue.position - (cue.size / 2);\n break;\n case \"end\":\n textPos = cue.position - cue.size;\n break;\n }\n\n // Horizontal box orientation; textPos is the distance from the left edge of the\n // area to the left edge of the box and cue.size is the distance extending to\n // the right from there.\n if (cue.vertical === \"\") {\n this.applyStyles({\n left: this.formatStyle(textPos, \"%\"),\n width: this.formatStyle(cue.size, \"%\")\n });\n // Vertical box orientation; textPos is the distance from the top edge of the\n // area to the top edge of the box and cue.size is the height extending\n // downwards from there.\n } else {\n this.applyStyles({\n top: this.formatStyle(textPos, \"%\"),\n height: this.formatStyle(cue.size, \"%\")\n });\n }\n\n this.move = function(box) {\n this.applyStyles({\n top: this.formatStyle(box.top, \"px\"),\n bottom: this.formatStyle(box.bottom, \"px\"),\n left: this.formatStyle(box.left, \"px\"),\n right: this.formatStyle(box.right, \"px\"),\n height: this.formatStyle(box.height, \"px\"),\n width: this.formatStyle(box.width, \"px\")\n });\n };\n }\n CueStyleBox.prototype = _objCreate(StyleBox.prototype);\n CueStyleBox.prototype.constructor = CueStyleBox;\n\n // Represents the co-ordinates of an Element in a way that we can easily\n // compute things with such as if it overlaps or intersects with another Element.\n // Can initialize it with either a StyleBox or another BoxPosition.\n function BoxPosition(obj) {\n var isIE8 = (typeof navigator !== \"undefined\") &&\n (/MSIE\\s8\\.0/).test(navigator.userAgent);\n\n // Either a BoxPosition was passed in and we need to copy it, or a StyleBox\n // was passed in and we need to copy the results of 'getBoundingClientRect'\n // as the object returned is readonly. All co-ordinate values are in reference\n // to the viewport origin (top left).\n var lh, height, width, top;\n if (obj.div) {\n height = obj.div.offsetHeight;\n width = obj.div.offsetWidth;\n top = obj.div.offsetTop;\n\n var rects = (rects = obj.div.childNodes) && (rects = rects[0]) &&\n rects.getClientRects && rects.getClientRects();\n obj = obj.div.getBoundingClientRect();\n // In certain cases the outter div will be slightly larger then the sum of\n // the inner div's lines. This could be due to bold text, etc, on some platforms.\n // In this case we should get the average line height and use that. This will\n // result in the desired behaviour.\n lh = rects ? Math.max((rects[0] && rects[0].height) || 0, obj.height / rects.length)\n : 0;\n\n }\n this.left = obj.left;\n this.right = obj.right;\n this.top = obj.top || top;\n this.height = obj.height || height;\n this.bottom = obj.bottom || (top + (obj.height || height));\n this.width = obj.width || width;\n this.lineHeight = lh !== undefined ? lh : obj.lineHeight;\n\n if (isIE8 && !this.lineHeight) {\n this.lineHeight = 13;\n }\n }\n\n // Move the box along a particular axis. Optionally pass in an amount to move\n // the box. If no amount is passed then the default is the line height of the\n // box.\n BoxPosition.prototype.move = function(axis, toMove) {\n toMove = toMove !== undefined ? toMove : this.lineHeight;\n switch (axis) {\n case \"+x\":\n this.left += toMove;\n this.right += toMove;\n break;\n case \"-x\":\n this.left -= toMove;\n this.right -= toMove;\n break;\n case \"+y\":\n this.top += toMove;\n this.bottom += toMove;\n break;\n case \"-y\":\n this.top -= toMove;\n this.bottom -= toMove;\n break;\n }\n };\n\n // Check if this box overlaps another box, b2.\n BoxPosition.prototype.overlaps = function(b2) {\n return this.left < b2.right &&\n this.right > b2.left &&\n this.top < b2.bottom &&\n this.bottom > b2.top;\n };\n\n // Check if this box overlaps any other boxes in boxes.\n BoxPosition.prototype.overlapsAny = function(boxes) {\n for (var i = 0; i < boxes.length; i++) {\n if (this.overlaps(boxes[i])) {\n return true;\n }\n }\n return false;\n };\n\n // Check if this box is within another box.\n BoxPosition.prototype.within = function(container) {\n return this.top >= container.top &&\n this.bottom <= container.bottom &&\n this.left >= container.left &&\n this.right <= container.right;\n };\n\n // Check if this box is entirely within the container or it is overlapping\n // on the edge opposite of the axis direction passed. For example, if \"+x\" is\n // passed and the box is overlapping on the left edge of the container, then\n // return true.\n BoxPosition.prototype.overlapsOppositeAxis = function(container, axis) {\n switch (axis) {\n case \"+x\":\n return this.left < container.left;\n case \"-x\":\n return this.right > container.right;\n case \"+y\":\n return this.top < container.top;\n case \"-y\":\n return this.bottom > container.bottom;\n }\n };\n\n // Find the percentage of the area that this box is overlapping with another\n // box.\n BoxPosition.prototype.intersectPercentage = function(b2) {\n var x = Math.max(0, Math.min(this.right, b2.right) - Math.max(this.left, b2.left)),\n y = Math.max(0, Math.min(this.bottom, b2.bottom) - Math.max(this.top, b2.top)),\n intersectArea = x * y;\n return intersectArea / (this.height * this.width);\n };\n\n // Convert the positions from this box to CSS compatible positions using\n // the reference container's positions. This has to be done because this\n // box's positions are in reference to the viewport origin, whereas, CSS\n // values are in referecne to their respective edges.\n BoxPosition.prototype.toCSSCompatValues = function(reference) {\n return {\n top: this.top - reference.top,\n bottom: reference.bottom - this.bottom,\n left: this.left - reference.left,\n right: reference.right - this.right,\n height: this.height,\n width: this.width\n };\n };\n\n // Get an object that represents the box's position without anything extra.\n // Can pass a StyleBox, HTMLElement, or another BoxPositon.\n BoxPosition.getSimpleBoxPosition = function(obj) {\n var height = obj.div ? obj.div.offsetHeight : obj.tagName ? obj.offsetHeight : 0;\n var width = obj.div ? obj.div.offsetWidth : obj.tagName ? obj.offsetWidth : 0;\n var top = obj.div ? obj.div.offsetTop : obj.tagName ? obj.offsetTop : 0;\n\n obj = obj.div ? obj.div.getBoundingClientRect() :\n obj.tagName ? obj.getBoundingClientRect() : obj;\n var ret = {\n left: obj.left,\n right: obj.right,\n top: obj.top || top,\n height: obj.height || height,\n bottom: obj.bottom || (top + (obj.height || height)),\n width: obj.width || width\n };\n return ret;\n };\n\n // Move a StyleBox to its specified, or next best, position. The containerBox\n // is the box that contains the StyleBox, such as a div. boxPositions are\n // a list of other boxes that the styleBox can't overlap with.\n function moveBoxToLinePosition(window, styleBox, containerBox, boxPositions) {\n\n // Find the best position for a cue box, b, on the video. The axis parameter\n // is a list of axis, the order of which, it will move the box along. For example:\n // Passing [\"+x\", \"-x\"] will move the box first along the x axis in the positive\n // direction. If it doesn't find a good position for it there it will then move\n // it along the x axis in the negative direction.\n function findBestPosition(b, axis) {\n var bestPosition,\n specifiedPosition = new BoxPosition(b),\n percentage = 1; // Highest possible so the first thing we get is better.\n\n for (var i = 0; i < axis.length; i++) {\n while (b.overlapsOppositeAxis(containerBox, axis[i]) ||\n (b.within(containerBox) && b.overlapsAny(boxPositions))) {\n b.move(axis[i]);\n }\n // We found a spot where we aren't overlapping anything. This is our\n // best position.\n if (b.within(containerBox)) {\n return b;\n }\n var p = b.intersectPercentage(containerBox);\n // If we're outside the container box less then we were on our last try\n // then remember this position as the best position.\n if (percentage > p) {\n bestPosition = new BoxPosition(b);\n percentage = p;\n }\n // Reset the box position to the specified position.\n b = new BoxPosition(specifiedPosition);\n }\n return bestPosition || specifiedPosition;\n }\n\n var boxPosition = new BoxPosition(styleBox),\n cue = styleBox.cue,\n linePos = computeLinePos(cue),\n axis = [];\n\n // If we have a line number to align the cue to.\n if (cue.snapToLines) {\n var size;\n switch (cue.vertical) {\n case \"\":\n axis = [ \"+y\", \"-y\" ];\n size = \"height\";\n break;\n case \"rl\":\n axis = [ \"+x\", \"-x\" ];\n size = \"width\";\n break;\n case \"lr\":\n axis = [ \"-x\", \"+x\" ];\n size = \"width\";\n break;\n }\n\n var step = boxPosition.lineHeight,\n position = step * Math.round(linePos),\n maxPosition = containerBox[size] + step,\n initialAxis = axis[0];\n\n // If the specified intial position is greater then the max position then\n // clamp the box to the amount of steps it would take for the box to\n // reach the max position.\n if (Math.abs(position) > maxPosition) {\n position = position < 0 ? -1 : 1;\n position *= Math.ceil(maxPosition / step) * step;\n }\n\n // If computed line position returns negative then line numbers are\n // relative to the bottom of the video instead of the top. Therefore, we\n // need to increase our initial position by the length or width of the\n // video, depending on the writing direction, and reverse our axis directions.\n if (linePos < 0) {\n position += cue.vertical === \"\" ? containerBox.height : containerBox.width;\n axis = axis.reverse();\n }\n\n // Move the box to the specified position. This may not be its best\n // position.\n boxPosition.move(initialAxis, position);\n\n } else {\n // If we have a percentage line value for the cue.\n var calculatedPercentage = (boxPosition.lineHeight / containerBox.height) * 100;\n\n switch (cue.lineAlign) {\n case \"middle\":\n linePos -= (calculatedPercentage / 2);\n break;\n case \"end\":\n linePos -= calculatedPercentage;\n break;\n }\n\n // Apply initial line position to the cue box.\n switch (cue.vertical) {\n case \"\":\n styleBox.applyStyles({\n top: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n case \"rl\":\n styleBox.applyStyles({\n left: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n case \"lr\":\n styleBox.applyStyles({\n right: styleBox.formatStyle(linePos, \"%\")\n });\n break;\n }\n\n axis = [ \"+y\", \"-x\", \"+x\", \"-y\" ];\n\n // Get the box position again after we've applied the specified positioning\n // to it.\n boxPosition = new BoxPosition(styleBox);\n }\n\n var bestPosition = findBestPosition(boxPosition, axis);\n styleBox.move(bestPosition.toCSSCompatValues(containerBox));\n }\n\n function WebVTT() {\n // Nothing\n }\n\n // Helper to allow strings to be decoded instead of the default binary utf8 data.\n WebVTT.StringDecoder = function() {\n return {\n decode: function(data) {\n if (!data) {\n return \"\";\n }\n if (typeof data !== \"string\") {\n throw new Error(\"Error - expected string data.\");\n }\n return decodeURIComponent(encodeURIComponent(data));\n }\n };\n };\n\n WebVTT.convertCueToDOMTree = function(window, cuetext) {\n if (!window || !cuetext) {\n return null;\n }\n return parseContent(window, cuetext);\n };\n\n var FONT_SIZE_PERCENT = 0.05;\n var FONT_STYLE = \"sans-serif\";\n var CUE_BACKGROUND_PADDING = \"1.5%\";\n\n // Runs the processing model over the cues and regions passed to it.\n // @param overlay A block level element (usually a div) that the computed cues\n // and regions will be placed into.\n WebVTT.processCues = function(window, cues, overlay) {\n if (!window || !cues || !overlay) {\n return null;\n }\n\n // Remove all previous children.\n while (overlay.firstChild) {\n overlay.removeChild(overlay.firstChild);\n }\n\n var paddedOverlay = window.document.createElement(\"div\");\n paddedOverlay.style.position = \"absolute\";\n paddedOverlay.style.left = \"0\";\n paddedOverlay.style.right = \"0\";\n paddedOverlay.style.top = \"0\";\n paddedOverlay.style.bottom = \"0\";\n paddedOverlay.style.margin = CUE_BACKGROUND_PADDING;\n overlay.appendChild(paddedOverlay);\n\n // Determine if we need to compute the display states of the cues. This could\n // be the case if a cue's state has been changed since the last computation or\n // if it has not been computed yet.\n function shouldCompute(cues) {\n for (var i = 0; i < cues.length; i++) {\n if (cues[i].hasBeenReset || !cues[i].displayState) {\n return true;\n }\n }\n return false;\n }\n\n // We don't need to recompute the cues' display states. Just reuse them.\n if (!shouldCompute(cues)) {\n for (var i = 0; i < cues.length; i++) {\n paddedOverlay.appendChild(cues[i].displayState);\n }\n return;\n }\n\n var boxPositions = [],\n containerBox = BoxPosition.getSimpleBoxPosition(paddedOverlay),\n fontSize = Math.round(containerBox.height * FONT_SIZE_PERCENT * 100) / 100;\n var styleOptions = {\n font: (fontSize * fontScale) + \"px \" + FONT_STYLE\n };\n\n (function() {\n var styleBox, cue;\n\n for (var i = 0; i < cues.length; i++) {\n cue = cues[i];\n\n // Compute the intial position and styles of the cue div.\n styleBox = new CueStyleBox(window, cue, styleOptions);\n paddedOverlay.appendChild(styleBox.div);\n\n // Move the cue div to it's correct line position.\n moveBoxToLinePosition(window, styleBox, containerBox, boxPositions);\n\n // Remember the computed div so that we don't have to recompute it later\n // if we don't have too.\n cue.displayState = styleBox.div;\n\n boxPositions.push(BoxPosition.getSimpleBoxPosition(styleBox));\n }\n })();\n };\n\n WebVTT.Parser = function(window, decoder, VTTCue) {\n this.window = window;\n this.state = \"INITIAL\";\n this.buffer = \"\";\n this.decoder = decoder || new TextDecoder(\"utf8\");\n this.regionList = [];\n this.VTTCue = VTTCue\n };\n\n WebVTT.Parser.prototype = {\n // If the error is a ParsingError then report it to the consumer if\n // possible. If it's not a ParsingError then throw it like normal.\n reportOrThrowError: function(e) {\n if (e instanceof ParsingError) {\n this.onparsingerror && this.onparsingerror(e);\n } else {\n throw e;\n }\n },\n parse: function (data) {\n var self = this;\n\n // If there is no data then we won't decode it, but will just try to parse\n // whatever is in buffer already. This may occur in circumstances, for\n // example when flush() is called.\n if (data) {\n // Try to decode the data that we received.\n self.buffer += self.decoder.decode(data, {stream: true});\n }\n\n function collectNextLine() {\n var buffer = self.buffer;\n var pos = 0;\n while (pos < buffer.length && buffer[pos] !== '\\r' && buffer[pos] !== '\\n') {\n ++pos;\n }\n var line = buffer.substr(0, pos);\n // Advance the buffer early in case we fail below.\n if (buffer[pos] === '\\r') {\n ++pos;\n }\n if (buffer[pos] === '\\n') {\n ++pos;\n }\n self.buffer = buffer.substr(pos);\n return line;\n }\n\n // 3.4 WebVTT region and WebVTT region settings syntax\n function parseRegion(input) {\n var settings = new Settings();\n\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"id\":\n settings.set(k, v);\n break;\n case \"width\":\n settings.percent(k, v);\n break;\n case \"lines\":\n settings.integer(k, v);\n break;\n case \"regionanchor\":\n case \"viewportanchor\":\n var xy = v.split(',');\n if (xy.length !== 2) {\n break;\n }\n // We have to make sure both x and y parse, so use a temporary\n // settings object here.\n var anchor = new Settings();\n anchor.percent(\"x\", xy[0]);\n anchor.percent(\"y\", xy[1]);\n if (!anchor.has(\"x\") || !anchor.has(\"y\")) {\n break;\n }\n settings.set(k + \"X\", anchor.get(\"x\"));\n settings.set(k + \"Y\", anchor.get(\"y\"));\n break;\n case \"scroll\":\n settings.alt(k, v, [\"up\"]);\n break;\n }\n }, /=/, /\\s/);\n\n // Create the region, using default values for any values that were not\n // specified.\n if (settings.has(\"id\")) {\n var region = new self.window.VTTRegion();\n region.width = settings.get(\"width\", 100);\n region.lines = settings.get(\"lines\", 3);\n region.regionAnchorX = settings.get(\"regionanchorX\", 0);\n region.regionAnchorY = settings.get(\"regionanchorY\", 100);\n region.viewportAnchorX = settings.get(\"viewportanchorX\", 0);\n region.viewportAnchorY = settings.get(\"viewportanchorY\", 100);\n region.scroll = settings.get(\"scroll\", \"\");\n // Register the region.\n self.onregion && self.onregion(region);\n // Remember the VTTRegion for later in case we parse any VTTCues that\n // reference it.\n self.regionList.push({\n id: settings.get(\"id\"),\n region: region\n });\n }\n }\n\n // draft-pantos-http-live-streaming-20\n // https://tools.ietf.org/html/draft-pantos-http-live-streaming-20#section-3.5\n // 3.5 WebVTT\n function parseTimestampMap(input) {\n var settings = new Settings();\n\n parseOptions(input, function(k, v) {\n switch (k) {\n case \"MPEGT\":\n settings.integer(k + 'S', v);\n break;\n case \"LOCA\":\n settings.set(k + 'L', parseTimeStamp(v));\n break;\n }\n }, /[^\\d]:/, /,/);\n\n self.ontimestampmap && self.ontimestampmap({\n \"MPEGTS\": settings.get(\"MPEGTS\"),\n \"LOCAL\": settings.get(\"LOCAL\")\n });\n }\n\n // 3.2 WebVTT metadata header syntax\n function parseHeader(input) {\n if (input.match(/X-TIMESTAMP-MAP/)) {\n // This line contains HLS X-TIMESTAMP-MAP metadata\n parseOptions(input, function(k, v) {\n switch (k) {\n case \"X-TIMESTAMP-MAP\":\n parseTimestampMap(v);\n break;\n }\n }, /=/);\n } else {\n parseOptions(input, function (k, v) {\n switch (k) {\n case \"Region\":\n // 3.3 WebVTT region metadata header syntax\n parseRegion(v);\n break;\n }\n }, /:/);\n }\n }\n\n // 5.1 WebVTT file parsing.\n\n function fail(e) {\n\n self.reportOrThrowError(e);\n\n // If we are currently parsing a cue, report what we have.\n if (self.state === \"CUETEXT\" && self.cue && self.oncue) {\n self.oncue(self.cue);\n }\n self.cue = null;\n // Enter BADWEBVTT state if header was not parsed correctly otherwise\n // another exception occurred so enter BADCUE state.\n self.state = self.state === \"INITIAL\" ? \"BADWEBVTT\" : \"BADCUE\";\n\n }\n\n var line;\n\n if (self.state === \"INITIAL\") {\n // We can't start parsing until we have the first line.\n if (!/\\r\\n|\\n/.test(self.buffer)) {\n return this;\n }\n\n line = collectNextLine();\n\n var m = line.match(/^WEBVTT([ \\t].*)?$/);\n if (!m || !m[0]) {\n fail(new ParsingError(ParsingError.Errors.BadSignature))\n return\n }\n\n self.state = \"HEADER\";\n }\n\n var alreadyCollectedLine = false;\n\n var lineparse = function() {\n // We can't parse a line until we have the full line.\n if (!self.buffer || !/\\r\\n|\\n/.test(self.buffer)) {\n self.flush()\n return\n }\n\n if (!alreadyCollectedLine) {\n line = collectNextLine();\n } else {\n alreadyCollectedLine = false;\n }\n\n switch (self.state) {\n case \"HEADER\":\n // 13-18 - Allow a header (metadata) under the WEBVTT line.\n if (/:/.test(line)) {\n parseHeader(line);\n } else if (!line) {\n // An empty line terminates the header and starts the body (cues).\n self.state = \"ID\";\n }\n linebyline();\n break;\n case \"NOTE\":\n // Ignore NOTE blocks.\n if (!line) {\n self.state = \"ID\";\n }\n linebyline();\n break;\n case \"ID\":\n // Check for the start of NOTE blocks.\n if (/^NOTE($|[ \\t])/.test(line)) {\n self.state = \"NOTE\";\n linebyline();\n break;\n }\n // 19-29 - Allow any number of line terminators, then initialize new cue values.\n if (!line) {\n linebyline();\n break;\n }\n self.cue = new (self.VTTCue || self.window.VTTCue)(0, 0, \"\");\n self.state = \"CUE\";\n // 30-39 - Check if self line contains an optional identifier or timing data.\n if (line.indexOf(\"-->\") === -1) {\n self.cue.id = line;\n linebyline();\n break;\n }\n // Process line as start of a cue.\n /*falls through*/\n case \"CUE\":\n // 40 - Collect cue timings and settings.\n\n parseCue(line, self.cue, self.regionList, function successCb() {\n\n self.state = \"CUETEXT\";\n\n linebyline();\n\n }, function errCb(err) {\n\n self.reportOrThrowError(err);\n\n // In case of an error ignore rest of the cue.\n self.cue = null;\n self.state = \"BADCUE\";\n\n linebyline();\n\n });\n\n break;\n case \"CUETEXT\":\n var hasSubstring = line.indexOf(\"-->\") !== -1;\n // 34 - If we have an empty line then report the cue.\n // 35 - If we have the special substring '-->' then report the cue,\n // but do not collect the line as we need to process the current\n // one as a new cue.\n if (!line || hasSubstring && (alreadyCollectedLine = true)) {\n // We are done parsing self cue.\n self.oncue && self.oncue(self.cue);\n self.cue = null;\n self.state = \"ID\";\n linebyline();\n break;\n }\n if (self.cue.text) {\n self.cue.text += \"\\n\";\n }\n self.cue.text += line;\n linebyline();\n break;\n case \"BADCUE\":\n // BADCUE\n // 54-62 - Collect and discard the remaining cue.\n if (!line) {\n self.state = \"ID\";\n }\n linebyline();\n break;\n }\n };\n\n var STACK_LIMIT = 1000;\n\n var count = 0\n\n function unwrapStack(fn) {\n return function() {\n count++\n if (count < STACK_LIMIT) return fn()\n setTimeout(function() {\n count = 0\n fn()\n })\n }\n }\n\n var linebyline = unwrapStack(lineparse)\n\n linebyline();\n\n return this;\n },\n flush: function () {\n var self = this;\n try {\n // Finish decoding the stream.\n self.buffer += self.decoder.decode();\n // Synthesize the end of the current cue or region.\n if (self.cue || self.state === \"HEADER\") {\n self.buffer += \"\\n\\n\";\n self.parse();\n }\n // If we've flushed, parsed, and we're still on the INITIAL state then\n // that means we don't have enough of the stream to parse the first\n // line.\n if (self.state === \"INITIAL\") {\n throw new ParsingError(ParsingError.Errors.BadSignature);\n }\n } catch(e) {\n self.reportOrThrowError(e);\n }\n self.onflush && self.onflush();\n return this;\n }\n };\n\n global.WebVTT = WebVTT;\n\n}(this));\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// If we're in Node.js then require VTTCue so we can extend it, otherwise assume\n// VTTCue is on the global.\nif (typeof module !== \"undefined\" && module.exports) {\n this.VTTCue = this.VTTCue || require(\"./vttcue\").VTTCue;\n}\n\n// Extend VTTCue with methods to convert to JSON, from JSON, and construct a\n// VTTCue from an options object. The primary purpose of this is for use in the\n// vtt.js test suite (for testing only properties that we care about). It's also\n// useful if you need to work with VTTCues in JSON format.\n(function(root) {\n\n root.VTTCue.prototype.toJSON = function() {\n var cue = {},\n self = this;\n // Filter out getCueAsHTML as it's a function and hasBeenReset and displayState as\n // they're only used when running the processing model algorithm.\n Object.keys(this).forEach(function(key) {\n if (key !== \"getCueAsHTML\" && key !== \"hasBeenReset\" && key !== \"displayState\") {\n cue[key] = self[key];\n }\n });\n return cue;\n };\n\n root.VTTCue.create = function(options) {\n if (!options.hasOwnProperty(\"startTime\") || !options.hasOwnProperty(\"endTime\") ||\n !options.hasOwnProperty(\"text\")) {\n throw new Error(\"You must at least have start time, end time, and text.\");\n }\n var cue = new root.VTTCue(options.startTime, options.endTime, options.text);\n for (var key in options) {\n if (cue.hasOwnProperty(key)) {\n cue[key] = options[key];\n }\n }\n return cue;\n };\n\n root.VTTCue.fromJSON = function(json) {\n return this.create(JSON.parse(json));\n };\n\n}(this));\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n(function(root) {\n\n var autoKeyword = \"auto\";\n var directionSetting = {\n \"\": true,\n \"lr\": true,\n \"rl\": true\n };\n var alignSetting = {\n \"start\": true,\n \"middle\": true,\n \"end\": true,\n \"left\": true,\n \"right\": true\n };\n\n function findDirectionSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var dir = directionSetting[value.toLowerCase()];\n return dir ? value.toLowerCase() : false;\n }\n\n function findAlignSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var align = alignSetting[value.toLowerCase()];\n return align ? value.toLowerCase() : false;\n }\n\n function extend(obj) {\n var i = 1;\n for (; i < arguments.length; i++) {\n var cobj = arguments[i];\n for (var p in cobj) {\n obj[p] = cobj[p];\n }\n }\n\n return obj;\n }\n\n function VTTCue(startTime, endTime, text) {\n var cue = this;\n var isIE8 = (/MSIE\\s8\\.0/).test(navigator.userAgent);\n var baseObj = {};\n\n if (isIE8) {\n cue = document.createElement('custom');\n } else {\n baseObj.enumerable = true;\n }\n\n /**\n * Shim implementation specific properties. These properties are not in\n * the spec.\n */\n\n // Lets us know when the VTTCue's data has changed in such a way that we need\n // to recompute its display state. This lets us compute its display state\n // lazily.\n cue.hasBeenReset = false;\n\n /**\n * VTTCue and TextTrackCue properties\n * http://dev.w3.org/html5/webvtt/#vttcue-interface\n */\n\n var _id = \"\";\n var _pauseOnExit = false;\n var _startTime = startTime;\n var _endTime = endTime;\n var _text = text;\n var _region = null;\n var _vertical = \"\";\n var _snapToLines = true;\n var _line = \"auto\";\n var _lineAlign = \"start\";\n var _position = 50;\n var _positionAlign = \"middle\";\n var _size = 50;\n var _align = \"middle\";\n\n Object.defineProperty(cue,\n \"id\", extend({}, baseObj, {\n get: function() {\n return _id;\n },\n set: function(value) {\n _id = \"\" + value;\n }\n }));\n\n Object.defineProperty(cue,\n \"pauseOnExit\", extend({}, baseObj, {\n get: function() {\n return _pauseOnExit;\n },\n set: function(value) {\n _pauseOnExit = !!value;\n }\n }));\n\n Object.defineProperty(cue,\n \"startTime\", extend({}, baseObj, {\n get: function() {\n return _startTime;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"Start time must be set to a number.\");\n }\n _startTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"endTime\", extend({}, baseObj, {\n get: function() {\n return _endTime;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"End time must be set to a number.\");\n }\n _endTime = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"text\", extend({}, baseObj, {\n get: function() {\n return _text;\n },\n set: function(value) {\n _text = \"\" + value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"region\", extend({}, baseObj, {\n get: function() {\n return _region;\n },\n set: function(value) {\n _region = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"vertical\", extend({}, baseObj, {\n get: function() {\n return _vertical;\n },\n set: function(value) {\n var setting = findDirectionSetting(value);\n // Have to check for false because the setting an be an empty string.\n if (setting === false) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _vertical = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"snapToLines\", extend({}, baseObj, {\n get: function() {\n return _snapToLines;\n },\n set: function(value) {\n _snapToLines = !!value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"line\", extend({}, baseObj, {\n get: function() {\n return _line;\n },\n set: function(value) {\n if (typeof value !== \"number\" && value !== autoKeyword) {\n throw new SyntaxError(\"An invalid number or illegal string was specified.\");\n }\n _line = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"lineAlign\", extend({}, baseObj, {\n get: function() {\n return _lineAlign;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _lineAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"position\", extend({}, baseObj, {\n get: function() {\n return _position;\n },\n set: function(value) {\n if (value < 0 || value > 100) {\n throw new Error(\"Position must be between 0 and 100.\");\n }\n _position = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"positionAlign\", extend({}, baseObj, {\n get: function() {\n return _positionAlign;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _positionAlign = setting;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"size\", extend({}, baseObj, {\n get: function() {\n return _size;\n },\n set: function(value) {\n if (value < 0 || value > 100) {\n throw new Error(\"Size must be between 0 and 100.\");\n }\n _size = value;\n this.hasBeenReset = true;\n }\n }));\n\n Object.defineProperty(cue,\n \"align\", extend({}, baseObj, {\n get: function() {\n return _align;\n },\n set: function(value) {\n var setting = findAlignSetting(value);\n if (!setting) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _align = setting;\n this.hasBeenReset = true;\n }\n }));\n\n /**\n * Other <track> spec defined properties\n */\n\n // http://www.whatwg.org/specs/web-apps/current-work/multipage/the-video-element.html#text-track-cue-display-state\n cue.displayState = undefined;\n\n if (isIE8) {\n return cue;\n }\n }\n\n /**\n * VTTCue methods\n */\n\n VTTCue.prototype.getCueAsHTML = function() {\n // Assume WebVTT.convertCueToDOMTree is on the global.\n return WebVTT.convertCueToDOMTree(window, this.text);\n };\n\n root.VTTCue = root.VTTCue || VTTCue;\n}(this));\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n// If we're in Node.js then require VTTRegion so we can extend it, otherwise assume\n// VTTRegion is on the global.\nif (typeof module !== \"undefined\" && module.exports) {\n this.VTTRegion = require(\"./vttregion\").VTTRegion;\n}\n\n// Extend VTTRegion with methods to convert to JSON, from JSON, and construct a\n// VTTRegion from an options object. The primary purpose of this is for use in the\n// vtt.js test suite. It's also useful if you need to work with VTTRegions in\n// JSON format.\n(function(root) {\n\n root.VTTRegion.create = function(options) {\n var region = new root.VTTRegion();\n for (var key in options) {\n if (region.hasOwnProperty(key)) {\n region[key] = options[key];\n }\n }\n return region;\n };\n\n root.VTTRegion.fromJSON = function(json) {\n return this.create(JSON.parse(json));\n };\n\n}(this));\n","/**\n * Copyright 2013 vtt.js Contributors\n *\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n */\n\n(function(root) {\n\n var scrollSetting = {\n \"\": true,\n \"up\": true\n };\n\n function findScrollSetting(value) {\n if (typeof value !== \"string\") {\n return false;\n }\n var scroll = scrollSetting[value.toLowerCase()];\n return scroll ? value.toLowerCase() : false;\n }\n\n function isValidPercentValue(value) {\n return typeof value === \"number\" && (value >= 0 && value <= 100);\n }\n\n // VTTRegion shim http://dev.w3.org/html5/webvtt/#vttregion-interface\n function VTTRegion() {\n var _width = 100;\n var _lines = 3;\n var _regionAnchorX = 0;\n var _regionAnchorY = 100;\n var _viewportAnchorX = 0;\n var _viewportAnchorY = 100;\n var _scroll = \"\";\n\n Object.defineProperties(this, {\n \"width\": {\n enumerable: true,\n get: function() {\n return _width;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"Width must be between 0 and 100.\");\n }\n _width = value;\n }\n },\n \"lines\": {\n enumerable: true,\n get: function() {\n return _lines;\n },\n set: function(value) {\n if (typeof value !== \"number\") {\n throw new TypeError(\"Lines must be set to a number.\");\n }\n _lines = value;\n }\n },\n \"regionAnchorY\": {\n enumerable: true,\n get: function() {\n return _regionAnchorY;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"RegionAnchorX must be between 0 and 100.\");\n }\n _regionAnchorY = value;\n }\n },\n \"regionAnchorX\": {\n enumerable: true,\n get: function() {\n return _regionAnchorX;\n },\n set: function(value) {\n if(!isValidPercentValue(value)) {\n throw new Error(\"RegionAnchorY must be between 0 and 100.\");\n }\n _regionAnchorX = value;\n }\n },\n \"viewportAnchorY\": {\n enumerable: true,\n get: function() {\n return _viewportAnchorY;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"ViewportAnchorY must be between 0 and 100.\");\n }\n _viewportAnchorY = value;\n }\n },\n \"viewportAnchorX\": {\n enumerable: true,\n get: function() {\n return _viewportAnchorX;\n },\n set: function(value) {\n if (!isValidPercentValue(value)) {\n throw new Error(\"ViewportAnchorX must be between 0 and 100.\");\n }\n _viewportAnchorX = value;\n }\n },\n \"scroll\": {\n enumerable: true,\n get: function() {\n return _scroll;\n },\n set: function(value) {\n var setting = findScrollSetting(value);\n // Have to check for false as an empty string is a legal value.\n if (setting === false) {\n throw new SyntaxError(\"An invalid or illegal string was specified.\");\n }\n _scroll = setting;\n }\n }\n });\n }\n\n root.VTTRegion = root.VTTRegion || VTTRegion;\n}(this));\n","function _arrayLikeToArray(arr, len) {\n if (len == null || len > arr.length) len = arr.length;\n for (var i = 0, arr2 = new Array(len); i < len; i++) {\n arr2[i] = arr[i];\n }\n return arr2;\n}\nmodule.exports = _arrayLikeToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _arrayWithHoles(arr) {\n if (Array.isArray(arr)) return arr;\n}\nmodule.exports = _arrayWithHoles, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _assertThisInitialized(self) {\n if (self === void 0) {\n throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n }\n return self;\n}\nmodule.exports = _assertThisInitialized, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\nmodule.exports = _classCallCheck, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, toPropertyKey(descriptor.key), descriptor);\n }\n}\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n Object.defineProperty(Constructor, \"prototype\", {\n writable: false\n });\n return Constructor;\n}\nmodule.exports = _createClass, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var toPropertyKey = require(\"./toPropertyKey.js\");\nfunction _defineProperty(obj, key, value) {\n key = toPropertyKey(key);\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n return obj;\n}\nmodule.exports = _defineProperty, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _getPrototypeOf(o) {\n module.exports = _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) {\n return o.__proto__ || Object.getPrototypeOf(o);\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _getPrototypeOf(o);\n}\nmodule.exports = _getPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var setPrototypeOf = require(\"./setPrototypeOf.js\");\nfunction _inherits(subClass, superClass) {\n if (typeof superClass !== \"function\" && superClass !== null) {\n throw new TypeError(\"Super expression must either be null or a function\");\n }\n subClass.prototype = Object.create(superClass && superClass.prototype, {\n constructor: {\n value: subClass,\n writable: true,\n configurable: true\n }\n });\n Object.defineProperty(subClass, \"prototype\", {\n writable: false\n });\n if (superClass) setPrototypeOf(subClass, superClass);\n}\nmodule.exports = _inherits, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _iterableToArray(iter) {\n if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter);\n}\nmodule.exports = _iterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _nonIterableRest() {\n throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\");\n}\nmodule.exports = _nonIterableRest, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar assertThisInitialized = require(\"./assertThisInitialized.js\");\nfunction _possibleConstructorReturn(self, call) {\n if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) {\n return call;\n } else if (call !== void 0) {\n throw new TypeError(\"Derived constructors may only return object or undefined\");\n }\n return assertThisInitialized(self);\n}\nmodule.exports = _possibleConstructorReturn, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _setPrototypeOf(o, p) {\n module.exports = _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) {\n o.__proto__ = p;\n return o;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;\n return _setPrototypeOf(o, p);\n}\nmodule.exports = _setPrototypeOf, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayWithHoles = require(\"./arrayWithHoles.js\");\nvar iterableToArray = require(\"./iterableToArray.js\");\nvar unsupportedIterableToArray = require(\"./unsupportedIterableToArray.js\");\nvar nonIterableRest = require(\"./nonIterableRest.js\");\nfunction _toArray(arr) {\n return arrayWithHoles(arr) || iterableToArray(arr) || unsupportedIterableToArray(arr) || nonIterableRest();\n}\nmodule.exports = _toArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nfunction _toPrimitive(input, hint) {\n if (_typeof(input) !== \"object\" || input === null) return input;\n var prim = input[Symbol.toPrimitive];\n if (prim !== undefined) {\n var res = prim.call(input, hint || \"default\");\n if (_typeof(res) !== \"object\") return res;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (hint === \"string\" ? String : Number)(input);\n}\nmodule.exports = _toPrimitive, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var _typeof = require(\"./typeof.js\")[\"default\"];\nvar toPrimitive = require(\"./toPrimitive.js\");\nfunction _toPropertyKey(arg) {\n var key = toPrimitive(arg, \"string\");\n return _typeof(key) === \"symbol\" ? key : String(key);\n}\nmodule.exports = _toPropertyKey, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n return (module.exports = _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) {\n return typeof obj;\n } : function (obj) {\n return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n }, module.exports.__esModule = true, module.exports[\"default\"] = module.exports), _typeof(obj);\n}\nmodule.exports = _typeof, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","var arrayLikeToArray = require(\"./arrayLikeToArray.js\");\nfunction _unsupportedIterableToArray(o, minLen) {\n if (!o) return;\n if (typeof o === \"string\") return arrayLikeToArray(o, minLen);\n var n = Object.prototype.toString.call(o).slice(8, -1);\n if (n === \"Object\" && o.constructor) n = o.constructor.name;\n if (n === \"Map\" || n === \"Set\") return Array.from(o);\n if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return arrayLikeToArray(o, minLen);\n}\nmodule.exports = _unsupportedIterableToArray, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\tid: moduleId,\n\t\tloaded: false,\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Flag the module as loaded\n\tmodule.loaded = true;\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","__webpack_require__.nmd = (module) => {\n\tmodule.paths = [];\n\tif (!module.children) module.children = [];\n\treturn module;\n};","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) scriptUrl = scripts[scripts.length - 1].src\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl + \"../../\";","// Copyright (C) 2017-2022 Smart code 203358507\n\nif (typeof process.env.SENTRY_DSN === 'string') {\n const Sentry = require('@sentry/browser');\n Sentry.init({ dsn: process.env.SENTRY_DSN });\n}\n\nconst Bowser = require('bowser');\nconst browser = Bowser.parse(window.navigator?.userAgent || '');\nif (browser?.platform?.type === 'desktop') {\n document.querySelector('meta[name=\"viewport\"]')?.setAttribute('content', '');\n}\n\nconst React = require('react');\nconst ReactDOM = require('react-dom/client');\nconst i18n = require('i18next');\nconst { initReactI18next } = require('react-i18next');\nconst stremioTranslations = require('stremio-translations');\nconst App = require('./App');\n\nconst translations = Object.fromEntries(Object.entries(stremioTranslations()).map(([key, value]) => [key, {\n translation: value\n}]));\n\ni18n\n .use(initReactI18next)\n .init({\n resources: translations,\n lng: 'en-US',\n fallbackLng: 'en-US',\n interpolation: {\n escapeValue: false\n }\n });\n\nconst root = ReactDOM.createRoot(document.getElementById('app'));\nroot.render(<App />);\n\nif (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {\n window.addEventListener('load', () => {\n navigator.serviceWorker.register('/service-worker.js')\n .catch((registrationError) => {\n console.error('SW registration failed: ', registrationError);\n });\n });\n}\n"],"names":["module","exports","arr","len","length","i","arr2","Array","__esModule","isArray","asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","fn","self","this","args","arguments","apply","err","undefined","instance","Constructor","TypeError","_defineProperties","target","props","descriptor","enumerable","configurable","writable","Object","defineProperty","protoProps","staticProps","prototype","obj","_i","Symbol","iterator","_s","_e","_arr","_n","_d","call","next","push","objectWithoutPropertiesLoose","source","excluded","getOwnPropertySymbols","sourceSymbolKeys","indexOf","propertyIsEnumerable","sourceKeys","keys","arrayWithHoles","iterableToArrayLimit","unsupportedIterableToArray","nonIterableRest","_typeof","constructor","arrayLikeToArray","o","minLen","n","toString","slice","name","from","test","_interopRequireDefault","_regenerator","_asyncToGenerator2","scope","handler","addEventListener","_ref2","mark","_callee","_ref","request","id","path","data","thisArg","wrap","_context","prev","abrupt","reduce","prop","sent","postMessage","response","result","t0","stop","_x","_ref3","_callee2","_context2","Math","random","onMessage","_ref4","removeEventListener","_x2","_x3","React","PropTypes","icons","Icon","forwardRef","ref","icon","createElement","assign","viewBox","paths","map","index","d","displayName","propTypes","oneOf","EventEmitter","ERROR","ChromecastSenderVideo","options","containerElement","HTMLElement","Error","chromecastTransport","device","getCastDevice","deviceNameContainerElement","document","style","display","flexDirection","alignItems","justifyContent","width","height","backgroundColor","deviceNameLabelElement","flex","maxWidth","fontSize","lineHeight","maxHeight","textAlign","color","innerText","friendlyName","appendChild","on","onMessageReceivedError","events","destroyed","observedProps","stream","loaded","paused","time","duration","buffering","buffered","audioTracks","selectedAudioTrackId","subtitlesTracks","selectedSubtitlesTrackId","subtitlesOffset","subtitlesSize","subtitlesTextColor","subtitlesBackgroundColor","subtitlesOutlineColor","volume","muted","playbackSpeed","extraSubtitlesTracks","selectedExtraSubtitlesTrackId","extraSubtitlesDelay","extraSubtitlesSize","extraSubtitlesOffset","extraSubtitlesTextColor","extraSubtitlesBackgroundColor","extraSubtitlesOutlineColor","onMessageSendError","action","emit","CHROMECAST_SENDER_VIDEO","MESSAGE_SEND_FAILED","INVALID_MESSAGE_RECEIVED","message","event","concat","onPropChanged","propName","propValue","eventName","listener","dispatch","type","hasOwnProperty","sendMessage","catch","commandName","commandArgs","removeAllListeners","off","removeChild","JSON","stringify","canPlayStream","manifest","external","commands","Hls","cloneDeep","deepFreeze","Color","getContentType","HLS_CONFIG","HTMLVideo","styleElement","sheet","insertRule","videoElement","controls","onerror","code","HTML_VIDEO","MEDIA_ERR_ABORTED","MEDIA_ERR_NETWORK","MEDIA_ERR_DECODE","MEDIA_ERR_SRC_NOT_SUPPORTED","UNKNOWN_ERROR","onError","critical","onVideoError","onended","onpause","onplay","ontimeupdate","ondurationchange","onwaiting","onseeking","onseeked","onstalled","onplaying","oncanplay","canplaythrough","onloadedmetadata","onloadeddata","onvolumechange","onratechange","textTracks","onchange","onCueChange","forEach","track","oncuechange","hls","getProp","readyState","HAVE_METADATA","currentTime","isFinite","floor","HAVE_FUTURE_DATA","start","end","freeze","String","lang","language","label","origin","embedded","mode","parseInt","cssRules","textShadow","audioTrack","playbackRate","cues","cue","snapToLines","line","command","url","autoplay","contentType","isSupported","Events","AUDIO_TRACKS_UPDATED","AUDIO_TRACK_SWITCHED","loadSource","attachMedia","src","UNSUPPORTED_STREAM","detachMedia","destroy","removeAttribute","load","pause","play","selecterdSubtitlesTrack","find","max","min","rgb","string","console","selecterdAudioTrack","split","pop","parseFloat","setProp","behaviorHints","notWebReady","canPlayType","proxyHeaders","fetch","method","resp","ok","headers","get","status","statusText","debug","enableWorker","lowLatencyMode","backBufferLength","maxBufferLength","maxMaxBufferLength","maxFragLookUpTolerance","maxBufferHole","appendErrorMaxRetry","nudgeMaxRetry","manifestLoadingTimeOut","manifestLoadingMaxRetry","IFrameVideo","iframeElement","border","allowFullscreen","allow","contentWindow","playerFrameUrl","window","onload","SUBS_SCALE_FACTOR","stremioToMPVProps","ShellVideo","ipc","shellTransport","stremioProps","send","continueFrom","avgDuration","setBackground","visible","bg","container","parentElement","background","last_time","log","windowRenderer","navigator","platform","videoOutput","mpvSeparateWindow","separateWindow","speed","aid","mute","sid","logProp","intDuration","round","embeddedProp","filter","x","title","current_time","actualId","argb","replace","selectVideoImplementation","StremioVideo","video","Video","TizenVideo","WebOsVideo","YouTubeVideo","withStreamingServer","withHTMLSubtitles","externalUrl","getCastState","cast","framework","CastState","CONNECTED","ytId","streamingServerURL","g","tizen","webOS","isBuffering","videoSpeed","currentSubTrack","currentAudioTrack","lastSub","promiseAudioTrackChange","size","offset","textColor","outlineColor","objElement","disabledSubs","refreshSubtitle","lastSubDurationDiff","now","renderSubtitle","text","subtitleTimeout","clearTimeout","subtitlesElement","hasChildNodes","lastChild","bottom","cueNode","innerHTML","padding","setTimeout","Listener","onbufferingstart","onbufferingprogress","onbufferingcomplete","oncurrentplaytime","onsubtitlechange","onstreamcompleted","webapis","avplay","setListener","position","right","left","zIndex","isPaused","getState","setSelectTrack","getCurrentTime","getDuration","totalTrackInfo","getTotalTrackInfo","textTrack","textTrackId","extra","parse","extra_info","e","textTrackLang","track_lang","trim","currentTracks","getCurrentStreamInfo","currentIndex","audioTrackId","audioTrackLang","open","setDisplayRect","innerWidth","innerHeight","setDisplayMethod","seekTo","prepare","willPause","lastKnownProp","selectedSubtitlesTrack","selectedAudioTrack","setSpeed","luna","params","fail","onSuccess","onFailure","service","runWebOS","failed","parameters","need","webOsColors","stremioColors","knownMediaId","subSize","subscribed","count_message","subscribe","cb","answered","sourceInfo","programInfo","numSubtitleTracks","subtitleTrackInfo","setSubs","numAudioTracks","audioTrackInfo","setTracks","unsubscribe","errorCode","unloadCompleted","mediaId","state","toggleSubtitles","startTime","lastSubColor","lastSubBgColor","lastSubBgOpacity","lastPlaybackSpeed","trackIndex","nextOffset","nextSubSize","nextColor","enabled","count","timer","setInterval","clearInterval","timeChangedTimeout","apiScriptElement","YT","ready","onAPIError","PlayerState","Player","videoContainerElement","playerVars","cc_load_policy","disablekb","enablejsapi","fs","iv_load_policy","loop","modestbranding","playsinline","rel","onReady","onVideoReady","onApiChange","onVideoAPIChange","onStateChange","onVideoStateChange","timeChangedIntervalId","pendingLoadArgs","YOUTUBE_VIDEO","API_LOAD_FAILED","videoError","INVALID_PARAMETER","HTML5_VIDEO","VIDEO_NOT_FOUND","VIDEO_NOT_EMBEDDABLE","loadModule","setOption","ENDED","CUED","UNSTARTED","PAUSED","PLAYING","getPlayerState","BUFFERING","getVolume","isMuted","getOption","languageCode","loadVideoById","videoId","startSeconds","cueVideoById","stopVideo","pauseVideo","playVideo","unMute","setVolume","selecterdTrack","WITH_HTML_SUBTITLES","LOAD_FAILED","WITH_STREAMING_SERVER","CONVERT_FAILED","mediaElement","VIDEO_CODEC_CONFIGS","codec","mime","aliases","AUDIO_CODEC_CONFIGS","canPlay","config","formats","videoCodecs","audioCodecs","maxAudioChannels","userAgent","AudioContext","maxChannelCount","destination","getMaxAudioChannels","array","middle","convertSrtCue","caption","s","splice","match","m","convert","includes","srt","cuelist","srt2webvtt","VTTJS","binarySearchUpperBound","parser","WebVTT","Parser","StringDecoder","errors","cuesByTime","oncue","c","endTime","onparsingerror","onflush","warn","times","sort","t1","t2","j","k","c1","c2","render","nodes","timeIndex","cuesForTime","node","convertCueToDOMTree","subtitlesParser","subtitlesRenderer","subtitlesConverter","VideoWithHTMLSubtitles","onVideoPropEvent","bind","onOtherVideoEvent","videoState","tracks","selectedTrackId","delay","renderSubtitles","videoPropValue","selectedTrack","findIndex","t","subtitles","exclusive","observeProp","magnet","createTorrent","seriesInfo","infoHash","fileIdx","announce","parsedMagnetURI","decode","sources","buildTorrentUrl","query","URLSearchParams","encodeURIComponent","body","torrent","peerSearch","guessFileIdx","season","episode","json","guessedFileIdx","hat","mediaCapabilities","convertStream","VideoWithStreamingServer","loadArgs","actionsQueue","mediaURL","canPlayStreamOptions","forceTranscoding","queryParams","set","videoCodec","append","audioCodec","shift","flushActionsQueue","probe","isFormatSupported","some","format","areStreamsSupported","streams","every","channels","r","l","toStringTag","create","default","p","VERSION","PALETTE_MATERIAL_CHROME","PALETTE_MATERIAL_500","COLOR_NAMES","getLuminance","intToRgb","rgbToInt","rgbToHsv","rgbToHsl","hslToRgb","rgbToHex","parseColor","parseColorToHsla","parseColorToHsl","parseColorToRgba","parseColorToRgb","createPicker","a","return","u","h","attachTo","showHSL","showRGB","showHEX","showAlpha","palette","paletteEditable","useAlphaInPalette","slBarSize","hueBarSize","alphaBarSize","f","b","v","NodeList","querySelector","jquery","getContext","createLinearGradient","addColorStop","setHue","fillStyle","fillRect","globalCompositeOperation","grabColor","getImageData","findColor","A","y","Number","nvl","hasAttribute","getAttribute","H","S","L","R","G","B","element","className","setupHueCanvas","hueBarHelper","huePointer","setupSlCanvas","slBarHelper","slPointer","preview","setupClipboard","setupInput","inputH","inputS","inputL","remove","inputR","inputG","inputB","inputRGBHEX","setPalette","paletteRow","setupAlphaCanvas","alphaPointer","onValueChanged","limit","clientX","getBoundingClientRect","clientY","top","toFixed","select","returnValue","execCommand","ensureArray","setAttribute","insertBefore","onPaletteColorAdd","onPaletteColorRemove","querySelectorAll","shiftKey","silent","updatePointerH","updateInputHSL","updateInputRGB","updateInputRGBHEX","updatePointerSL","F","E","updatePointerA","C","cssColorToRgb","w","T","I","P","D","oncoloradd","oncolorremove","listeners","change","coloradd","colorremove","hsl","rgbhex","all","hex","rgba","hsla","setColor","updatePalette","show","classList","hide","add","toggle","ctrl","cssHslaToHsla","cssHslToHsl","cssRgbaToRgba","cssRgbToRgb","cssColorToRgba","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgrey","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgrey","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","isNaN","toLowerCase","exec","pow","btoa","unescape","sourceRoot","join","require","useTranslation","Router","Core","Shell","Chromecast","DragAndDrop","KeyboardShortcuts","ServicesProvider","NotFound","ToastProvider","CONSTANTS","ServicesToaster","DeepLinkHandler","ErrorDialog","routerViewsConfig","styles","i18n","onPathNotMatch","useCallback","services","useMemo","core","appVersion","process","shellVersion","shell","chromecast","keyboardShortcuts","dragAndDrop","useState","initialized","setInitialized","useEffect","prevPath","location","hash","onLocationHashChange","active","transport","analytics","onCoreStateChanged","onShellStateChanged","onChromecastStateChange","setOptions","receiverApplicationId","CHROMECAST_RECEIVER_APP_ID","autoJoinPolicy","chrome","AutoJoinPolicy","PAGE_SCOPED","resumeSavedSession","onCoreEvent","settings","interfaceLanguage","changeLanguage","onWindowFocus","profile","StrictMode","viewsConfig","withCoreSuspender","useStreamingServer","streamingServer","content","deepLinks","metaDetailsVideos","classnames","Button","Image","dataCleared","setDataCleared","reload","clearData","localStorage","clear","alt","onClick","disabled","useServices","useToast","toast","uid","transport_url","startsWith","timeout","dataset","onDragAndDropError","file","App","routes","routesRegexp","board","component","Board","intro","Intro","discover","Discover","library","Library","continuewatching","search","Search","metadetails","MetaDetails","addons","Addons","Settings","player","AddonDetails","version","logo","description","types","transportUrl","official","renderLogoFallback","renderFallback","arrayOf","bool","ModalDialog","AddonDetailsWithRemoteAndLocalAddon","withRemoteAndLocalAddon","remoteAddon","localAddon","addon","flags","useAddonDetails","AddonDetailsModal","onCloseRequest","addonDetails","modalButtons","cancelButton","reactEvent","nativeEvent","configureButton","toggleButton","buttons","selected","func","AddonDetailsModalFallback","useModelState","model","href","children","onKeyDown","buttonClickPrevented","currentTarget","click","onMouseDown","buttonBlurPrevented","preventDefault","activeElement","blur","tabIndex","TYPE_PRIORITIES","movie","series","channel","tv","music","radio","podcast","game","book","adult","other","Infinity","ICON_FOR_TYPE","Map","SUBTITLES_SIZES","SUBTITLES_FONTS","SEEK_TIME_DURATIONS","NEXT_VIDEO_POPUP_DURATIONS","CATALOG_PREVIEW_SIZE","CATALOG_PAGE_SIZE","NONE_EXTRA_VALUE","SKIP_EXTRA_NAME","META_LINK_CATEGORY","IMDB_LINK_CATEGORY","SHARE_LINK_CATEGORY","WRITERS_LINK_CATEGORY","Checkbox","checked","AColorPicker","useBinaryState","ColorPicker","ColorInput","onChange","modalOpen","openModal","closeModal","tempValue","setTempValue","labelButtonStyle","isTransparent","endsWith","labelButtonOnClick","openModalPrevented","modalDialogOnClick","colorPickerOnInput","useLayoutEffect","onInput","object","pickerRef","useRef","pickerElementRef","current","pickerClipboard","picker","nextValue","CoreSuspenderContext","createContext","wrapPromise","promise","suspender","read","useCoreSuspender","useContext","Component","Fallback","parentSuspender","setRender","statesRef","streamsRef","decodeStream","Suspense","fallback","Provider","DelayedRenderer","fallbackSrc","broken","setBroken","MetaItem","OPTIONS","LibItem","_id","removable","metaDetailsStreams","progress","option","optionOnSelect","optionSelectPrevented","number","shape","VerticalNavBar","HorizontalNavBar","TABS","MainNavBars","memo","route","backButton","searchBar","addonsButton","fullscreenButton","navMenu","tabs","filterInvalidDOMProps","Multiselect","PlayIconCircleCentered","poster","posterShape","playIcon","menuOpen","onMenuOpen","onMenuClose","metaItemOnClick","selectPrevented","menuOnClick","menuOnSelect","renderPosterFallback","has","renderMenuLabelContent","renderLabelContent","onOpen","onClose","onSelect","ActionButton","MetaLinks","links","toUpperCase","UrlUtils","SharePrompt","MetaPreviewPlaceholder","ALLOWED_LINK_REDIRECTS","regexp","MetaPreview","compact","runtime","releaseInfo","released","trailerStreams","inLibrary","toggleInLibrary","shareModalOpen","openShareModal","closeShareModal","linksGroups","link","category","protocol","pathname","hostname","showHref","trailerHref","Date","getTime","getFullYear","Fragment","Placeholder","instanceOf","ReactIs","MetaRowPlaceholder","MetaRow","items","itemComponent","isValidElementType","item","fill","_","elementType","useRouteFocused","useModalsContainer","Modal","routeFocused","modalsContainer","modalContainerRef","closeButtonOnClick","onModalContainerMouseDown","closeModalDialogPrevented","onModalDialogContainerMouseDown","childNodes","childElementCount","oneOfType","Popup","direction","renderLabelText","closeMenu","toggleMenu","labelOnClick","toggleMenuPrevented","menuOnKeyDown","optionOnClick","closeMenuPrevented","mountedRef","renderLabel","renderMenu","renderPopupLabel","labelProps","any","isRequired","useFullscreen","SearchBar","NavMenu","backButtonOnClick","history","back","fullscreen","requestFullscreen","exitFullscreen","renderNavMenuLabel","NavMenuContent","popupLabelOnClick","togglePopupPrevented","popupMenuOnClick","useProfile","useTorrent","createTorrentFromMagnet","logoutButtonOnClick","onPlayMagnetLinkClick","clipboard","readText","clipboardText","backgroundImage","auth","user","avatar","email","TextInput","searchInputRef","searchBarOnClick","queryInputOnChange","queryInputOnSubmit","focus","placeholder","defaultValue","onSubmit","SearchBarFallback","NavTabButton","tab","PaginationInput","prevNextButtonOnClick","cx","cy","FocusLock","getAnchorElement","documentElement","getComputedStyle","overflowY","labelRef","menuRef","autoDirection","setAutoDirection","menuOnMouseDown","closePopupPrevented","onCloseEvent","closeEvent","contains","anchorRect","labelRect","menuRect","labelPosition","autoFocus","lockProps","SearchBarPlaceholder","inputRef","selectInputContent","copyToClipboard","readOnly","useAnimationFrame","useLiveRef","Slider","minimumValue","maximumValue","onSlide","onComplete","minimumValueRef","maximumValueRef","valueRef","onSlideRef","onCompleteRef","sliderContainerRef","requestThumbAnimation","cancelThumbAnimation","calculateValueForMouseX","mouseX","sliderX","sliderWidth","retainThumb","onBlur","onMouseUp","onMouseMove","releaseThumb","classIndex","button","thumbPosition","marginLeft","StreamingServerWarning","onLaterClick","streamingServerWarningDismissed","setMonth","getMonth","onDismissClick","setFullYear","submitPrevented","autoCorrect","autoCapitalize","autoComplete","spellCheck","ToastContext","ToastItem","toastOnClick","selectToastPrevented","closeToastPrevented","setContainer","useReducer","itemOnClose","filters","addFilter","removeFilter","priorities","localeCompare","NEGATIVE_INFINITY","child","elementTop","offsetTop","elementBottom","clientHeight","containerTop","scrollTop","containerBottom","isChildVisible","comparatorWithPriorities","getVisibleChildrenRange","interfaceLanguages","languageNames","translateOption","useOnScrollToBottom","urlParamsNames","translateKeyPrefix","translateKey","translateValue","charAt","animationFrameId","cancel","cancelAnimationFrame","requestAnimationFrame","initialValue","setValue","fullscreenElement","setFullscreen","toggleFullscreen","onFullscreenChange","throttle","isEqual","intersection","deps","prevState","nextState","setState","useInsertionEffect","onNewState","models","onNewStateThrottled","threshold","triggeredRef","onScroll","scrollHeight","ctx","NaN","createTorrentTimeout","parsed","ReactDOM","createPortal","ModalsContainerContext","ModalsContainerProvider","Route","RouteFocusedContext","RouteFocusedProvider","routeConfigForPath","urlParamsForPath","views","setViews","routeConfig","urlParams","routeViewIndex","vc","routeIndex","rc","view","entries","exact","RegExp","matches","decodeURIComponent","Addon","installed","onToggle","onConfigure","onShare","toggleButtonOnClick","configureButtonOnClick","shareButtonOnClick","configurationRequired","p2p","useInstalledAddons","useRemoteAddons","useAddonDetailsTransportUrl","useSelectableInputs","installedAddons","remoteAddons","addonDetailsTransportUrl","setAddonDetailsTransportUrl","selectInputs","filtersModalOpen","openFiltersModal","closeFiltersModal","addAddonModalOpen","openAddAddonModal","closeAddAddonModal","addAddonUrlInputRef","addAddonOnSubmit","addAddonModalButtons","setSearch","searchInputOnChange","sharedAddon","setSharedAddon","clearSharedAddon","onAddonShare","onAddonToggle","onAddonConfigure","closeAddonDetails","searchFilterPredicate","selectInput","selectable","catalog","catalogId","setTransportUrl","nextQueryParams","base","resource","selectableInputs","catalogSelect","catalogs","selectableCatalog","typeSelect","mapSelectableInputs","debounce","useBoard","useContinueWatchingPreview","continueWatchingPreview","loadBoardRows","boardCatalogsOffset","libraryItems","scrollContainerRef","onVisibleRangeChange","range","loadRange","useDiscover","loadNextPage","hasNextPage","inputsModalOpen","openInputsModal","closeInputsModal","addonModalOpen","openAddonModal","closeAddonModal","selectedMetaItemIndex","setSelectedMetaItemIndex","selectedMetaItem","addToLibrary","removeFromLibrary","metaItemsOnFocusCapture","onScrollToBottom","onFocusCapture","metaItem","extraSelects","nextPage","ConsentCheckbox","checkboxOnClick","togglePrevented","linkOnClick","CredentialsTextInput","navigationPrevented","spatialNavigationPrevented","navigate","PasswordResetModal","useFacebookToken","SIGNUP_FORM","LOGIN_FORM","getFacebookToken","emailRef","passwordRef","confirmPasswordRef","termsRef","privacyPolicyRef","marketingRef","errorRef","passwordRestModalOpen","openPasswordRestModal","closePasswordResetModal","loaderModalOpen","openLoaderModal","closeLoaderModal","form","password","confirmPassword","termsAccepted","privacyPolicyAccepted","marketingAccepted","loginWithFacebook","accessToken","fbLoginToken","facebook","loginWithEmail","validity","valid","loginAsGuest","signup","gdpr_consent","tos","privacy","marketing","emailOnChange","emailOnSubmit","passwordOnChange","passwordOnSubmit","confirmPasswordOnChange","confirmPasswordOnSubmit","toggleTermsAccepted","togglePrivacyPolicyAccepted","toggleMarketingAccepted","switchFormOnClick","scrollIntoView","setError","goToPasswordReset","passwordResetModalButtons","getToken","FB","getLoginStatus","authResponse","login","fbAsyncInit","init","appId","xfbml","sdkScriptElement","async","defer","useLibrary","sortSelect","paginationInput","libItem","LibraryFallback","withModel","page","sorts","prevPage","StreamsList","VideosList","useMetaDetails","useSeason","useMetaExtensionTabs","metaDetails","setSeason","metaExtensions","metaExtension","clearMetaExtension","metaPath","streamPath","videos","seasonOnSelect","renderBackgroundImageFallback","overview","sandbox","StreamPlaceholder","Stream","addonName","thumbnail","renderThumbnailFallback","ALL_ADDONS_KEY","selectedAddon","setSelectedAddon","onAddonSelected","streamsByAddon","filteredStreams","values","flat","selectableOptions","SeasonsBarPlaceholder","SeasonsBar","seasons","seasonIndex","valueIndex","VideoPlaceholder","upcoming","watched","scheduled","ctrlKey","popupLabelOnKeyDown","popupLabelOnContextMenu","popupMenuOnContextMenu","toggleWatchedOnClick","toLocaleString","year","month","day","onContextMenu","MAX_SAFE_INTEGER","selectedSeason","nonSpecialSeasons","videosForSeason","extension","setSelected","BufferingLoader","SeekBar","VolumeSlider","ControlBar","nextVideo","onPlayRequested","onPauseRequested","onMuteRequested","onUnmuteRequested","onVolumeChangeRequested","onSeekRequested","onToggleSubtitlesMenu","onToggleInfoMenu","onToggleSpeedMenu","onToggleVideosMenu","onToggleOptionsMenu","chromecastServiceActive","setChromecastServiceActive","buttonsMenuOpen","toogleButtonsMenu","onSubtitlesButtonMouseDown","subtitlesMenuClosePrevented","onInfoButtonMouseDown","infoMenuClosePrevented","onSpeedButtonMouseDown","speedMenuClosePrevented","onVideosButtonMouseDown","videosMenuClosePrevented","onOptionsButtonMouseDown","optionsMenuClosePrevented","onPlayPauseButtonClick","onNextVideoButtonClick","onMuteButtonClick","onSubtitlesButtonClick","onInfoButtonClick","onSpeedButtonClick","onVideosButtonClick","onOptionsButtonClick","onChromecastButtonClick","requestSession","onStateChanged","formatTime","seekTime","setSeekTime","resetTimeDebounced","formatUnit","hours","minutes","seconds","slidingVolume","setSlidingVolume","resetVolumeDebounced","InfoMenu","NextVideoPopup","onDismiss","onPlayNextVideoRequested","watchNowButtonRef","animationEnded","setAnimationEnded","videoName","onAnimationEnd","onDismissButtonClick","onWatchNowButtonClick","Option","deviceId","onButtonClick","OptionsMenu","playbackDevices","externalPlayer","streaming","download","streamingUrl","downloadUrl","externalDevices","onCopyStreamButtonClick","writeText","onDownloadVideoButtonClick","onExternalDeviceRequested","langs","VideosMenu","SubtitlesMenu","SpeedMenu","usePlayer","useSettings","nextVideoState","videoParams","setVideoState","timeChanged","pausedChanged","ended","pushToLibrary","updateSettings","casting","setCasting","immersed","setImmersed","setImmersedDebounced","optionsMenuOpen","closeOptionsMenu","toggleOptionsMenu","subtitlesMenuOpen","closeSubtitlesMenu","toggleSubtitlesMenu","infoMenuOpen","closeInfoMenu","toggleInfoMenu","speedMenuOpen","closeSpeedMenu","toggleSpeedMenu","videosMenuOpen","closeVideosMenu","toggleVideosMenu","nextVideoPopupOpen","openNextVideoPopup","closeNextVideoPopup","nextVideoPopupDismissed","defaultSubtitlesSelected","defaultAudioTrackSelected","videoRef","onImplementationChanged","onEnded","onSubtitlesTrackLoaded","onExtraSubtitlesTrackLoaded","onPlayRequestedDebounced","onPauseRequestedDebounced","onPlaybackSpeedChanged","rate","onSubtitlesTrackSelected","onExtraSubtitlesTrackSelected","onAudioTrackSelected","onExtraSubtitlesDelayChanged","onSubtitlesSizeChanged","onSubtitlesOffsetChanged","onDismissNextVideoPopup","onVideoClick","onVideoDoubleClick","onContainerMouseDown","onContainerMouseMove","immersePrevented","onContainerMouseLeave","onBarMouseMove","baseUrl","metaRequest","libraryItem","streamRequest","video_id","timeOffset","bingeWatching","nextVideoNotificationDuration","findTrackByLang","where","subtitlesTrack","subtitlesLanguage","extraSubtitlesTrack","audioLanguage","intervalId","toastFilter","onCastStateChange","onChromecastServiceStateChange","CastContextEventType","CAST_STATE_CHANGED","seekTimeMultiplier","seekTimeDuration","onMouseOver","onMouseLeave","onPropValue","onDoubleClick","fileName","onExtraSubtitlesOffsetChanged","onExtraSubtitlesSizeChanged","streamTransportUrl","metaTransportUrl","OptionButton","RATES","reverse","onOptionSelect","DiscreteSelectInput","buttonOnClick","ORIGIN_PRIORITIES","LANGUAGE_PRIORITIES","subtitlesLanguages","selectedSubtitlesLanguage","subtitlesTracksForLanguage","subtitlesLanguageOnClick","subtitlesTrackOnClick","onSubtitlesDelayChanged","delta","extraDelay","sizeIndex","extraSizeIndex","extraSize","audioTrackOnClick","onEndedRef","onErrorRef","onPropValueRef","onPropChangedRef","onSubtitlesTrackLoadedRef","onExtraSubtitlesTrackLoadedRef","onImplementationChangedRef","videoElementRef","useImperativeHandle","subtitlesPath","useSearch","loadSearchRows","reduceRight","SearchFallback","useProfileSettingsInputs","useStreamingServerSettingsInputs","useDataExport","GENERAL_SECTION","PLAYER_SECTION","STREAMING_SECTION","SHORTCUTS_SECTION","dataExport","loadDataExport","interfaceLanguageSelect","subtitlesLanguageSelect","subtitlesSizeSelect","subtitlesTextColorInput","subtitlesBackgroundColorInput","subtitlesOutlineColorInput","audioLanguageSelect","seekTimeDurationSelect","nextVideoPopupDurationSelect","bingeWatchingCheckbox","playInBackgroundCheckbox","playInExternalPlayerCheckbox","hardwareDecodingCheckbox","streamingServerUrlInput","cacheSizeSelect","torrentProfileSelect","configureServerUrlModalOpen","openConfigureServerUrlModal","closeConfigureServerUrlModal","configureServerUrlInputRef","configureServerUrlOnSubmit","traktAuthStarted","setTraktAuthStarted","isTraktAuthenticated","trakt","created_at","expires_in","configureServerUrlModalButtons","toggleTraktOnClick","subscribeCalendarOnClick","exportDataOnClick","reloadStreamingServer","sectionsContainerRef","generalSectionRef","playerSectionRef","streamingServerSectionRef","shortcutsSectionRef","sections","selectedSectionId","setSelectedSectionId","updateSelectedSectionId","sideMenuButtonOnClick","section","scrollTo","behavior","sectionsContainerOnScorll","exportUrl","serverVersion","codes","playInBackground","playInExternalPlayer","hardwareDecoding","streamingServerUrl","CACHE_SIZES","cacheSizeToString","ceil","EPSILON","TORRENT_PROFILES","btDownloadSpeedHardLimit","btDownloadSpeedSoftLimit","btHandshakeTimeout","btMaxConnections","btMinPeersForStable","btRequestTimeout","soft","fast","cacheSize","selectedTorrentProfile","isCustomTorrentProfileSelected","torrentProfile","profileName","ChromecastTransport","starting","onTransportInit","onTransportInitError","cause","defineProperties","MESSAGE_NAMESPACE","CHUNK_SIZE","castAPIAvailable","castAPIEvents","available","messages","chunk","parsedMessage","onApplicationStatusChanged","CastSession","APPLICATION_STATUS_CHANGED","onApplicationMetadataChanged","APPLICATION_METADATA_CHANGED","onActiveInputStateChanged","ACTIVE_INPUT_STATE_CHANGED","onVolumeChanged","VOLUME_CHANGED","onMediaSessionChanged","MEDIA_SESSION","onCastStateChanged","onSesstionStateChanged","SESSION_STATE_CHANGED","sessionState","SessionState","SESSION_STARTED","session","addMessageListener","SESSION_ENDED","removeMessageListener","onCastAPIAvailabilityChanged","CastContext","getInstance","getSessionState","getCurrentSession","endCurrentSession","stopCasting","castSession","serializedMessage","chunksCount","chunks","CoreTransport","onTransportError","Bridge","worker","Worker","bridge","field","getDebugState","onDragOver","onDrop","dataTransfer","files","FileList","arrayBuffer","Uint8Array","keyboardShortcutPrevented","tagName","altKey","metaKey","forward","ServicesContext","ShellTransport","shellAvailable","shellEvents","QtMsgTypes","QtObjId","initShellComm","qt","onShellAvailabilityChanged","webChannelTransport","msg","onmessage","properties","shellVersionArr","signals","sig","signal","onEvent","methods","ev","byteLength","b64","lens","getLens","validLen","placeHoldersLen","toByteArray","tmp","Arr","_byteLength","curByte","revLookup","charCodeAt","fromByteArray","uint8","extraBytes","parts","maxChunkLength","len2","encodeChunk","lookup","num","output","parseRange","acc","cur","idx","generateRange","compose","getFirstMatch","getSecondMatch","matchAndReturnConst","getWindowsVersionName","getMacOSVersionName","getAndroidVersionName","getVersionPrecision","compareVersions","getBrowserAlias","BROWSER_ALIASES_MAP","getBrowserTypeByAlias","BROWSER_MAP","ENGINE_MAP","OS_MAP","PLATFORMS_MAP","Bada","BlackBerry","Chrome","Chromium","Electron","Epiphany","Firefox","Focus","Generic","Googlebot","Maxthon","Opera","PhantomJS","Puffin","QupZilla","QQ","QQLite","Safari","Sailfish","SeaMonkey","Sleipnir","Swing","Tizen","Vivaldi","WeChat","Roku","amazon_silk","android","bada","blackberry","chromium","electron","epiphany","firefox","generic","googlebot","google_search","ie","k_meleon","maxthon","edge","mz","naver","opera","opera_coast","phantomjs","puffin","qupzilla","qq","qqlite","safari","sailfish","samsung_internet","seamonkey","sleipnir","swing","uc","vivaldi","webos","wechat","yandex","tablet","mobile","desktop","WindowsPhone","Windows","MacOS","iOS","Android","WebOS","Linux","ChromeOS","PlayStation4","EdgeHTML","Blink","Trident","Presto","Gecko","WebKit","getParser","getResult","_ua","parsedResult","getUA","parseBrowser","browser","describe","getBrowser","getBrowserName","getBrowserVersion","getOS","os","parseOS","getOSName","getOSVersion","getPlatform","parsePlatform","getPlatformType","getEngine","engine","parseEngine","getEngineName","satisfies","isOS","isPlatform","isBrowser","compareVersion","substr","isEngine","is","versionName","vendor","base64","ieee754","customInspectSymbol","Buffer","SlowBuffer","alloc","INSPECT_MAX_BYTES","K_MAX_LENGTH","createBuffer","RangeError","buf","setPrototypeOf","encodingOrOffset","allocUnsafe","encoding","isEncoding","actual","write","fromString","ArrayBuffer","isView","arrayView","isInstance","copy","fromArrayBuffer","buffer","byteOffset","fromArrayLike","fromArrayView","SharedArrayBuffer","valueOf","isBuffer","numberIsNaN","fromObject","toPrimitive","assertSize","mustMatch","loweredCase","utf8ToBytes","base64ToBytes","slowToString","hexSlice","utf8Slice","asciiSlice","latin1Slice","base64Slice","utf16leSlice","swap","bidirectionalIndexOf","val","dir","arrayIndexOf","lastIndexOf","indexSize","arrLength","valLength","readUInt16BE","foundIndex","found","hexWrite","remaining","strLen","utf8Write","blitBuffer","asciiWrite","str","byteArray","asciiToBytes","base64Write","ucs2Write","units","hi","lo","utf16leToBytes","res","firstByte","codePoint","bytesPerSequence","secondByte","thirdByte","fourthByte","tempCodePoint","codePoints","MAX_ARGUMENTS_LENGTH","fromCharCode","decodeCodePointsArray","kMaxLength","TYPED_ARRAY_SUPPORT","proto","foo","typedArraySupport","poolSize","allocUnsafeSlow","_isBuffer","compare","list","pos","swap16","swap32","swap64","equals","inspect","thisStart","thisEnd","thisCopy","targetCopy","toJSON","ret","out","hexSliceLookupTable","bytes","checkOffset","ext","checkInt","wrtBigUInt64LE","checkIntBI","BigInt","wrtBigUInt64BE","checkIEEE754","writeFloat","littleEndian","noAssert","writeDouble","newBuf","subarray","readUintLE","readUIntLE","mul","readUintBE","readUIntBE","readUint8","readUInt8","readUint16LE","readUInt16LE","readUint16BE","readUint32LE","readUInt32LE","readUint32BE","readUInt32BE","readBigUInt64LE","defineBigIntMethod","validateNumber","first","last","boundsError","readBigUInt64BE","readIntLE","readIntBE","readInt8","readInt16LE","readInt16BE","readInt32LE","readInt32BE","readBigInt64LE","readBigInt64BE","readFloatLE","readFloatBE","readDoubleLE","readDoubleBE","writeUintLE","writeUIntLE","writeUintBE","writeUIntBE","writeUint8","writeUInt8","writeUint16LE","writeUInt16LE","writeUint16BE","writeUInt16BE","writeUint32LE","writeUInt32LE","writeUint32BE","writeUInt32BE","writeBigUInt64LE","writeBigUInt64BE","writeIntLE","sub","writeIntBE","writeInt8","writeInt16LE","writeInt16BE","writeInt32LE","writeInt32BE","writeBigInt64LE","writeBigInt64BE","writeFloatLE","writeFloatBE","writeDoubleLE","writeDoubleBE","targetStart","copyWithin","sym","getMessage","Base","super","stack","addNumericalSeparator","ERR_OUT_OF_RANGE","checkBounds","ERR_INVALID_ARG_TYPE","ERR_BUFFER_OUT_OF_BOUNDS","input","received","isInteger","abs","INVALID_BASE64_RE","leadSurrogate","base64clean","dst","alphabet","table","i16","BufferBigIntNotDefined","hasOwn","classNames","classes","argType","inner","colorNames","swizzle","reverseNames","cs","to","clamp","hexDouble","substring","hwb","hexAlpha","i2","alpha","percent","hwba","keyword","colorString","skippedModels","hashedModelKeys","labels","limiters","valpha","newArray","zeroArray","hashedKeys","places","percentString","unitArray","unitObject","roundToPlace","getset","maxfn","hue","saturationl","lightness","saturationv","chroma","wblack","z","hexa","rgbArray","alphaHex","rgbNumber","luminosity","lum","chan","contrast","color2","lum1","lum2","level","contrastRatio","isDark","isLight","negate","lighten","ratio","darken","saturate","desaturate","whiten","blacken","grayscale","fade","opaquer","rotate","degrees","mix","mixinColor","weight","color1","w1","w2","raw","roundTo","modifier","cssKeywords","reverseKeywords","hsv","cmyk","xyz","lab","lch","ansi16","ansi256","hcg","apple","rdif","gdif","bdif","diff","diffc","reversed","currentClosestKeyword","currentClosestDistance","distance","t3","smin","lmin","q","vmin","sl","wh","bl","y2","x2","z2","atan2","PI","sqrt","hr","cos","sin","saturation","ansi","mult","rem","char","integer","pure","mg","conversions","fromModel","toModel","wrappedFn","arg0","conversion","wrapRounded","wrapRaw","deriveBFS","graph","parent","buildGraph","queue","adjacents","adjacent","unshift","wrapConversion","getOwnPropertyNames","isFrozen","prefix","EE","context","once","addListener","emitter","evt","_events","_eventsCount","clearEvent","__proto__","eventNames","names","handlers","ee","listenerCount","a1","a2","a3","a4","a5","removeListener","prefixed","domProps","isValidDOMProp","_htmlAttributes","_htmlAttributes2","eventProps","onCopy","onCut","onPaste","onLoad","onWheel","onCompositionEnd","onCompositionStart","onCompositionUpdate","onKeyPress","onKeyUp","onFocus","onDrag","onDragEnd","onDragEnter","onDragExit","onDragLeave","onDragStart","onMouseEnter","onMouseOut","onTouchCancel","onTouchEnd","onTouchMove","onTouchStart","onAnimationStart","onAnimationIteration","onTransitionEnd","bits","digits","rack","expandBy","iters","hats","factory","modules","installedModules","moduleId","getter","ns","property","__webpack_require__","URL_REGEX","FIRST_SEGMENT_REGEX","SLASH_DOT_REGEX","SLASH_DOT_DOT_REGEX","URLToolkit","buildAbsoluteURL","baseURL","relativeURL","opts","alwaysNormalize","basePartsForNormalise","parseURL","normalizePath","buildURLFromParts","relativeParts","scheme","baseParts","netLoc","pathParts","builtParts","fragment","baseURLPath","newPath","webpackBootstrapFunc","oe","ENTRY_MODULE","moduleNameReqExp","dependencyRegExp","quoteRegExp","getModuleDependencies","queueName","retval","fnString","wrapperSignature","webpackRequireName","re","hasValuesInQueues","queues","hasValues","main","requiredModules","modulesQueue","seenModules","moduleToCheck","newModules","newModulesKeys","getRequiredModules","entryModule","blob","Blob","bare","workerUrl","URL","webkitURL","mozURL","msURL","createObjectURL","objectURL","__webpack_exports__","hlsDefaultConfig","mergeConfig","enableStreamingMode","_controller_abr_controller__WEBPACK_IMPORTED_MODULE_0__","_controller_audio_stream_controller__WEBPACK_IMPORTED_MODULE_1__","_controller_audio_track_controller__WEBPACK_IMPORTED_MODULE_2__","_controller_subtitle_stream_controller__WEBPACK_IMPORTED_MODULE_3__","_controller_subtitle_track_controller__WEBPACK_IMPORTED_MODULE_4__","_controller_buffer_controller__WEBPACK_IMPORTED_MODULE_5__","_controller_timeline_controller__WEBPACK_IMPORTED_MODULE_6__","_controller_cap_level_controller__WEBPACK_IMPORTED_MODULE_7__","_controller_fps_controller__WEBPACK_IMPORTED_MODULE_8__","_controller_eme_controller__WEBPACK_IMPORTED_MODULE_9__","_controller_cmcd_controller__WEBPACK_IMPORTED_MODULE_10__","_utils_xhr_loader__WEBPACK_IMPORTED_MODULE_11__","_utils_fetch_loader__WEBPACK_IMPORTED_MODULE_12__","_utils_cues__WEBPACK_IMPORTED_MODULE_13__","_utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_14__","_utils_logger__WEBPACK_IMPORTED_MODULE_15__","_extends","ownKeys","enumerableOnly","symbols","getOwnPropertyDescriptor","_objectSpread","_defineProperty","getOwnPropertyDescriptors","autoStartLoad","startPosition","defaultAudioCodec","capLevelOnFPSDrop","capLevelToPlayerSize","ignoreDevicePixelRatio","initialLiveManifestSize","maxBufferSize","highBufferWatchdogPeriod","nudgeOffset","liveSyncDurationCount","liveMaxLatencyDurationCount","liveSyncDuration","liveMaxLatencyDuration","maxLiveSyncPlaybackRate","liveDurationInfinity","liveBackBufferLength","enableSoftwareAES","manifestLoadingRetryDelay","manifestLoadingMaxRetryTimeout","startLevel","levelLoadingTimeOut","levelLoadingMaxRetry","levelLoadingRetryDelay","levelLoadingMaxRetryTimeout","fragLoadingTimeOut","fragLoadingMaxRetry","fragLoadingRetryDelay","fragLoadingMaxRetryTimeout","startFragPrefetch","fpsDroppedMonitoringPeriod","fpsDroppedMonitoringThreshold","loader","fLoader","pLoader","xhrSetup","licenseXhrSetup","licenseResponseCallback","abrController","bufferController","capLevelController","fpsController","stretchShortVideoTrack","maxAudioFramesDrift","forceKeyFrameOnDiscontinuity","abrEwmaFastLive","abrEwmaSlowLive","abrEwmaFastVoD","abrEwmaSlowVoD","abrEwmaDefaultEstimate","abrBandWidthFactor","abrBandWidthUpFactor","abrMaxWithRealBitrate","maxStarvationDelay","maxLoadingDelay","minAutoBitrate","emeEnabled","widevineLicenseUrl","drmSystemOptions","requestMediaKeySystemAccessFunc","testBandwidth","progressive","cmcd","enableDateRangeMetadataCues","enableEmsgMetadataCues","enableID3MetadataCues","cueHandler","enableWebVTT","enableIMSC1","enableCEA708Captions","captionsTextTrack1Label","captionsTextTrack1LanguageCode","captionsTextTrack2Label","captionsTextTrack2LanguageCode","captionsTextTrack3Label","captionsTextTrack3LanguageCode","captionsTextTrack4Label","captionsTextTrack4LanguageCode","renderTextTracksNatively","subtitleStreamController","subtitleTrackController","timelineController","audioStreamController","audioTrackController","emeController","cmcdController","defaultConfig","userConfig","currentLoader","_home_slim_stremio_hlsjs_src_polyfills_number__WEBPACK_IMPORTED_MODULE_0__","_utils_ewma_bandwidth_estimator__WEBPACK_IMPORTED_MODULE_1__","_events__WEBPACK_IMPORTED_MODULE_2__","_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_3__","_errors__WEBPACK_IMPORTED_MODULE_4__","_types_loader__WEBPACK_IMPORTED_MODULE_5__","_utils_logger__WEBPACK_IMPORTED_MODULE_6__","AbrController","lastLoadedFragLevel","_nextAutoLevel","onCheck","_abandonRulesCheck","fragCurrent","partCurrent","bitrateTestDelay","bwEstimator","registerListeners","_proto","FRAG_LOADING","onFragLoading","FRAG_LOADED","onFragLoaded","FRAG_BUFFERED","onFragBuffered","LEVEL_LOADED","onLevelLoaded","unregisterListeners","clearTimer","_data$part","frag","MAIN","part","details","live","update","autoLevelEnabled","media","stats","aborted","requestDelay","performance","loading","levels","minAutoLevel","expectedLen","total","maxBitrate","loadRate","bwEstimate","fragLoadedDelay","bufferStarvationDelay","bufferInfo","nextLoadLevel","fragLevelNextLoadedDelay","POSITIVE_INFINITY","getEstimate","sn","sample","abort","trigger","FRAG_LOAD_EMERGENCY_ABORTED","loadedBytes","loadedDuration","realBitrate","bitrateTest","fragBufferedData","processingMs","parsing","FRAG_LOAD_ERROR","FRAG_LOAD_TIMEOUT","getNextABRAutoLevel","maxAutoLevel","currentFragDuration","avgbw","bestLevel","findBestLevel","trace","bwFactor","bwUpFactor","currentBw","maxFetchDuration","_level$details","currentLevel","currentCodecSet","codecSet","levelInfo","levelDetails","partTarget","averagetargetduration","adjustedbw","bitrate","fetchDuration","forcedAutoLevel","canEstimate","nextABRAutoLevel","loadError","nextLevel","_base_stream_controller__WEBPACK_IMPORTED_MODULE_1__","_fragment_tracker__WEBPACK_IMPORTED_MODULE_4__","_types_level__WEBPACK_IMPORTED_MODULE_5__","_types_loader__WEBPACK_IMPORTED_MODULE_6__","_loader_fragment__WEBPACK_IMPORTED_MODULE_7__","_demux_chunk_cache__WEBPACK_IMPORTED_MODULE_8__","_demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_9__","_types_transmuxer__WEBPACK_IMPORTED_MODULE_10__","_fragment_finders__WEBPACK_IMPORTED_MODULE_11__","_utils_discontinuities__WEBPACK_IMPORTED_MODULE_12__","_errors__WEBPACK_IMPORTED_MODULE_13__","_setPrototypeOf","AudioStreamController","_BaseStreamController","subClass","superClass","fragmentTracker","_this","videoBuffer","videoTrackCC","waitingVideoCC","audioSwitch","trackId","waitingData","mainDetails","bufferFlushed","cachedTrackLoadedData","_registerListeners","onHandlerDestroying","_unregisterListeners","MEDIA_ATTACHED","onMediaAttached","MEDIA_DETACHING","onMediaDetaching","MANIFEST_LOADING","onManifestLoading","onAudioTracksUpdated","AUDIO_TRACK_SWITCHING","onAudioTrackSwitching","AUDIO_TRACK_LOADED","onAudioTrackLoaded","BUFFER_RESET","onBufferReset","BUFFER_CREATED","onBufferCreated","BUFFER_FLUSHED","onBufferFlushed","INIT_PTS_FOUND","onInitPtsFound","initPTS","cc","WAITING_INIT_PTS","tick","startLoad","STOPPED","lastCurrentTime","stopLoad","fragLoadError","IDLE","loadedmetadata","WAITING_TRACK","nextLoadPosition","doTick","doTickIdle","_levels$trackId","waitForCdnTuneIn","FRAG_LOADING_WAITING_RETRY","_this$media","retryDate","seeking","resetStartWhenNotLoaded","cache","complete","payload","flush","networkDetails","_handleFragmentLoadProgress","_handleFragmentLoadComplete","clearWaitingFragment","getLoadPosition","mediaBuffer","onTickEnd","removeFragment","resetLoadingState","_frag$decryptdata","_frag$decryptdata2","startFragRequested","trackDetails","levelLastLoaded","bufferable","afterBufferFlushed","AUDIO","getFwdBufferInfo","mainBufferInfo","bufferLen","maxBufLen","getMaxBufferLength","_streamEnded","BUFFER_EOS","fragments","targetBufferTime","PTSKnown","nextStart","targetduration","getNextFragment","decryptdata","keyFormat","loadFragment","loadKey","mainBufferLength","maxConfigBuffer","resetTransmuxer","mediaPlaylist","altAudio","removeAllFragments","_track$details","newDetails","startSN","endSN","totalduration","sliding","deltaUpdateFailed","hasProgramDateTime","alignPlaylists","setStartPosition","_frag$initSegment","assert","transmuxer","_handleTransmuxComplete","_handleTransmuxerFlush","initSegmentData","initSegment","partIndex","partial","chunkMeta","chunkCount","fragLoadedData","audio","fragContextChanged","fragPrevious","fragBufferedComplete","KEY_LOAD_ERROR","KEY_LOAD_TIMEOUT","onFragmentOrKeyLoadError","AUDIO_TRACK_LOAD_ERROR","AUDIO_TRACK_LOAD_TIMEOUT","fatal","BUFFER_FULL_ERROR","PARSING","PARSED","flushBuffer","bufferedInfo","reduceMaxBufferLength","flushMainBuffer","transmuxResult","_id3$samples","remuxResult","getCurrentContext","id3","completeAudioSwitch","_bufferInitSegment","FRAG_PARSING_INIT_SEGMENT","startPTS","endPTS","startDTS","endDTS","elementaryStreams","setElementaryStreamInfo","bufferFragmentData","samples","emittedID3","FRAG_PARSING_METADATA","emittedText","FRAG_PARSING_USERDATA","levelCodec","BUFFER_CODECS","segment","BUFFER_APPENDING","fragState","NOT_LOADED","PARTIAL","_loadInitSegment","_events__WEBPACK_IMPORTED_MODULE_0__","_errors__WEBPACK_IMPORTED_MODULE_1__","_base_playlist_controller__WEBPACK_IMPORTED_MODULE_2__","_types_loader__WEBPACK_IMPORTED_MODULE_3__","AudioTrackController","_BasePlaylistControll","groupId","tracksInGroup","trackName","selectDefaultTrack","MANIFEST_PARSED","onManifestParsed","LEVEL_LOADING","onLevelLoading","LEVEL_SWITCHING","onLevelSwitching","currentTrack","curDetails","retryCount","playlistLoaded","switchLevel","levelIndex","audioGroupIds","audioGroupId","urlId","audioTracksUpdated","selectInitialTrack","AUDIO_TRACK","retryLoadingOrFail","setAudioTrack","newId","lastTrack","_track$groupId","hlsUrlParameters","switchParams","loadPlaylist","currentAudioTrackName","findTrackId","MEDIA_ERROR","shouldLoadTrack","addDirectives","AUDIO_TRACK_LOADING","deliveryDirectives","BasePlaylistController","_types_level__WEBPACK_IMPORTED_MODULE_1__","_level_helper__WEBPACK_IMPORTED_MODULE_2__","_utils_logger__WEBPACK_IMPORTED_MODULE_3__","logPrefix","canLoad","NETWORK_ERROR","playlistUri","previous","renditionReports","attr","uri","URI","msn","currentGoal","age","No","previousDetails","elapsed","advancedDateTime","reloaded","advanced","lastPartSn","lastPartIndex","canBlockReload","endSn","lastPart","lastAdvanced","cdnAge","ageHeader","tuneInGoal","segments","getDeliveryDirectives","reloadInterval","previousDeliveryDirectives","skip","errorEvent","_errorEvent$context","_this2","retry","State","BaseStreamController","_task_loop__WEBPACK_IMPORTED_MODULE_1__","_fragment_tracker__WEBPACK_IMPORTED_MODULE_2__","_utils_logger__WEBPACK_IMPORTED_MODULE_4__","_events__WEBPACK_IMPORTED_MODULE_5__","_errors__WEBPACK_IMPORTED_MODULE_6__","_types_transmuxer__WEBPACK_IMPORTED_MODULE_7__","_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_8__","_utils_discontinuities__WEBPACK_IMPORTED_MODULE_9__","_fragment_finders__WEBPACK_IMPORTED_MODULE_10__","_level_helper__WEBPACK_IMPORTED_MODULE_11__","_loader_fragment_loader__WEBPACK_IMPORTED_MODULE_12__","_crypt_decrypter__WEBPACK_IMPORTED_MODULE_13__","_utils_time_ranges__WEBPACK_IMPORTED_MODULE_14__","_types_loader__WEBPACK_IMPORTED_MODULE_15__","_assertThisInitialized","ReferenceError","KEY_LOADING","WAITING_LEVEL","_TaskLoop","_state","fragmentLoader","decrypter","onvseeking","onvended","KEY_LOADED","onKeyLoaded","clearNextTick","partList","isBuffered","OK","onMediaSeeking","onMediaEnded","tolerance","fragStartOffset","pastFragment","tickImmediate","onHandlerDestroyed","_loadFragForPlayback","_doFragLoad","reason","resetFragmentLoading","startOffset","endOffset","flushScope","BUFFER_FLUSHING","_this3","decryptData","iv","webCryptoDecrypt","decryptedData","FRAG_DECRYPTED","tstart","tdecrypt","getBuffered","seekToStartPos","fragLoadedEndData","partsLoaded","fragLoaded","progressCallback","_this4","fragmentHint","getNextPart","doFragPartsLoad","handleFragLoadError","loadedEndOfParts","_this5","loadPartIndex","loadPart","partLoadedData","loadedPart","nextPart","INTERNAL_ABORTED","handleFragLoadAborted","updateLevelTiming","data1","data2","dropped","independent","flushBufferGap","fragDuration","segmentFraction","bufferedFragAtPos","getBufferedFrag","levelBitrate","minLength","fragLen","getInitialLiveFragment","liveSyncPosition","partEnd","fragmentEnd","getFragmentAtPosition","mapToInitFragWhenRequired","contiguous","independentAttrOmitted","programDateTime","endProgramDateTime","targetSN","fragNext","liveStart","bufferEnd","loadingParts","lookupTolerance","curSNIdx","nextFrag","synchronizeToLiveEdge","withinSlidingWindow","maxLatency","lastLevel","slidingStart","firstLevelLoad","aligned","alignedSliding","alignedSlidingStart","partHoldBack","startTimeOffset","filterType","levelRetry","bufferType","playlistType","bufferedTimeRanges","detectEvictedFragments","_this6","parsedDuration","drift","LEVEL_PTS_UPDATED","FRAG_PARSED","previousState","BufferController","_events__WEBPACK_IMPORTED_MODULE_1__","_utils_logger__WEBPACK_IMPORTED_MODULE_2__","_errors__WEBPACK_IMPORTED_MODULE_3__","_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_4__","_utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_5__","_loader_fragment__WEBPACK_IMPORTED_MODULE_6__","_buffer_operation_queue__WEBPACK_IMPORTED_MODULE_7__","MediaSource","VIDEO_CODEC_PROFILE_REPACE","_hls","_objectUrl","operationQueue","bufferCodecEventsExpected","_bufferCodecEventsTotal","mediaSource","appendError","pendingTracks","sourceBuffer","_onMediaSourceOpen","updateMediaElementDuration","checkPendingTracks","_onMediaSourceClose","_onMediaSourceEnded","_initSourceBuffer","hasSourceTypes","getSourceBufferTypes","MEDIA_ATTACHING","onMediaAttaching","onBufferAppending","onBufferCodecs","onBufferEos","onBufferFlushing","LEVEL_UPDATED","onLevelUpdated","onFragParsed","FRAG_CHANGED","onFragChanged","audiovideo","codecEvents","ms","endOfStream","revokeObjectURL","MEDIA_DETACHED","sb","removeBufferListeners","removeSourceBuffer","sourceBufferCount","changeType","_data$trackName","metadata","currentCodec","nextCodec","mimeType","appendChangeType","operation","execute","shiftAndExecuteNext","onStart","eventData","chunkStats","bufferAppendingStart","fragBuffering","partBuffering","checkTimestampOffset","executeStart","timestampOffset","appendExecutor","executeEnd","timeRanges","_type","BUFFER_APPENDED","BUFFER_APPEND_ERROR","DOMException","QUOTA_EXCEEDED_ERR","flushOperation","removeExecutor","_this7","buffersAppendedTo","AUDIOVIDEO","VIDEO","blockBuffers","flushBackBuffer","_this8","sourceBufferTypes","targetDuration","levelTargetDuration","maxBackBufferLength","targetBackBufferPosition","BACK_BUFFER_REACHED","LIVE_BACK_BUFFER_REACHED","levelDuration","mediaDuration","msDuration","updateSeekableRange","setLiveSeekableRange","pendingTracksCount","createSourceBuffers","buffers","BUFFER_INCOMPATIBLE_CODECS_ERROR","executeNext","tracksCreated","addSourceBuffer","sbName","addBufferListener","_onSBUpdateStart","_onSBUpdateEnd","_onSBUpdateError","BUFFER_ADD_CODEC_ERROR","BUFFER_APPENDING_ERROR","removeStart","removeEnd","updating","appendBuffer","onUnblocked","_this9","blockingOperations","appendBlocker","BufferOperationQueue","_utils_logger__WEBPACK_IMPORTED_MODULE_0__","sourceBufferReference","insertAbort","CapLevelController","autoLevelCapping","firstLevel","restrictedLevels","streamController","clientRect","setStreamController","unregisterListener","stopCapping","FPS_DROP_LEVEL_CAPPING","onFpsDropLevelCapping","isLevelAllowed","droppedLevel","HTMLVideoElement","startCapping","detectPlayerSize","mediaHeight","mediaWidth","getMaxLevel","nextLevelSwitch","capLevelIndex","validLevels","getMaxLevelByMediaSize","getDimensions","boundsRect","curLevel","maxLevelIndex","contentScaleFactor","pixelRatio","devicePixelRatio","CMCDController","_types_cmcd__WEBPACK_IMPORTED_MODULE_1__","_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_2__","_createClass","_createForOfIteratorHelperLoose","allowArrayLike","it","_arrayLikeToArray","_unsupportedIterableToArray","cid","useHeaders","starved","audioBuffer","onWaiting","onPlaying","applyPlaylistData","ot","MANIFEST","su","applyFragmentData","getObjectType","MUXED","br","tb","getTopBandwidth","getBufferLength","createPlaylistLoader","createFragmentLoader","sessionId","uuid","contentId","onMediaDetached","_data$tracks$audio","_data$tracks$video","createData","sf","HLS","pr","mtp","bandwidthEstimate","isVideo","INIT","bs","toHeaders","toQuery","appendQueryToUri","TIMED_TEXT","_step","_iterator","Ctor","CmcdPlaylistLoader","_proto2","callbacks","CmcdFragmentLoader","_proto3","serialize","_step2","results","isValid","toRounded","toHundred","formatters","dl","nor","rtp","_iterator2","formatter","headerNames","headerGroups","headerMap","nrr","st","_keys","separator","_utils_mediakeys_helper__WEBPACK_IMPORTED_MODULE_3__","EMEController","_widevineLicenseUrl","_licenseXhrSetup","_licenseResponseCallback","_emeEnabled","_requestMediaKeySystemAccess","_drmSystemOptions","_config","_mediaKeysList","_media","_hasSetMediaKeys","_requestLicenseFailureCount","mediaKeysPromise","_onMediaEncrypted","onMediaEncrypted","getLicenseServerUrl","keySystem","WIDEVINE","_attemptKeySystemAccess","mediaKeySystemConfigs","baseConfig","audioCapabilities","videoCapabilities","robustness","audioRobustness","videoRobustness","createWidevineMediaKeySystemConfigurations","getSupportedMediaKeySystemConfigurations","keySystemAccessPromise","requestMediaKeySystemAccess","mediaKeySystemAccess","_onMediaKeySystemAccessObtained","mediaKeysListItem","mediaKeysSessionInitialized","mediaKeySystemDomain","createMediaKeys","mediaKeys","_onMediaKeysCreated","mediaKeysSession","createSession","_onNewMediaKeySession","keySession","_onKeySessionMessage","_requestLicense","initDataType","KEY_SYSTEM_ERROR","KEY_SYSTEM_NO_KEYS","finallySetKeyAndStartSession","_attemptSetMediaKeys","_generateRequestWithPreferredKeySession","initData","keysListItem","setMediaKeys","KEY_SYSTEM_NO_ACCESS","KEY_SYSTEM_NO_SESSION","KEY_SYSTEM_NO_INIT_DATA","generateRequest","_createLicenseXhr","keyMessage","callback","xhr","XMLHttpRequest","responseType","onreadystatechange","_onLicenseRequestReadyStageChange","_data","KEY_SYSTEM_LICENSE_REQUEST_FAILED","attemptsLeft","_generateLicenseRequestChallenge","_url","_xhr","challenge","mediaKeysList","close","_utils_logger__WEBPACK_IMPORTED_MODULE_1__","FPSController","isVideoPlaybackQualityAvailable","lastTime","lastDroppedFrames","lastDecodedFrames","getVideoPlaybackQuality","checkFPSInterval","checkFPS","decodedFrames","droppedFrames","currentPeriod","currentDropped","currentDecoded","droppedFPS","FPS_DROP","totalDroppedFrames","videoPlaybackQuality","totalVideoFrames","droppedVideoFrames","webkitDecodedFrameCount","webkitDroppedFrameCount","findFragmentByPDT","findFragmentByPTS","fragmentWithinToleranceTest","pdtWithinToleranceTest","findFragWithCC","_utils_binary_search__WEBPACK_IMPORTED_MODULE_1__","PDTValue","seg","foundFragment","candidate","candidateLookupTolerance","deltaPTS","pdtBufferEnd","FragmentState","FragmentTracker","_types_loader__WEBPACK_IMPORTED_MODULE_1__","activeFragment","activeParts","bufferPadding","onBufferAppended","getAppendedFrag","levelType","activePart","appendedPTS","fragmentEntity","elementaryStream","timeRange","esData","isNotBuffered","isTimeBuffered","detectPartialFragments","fragKey","getFragmentKey","streamInfo","getBufferedTimes","fragBuffered","minEndPTS","maxStartPTS","getPartialFragment","timePadding","bestFragment","bestOverlap","isPartial","APPENDING","hasFragment","removeFragmentsInRange","clearElementaryStreamInfo","_fragmentEntity$range","_fragmentEntity$range2","STALL_MINIMUM_DURATION_MS","MAX_START_GAP_JUMP","SKIP_BUFFER_HOLE_STEP_SECONDS","SKIP_BUFFER_RANGE_START","GapController","_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_0__","nudgeRetry","stallReported","stalled","moved","poll","activeFrag","seeked","beginSeek","hasEnoughBuffer","noBufferGap","startJump","maxStartGapJump","_trySkipBufferHole","tnow","stalledDuration","_reportStall","bufferedWithHoles","_tryFixBufferStall","_stalledDuration","stalledDurationMs","_tryNudgeBuffer","BUFFER_STALLED_ERROR","lastEndTime","targetTime","BUFFER_SEEK_OVER_HOLE","BUFFER_NUDGE_ON_STALL","_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__","_demux_id3__WEBPACK_IMPORTED_MODULE_3__","_loader_date_range__WEBPACK_IMPORTED_MODULE_4__","_types_demuxer__WEBPACK_IMPORTED_MODULE_5__","getCueClass","WebKitDataCue","VTTCue","TextTrackCue","dateRangeDateToTimelineSeconds","date","ID3TrackController","id3Track","dateRangeCuesAppended","onFragParsingMetadata","createTrack","getID3Track","kind","addTextTrack","_this$hls$config","maxCueTime","Cue","updateCueRanges","frameTypesAdded","emsg","frames","pts","frame","addCue","updateId3CueEnds","_this$id3Track","_cue$value","frameType","predicate","_hls$config","audioId3","dateRanges","ids","idsToRemove","_loop","removeCue","lastFragment","dateTimeOffset","_loop2","dateRange","appendedDateRangeCues","durationKnown","startDate","endDate","endOnNext","nextDateRangeWithSameClass","filterMapArray","class","attributes","ID","CLASS","START_DATE","DURATION","END_DATE","END_ON_NEXT","SCTE35_OUT","SCTE35_IN","LatencyController","_errors__WEBPACK_IMPORTED_MODULE_0__","stallCount","_latency","timeupdateHandler","timeupdate","latency","computeLatency","_this$config","targetLatency","distanceFromTarget","inLiveRange","forwardBufferLength","exp","edgeStalled","estimateLiveEdge","liveEdge","holdBack","_this$config2","maxLiveSyncOnStallIncrease","syncPosition","maxLevelUpdateAge","bufferedRanges","LevelController","_types_level__WEBPACK_IMPORTED_MODULE_0__","_errors__WEBPACK_IMPORTED_MODULE_2__","_utils_codecs__WEBPACK_IMPORTED_MODULE_3__","_level_helper__WEBPACK_IMPORTED_MODULE_4__","_base_playlist_controller__WEBPACK_IMPORTED_MODULE_5__","chromeOrFirefox","_levels","_firstLevel","_startLevel","currentLevelIndex","manualLevelIndex","onParsedComplete","MANIFEST_LOADED","onManifestLoaded","onAudioTrackSwitched","bitrateStart","levelFromSet","subtitleTracks","levelSet","resolutionFound","videoCodecFound","audioCodecFound","levelParsed","attrs","levelKey","RESOLUTION","CODECS","SUBTITLES","audioOnly","edata","forceStartLoad","MANIFEST_INCOMPATIBLE_CODECS_ERROR","_data$level","SUBTITLE_TRACK","textGroupIds","redundantFailover","levelError","levelSwitch","variantLevelIndex","_level","fragmentError","LEVEL_LOAD_ERROR","LEVEL_LOAD_TIMEOUT","REMUX_ALLOC_ERROR","recoverLevel","errorDetails","redundantLevels","nextAutoLevel","newUrlId","_data$deliveryDirecti2","_data$deliveryDirecti","removeLevel","filterLevelAndGroupByIdIndex","LEVELS_UPDATED","newLevel","_levels$newLevel","OTHER_ERROR","LEVEL_SWITCH_ERROR","lastLevelIndex","levelSwitchingData","_urlId","configStartLevel","addGroupId","assignTrackIdsByGroup","updatePTS","updateFragPTSDTS","mergeDetails","mapPartIntersection","mapFragmentIntersection","adjustSliding","addSliding","computeReloadInterval","getFragmentWithSN","getPartWith","_loader_date_range__WEBPACK_IMPORTED_MODULE_2__","groups","fromIdx","toIdx","updateFromToPTS","fragFrom","fragTo","fragToPTS","fragStartPts","fragEndPts","fragIdx","oldDetails","currentInitSegment","oldFragments","oldInit","PTSFrag","oldDateRanges","deltaDateRanges","recentlyRemovedDateranges","ccOffset","oldFrag","newFrag","relurl","_currentInitSegment","skippedSegments","startCC","canSkipDateRanges","newFragments","_i2","oldPart","newPart","driftStartTime","driftStart","driftEndTime","driftEnd","oldParts","newParts","intersectionFn","_oldPart","_newPart","newFrags","oldFrags","_oldFrag","_newFrag","estimatedTimeUntilUpdate","reloadIntervalAfterMiss","timeSinceLastModified","useLastModified","roundTrip","availabilityDelay","updated","minRetry","misses","StreamController","_is_supported__WEBPACK_IMPORTED_MODULE_2__","_events__WEBPACK_IMPORTED_MODULE_3__","_fragment_tracker__WEBPACK_IMPORTED_MODULE_5__","_demux_transmuxer_interface__WEBPACK_IMPORTED_MODULE_8__","_types_transmuxer__WEBPACK_IMPORTED_MODULE_9__","_gap_controller__WEBPACK_IMPORTED_MODULE_10__","_errors__WEBPACK_IMPORTED_MODULE_11__","audioCodecSwap","gapController","_forceStartLoad","fragPlaying","onvplaying","onvseeked","fragLastKbps","couldBacktrack","backtrackFragment","audioCodecSwitch","onFragLoadEmergencyAborted","onLevelsUpdated","_levels$level","checkBuffer","checkFragmentChanged","getMainFwdBufferInfo","_this$backtrackFragme","backtrackFrag","_this$media2","_loadBitrateTestFrag","fragOrPart","followingBufferedFrag","immediateLevelSwitch","abortCurrentFrag","fetchdelay","fragPlayingCurrent","bufferedFrag","nextBufferedFrag","maxStart","startPts","onMediaPlaying","onMediaSeeked","aac","heaac","_curLevel$details","newLevelId","endCC","accurateTimeOffset","_getAudioCodec","fromAltAudio","mediaTrack","alternate","videoTrack","swapAudioCodec","timescale","firstKeyFrame","firstKeyFramePTS","backtrack","_startPTS","_endPTS","_startDTS","_endDTS","ua","channelCount","fragCurrentLevel","LEVEL_SWITCHED","currentFrag","epocMs","SubtitleStreamController","_utils_buffer_helper__WEBPACK_IMPORTED_MODULE_1__","_fragment_finders__WEBPACK_IMPORTED_MODULE_2__","_utils_discontinuities__WEBPACK_IMPORTED_MODULE_3__","_base_stream_controller__WEBPACK_IMPORTED_MODULE_6__","_types_loader__WEBPACK_IMPORTED_MODULE_7__","_types_level__WEBPACK_IMPORTED_MODULE_8__","currentTrackId","tracksBuffered","SUBTITLE_TRACKS_UPDATED","onSubtitleTracksUpdated","SUBTITLE_TRACK_SWITCH","onSubtitleTrackSwitch","SUBTITLE_TRACK_LOADED","onSubtitleTrackLoaded","SUBTITLE_FRAG_PROCESSED","onSubtitleFragProcessed","success","fragStart","fragEnd","endOffsetSubtitles","SUBTITLE","_this$fragCurrent","mediaBufferTimeRanges","mainSlidingStartFragment","foundFrag","encrypted","BufferableInstance","timeranges","getRange","_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_1__","SubtitleTrackController","queuedDefaultTrack","trackChangeListener","onTextTracksChanged","asyncPollTrackChange","pollTrackChange","useTextTrackPolling","subtitlePollingInterval","_subtitleDisplay","subtitleTrack","filterSubtitleTracks","textGroupId","initialTrackId","subtitleTracksUpdated","setSubtitleTrack","SUBTITLE_TRACK_LOADING","toggleTrackModes","groupTracks","oldTrack","nextTrack","subtitleDisplay","_tracks$newId","textTrackList","TimelineController","_utils_cea_608_parser__WEBPACK_IMPORTED_MODULE_2__","_utils_output_filter__WEBPACK_IMPORTED_MODULE_3__","_utils_webvtt_parser__WEBPACK_IMPORTED_MODULE_4__","_utils_texttrack_utils__WEBPACK_IMPORTED_MODULE_5__","_utils_imsc1_ttml_parser__WEBPACK_IMPORTED_MODULE_6__","_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_7__","_types_loader__WEBPACK_IMPORTED_MODULE_8__","_utils_logger__WEBPACK_IMPORTED_MODULE_9__","Cues","unparsedVttFrags","captionsTracks","nonNativeCaptionsTracks","cea608Parser1","cea608Parser2","lastSn","prevCC","vttCCs","presentationOffset","new","captionsProperties","textTrack1","textTrack2","textTrack3","textTrack4","channel1","channel2","channel3","channel4","onFragParsingUserdata","onFragDecrypted","SUBTITLE_TRACKS_CLEARED","onSubtitleTracksCleared","addCues","screen","cueRanges","x1","y1","merged","cueRange","overlap","newCue","CUES_PARSED","getExistingTrack","createCaptionsTrack","createNativeTrack","createNonNativeTrack","_captionsProperties$t","existingTrack","createTextTrack","trackProperties","closedCaptions","NON_NATIVE_TEXT_TRACKS_FOUND","_cleanTracks","reset","hasIMSC1","textCodec","sameTracks","inUseTracks","inUseTrack","canReuseVttTextTrack","textTrackKind","_captionsOrSubtitlesFromCharacteristics","tracksList","_track$attrs","CHARACTERISTICS","transcribesSpokenDialog","describesMusicAndSound","captions","captionsTrack","instreamIdMatch","instreamId","_data$part$index","decrypted","trackPlaylistMedia","_parseIMSC1","_parseVTTs","_appendCues","payloadWebVTT","_fallbackToIMSC1","fragLevel","ccBytes","ccdatas","extractCea608Data","addData","actualCCBytes","tmpByte","ccbyte1","ccbyte2","ccType","manifestTrack","AESCrypto","subtle","aesIV","decrypt","removePadding","AESDecryptor","_utils_typed_array__WEBPACK_IMPORTED_MODULE_0__","outputBytes","paddingBytes","DataView","getUint8","rcon","subMix","Uint32Array","invSubMix","sBox","invSBox","ksRows","keySize","keySchedule","invKeySchedule","initTable","uint8ArrayToUint32Array_","getUint32","subMix0","subMix1","subMix2","subMix3","invSubMix0","invSubMix1","invSubMix2","invSubMix3","xi","sx","x4","x8","expandKey","keyBuffer","sameKey","ksRow","invKsRow","sbox","networkToHostOrderSwap","word","inputArrayBuffer","s0","s1","s2","s3","inputWords0","inputWords1","inputWords2","inputWords3","nRounds","invSBOX","initVector","initVector0","initVector1","initVector2","initVector3","inputInt32","Int32Array","outputInt32","swapWord","Decrypter","_aes_crypto__WEBPACK_IMPORTED_MODULE_0__","_fast_aes_key__WEBPACK_IMPORTED_MODULE_1__","_aes_decryptor__WEBPACK_IMPORTED_MODULE_2__","_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_4__","_utils_typed_array__WEBPACK_IMPORTED_MODULE_5__","observer","_temp","_ref$removePKCS7Paddi","removePKCS7Padding","logEnabled","softwareDecrypter","fastAesKey","remainderData","currentIV","currentResult","browserCrypto","crypto","webkitSubtle","isSync","softwareDecrypt","decryptResult","logOnce","currentChunk","getValidChunk","aesKey","onWebCryptoError","splitPoint","FastAESKey","importKey","_base_audio_demuxer__WEBPACK_IMPORTED_MODULE_0__","_adts__WEBPACK_IMPORTED_MODULE_1__","AACDemuxer","_BaseAudioDemuxer","resetInitSegment","trackDuration","_audioTrack","pid","sequenceNumber","segmentCodec","manifestCodec","inputTimeScale","canParse","appendFrame","basePTS","frameIndex","missing","getAudioConfig","isHeaderPattern","getHeaderLength","getFullFrameLength","canGetFrameLength","isHeader","initTrackConfig","getFrameDuration","parseFrameHeader","adtsObjectType","adtsExtensionSamplingIndex","adtsChanelConfig","adtsSampleingRates","adtsSamplingIndex","samplerate","FRAG_PARSING_ERROR","headerLength","frameLength","newOffset","unit","stamp","header","_length","_sample","initPTSFn","_demux_id3__WEBPACK_IMPORTED_MODULE_1__","_types_demuxer__WEBPACK_IMPORTED_MODULE_2__","_dummy_demuxed_track__WEBPACK_IMPORTED_MODULE_3__","BaseAudioDemuxer","_id3Track","cachedData","resetTimeStamp","deaultTimestamp","resetContiguity","demux","lastDataIndex","id3Data","timestamp","dts","partialData","demuxSampleAes","keyData","ChunkCache","dataLength","concatUint8Arrays","dummyTrack","ExpGolomb","bytesAvailable","bitsAvailable","loadWord","workingBytes","availableBytes","skipBits","skipBytes","readBits","valu","skipLZ","leadingZeroCount","skipUEG","skipEG","readUEG","clz","readEG","readBoolean","readUByte","readUShort","readUInt","skipScalingList","lastScale","nextScale","readSPS","numRefFramesInPicOrderCntCycle","scalingListCount","frameCropLeftOffset","frameCropRightOffset","frameCropTopOffset","frameCropBottomOffset","profileIdc","chromaFormatIdc","picOrderCntType","picWidthInMbsMinus1","picHeightInMapUnitsMinus1","frameMbsOnlyFlag","readSliceType","isFooter","getID3Data","getTimeStamp","isTimeStampFrame","getID3Frames","decodeFrame","utf8ArrayToStr","testables","decoder","front","readSize","readTimeStamp","getFrameData","frameData","decodePrivFrame","decodeURLFrame","decodeTextFrame","owner","privateData","timeStampFrame","pts33Bit","exitOnNull","getTextDecoder","decoded","char2","char3","TextDecoder","_mpegaudio__WEBPACK_IMPORTED_MODULE_3__","MP3Demuxer","_types_demuxer__WEBPACK_IMPORTED_MODULE_1__","_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_2__","emsgSchemePattern","MP4Demuxer","txtTrack","captionTrack","_initData$video","_initData$audio","_timescale","_codec","sampleDuration","videoSamples","segmentedData","remainder","extractID3Track","emsgs","emsgInfo","schemeIdUri","presentationTime","timeScale","presentationTimeDelta","parseHeader","chromeVersion","BitratesMap","SamplingRateMap","SamplesCoefficients","BytesInSlot","samplesPerFrame","sampleRate","mpegVersion","mpegLayer","bitRateIndex","sampleRateIndex","paddingBit","channelMode","bitRate","sampleCoefficient","bytesInSlot","_crypt_decrypter__WEBPACK_IMPORTED_MODULE_0__","_tsdemuxer__WEBPACK_IMPORTED_MODULE_1__","SampleAesDecrypter","decryptBuffer","encryptedData","decryptAacSample","sampleIndex","sync","curUnit","encryptedBuffer","localthis","decryptedBuffer","decryptAacSamples","getAvcEncryptedData","decodedData","encryptedDataLen","Int8Array","outputPos","inputPos","getAvcDecryptedUnit","uint8DecryptedData","decryptAvcSample","unitIndex","decryptAvcSamples","curUnits","TransmuxerInterface","webworkify_webpack__WEBPACK_IMPORTED_MODULE_0__","_demux_transmuxer__WEBPACK_IMPORTED_MODULE_2__","eventemitter3__WEBPACK_IMPORTED_MODULE_6__","isTypeSupported","onTransmuxComplete","onFlush","onwmsg","forwardMessage","typeSupported","mp4","mpeg","mp3","onWorkerMessage","INTERNAL_EXCEPTION","filename","lineno","cmd","terminate","defaultInitPTS","_lastFrag$initSegment","transmuxing","lastFrag","discontinuity","trackSwitch","snDiff","partDiff","initSegmentChange","configureTransmuxer","_transmuxResult","handleTransmuxComplete","_transmuxResult2","handleFlushResult","logType","configure","TransmuxerWorker","_demux_transmuxer__WEBPACK_IMPORTED_MODULE_0__","eventemitter3__WEBPACK_IMPORTED_MODULE_3__","logFn","forwardWorkerLogs","emitTransmuxComplete","transferable","_transmuxResult$remux","addToTransferable","Transmuxer","isPromise","TransmuxConfig","TransmuxState","_crypt_decrypter__WEBPACK_IMPORTED_MODULE_2__","_demux_aacdemuxer__WEBPACK_IMPORTED_MODULE_3__","_demux_mp4demuxer__WEBPACK_IMPORTED_MODULE_4__","_demux_tsdemuxer__WEBPACK_IMPORTED_MODULE_5__","_demux_mp3demuxer__WEBPACK_IMPORTED_MODULE_6__","_remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_7__","_remux_passthrough_remuxer__WEBPACK_IMPORTED_MODULE_8__","muxConfig","remux","demuxer","remuxer","decryptionPromise","transmuxConfig","currentTransmuxState","uintData","defaultInitPts","resetInitialTimestamp","encryptionType","getEncryptionType","getDecrypter","emptyResult","needsProbing","transmux","currentState","transmuxResults","demuxResultOrPromise","demuxResult","flushRemux","_this$currentTransmux","resetNextTimestamp","transmuxSampleAes","transmuxUnencrypted","_demux","mux","Remuxer","Demuxer","Function","discardEPB","_adts__WEBPACK_IMPORTED_MODULE_0__","_mpegaudio__WEBPACK_IMPORTED_MODULE_1__","_exp_golomb__WEBPACK_IMPORTED_MODULE_2__","_sample_aes__WEBPACK_IMPORTED_MODULE_3__","_events__WEBPACK_IMPORTED_MODULE_4__","_utils_mp4_tools__WEBPACK_IMPORTED_MODULE_5__","_errors__WEBPACK_IMPORTED_MODULE_7__","_types_demuxer__WEBPACK_IMPORTED_MODULE_8__","TSDemuxer","sampleAes","pmtParsed","_duration","_pmtId","_avcTrack","_txtTrack","aacOverFlow","avcSample","pesData","isSampleAes","pes","avcId","avcData","audioId","id3Id","audioData","unknownPID","pmtId","tsPacketErrors","stt","parsePES","parseAVCPES","parseAACPES","parseMPEGPES","parseID3PES","parsePAT","parsedPIDs","parsePMT","avc","extractRemainingSamples","parseAVCNALu","spsfound","audFound","pushAccessUnit","createAVCSample","sliceType","sps","codecarray","codecstring","pps","getLastNalUnit","_avcSample","lastUnit","overflow","naluState","lastState","lastUnitStart","lastUnitType","_unit","_lastUnit","_tmp","frameMissingBytes","sampleLength","frameOverflowBytes","frameDuration","id3Sample","tableEnd","pesLen","pesHdrLen","pesPts","pesDts","newData","pesFlags","payloadStartOffset","dataLen","avcTrack","nbSamples","lastSample","EPBPositions","newLength","sourceIndex","ErrorTypes","ErrorDetails","url_toolkit__WEBPACK_IMPORTED_MODULE_0__","_loader_playlist_loader__WEBPACK_IMPORTED_MODULE_1__","_loader_key_loader__WEBPACK_IMPORTED_MODULE_2__","_controller_id3_track_controller__WEBPACK_IMPORTED_MODULE_3__","_controller_latency_controller__WEBPACK_IMPORTED_MODULE_4__","_controller_level_controller__WEBPACK_IMPORTED_MODULE_5__","_controller_fragment_tracker__WEBPACK_IMPORTED_MODULE_6__","_controller_stream_controller__WEBPACK_IMPORTED_MODULE_7__","_is_supported__WEBPACK_IMPORTED_MODULE_8__","_config__WEBPACK_IMPORTED_MODULE_10__","eventemitter3__WEBPACK_IMPORTED_MODULE_11__","_events__WEBPACK_IMPORTED_MODULE_12__","coreComponents","networkControllers","_emitter","_autoLevelCapping","latencyController","levelController","DefaultConfig","ConfigAbrController","ConfigBufferController","ConfigCapLevelController","ConfigFpsController","playListLoader","keyLoader","id3TrackController","createController","ControllerClass","components","controllerInstance","eventObject","DESTROYING","loadedSource","loadingSource","controller","recoverMediaError","loadLevel","manualLevel","shouldStartCapping","newCapLevelToPlayerSize","currentProgramDateTime","subtitleTrackId","changeTypeSupported","_utils_mediasource_helper__WEBPACK_IMPORTED_MODULE_0__","getSourceBuffer","SourceBuffer","WebKitSourceBuffer","sourceBufferValidAPI","_sourceBuffer$prototy","DateRangeAttribute","DateRange","_utils_attr_list__WEBPACK_IMPORTED_MODULE_1__","dateRangeAttr","dateRangeWithSameId","_startDate","_endDate","_badValueForSameId","previousAttr","decimalFloatingPoint","PLANNED_DURATION","FragmentLoader","LoadError","_wrapNativeSuper","Class","_cache","Wrapper","_construct","_getPrototypeOf","Parent","_isNativeReflectConstruct","Reflect","construct","sham","Proxy","Boolean","getPrototypeOf","MIN_CHUNK_SIZE","partLoadTimeout","_onProgress","FragmentILoader","DefaultILoader","loaderContext","createLoaderContext","loaderConfig","maxRetry","retryDelay","maxRetryDelay","highWaterMark","resetLoader","onAbort","onTimeout","onProgress","updateStatsFromPart","fragStats","partStats","partTotal","estTotalParts","estLoadedParts","estRemainingBytes","fragLoading","partLoading","rangeStart","rangeEnd","byteRangeStartOffset","byteRangeEndOffset","_Error","_len","_key","ElementaryStreamTypes","BaseSegment","Part","url_toolkit__WEBPACK_IMPORTED_MODULE_1__","_level_key__WEBPACK_IMPORTED_MODULE_3__","_load_stats__WEBPACK_IMPORTED_MODULE_4__","_inheritsLoose","baseurl","_this$elementaryStrea","_byteRange","setByteRange","byteRange","_BaseSegment","_decryptdata","rawProgramDateTime","tagList","levelkey","createInitializationVector","segmentNumber","uint8View","setDecryptDataFromLevelKey","fromURI","_this$decryptdata","_BaseSegment2","partAttrs","fragOffset","gap","enumeratedString","KeyLoader","loaders","decryptkey","decrypturl","destroyInternalLoaders","onKeyLoading","loaderName","Loader","fragLoader","loaderCallbacks","loadsuccess","loaderror","loadtimeout","LevelDetails","needSidxRanges","m3u8","canSkipUntil","preloadHint","partSnDiff","partIndexDiff","runTime","_this$partList","_this$fragments","_this$partList2","_this$partList3","LevelKey","absoluteOrBaseURI","_uri","keyFormatVersions","keyID","fromURL","relativeUrl","LoadStats","M3U8Parser","_date_range__WEBPACK_IMPORTED_MODULE_2__","_fragment__WEBPACK_IMPORTED_MODULE_3__","_level_details__WEBPACK_IMPORTED_MODULE_4__","_level_key__WEBPACK_IMPORTED_MODULE_5__","_utils_attr_list__WEBPACK_IMPORTED_MODULE_6__","_utils_logger__WEBPACK_IMPORTED_MODULE_7__","_utils_codecs__WEBPACK_IMPORTED_MODULE_8__","MASTER_PLAYLIST_REGEX","MASTER_PLAYLIST_MEDIA_REGEX","LEVEL_PLAYLIST_REGEX_FAST","LEVEL_PLAYLIST_REGEX_SLOW","MP4_REGEX_SUFFIX","findGroup","mediaGroupId","group","convertAVC1ToAVCOTI","avcdata","parseMasterPlaylist","sessionData","hasSessionData","lastIndex","decimalInteger","NAME","resolution","decimalResolution","setCodecs","sessionAttrs","parseMasterPlaylistMedia","medias","TYPE","LANGUAGE","autoselect","forced","groupCodec","assignCodec","parseLevelPlaylist","levelUrlId","currentSN","currentPart","discontinuityCounter","prevFrag","firstPdtIndex","createNextFrag","assignProgramDateTime","tag","value1","value2","skipAttrs","_keyAttrs$enumeratedS","keyAttrs","decryptmethod","decrypturi","decryptiv","hexadecimalInteger","decryptkeyformatversions","decryptkeyid","decryptkeyformat","mapAttrs","setInitSegment","serverControlAttrs","optionalFloat","partInfAttrs","previousFragmentPart","preloadHintAttrs","renditionReportAttrs","fragmentLength","firstFragment","_URLToolkit$parseURL$","_URLToolkit$parseURL","fragPrev","backfillProgramDateTimes","codecs","filtered","preferred","unknownCodecs","groupItem","codecProperty","codecValue","BYTERANGE","_m3u8_parser__WEBPACK_IMPORTED_MODULE_5__","_utils_attr_list__WEBPACK_IMPORTED_MODULE_7__","getResponseUrl","PlaylistLoader","onAudioTrackLoading","onSubtitleTrackLoading","createInternalLoader","PLoader","getInternalLoader","resetInternalLoader","contextType","LEVEL","_context$deliveryDire","isSidxRequest","handleSidxRequest","handlePlaylistLoaded","handleTrackOrLevelPlaylist","handleMasterPlaylist","handleManifestParsingError","handleNetworkError","_M3U8Parser$parseMast","audioGroups","subtitleGroups","levelId","mapContextToLevelType","singleLevel","_levelDetails$fragmen","sidxUrl","LEVEL_EMPTY_ERROR","sidxBox","sidxInfo","sidxReferences","references","segmentRef","segRefInfo","moovBox","moovEndOffset","MANIFEST_PARSING_ERROR","UNKNOWN","MANIFEST_LOAD_TIMEOUT","MANIFEST_LOAD_ERROR","SUBTITLE_TRACK_LOAD_TIMEOUT","SUBTITLE_LOAD_ERROR","errorData","getCacheAge","isFiniteNumber","AAC","getSilentFrame","UINT32_MAX","MP4","avc1","avcC","btrt","dinf","dref","esds","ftyp","hdlr","mdat","mdhd","mdia","mfhd","minf","moof","moov","mp4a","mvex","mvhd","pasp","sdtp","stbl","stco","stsc","stsd","stsz","stts","tfdt","tfhd","traf","trak","trun","trex","tkhd","vmhd","smhd","videoHdlr","audioHdlr","HDLR_TYPES","STTS","STSC","STCO","STSZ","VMHD","SMHD","STSD","majorBrand","avc1Brand","minorVersion","FTYP","box","DINF","upperWordDuration","lowerWordDuration","baseMediaDecodeTime","boxes","dependsOn","isDependedOn","hasRedundancy","avcc","hSpacing","vSpacing","configlen","sampleDependencyTable","upperWordBaseMediaDecodeTime","lowerWordBaseMediaDecodeTime","cts","arraylen","isLeading","paddingValue","isNonSync","degradPrio","MP4Remuxer","normalizePts","flushTextTrackMetadataCueSamples","flushTextTrackUserdataCueSamples","_aac_helper__WEBPACK_IMPORTED_MODULE_1__","_mp4_generator__WEBPACK_IMPORTED_MODULE_2__","_utils_logger__WEBPACK_IMPORTED_MODULE_5__","_utils_timescale_conversion__WEBPACK_IMPORTED_MODULE_7__","safariWebkitVersion","ISGenerated","_initPTS","_initDTS","nextAvcDts","nextAudioPts","videoSampleDuration","isAudioContiguous","isVideoContiguous","_result","defaultTimeStamp","getVideoStartPts","rolloverDetected","minPTS","audioTimeOffset","videoTimeOffset","hasAudio","hasVideo","enoughAudioSamples","enoughVideoSamples","generateIS","firstKeyFrameIndex","findKeyframeIndex","audiovideoTimestampDelta","remuxAudio","audioTrackLength","remuxVideo","initDTS","audioSamples","computePTSDTS","firstDTS","lastDTS","inputSamples","outputSamples","mp4SampleDuration","maxPTS","sortSamples","deltadts","deltapts","inputDuration","averageSampleDuration","foundHole","firstPTS","nbNalu","naluLen","nbUnits","sampleLen","mdatSize","MUX_ERROR","setUint32","stretchedLastFrame","minDtsDelta","minPtsDelta","maxDtsDelta","maxPtsDelta","avcSampleUnits","mp4SampleLength","_j","_nbUnits","unitData","unitDataLen","ptsDelta","lastFrameDuration","gapTolerance","deltaToFrameEnd","compositionTimeOffset","Mp4Sample","_i3","nextDts","_pts","nextPts","nb","scaleFactor","inputSampleDuration","rawMPEG","alignedWithVideo","timeOffsetMpegTS","newStamp","fillFrame","lastPTS","_j2","_nbSamples","audioSample","_pts2","unitLen","remuxEmptyAudio","videoData","silentFrame","reference","isKeyframe","Mp4SampleFlags","_mp4_remuxer__WEBPACK_IMPORTED_MODULE_1__","_loader_fragment__WEBPACK_IMPORTED_MODULE_3__","PassThroughRemuxer","emitInitSegment","initTracks","generateInitSegment","getParsedTrackCodec","_this$initPTS","initPtsNum","parsedCodec","TaskLoop","_boundTick","_tickTimer","_tickInterval","_tickCallCount","hasInterval","hasNextTick","millis","CMCDVersion","CMCDObjectType","CMCDStreamingFormat","CMCDStreamType","MetadataSchema","HlsSkip","getSkipValue","v2","Yes","HlsUrlParameters","Level","searchParams","newValue","PlaylistContextType","PlaylistLevelType","ChunkMetadata","AttrList","DECIMAL_RESOLUTION_REGEX","ATTR_LIST_REGEX","parseAttrList","attrName","intValue","stringValue","hexadecimalIntegerAsNumber","comparisonFn","minIndex","maxIndex","currentElement","comparisonResult","BufferHelper","_logger__WEBPACK_IMPORTED_MODULE_0__","noopBuffered","maxHoleDuration","vbuffered","buffered2","buf2len","buf2end","bufferStartNext","bufferStart","Row","CaptionScreen","VerboseLevel","specialCea608CharsCodes","getCharForByte","_byte","charCode","NR_ROWS","NR_COLS","rowsLowCh1","rowsHighCh1","rowsLowCh2","rowsHighCh2","backgroundColors","CaptionsLogger","verboseLevel","severity","numArrayToHexArray","numArray","hexArray","PenState","foreground","underline","italics","flash","setStyles","attribs","isDefault","newPenState","StyledUnicodeChar","uchar","penState","setChar","setPenState","newChar","isEmpty","logger","chars","currPenState","cueStartTime","_proto4","equal","empty","setCursor","absPos","DEBUG","moveCursor","relPos","newPos","backSpace","insertChar","_byte2","_char","clearFromPos","startPos","clearToEndOfRow","getTextString","_char2","setPenStyles","rows","currRow","nrRollUpRows","lastOutputScreen","_proto5","_char3","setPen","INFO","setPAC","pacData","newRow","row","topRowIndex","prevLineTime","indent","prevPos","setBkgData","bkgData","setRollUpRows","nrRows","rollUp","TEXT","getDisplayText","topRow","asOneRow","displayText","rowNr","rowText","getTextAndFormat","Cea608Channel","channelNumber","outputFilter","chNr","verbose","displayedMemory","nonDisplayedMemory","currRollUpRow","writeScreen","_proto6","getHandler","setHandler","newHandler","setMode","newMode","insertChars","outputDataUpdate","ccRCL","ccBS","ccAOF","ccAON","ccDER","ccRU","ccFON","ccRDC","ccTR","ccRTD","ccEDM","ccCR","ccENM","ccEOC","ccTO","nrCols","ccMIDROW","colorIndex","dispatchCue","cueSplitAtTime","Cea608Parser","out1","out2","currentChannel","cmdHistory","_proto7","byteList","cmdFound","charsFound","DATA","parseCmd","parseMidrow","parsePAC","parseBackgroundAttributes","parseChars","currChNr","WARNING","hasCmdRepeated","setLastCmd","interpretPAC","_byte3","pacIndex","channelNr","oneCode","charCodes","charCode1","hexCodes","isCodecType","isCodecSupportedInMp4","sampleEntryCodesISO","a3ds","alac","alaw","dra1","dtsc","dtse","dtsh","enca","g719","g726","m4ae","mha1","mha2","mhm1","mhm2","mlpa","Opus","samr","sawb","sawp","sevc","sqcp","ssmv","twos","ulaw","avc2","avc3","avc4","avcp","av01","drac","dvav","dvhe","encv","hev1","hvc1","mjp2","mp4v","mvc1","mvc2","mvc3","mvc4","resv","rv60","s263","svc1","svc2","vp08","vp09","stpp","wvtt","typeCodes","_vttparser__WEBPACK_IMPORTED_MODULE_0__","_webvtt_parser__WEBPACK_IMPORTED_MODULE_1__","_texttrack_utils__WEBPACK_IMPORTED_MODULE_2__","WHITESPACE_CHAR","captionScreen","indenting","cueText","getCueById","align","cueA","cueB","findFirstFragWithCC","shouldAlignOnDiscontinuities","findDiscontinuousReferenceFrag","adjustSlidingStart","alignStream","alignPDT","alignFragmentByPDTDelta","alignMediaPlaylistByPDT","_logger__WEBPACK_IMPORTED_MODULE_1__","_controller_level_helper__WEBPACK_IMPORTED_MODULE_2__","firstFrag","prevDetails","prevFrags","curFrags","prevStartFrag","adjustFragmentStart","referenceFrag","alignDiscontinuities","lastDetails","lastPDT","newPDT","refDetails","_utils_ewma__WEBPACK_IMPORTED_MODULE_0__","EwmaBandWidthEstimator","slow","defaultEstimate","defaultEstimate_","minWeight_","minDelayMs_","slow_","fast_","halfLife","getTotalWeight","durationMs","numBytes","durationS","bandwidthInBps","EWMA","estimate","alpha_","estimate_","totalWeight_","adjAlpha","zeroFactor","fetchSupported","_loader_load_stats__WEBPACK_IMPORTED_MODULE_1__","_demux_chunk_cache__WEBPACK_IMPORTED_MODULE_2__","AbortController","ReadableStream","Request","FetchLoader","fetchSetup","requestTimeout","getRequest","abortInternal","_this$callbacks","initParams","credentials","Headers","getRequestParameters","isArrayBuffer","LENGTH","FetchError","loadProgressively","responseData","loaderResponse","chunkCache","reader","getReader","pump","IMSC1_CODEC","parseIMSC1","_mp4_tools__WEBPACK_IMPORTED_MODULE_0__","_vttparser__WEBPACK_IMPORTED_MODULE_1__","_vttcue__WEBPACK_IMPORTED_MODULE_2__","_timescale_conversion__WEBPACK_IMPORTED_MODULE_4__","_webvtt_parser__WEBPACK_IMPORTED_MODULE_5__","HMSF_REGEX","TIME_UNIT_REGEX","textAlignToLineAlign","center","callBack","errorCallBack","ttmlList","syncTime","ttml","tt","DOMParser","parseFromString","getElementsByTagName","defaultRateInfo","frameRate","subFrameRate","frameRateMultiplier","tickRate","rateInfo","styleElements","collectionToDictionary","getElementCollection","regionElements","cueElements","cueElement","getTextContent","parseTtmlTime","timestampParsingError","region","ttsNs","regionStyle","styleAttributes","regionStyleName","getAttributeNS","getTtmlStyles","lineAlign","parseTTML","fromElement","parentName","childName","elementsWithId","dict","_node$childNodes","nodeName","textContent","hasAttributeNS","timeAttributeValue","parseHoursMinutesSecondsFrames","parseTimeUnits","enableLogs","noop","fakeLogger","exportedLogger","consolePrintFn","debugConfig","functions","exportLoggerFunctions","KeySystems","getMediaSource","WebKitMediaSource","RemuxerTrackIdConfig","bin2str","readUint16","readUint32","readSint32","writeUint32","findBox","parseSegmentIndex","parseInitSegment","getStartDTS","computeRawDurationFromSamples","offsetStartDTS","segmentValidRange","appendUint8Array","parseSamples","parseSEIMessageFromNALu","parseEmsg","_typed_array__WEBPACK_IMPORTED_MODULE_0__","_loader_fragment__WEBPACK_IMPORTED_MODULE_1__","_demux_id3__WEBPACK_IMPORTED_MODULE_2__","endbox","subresults","sidx","startByte","referencesCount","referenceIndex","referenceInfo","referenceSize","subsegmentDuration","earliestPresentationTime","traks","_index","hdlrType","soun","vide","fmp4","baseTime","sidxDuration","sidxs","dur","rawDuration","videoDuration","audioDuration","trafs","trackDefault","tfhdFlags","truns","sampleCount","upper","lower","segmentedRange","moofs","temp","seiSamples","isHEVCFlavor","moofOffset","defaultSampleDuration","defaultSampleSizePresent","defaultSampleSize","defaultSampleFlagsPresent","tfhdOffset","delimit","baseCodec","isHEVC","dataOffsetPresent","dataOffset","firstSampleFlagsPresent","sampleDurationPresent","sampleSizePresent","sampleSize","sampleFlagsPresent","sampleCompositionOffsetsPresent","compositionOffset","trunOffset","sampleOffset","ix","naluTotalSize","naluSize","naluType","isSEIMessage","unescapedData","seiPtr","payloadType","payloadSize","endOfCaptions","leftOver","providerCode","userStructure","userDataType","totalBytes","uuidStrArray","_b","userDataBytes","userData","eventDuration","leftPresentationTime","rightPresentationTime","isSafeInteger","OutputFilter","sendAddTrackEvent","addCueToTrack","clearCurrentCues","removeCuesInRange","getCuesInRange","videoEl","Event","createEvent","initEvent","dispatchEvent","textTrackCue","cuesFound","firstCueInRange","mid","getFirstCueIndexAfterTime","_cue","toTimescaleFromBase","destScale","srcBase","toTimescaleFromScale","srcScale","toMsFromMpegTsClock","toMpegTsClockFromTimescale","sliceUint8","AllowedDirections","AllowedAlignments","isAllowedValue","allowed","lcValue","findAlignSetting","extend","rest","cobj","baseObj","hasBeenReset","_pauseOnExit","_startTime","_endTime","_text","_region","_vertical","_snapToLines","_line","_lineAlign","_position","_positionAlign","_size","_align","setting","findDirectionSetting","SyntaxError","displayState","getCueAsHTML","parseTimeStamp","fixLineBreaks","VTTParser","_vttcue__WEBPACK_IMPORTED_MODULE_0__","computeSeconds","dflt","defaultKey","parseOptions","keyValueDelim","groupDelim","kv","defaults","parseCue","regionList","oInput","consumeTimeStamp","ts","skipWhitespace","vals","vertical","consumeCueSettings","collectNextLine","alreadyCollectedLine","hasSubstring","generateCueId","parseWebVTT","_timescale_conversion__WEBPACK_IMPORTED_MODULE_3__","_remux_mp4_remuxer__WEBPACK_IMPORTED_MODULE_4__","LINEBREAKS","inputString","searchString","vttByteArray","parsingError","vttLines","initPTS90Hz","cueTime","timestampMapMPEGTS","timestampMapLOCAL","inHeader","currCC","cueOffset","webVttMpegTsMapOffset","_prevCC","calculateOffset","timeString","secs","mins","cueString2millis","AGE_HEADER_LINE_REGEX","XhrLoader","retryTimeout","onprogress","loadInternal","setRequestHeader","readystatechange","loadprogress","responseText","responseURL","lengthComputable","getAllResponseHeaders","getResponseHeader","voidElement","comment","_classCallCheck","_inherits","_possibleConstructorReturn","_toArray","_interopDefaultLegacy","_typeof__default","_classCallCheck__default","_createClass__default","_assertThisInitialized__default","_inherits__default","_possibleConstructorReturn__default","_getPrototypeOf__default","_defineProperty__default","_toArray__default","ownKeys$6","_objectSpread$6","consoleLogger","baseLogger","Logger","concreteLogger","_len2","_key2","_len3","_key3","_len4","_key4","lvl","debugOnly","moduleName","observers","cloned","_cloned","rej","makeString","getLastOfPath","Empty","cleanKey","canNotTraverseDeeper","setPath","_getLastOfPath","getPath","_getLastOfPath3","getPathWithDefaults","defaultData","deepExtend","overwrite","regexEscape","_entityMap","escape","isIE10","userAgentData","ownKeys$5","_objectSpread$5","_createSuper$3","Derived","hasNativeReflectConstruct","_isNativeReflectConstruct$3","Super","NewTarget","deepFind","keySeparator","joinedPath","ResourceStore","_EventEmitter","_super","defaultNS","ignoreJSONStructure","lng","addNamespaces","resources","addResource","deep","pack","hasResourceBundle","removeNamespaces","getResource","compatibilityAPI","getDataByLanguage","postProcessor","processors","addPostProcessor","handle","translator","processor","ownKeys$4","_objectSpread$4","_createSuper$2","_isNativeReflectConstruct$2","checkedLoadedFor","Translator","interpolation","resolved","nsSeparator","namespaces","wouldCheckForNsInKey","seemsNaturalLanguage","userDefinedKeySeparator","userDefinedNsSeparator","possibleChars","matched","ki","looksLikeObjectPath","interpolator","nestingRegexp","lastKey","overloadTranslationOptionHandler","returnDetails","_this$extractFromKey","extractFromKey","namespace","appendNamespaceToCIMode","resUsedKey","usedKey","resExactUsedKey","exactUsedKey","resType","noObject","joinArrays","handleAsObjectInI18nFormat","i18nFormat","handleAsObject","returnObjects","returnedObjectHandler","resTypeIsArray","newKeyToUse","deepKey","translate","extendTranslation","usedDefault","needsPluralHandling","hasDefaultValue","defaultValueSuffix","pluralResolver","getSuffix","isValidLookup","missingKeyNoValueFallbackToKey","resForMissing","updateMissing","fk","lngs","fallbackLngs","languageUtils","getFallbackCodes","fallbackLng","saveMissingTo","toResolveHierarchy","specificDefaultValue","defaultForMissing","missingKeyHandler","backendConnector","saveMissing","saveMissingPlurals","getSuffixes","suffix","appendNamespaceToMissingKey","parseMissingKeyHandler","defaultVariables","usedLng","usedNS","skipInterpolation","nestBef","skipOnVariables","interpolate","na","nest","postProcess","postProcessorNames","applyPostProcessor","postProcessPassResolved","i18nResolved","extracted","fallbackNS","needsZeroSuffixLookup","ordinal","shouldUseIntlApi","needsContextHandling","utils","hasLoadedNamespace","possibleKey","finalKeys","addLookupKeys","pluralSuffix","zeroSuffix","pluralSeparator","contextKey","contextSeparator","returnNull","returnEmptyString","resourceStore","capitalize","LanguageUtil","supportedLngs","formatLanguageCode","specialCases","lowerCaseLng","cleanCode","nonExplicitSupportedLngs","getLanguagePartFromCode","cleanedLng","isSupportedCode","lngOnly","supportedLng","fallbacks","getScriptPartFromCode","fallbackCode","fallbackCodes","addCode","fc","sets","nr","_rulesPluralsTypes","deprecatedJsonVersions","suffixesOrder","zero","one","two","few","many","createRules","rules","numbers","plurals","PluralResolver","compatibilityJSON","Intl","PluralRules","_unused","rule","getRule","resolvedOptions","pluralCategories","pluralCategory1","pluralCategory2","pluralCategory","prepend","getSuffixRetroCompatible","noAbs","simplifyPluralSuffix","returnSuffix","ownKeys$3","_objectSpread$3","Interpolator","escapeValue","iOpts","useRawValueToEscape","prefixEscaped","suffixEscaped","formatSeparator","unescapePrefix","unescapeSuffix","nestingPrefix","nestingPrefixEscaped","nestingSuffix","nestingSuffixEscaped","nestingOptionsSeparator","maxReplaces","alwaysFormat","resetRegExp","regexpStr","regexpUnescapeStr","regexpUnescape","nestingRegexpStr","replaces","regexSafe","handleFormat","interpolationkey","missingInterpolationHandler","regex","safeValue","todo","matchedVar","clonedOptions","handleHasOptions","inheritedOptions","sep","optionsString","matchedSingleQuotes","matchedDoubleQuotes","doReduce","elem","ownKeys$2","_objectSpread$2","createCachedFormatter","Formatter","NumberFormat","currency","datetime","DateTimeFormat","relativetime","RelativeTimeFormat","ListFormat","_format","mem","_parseFormatStr","formatStr","formatName","formatOptions","optStr","opt","_opt$split","_opt$split2","parseFormatStr","formatted","valOptions","formatParams","locale","ownKeys$1","_objectSpread$1","_createSuper$1","_isNativeReflectConstruct$1","Connector","backend","store","waitingReads","maxParallelReads","readingCalls","maxRetries","languages","toLoad","pending","toLoadLanguages","toLoadNamespaces","hasAllNamespaces","pendingCount","addResourceBundle","_getLastOfPath2","removePending","loadedKeys","fcName","tried","wait","resolver","queueLoad","loadOne","prepareLoading","fallbackValue","isUpdate","clb","initImmediate","preload","partialBundledLanguages","tDescription","transformOptions","_createSuper","bindMemberFunctions","inst","I18n","isInitialized","isClone","defOpts","createClassOnDemand","ClassOrObject","lu","languageDetector","detection","storeApi","_this2$store","storeApiChained","_this2$store2","deferred","finish","initializedStoreOnce","usedCallback","resolvedLanguage","setResolvedLanguage","li","lngInLngs","hasLanguageSomeTranslations","isLanguageChangingTo","setLngProps","setLng","getBestMatchFromCodes","cacheUserLanguage","loadResources","detect","keyPrefix","fixedT","resultKey","_this$translator","_this$translator2","exists","lastLng","loadNotPending","loadState","precheck","preResult","preloaded","newLngs","mergedOptions","clone","membersToCopy","createInstance","isLE","mLen","nBytes","eLen","eMax","eBias","nBits","rt","LN2","crit","findBy","isValidType","forAll","local","HASH_UNDEFINED","argsTag","boolTag","dateTag","funcTag","genTag","mapTag","numberTag","objectTag","promiseTag","regexpTag","setTag","stringTag","symbolTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","reFlags","reIsHostCtor","reIsUint","cloneableTags","freeGlobal","freeSelf","root","freeExports","nodeType","freeModule","moduleExports","addMapEntry","pair","addSetEntry","arrayReduce","iteratee","accumulator","initAccum","isHostObject","mapToArray","overArg","transform","setToArray","arrayProto","funcProto","objectProto","coreJsData","maskSrcKey","IE_PROTO","funcToString","objectToString","reIsNative","getPrototype","objectCreate","nativeGetSymbols","nativeIsBuffer","nativeKeys","getNative","Set","WeakMap","nativeCreate","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","Hash","entry","ListCache","MapCache","Stack","__data__","arrayLikeKeys","inherited","isObjectLike","isArrayLike","isArrayLikeObject","isArguments","baseTimes","skipIndexes","isIndex","assignValue","objValue","eq","assocIndexOf","baseClone","isDeep","isFull","customizer","isObject","isArr","initCloneArray","copyArray","getTag","isFunc","cloneBuffer","isPrototype","initCloneObject","copyObject","getSymbols","copySymbols","baseAssign","cloneFunc","cloneArrayBuffer","dataView","cloneDataView","typedArray","cloneTypedArray","cloneMap","cloneRegExp","cloneSet","symbol","initCloneByTag","stacked","keysFunc","symbolsFunc","arrayPush","baseGetAllKeys","getAllKeys","arrayEach","subValue","baseIsNative","isFunction","getMapData","getValue","pairs","LARGE_ARRAY_SIZE","ctorString","isLength","baseKeys","reTrim","reIsBadHex","reIsBinary","reIsOctal","freeParseInt","nativeMax","nativeMin","toNumber","isSymbol","isBinary","lastArgs","lastThis","maxWait","timerId","lastCallTime","lastInvokeTime","leading","maxing","trailing","invokeFunc","leadingEdge","timerExpired","shouldInvoke","timeSinceLastCall","trailingEdge","remainingWait","debounced","isInvoking","arrayIncludes","fromIndex","fromRight","baseFindIndex","baseIsNaN","baseIndexOf","arrayIncludesWith","comparator","arrayMap","baseUnary","cacheHas","SetCache","pattern","castArrayLikeObject","arrays","mapped","othLength","othIndex","caches","maxLength","seen","outer","computed","baseIntersection","otherArgs","arrayTag","errorTag","typedArrayTags","freeProcess","nodeUtil","binding","nodeIsTypedArray","isTypedArray","arraySome","nativeObjectToString","symToStringTag","isArg","isBuff","isType","baseGetTag","isOwn","unmasked","getRawTag","baseIsArguments","baseIsEqual","bitmask","equalFunc","objIsArr","othIsArr","objTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","objLength","skipCtor","othValue","compared","objCtor","othCtor","equalObjects","baseIsEqualDeep","isMasked","arrValue","resIndex","arrayFilter","FUNC_ERROR_TEXT","magnetURIDecode","encode","xts","xt","infoHashBuffer","infoHashV2Buffer","infoHashV2","xtsDeduped","publicKeyBuffer","xs","publicKey","dn","keywords","kt","tr","urlList","ws","as","peerAddresses","bep53Range","base32","param","keyval","decodedStr","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","resetWarningCache","shim","componentName","propFullName","secret","getShim","ReactPropTypes","objectOf","checkPropTypes","global","punycode","maxInt","regexPunycode","regexNonASCII","regexSeparators","stringFromCharCode","mapDomain","ucs2decode","counter","ucs2encode","digitToBasic","digit","flag","adapt","numPoints","firstTime","baseMinusTMin","basic","oldi","baseMinusT","inputLength","bias","handledCPCount","basicLength","currentValue","handledCPCountPlusOne","qMinusT","qs","maxKeys","kstr","vstr","stringifyPrimitive","ks","aa","ca","da","ea","fa","ha","ia","ja","ka","la","ma","acceptsBooleans","attributeName","attributeNamespace","mustUseProperty","propertyName","sanitizeURL","removeEmptyString","ra","sa","ta","pa","qa","oa","setAttributeNS","xlinkHref","__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED","va","for","wa","ya","za","Aa","Ba","Ca","Da","Ea","Fa","Ga","Ha","Ia","Ja","Ka","La","Ma","Na","Oa","prepareStackTrace","Pa","Qa","$$typeof","_payload","_init","Ra","Sa","Ta","Va","_valueTracker","stopTracking","Ua","Wa","Xa","Ya","defaultChecked","_wrapperState","initialChecked","Za","controlled","ab","bb","db","ownerDocument","eb","fb","defaultSelected","gb","dangerouslySetInnerHTML","hb","ib","jb","kb","lb","mb","namespaceURI","firstChild","MSApp","execUnsafeLocalFunction","ob","nodeValue","pb","animationIterationCount","aspectRatio","borderImageOutset","borderImageSlice","borderImageWidth","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","columns","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridArea","gridRow","gridRowEnd","gridRowSpan","gridRowStart","gridColumn","gridColumnEnd","gridColumnSpan","gridColumnStart","fontWeight","lineClamp","opacity","order","orphans","tabSize","widows","zoom","fillOpacity","floodOpacity","stopOpacity","strokeDasharray","strokeDashoffset","strokeMiterlimit","strokeOpacity","strokeWidth","qb","rb","setProperty","menuitem","area","col","embed","img","keygen","meta","wbr","ub","vb","wb","xb","srcElement","correspondingUseElement","parentNode","yb","zb","Ab","Bb","Cb","stateNode","Db","Eb","Fb","Gb","Hb","Ib","Jb","Kb","Lb","Mb","Nb","Ob","Pb","Qb","Rb","Sb","Tb","Vb","Wb","memoizedState","dehydrated","Xb","Zb","sibling","Yb","$b","ac","unstable_scheduleCallback","bc","unstable_cancelCallback","unstable_shouldYield","dc","unstable_requestPaint","unstable_now","ec","unstable_getCurrentPriorityLevel","unstable_ImmediatePriority","gc","unstable_UserBlockingPriority","hc","unstable_NormalPriority","jc","unstable_LowPriority","unstable_IdlePriority","kc","lc","oc","clz32","pc","qc","sc","tc","pendingLanes","suspendedLanes","pingedLanes","entangledLanes","entanglements","xc","yc","zc","Ac","eventTimes","Cc","Dc","Ec","Fc","Gc","Hc","Ic","Jc","Kc","Lc","Mc","Nc","Oc","Pc","Qc","Rc","Sc","delete","pointerId","Tc","blockedOn","domEventName","eventSystemFlags","targetContainers","Vc","Wc","priority","isDehydrated","containerInfo","Xc","Yc","Zc","$c","ad","bd","cd","ReactCurrentBatchConfig","dd","ed","transition","fd","gd","hd","Uc","stopPropagation","jd","kd","ld","md","nd","od","keyCode","pd","qd","rd","_reactName","_targetInst","isDefaultPrevented","defaultPrevented","isPropagationStopped","cancelBubble","persist","isPersistent","wd","xd","yd","sd","eventPhase","bubbles","cancelable","timeStamp","isTrusted","td","ud","detail","vd","Ad","screenX","screenY","pageX","pageY","getModifierState","zd","relatedTarget","toElement","movementX","movementY","Bd","Dd","Fd","Hd","animationName","elapsedTime","pseudoElement","Id","clipboardData","Jd","Ld","Md","Esc","Spacebar","Left","Up","Right","Down","Del","Win","Menu","Apps","Scroll","MozPrintableKey","Nd","Od","Alt","Control","Meta","Shift","Pd","Qd","repeat","which","Rd","Td","pressure","tangentialPressure","tiltX","tiltY","twist","pointerType","isPrimary","Vd","touches","targetTouches","changedTouches","Xd","Yd","deltaX","wheelDeltaX","deltaY","wheelDeltaY","wheelDelta","deltaZ","deltaMode","Zd","$d","ae","be","documentMode","ce","de","fe","ge","he","le","tel","week","me","ne","pe","qe","se","te","ue","ve","we","xe","ye","ze","oninput","Ae","detachEvent","Be","Ce","attachEvent","De","Ee","Fe","He","Ie","Je","Ke","nextSibling","Le","compareDocumentPosition","Me","HTMLIFrameElement","Ne","contentEditable","Oe","focusedElem","selectionRange","selectionStart","selectionEnd","defaultView","getSelection","rangeCount","anchorNode","anchorOffset","focusNode","focusOffset","createRange","setStart","removeAllRanges","addRange","setEnd","scrollLeft","Pe","Qe","Re","Se","Te","Ue","Ve","We","animationend","animationiteration","animationstart","transitionend","Xe","Ye","Ze","animation","$e","af","bf","cf","df","ef","ff","gf","hf","lf","mf","nf","Ub","of","pf","qf","rf","capture","passive","J","tf","uf","parentWindow","vf","wf","xa","$a","ba","je","ke","xf","yf","zf","Af","Bf","Cf","Df","Ef","__html","Ff","Gf","Hf","Jf","queueMicrotask","If","Kf","Lf","Mf","previousSibling","Nf","Of","Pf","Qf","Rf","Sf","Tf","Uf","Vf","Wf","Xf","Yf","contextTypes","__reactInternalMemoizedUnmaskedChildContext","__reactInternalMemoizedMaskedChildContext","Zf","childContextTypes","$f","ag","getChildContext","cg","__reactInternalMemoizedMergedChildContext","dg","eg","fg","gg","hg","jg","kg","lg","ng","og","pg","qg","rg","sg","tg","ug","vg","wg","xg","yg","zg","Ag","Bg","deletions","Cg","pendingProps","treeContext","retryLane","Dg","Eg","Fg","Gg","memoizedProps","Hg","Ig","Jg","Kg","Lg","defaultProps","Mg","Ng","Og","Pg","Qg","Rg","_currentValue","Sg","childLanes","Tg","dependencies","firstContext","lanes","Ug","Vg","memoizedValue","Wg","Xg","Yg","interleaved","Zg","$g","ah","updateQueue","baseState","firstBaseUpdate","lastBaseUpdate","shared","effects","bh","ch","eventTime","lane","dh","K","eh","fh","gh","hh","ih","jh","refs","kh","nh","isMounted","_reactInternals","enqueueSetState","lh","mh","enqueueReplaceState","enqueueForceUpdate","oh","shouldComponentUpdate","isPureReactComponent","ph","updater","qh","componentWillReceiveProps","UNSAFE_componentWillReceiveProps","rh","getDerivedStateFromProps","getSnapshotBeforeUpdate","UNSAFE_componentWillMount","componentWillMount","componentDidMount","sh","_owner","_stringRef","th","uh","vh","xh","yh","implementation","zh","Ah","Bh","Ch","Dh","Eh","Fh","Gh","Hh","Ih","Jh","Kh","Lh","M","Mh","revealOrder","Nh","Oh","_workInProgressVersionPrimary","Ph","ReactCurrentDispatcher","Qh","Rh","N","O","Sh","Th","Uh","Vh","Q","Wh","Xh","Yh","Zh","$h","ai","bi","ci","baseQueue","di","ei","fi","lastRenderedReducer","hasEagerState","eagerState","lastRenderedState","gi","ii","ji","getSnapshot","mi","ni","lastEffect","stores","oi","pi","qi","ri","si","ti","ui","vi","wi","yi","zi","Ai","Bi","Ci","Di","Ei","Fi","Gi","Hi","Ii","Ji","readContext","useDebugValue","useDeferredValue","useTransition","useMutableSource","useSyncExternalStore","useId","unstable_isNewReconciler","identifierPrefix","Ki","digest","Li","Mi","Ni","Oi","Pi","Qi","Ri","getDerivedStateFromError","componentDidCatch","Si","componentStack","Ti","pingCache","Ui","Vi","Wi","Xi","ReactCurrentOwner","Yi","Zi","$i","aj","bj","cj","dj","ej","baseLanes","cachePool","transitions","fj","gj","hj","ij","jj","UNSAFE_componentWillUpdate","componentWillUpdate","componentDidUpdate","kj","lj","pendingContext","mj","Aj","Cj","Dj","nj","oj","pj","qj","rj","tj","dgst","uj","vj","_reactRetry","sj","subtreeFlags","wj","xj","isBackwards","rendering","renderingStartTime","tail","tailMode","yj","Ej","Fj","Gj","wasMultiple","multiple","suppressHydrationWarning","onclick","createElementNS","createTextNode","Hj","Ij","Jj","Kj","U","Lj","WeakSet","V","Mj","W","Nj","Oj","Qj","Rj","Sj","Tj","Uj","Vj","Wj","_reactRootContainer","Xj","X","Yj","Zj","ak","onCommitFiberUnmount","componentWillUnmount","bk","ck","dk","ek","isHidden","gk","hk","ik","jk","kk","lk","__reactInternalSnapshotBeforeUpdate","Wk","mk","nk","pk","Y","Z","qk","rk","sk","tk","uk","vk","wk","xk","yk","zk","Ak","Bk","Ck","Dk","Ek","callbackNode","expirationTimes","expiredLanes","wc","callbackPriority","ig","Fk","Gk","Hk","Ik","Jk","Kk","Lk","Mk","Nk","Ok","Pk","finishedWork","finishedLanes","Qk","timeoutHandle","Rk","Sk","Tk","Uk","Vk","mutableReadLanes","Bc","Pj","onCommitFiberRoot","mc","onRecoverableError","Xk","onPostCommitFiberRoot","Yk","Zk","al","isReactComponent","pendingChildren","mutableSourceEagerHydrationData","cl","pendingSuspenseBoundaries","el","fl","gl","hl","il","jl","zj","$k","ll","reportError","ml","_internalRoot","nl","ol","pl","ql","rl","unmount","unstable_scheduleHydration","tl","usingClientEntryPoint","ul","findFiberByHostInstance","bundleType","rendererPackageName","vl","rendererConfig","overrideHookState","overrideHookStateDeletePath","overrideHookStateRenamePath","overrideProps","overridePropsDeletePath","overridePropsRenamePath","setErrorHandler","setSuspenseHandler","scheduleUpdate","currentDispatcherRef","findHostInstanceByFiber","findHostInstancesForRefresh","scheduleRefresh","scheduleRoot","setRefreshHandler","getCurrentFiber","reconcilerVersion","__REACT_DEVTOOLS_GLOBAL_HOOK__","wl","isDisabled","supportsFiber","inject","createRoot","unstable_strictMode","findDOMNode","flushSync","hydrate","hydrateRoot","hydratedSources","_getVersion","_source","unmountComponentAtNode","unstable_batchedUpdates","unstable_renderSubtreeIntoContainer","checkDCE","FOCUS_GROUP","FOCUS_DISABLED","useMergeRefs","assignRef","facade","hiddenGuard","InFocusGuard","__assign","ItoI","innerCreateMedium","middleware","assigned","useMedium","assignSyncMedium","cbs","assignMedium","pendingQueue","executeQueue","cycle","createMedium","mediumFocus","mediumBlur","mediumEffect","mediumSidecar","medium","ssr","createSidecarMedium","emptyArray","parentRef","_extends2","_React$useState","realObserved","setObserved","observed","isActive","originalFocusedElement","noFocusGuards","persistentFocus","crossFrame","allowTextSelection","whiteList","hasPositiveIndices","_props$shards","shards","_props$as","Container","_props$lockProps","containerProps","SideCar","sideCar","shouldReturnFocus","returnFocus","focusOptions","onActivationCallback","onActivation","onDeactivationCallback","onDeactivation","allowDefer","returnFocusTo","howToReturnFocus","returnFocusOptions","setObserveNode","newObserved","hasLeadingGuards","hasTailingGuards","mergedRef","reducePropsToState","handleStateChangeOnClient","WrappedComponent","mountedInstances","emitChange","SideEffect","_PureComponent","peek","PureComponent","getDisplayName","getParentNode","Node","DOCUMENT_FRAGMENT_NODE","host","isTopNode","DOCUMENT_NODE","isVisibleUncached","checkParent","ELEMENT_NODE","computedStyle","getPropertyValue","isElementHidden","isVisibleCached","visibilityCache","cached","isAutoFocusAllowedCached","isAutoFocusAllowed","isAutoFocusAllowedUncached","getDataset","isHTMLInputElement","isRadioElement","attribute","isGuard","_a","focusGuard","isNotAGuard","isDefined","correctNode","findSelectedRadio","pickFirstFocus","pickFocusable","NEW_FOCUS","newFocus","innerNodes","outerNodes","lastNode","cnt","firstFocus","lastFocus","isOnGuard","resultSet","activeIndex","lastNodeInside","indexDiff","firstNodeIndex","lastNodeIndex","correctedNodes","correctedIndexDiff","returnFirstNode","returnLastNode","toArray","asArray","tabSort","tabDiff","orderByTabIndex","filterNegative","keepGuards","queryTabbables","queryGuardTabbables","getFocusablesWithShadowDom","withGuards","shadowRoot","getFocusables","parents","filterFocusable","isHTMLButtonElement","notHiddenInput","filterAutoFocusable","getTabbableNodes","topNodes","getAllTabbableNodes","parentAutofocusables","topNode","parentFocus","getParentAutofocusables","getTopParent","getAllAffectedNodes","currentNode","contained","DOCUMENT_POSITION_CONTAINED_BY","DOCUMENT_POSITION_CONTAINS","filterNested","getNestedShadowActiveElement","getActiveElement","getParents","getCommonParent","nodeA","nodeB","parentsA","parentsB","currentParent","getTopCommonParent","baseActiveElement","leftEntry","rightEntries","activeElements","leftEntries","topCommon","subEntry","common","getFocusMerge","commonParent","anyFocusable","innerElements","srcNodes","dstNodes","remap","autoFocusables","orderedInnerElements","entity","autoFocusable","allParentAutofocusables","autofocus","guardCount","lockDisabled","focusable","focusInsideIframe","focusInside","getFocusabledIn","lockItem","guard","deferAction","setImmediate","isFreeFocus","lastActiveTrap","lastActiveFocus","lastPortaledElement","focusWasOutsideWindow","defaultWhitelist","autoGuard","startIndex","step","allNodes","lastGuard","focusAutoGuard","extractRef","checkInHost","check","boundary","activateTrap","_lastActiveTrap","workingNode","portaledElement","workingArea","focusWhitelisted","withinHost","newActiveElement","focusedIndex","onTrap","observerNode","onWindowBlur","moveFocusInside","propsList","_ref5","traps","trap","lastTrap","sameTrap","_ref6","FocusLockCombination","_objectWithoutPropertiesLoose","I18nextProvider","_react","I18nContext","Trans","i18nKey","_ref$tOptions","tOptions","i18nFromProps","tFromProps","shouldUnescape","additionalProps","_objectWithoutProperties2","_excluded","i18nFromContext","defaultNSFromContext","getI18n","_TransWithoutContext","_defineProperty2","nodesToString","_excluded2","_i18nInstance","_utils","warnOnce","reactI18nextOptions","_defaults","getDefaults","react","transEmptyNodeValue","hashTransKey","interpolationOverride","combinedTOpts","translation","targetString","i18nOptions","keepArray","transKeepBasicHtmlNodesFor","emptyChildrenButNeedsHandling","getData","childs","getAsArray","hasChildren","getChildren","_typeof2","isValidElement","ast","_htmlParseStringify","renderInner","rootReactNode","mappedChildren","mapAST","hasValidReactChildren","pushTranslatedJSX","isVoid","dummy","cloneElement","reactNode","astNode","reactNodes","newTarget","translationContent","isElement","isValidTranslationWithChildren","isEmptyTransWithHTML","isKnownComponent","_inner","transSupportBasicHtmlNodes","_inner3","_inner4","wrapTextNodes","transWrapTextNodes","_content","renderNodes","useAsParent","defaultTransParent","checkLength","stringNode","childrenArray","childIndex","childPropsCount","shouldKeepChild","childChildren","i18nIsDynamicList","Translation","_useTranslation","_useTranslation3","_useTranslation2","_slicedToArray2","composeInitialProps","ForComponent","i18nInitialProps","getInitialProps","componentsInitialProps","setDefaults","setI18n","_initReactI18next","initReactI18next","ReportNamespaces","_classCallCheck2","_createClass2","usedNamespaces","reportNamespaces","getUsedNamespaces","initialI18nStore","getResourceBundle","initialLanguage","defaultOptions","bindI18n","bindI18nStore","useSuspense","i18nInstance","_Trans","_withTranslation","withTranslation","_Translation","_I18nextProvider","_withSSR","withSSR","_useSSR","useSSR","selectOrdinal","plural","matchHtmlEntity","htmlEntities","unescapeHtmlEntity","lngResources","initializedLanguageOnce","notReadyT","retNotReady","addUsedNamespaces","getT","getFixedT","nsMode","_useState","_useState2","setT","joinedNS","previousJoinedNS","usePrevious","boundReset","loadNamespaces","isInitial","ignore","_console","isNewerI18next","oldI18nextHasLoadedNamespace","alreadyWarned","I18nextWithSSR","I18nextWithTranslation","forwardedRef","passDownProps","tReady","withRef","ContextConsumer","ContextProvider","Element","ForwardRef","Lazy","Memo","Portal","Profiler","SuspenseList","isAsyncMode","isConcurrentMode","isContextConsumer","isContextProvider","isForwardRef","isFragment","isLazy","isMemo","isPortal","isProfiler","isStrictMode","isSuspense","isSuspenseList","getModuleId","typeOf","forceUpdate","__self","__source","_status","Children","only","_currentValue2","_threadCount","Consumer","_defaultValue","_globalName","createFactory","createRef","lazy","startTransition","unstable_act","Op","desc","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","define","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","Context","makeInvokeMethod","tryCatch","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","ContinueSentinel","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","NativeIteratorPrototype","Gp","defineIteratorMethods","_invoke","AsyncIterator","PromiseImpl","invoke","record","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","doneResult","delegate","delegateResult","maybeInvokeDelegate","_sent","dispatchException","methodName","resultName","nextLoc","pushTryEntry","locs","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","iterable","iteratorMethod","isGeneratorFunction","genFun","ctor","awrap","iter","skipTempReset","rootRecord","rval","exception","loc","caught","hasCatch","hasFinally","finallyEntry","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","globalThis","sortIndex","expirationTime","priorityLevel","scheduling","isInputPending","MessageChannel","port2","port1","unstable_Profiling","unstable_continueExecution","unstable_forceFrameRate","unstable_getFirstCallbackNode","unstable_next","unstable_pauseExecution","unstable_runWithPriority","unstable_wrapCallback","isArrayish","ARROW_KEY_CODE","mapOfBoundRect","startingPoint","initiateSpatialNavigation","spatialNavigationSearch","focusableAreas","getSpatialNavigationContainer","CSS","registerProperty","syntax","inherits","currentKeyMode","__spatialNavigation__","keyMode","eventTarget","focusNavigableArrowKey","up","down","SPINNABLE_INPUT_TYPES","TEXT_INPUT_TYPES","endPosition","handlingEditableElement","searchOrigin","findSearchOrigin","elementFromPosition","elementFromPoint","isFocusable","isContainer","contentDocument","bestInsideCandidate","getCSSSpatNavAction","scrollingController","candidates","getSpatialNavigationCandidates","inside","focusingController","parentContainer","navigateChain","bestCandidate","elementStyle","isScrollable","rect","containerRect","isEntirelyVisible","createSpatNavEvents","isScrollBoundary","moveScroll","isHTMLScrollBoundary","isDelegableContainer","isVisible","getFilteredSpatialNavigationCandidates","targetElement","filteredCandidates","bestTarget","internalCandidates","externalCandidates","currentElm","getClosestElement","getDistanceFromPoint","getInnerDistance","selectBestCandidateFromEdge","spatialNavigationFunction","currentElmRect","distanceFunction","alignedCandidates","elm","isAligned","getAbsoluteDistance","getEuclideanDistance","getDistance","selectBestCandidate","innerTarget","descendantsBest","originalContainer","eventTargetRect","candidateRect","candidateBody","isOutside","childRect","rightEdgeCheck","leftEdgeCheck","topEdgeCheck","bottomEdgeCheck","isInside","frameElement","minDistance","minDistanceElements","focusables","eventType","triggeredEvent","CustomEvent","causedTarget","readCssVar","varName","currentOption","isScrollContainer","overflowX","isOverflow","scrollWidth","clientWidth","scrollX","scrollY","winScrollY","winScrollX","isAtagWithoutHref","isActuallyDisabled","inert","isExpresslyInert","isVisibleStyleProperty","isBeingRendered","elementRect","offsetX","offsetWidth","offsetY","offsetHeight","hitTestPoint","leftTop","rightBottom","point","elemFromPoint","hitTest","thisVisibility","rect1","rect2","isRightSide","isBelow","points","getEntryAndExitPoints","P1","entryPoint","exitPoint","P2","baseEdge","orthogonalBias","alignBias","intersectionRect","intersection_rect","new_location","new_max_point","getIntersectionRect","boundingClientRect","enableExperimentalAPIs","getInitialAPIs","canScroll","findTarget","findCandidate","bestNextTarget","findCandidates","findNextTarget","getDistanceFromTarget","candidateElement","getExperimentalAPI","seal","_keymode","setStartingPoint","byteTable","plain","buff","quintets","shiftIndex","encoded","plainChar","plainDigit","plainPos","encodedByte","util","Url","slashes","port","urlParse","relative","resolveObject","isString","protocolPattern","portPattern","simplePathPattern","unwise","autoEscape","nonHostChars","hostEndingChars","hostnamePartPattern","hostnamePartStart","unsafeProtocol","hostlessProtocol","slashedProtocol","querystring","parseQueryString","slashesDenoteHost","queryIndex","splitter","uSplit","simplePath","lowerProto","atSign","hostEnd","hec","parseHost","ipv6Hostname","hostparts","newpart","validParts","notHost","bit","toASCII","esc","qm","tkeys","tkey","rkeys","rkey","relPath","isSourceAbs","isRelAbs","mustEndAbs","removeAllDots","srcPath","psychotic","isNullOrUndefined","authInHost","isNull","hasTrailingSlash","isAbsolute","VTTRegion","makeColorSet","fontScale","observe","subject","topic","fontColor","Services","prefs","getCharPref","fontOpacity","getIntPref","WebVTTSet","fontSet","backgroundOpacity","backgroundSet","edgeType","edgeColor","edgeSet","pref","addObserver","_objCreate","ParsingError","Errors","BadSignature","BadTimeStamp","ESCAPE","TAG_NAME","ruby","TAG_ANNOTATION","NEEDS_PARENT","parseContent","nextToken","unescape1","shouldAdd","localName","annotation","rootDiv","tagStack","createProcessingInstruction","strongRTLRanges","isStrongRTLChar","currentRange","StyleBox","CueStyleBox","styleOptions","isIE8","cueDiv","writingMode","unicodeBidi","applyStyles","div","font","whiteSpace","nodeStack","pushNodes","nextTextNode","determineBidi","stylesunicodeBidi","textPos","positionAlign","formatStyle","move","BoxPosition","rects","getClientRects","moveBoxToLinePosition","styleBox","containerBox","boxPositions","boxPosition","linePos","trackList","computeLinePos","axis","maxPosition","initialAxis","calculatedPercentage","bestPosition","specifiedPosition","percentage","overlapsOppositeAxis","within","overlapsAny","intersectPercentage","findBestPosition","toCSSCompatValues","toMove","overlaps","b2","getSimpleBoxPosition","cuetext","processCues","overlay","paddedOverlay","margin","shouldCompute","reportOrThrowError","ontimestampmap","parseTimestampMap","xy","anchor","lines","regionAnchorX","regionAnchorY","viewportAnchorX","viewportAnchorY","scroll","onregion","parseRegion","linebyline","successCb","errCb","vals0","fromJSON","directionSetting","alignSetting","scrollSetting","isValidPercentValue","_width","_lines","_regionAnchorX","_regionAnchorY","_viewportAnchorX","_viewportAnchorY","_scroll","findScrollSetting","toPropertyKey","assertThisInitialized","iterableToArray","hint","prim","__webpack_module_cache__","cachedModule","__webpack_modules__","definition","nmd","scriptUrl","importScripts","currentScript","scripts","stremioTranslations","translations","fromEntries","use","getElementById","serviceWorker","register","registrationError"],"sourceRoot":""} \ No newline at end of file diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js new file mode 100644 index 000000000..c6aaa98ee --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js @@ -0,0 +1,2 @@ +(()=>{var t={8926:t=>{function e(t,e,n,r,o,a,i){try{var u=t[a](i),c=u.value}catch(t){return void n(t)}u.done?e(c):Promise.resolve(c).then(r,o)}t.exports=function(t){return function(){var n=this,r=arguments;return new Promise((function(o,a){var i=t.apply(n,r);function u(t){e(i,o,a,u,c,"next",t)}function c(t){e(i,o,a,u,c,"throw",t)}u(void 0)}))}},t.exports.default=t.exports,t.exports.__esModule=!0},5318:t=>{t.exports=function(t){return t&&t.__esModule?t:{default:t}},t.exports.default=t.exports,t.exports.__esModule=!0},8:t=>{function e(n){return"function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?(t.exports=e=function(t){return typeof t},t.exports.default=t.exports,t.exports.__esModule=!0):(t.exports=e=function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},t.exports.default=t.exports,t.exports.__esModule=!0),e(n)}t.exports=e,t.exports.default=t.exports,t.exports.__esModule=!0},7757:(t,e,n)=>{t.exports=n(5666)},6553:(t,e,n)=>{"use strict";var r=n(5318),o=r(n(7757)),a=r(n(8926));t.exports=function(t,e){e.addEventListener("message",(function(){var n=(0,a.default)(o.default.mark((function n(r){var a,i,u,c,s,f,_;return o.default.wrap((function(n){for(;;)switch(n.prev=n.next){case 0:if(a=r.data.request){n.next=3;break}return n.abrupt("return");case 3:if(i=a.id,u=a.path,c=a.args,n.prev=4,"function"!=typeof(s=u.reduce((function(t,e){return t[e]}),t))){n.next=13;break}return _=u.slice(0,u.length-1).reduce((function(t,e){return t[e]}),t),n.next=10,s.apply(_,c);case 10:f=n.sent,n.next=16;break;case 13:return n.next=15,s;case 15:f=n.sent;case 16:e.postMessage({response:{id:i,result:{data:f}}}),n.next=22;break;case 19:n.prev=19,n.t0=n.catch(4),e.postMessage({response:{id:i,result:{error:n.t0}}});case 22:case"end":return n.stop()}}),n,null,[[4,19]])})));return function(t){return n.apply(this,arguments)}})()),this.call=(function(){var t=(0,a.default)(o.default.mark((function t(n,r){var a;return o.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return a=Math.random().toString(32).slice(2),t.abrupt("return",new Promise((function(t,o){e.addEventListener("message",(function n(r){var i=r.data.response;i&&i.id===a&&(e.removeEventListener("message",n),"error"in i.result?o(i.result.error):t(i.result.data))})),e.postMessage({request:{id:a,path:n,args:r}})})));case 2:case"end":return t.stop()}}),t)})));return function(e,n){return t.apply(this,arguments)}})()}},6489:(t,e,n)=>{"use strict";var r=n(5318);Object.defineProperty(e,"__esModule",{value:!0}),e.analytics=function(t,e){o.analytics(p(t),p(e))},e.decode_stream=function(t){return l(o.decode_stream(p(t)))},e.default=void 0,e.dispatch=function(t,e,n){o.dispatch(p(t),p(e),p(n))},e.get_state=function(t){return l(o.get_state(p(t)))},e.initialize_runtime=function(t){return l(o.initialize_runtime(p(t)))},e.start=function(){o.start()};var o,a=r(n(7757)),i=r(n(8926)),u=r(n(8)),c={url:new URL("/stremio_core_web.js",document.baseURI).href},s=new Array(32).fill(void 0);function f(t){return s[t]}s.push(void 0,null,!0,!1);var _=s.length;function l(t){var e=f(t);return(function(t){t<36||(s[t]=_,_=t)})(t),e}var b=new TextDecoder("utf-8",{ignoreBOM:!0,fatal:!0});b.decode();var g=null;function d(){return null!==g&&g.buffer===o.memory.buffer||(g=new Uint8Array(o.memory.buffer)),g}function w(t,e){return b.decode(d().subarray(t,t+e))}function p(t){_===s.length&&s.push(s.length+1);var e=_;return _=s[e],s[e]=t,e}var h=0,y=new TextEncoder("utf-8"),v="function"==typeof y.encodeInto?function(t,e){return y.encodeInto(t,e)}:function(t,e){var n=y.encode(t);return e.set(n),{read:t.length,written:n.length}};function m(t,e,n){if(void 0===n){var r=y.encode(t),o=e(r.length);return d().subarray(o,o+r.length).set(r),h=r.length,o}for(var a=t.length,i=e(a),u=d(),c=0;c<a;c++){var s=t.charCodeAt(c);if(s>127)break;u[i+c]=s}if(c!==a){0!==c&&(t=t.slice(c)),i=n(i,a,a=c+3*t.length);var f=d().subarray(i+c,i+a);c+=v(t,f).written}return h=c,i}function x(t){return null==t}var k=null;function E(){return null!==k&&k.buffer===o.memory.buffer||(k=new Int32Array(o.memory.buffer)),k}function L(t){var e=(0,u.default)(t);if("number"==e||"boolean"==e||null==t)return"".concat(t);if("string"==e)return'"'.concat(t,'"');if("symbol"==e){var n=t.description;return null==n?"Symbol":"Symbol(".concat(n,")")}if("function"==e){var r=t.name;return"string"==typeof r&&r.length>0?"Function(".concat(r,")"):"Function"}if(Array.isArray(t)){var o=t.length,a="[";o>0&&(a+=L(t[0]));for(var i=1;i<o;i++)a+=", "+L(t[i]);return a+="]"}var c,s=/\[object ([^\]]+)\]/.exec(toString.call(t));if(!(s.length>1))return toString.call(t);if("Object"==(c=s[1]))try{return"Object("+JSON.stringify(t)+")"}catch(t){return"Object"}return t instanceof Error?"".concat(t.name,": ").concat(t.message,"\n").concat(t.stack):c}function S(t,e,n,r){var a={a:t,b:e,cnt:1,dtor:n},i=function(){a.cnt++;var t=a.a;a.a=0;try{for(var e=arguments.length,n=new Array(e),i=0;i<e;i++)n[i]=arguments[i];return r.apply(void 0,[t,a.b].concat(n))}finally{0==--a.cnt?o.__wbindgen_export_2.get(a.dtor)(t,a.b):a.a=t}};return i.original=a,i}function j(t,e){o._dyn_core__ops__function__FnMut_____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h1a6784ec167a5430(t,e)}function O(t,e,n){o._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hdf2bb55ffabdfc36(t,e,p(n))}function R(t,e){try{return t.apply(this,e)}catch(t){o.__wbindgen_exn_store(p(t))}}function A(t,e){return d().subarray(t/1,t/1+e)}function M(t,e,n,r){o.wasm_bindgen__convert__closures__invoke2_mut__h23a6b10e1d576a11(t,e,p(n),p(r))}function T(t,e){return F.apply(this,arguments)}function F(){return(F=(0,i.default)(a.default.mark((function t(e,n){var r,o;return a.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:if(!("function"==typeof Response&&e instanceof Response)){t.next=23;break}if("function"!=typeof WebAssembly.instantiateStreaming){t.next=15;break}return t.prev=2,t.next=5,WebAssembly.instantiateStreaming(e,n);case 5:case 20:return t.abrupt("return",t.sent);case 8:if(t.prev=8,t.t0=t.catch(2),"application/wasm"==e.headers.get("Content-Type")){t.next=14;break}console.warn("`WebAssembly.instantiateStreaming` failed because your server does not serve wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\n",t.t0),t.next=15;break;case 14:throw t.t0;case 15:return t.next=17,e.arrayBuffer();case 17:return r=t.sent,t.next=20,WebAssembly.instantiate(r,n);case 23:return t.next=25,WebAssembly.instantiate(e,n);case 25:if(!((o=t.sent)instanceof WebAssembly.Instance)){t.next=30;break}return t.abrupt("return",{instance:o,module:e});case 30:return t.abrupt("return",o);case 31:case"end":return t.stop()}}),t,null,[[2,8]])})))).apply(this,arguments)}function I(t){return P.apply(this,arguments)}function P(){return P=(0,i.default)(a.default.mark((function t(e){var r,i,s,_;return a.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return void 0===e&&(e=new URL("stremio_core_web_bg.wasm",c.url)),(r={}).wbg={},r.wbg.__wbg_new_693216e109162396=function(){return p(new Error)},r.wbg.__wbg_stack_0ddaca5d1abfb52f=function(t,e){var n=m(f(e).stack,o.__wbindgen_malloc,o.__wbindgen_realloc),r=h;E()[t/4+1]=r,E()[t/4+0]=n},r.wbg.__wbg_error_09919627ac0992f5=function(t,e){try{console.error(w(t,e))}finally{o.__wbindgen_free(t,e)}},r.wbg.__wbindgen_object_drop_ref=function(t){l(t)},r.wbg.__wbg_crypto_8fd02d72c4ba6c5c=function(t){return p(f(t).crypto)},r.wbg.__wbindgen_is_object=function(t){var e=f(t);return"object"===(0,u.default)(e)&&null!==e},r.wbg.__wbg_process_bd02d71a65cf734c=function(t){return p(f(t).process)},r.wbg.__wbg_versions_1d70d407cb23129d=function(t){return p(f(t).versions)},r.wbg.__wbg_node_0091cdf1ffa73e4d=function(t){return p(f(t).node)},r.wbg.__wbindgen_is_string=function(t){return"string"==typeof f(t)},r.wbg.__wbg_require_b06abd91965488c8=function(){return R((function(){return p(_.require)}),arguments)},r.wbg.__wbindgen_is_function=function(t){return"function"==typeof f(t)},r.wbg.__wbindgen_string_new=function(t,e){return p(w(t,e))},r.wbg.__wbg_msCrypto_7e1e6014bddd75de=function(t){return p(f(t).msCrypto)},r.wbg.__wbg_newwithlength_929232475839a482=function(t){return p(new Uint8Array(t>>>0))},r.wbg.__wbindgen_object_clone_ref=function(t){return p(f(t))},r.wbg.__wbg_self_c6fbdfc2918d5e58=function(){return R((function(){return p(self.self)}),arguments)},r.wbg.__wbg_window_baec038b5ab35c54=function(){return R((function(){return p(window.window)}),arguments)},r.wbg.__wbg_globalThis_3f735a5746d41fbd=function(){return R((function(){return p(globalThis.globalThis)}),arguments)},r.wbg.__wbg_global_1bc0b39582740e95=function(){return R((function(){return p(n.g.global)}),arguments)},r.wbg.__wbindgen_is_undefined=function(t){return void 0===f(t)},r.wbg.__wbg_newnoargs_be86524d73f67598=function(t,e){return p(new Function(w(t,e)))},r.wbg.__wbg_call_888d259a5fefc347=function(){return R((function(t,e){return p(f(t).call(f(e)))}),arguments)},r.wbg.__wbg_call_346669c262382ad7=function(){return R((function(t,e,n){return p(f(t).call(f(e),f(n)))}),arguments)},r.wbg.__wbindgen_string_get=function(t,e){var n=f(e),r="string"==typeof n?n:void 0,a=x(r)?0:m(r,o.__wbindgen_malloc,o.__wbindgen_realloc),i=h;E()[t/4+1]=i,E()[t/4+0]=a},r.wbg.__wbg_set_82a4e8a85e31ac42=function(){return R((function(t,e,n){return Reflect.set(f(t),f(e),f(n))}),arguments)},r.wbg.__wbg_now_af172eabe2e041ad=function(){return Date.now()},r.wbg.__wbg_randomFillSync_f20541303a990429=function(){return R((function(t,e,n){f(t).randomFillSync(A(e,n))}),arguments)},r.wbg.__wbg_subarray_8b658422a224f479=function(t,e,n){return p(f(t).subarray(e>>>0,n>>>0))},r.wbg.__wbg_getRandomValues_f308e7233e5601b7=function(){return R((function(t,e){f(t).getRandomValues(f(e))}),arguments)},r.wbg.__wbg_length_1eb8fc608a0d4cdb=function(t){return f(t).length},r.wbg.__wbindgen_memory=function(){return p(o.memory)},r.wbg.__wbg_buffer_397eaa4d72ee94dd=function(t){return p(f(t).buffer)},r.wbg.__wbg_new_a7ce447f15ff496f=function(t){return p(new Uint8Array(f(t)))},r.wbg.__wbg_set_969ad0a60e51d320=function(t,e,n){f(t).set(f(e),n>>>0)},r.wbg.__wbindgen_json_serialize=function(t,e){var n=f(e),r=m(JSON.stringify(void 0===n?null:n),o.__wbindgen_malloc,o.__wbindgen_realloc),a=h;E()[t/4+1]=a,E()[t/4+0]=r},r.wbg.__wbg_instanceof_WorkerGlobalScope_f191ca0158f5637b=function(t){return f(t)instanceof WorkerGlobalScope},r.wbg.__wbg_static_accessor_app_version_0d438539d98a0943=function(t){var e=m(self.app_version,o.__wbindgen_malloc,o.__wbindgen_realloc),n=h;E()[t/4+1]=n,E()[t/4+0]=e},r.wbg.__wbg_static_accessor_shell_version_1f62a14e53964af1=function(t){var e=self.shell_version,n=x(e)?0:m(e,o.__wbindgen_malloc,o.__wbindgen_realloc),r=h;E()[t/4+1]=r,E()[t/4+0]=n},r.wbg.__wbg_navigator_8bc0889cda8f8500=function(t){return p(f(t).navigator)},r.wbg.__wbg_language_cd6e22892ba36a1f=function(t,e){var n=f(e).language,r=x(n)?0:m(n,o.__wbindgen_malloc,o.__wbindgen_realloc),a=h;E()[t/4+1]=a,E()[t/4+0]=r},r.wbg.__wbg_new_b1d61b5687f5e73a=function(t,e){try{var n={a:t,b:e},r=new Promise((function(t,e){var r=n.a;n.a=0;try{return M(r,n.b,t,e)}finally{n.a=r}}));return p(r)}finally{n.a=n.b=0}},r.wbg.__wbindgen_json_parse=function(t,e){return p(JSON.parse(w(t,e)))},r.wbg.__wbg_new_0b83d3df67ecb33e=function(){return p(new Object)},r.wbg.__wbg_fetch_b4e81012e07ff95a=function(t,e){return p(f(t).fetch(f(e)))},r.wbg.__wbg_getlocationhash_97299d3c8a498b17=function(){return R((function(){return p(self.get_location_hash())}),arguments)},r.wbg.__wbg_instanceof_Error_561efcb1265706d8=function(t){return f(t)instanceof Error},r.wbg.__wbg_message_9f7d15ff97fc4102=function(t){return p(f(t).message)},r.wbg.__wbg_instanceof_Response_e1b11afbefa5b563=function(t){return f(t)instanceof Response},r.wbg.__wbg_status_6d8bb444ddc5a7b2=function(t){return f(t).status},r.wbg.__wbg_setInterval_a02797f5ab1c7eb1=function(){return R((function(t,e,n){return f(t).setInterval(f(e),n)}),arguments)},r.wbg.__wbg_localstorageremoveitem_8ad2d96138ff136a=function(){return R((function(t,e){try{return p(self.local_storage_remove_item(w(t,e)))}finally{o.__wbindgen_free(t,e)}}),arguments)},r.wbg.__wbg_localstoragesetitem_7d75d2eac814d3d8=function(){return R((function(t,e,n,r){try{return p(self.local_storage_set_item(w(t,e),w(n,r)))}finally{o.__wbindgen_free(t,e),o.__wbindgen_free(n,r)}}),arguments)},r.wbg.__wbg_localstoragegetitem_318a1e7771661e01=function(){return R((function(t,e){try{return p(self.local_storage_get_item(w(t,e)))}finally{o.__wbindgen_free(t,e)}}),arguments)},r.wbg.__wbindgen_debug_string=function(t,e){var n=m(L(f(e)),o.__wbindgen_malloc,o.__wbindgen_realloc),r=h;E()[t/4+1]=r,E()[t/4+0]=n},r.wbg.__wbindgen_throw=function(t,e){throw new Error(w(t,e))},r.wbg.__wbg_then_8c2d62e8ae5978f7=function(t,e,n){return p(f(t).then(f(e),f(n)))},r.wbg.__wbg_then_2fcac196782070cc=function(t,e){return p(f(t).then(f(e)))},r.wbg.__wbg_resolve_d23068002f584f22=function(t){return p(Promise.resolve(f(t)))},r.wbg.__wbindgen_cb_drop=function(t){var e=l(t).original;if(1==e.cnt--)return e.a=0,!0;return!1},r.wbg.__wbg_newwithstrandinit_9b0fa00478c37287=function(){return R((function(t,e,n){return p(new Request(w(t,e),f(n)))}),arguments)},r.wbg.__wbg_json_88cc6d5cf8f61121=function(){return R((function(t){return p(f(t).json())}),arguments)},r.wbg.__wbindgen_closure_wrapper4955=function(t,e,n){return p(S(t,e,127,j))},r.wbg.__wbindgen_closure_wrapper5985=function(t,e,n){return p(S(t,e,134,O))},("string"==typeof e||"function"==typeof Request&&e instanceof Request||"function"==typeof URL&&e instanceof URL)&&(e=fetch(e)),t.t0=T,t.next=71,e;case 71:return t.t1=t.sent,t.t2=r,t.next=75,(0,t.t0)(t.t1,t.t2);case 75:return i=t.sent,s=i.instance,_=i.module,o=s.exports,I.__wbindgen_wasm_module=_,o.__wbindgen_start(),t.abrupt("return",o);case 82:case"end":return t.stop()}}),t)}))),P.apply(this,arguments)}var N=I;e.default=N},5666:t=>{var e=(function(t){"use strict";var e,n=Object.prototype,r=n.hasOwnProperty,o=Object.defineProperty||function(t,e,n){t[e]=n.value},a="function"==typeof Symbol?Symbol:{},i=a.iterator||"@@iterator",u=a.asyncIterator||"@@asyncIterator",c=a.toStringTag||"@@toStringTag";function s(t,e,n){return Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}),t[e]}try{s({},"")}catch(t){s=function(t,e,n){return t[e]=n}}function f(t,e,n,r){var a=e&&e.prototype instanceof w?e:w,i=Object.create(a.prototype),u=new R(r||[]);return o(i,"_invoke",{value:L(t,n,u)}),i}function _(t,e,n){try{return{type:"normal",arg:t.call(e,n)}}catch(t){return{type:"throw",arg:t}}}t.wrap=f;var l="suspendedStart",b="executing",g="completed",d={};function w(){}function p(){}function h(){}var y={};s(y,i,(function(){return this}));var v=Object.getPrototypeOf,m=v&&v(v(A([])));m&&m!==n&&r.call(m,i)&&(y=m);var x=h.prototype=w.prototype=Object.create(y);function k(t){["next","throw","return"].forEach((function(e){s(t,e,(function(t){return this._invoke(e,t)}))}))}function E(t,e){function n(o,a,i,u){var c=_(t[o],t,a);if("throw"!==c.type){var s=c.arg,f=s.value;return f&&"object"==typeof f&&r.call(f,"__await")?e.resolve(f.__await).then((function(t){n("next",t,i,u)}),(function(t){n("throw",t,i,u)})):e.resolve(f).then((function(t){s.value=t,i(s)}),(function(t){return n("throw",t,i,u)}))}u(c.arg)}var a;o(this,"_invoke",{value:function(t,r){function o(){return new e((function(e,o){n(t,r,e,o)}))}return a=a?a.then(o,o):o()}})}function L(t,e,n){var r=l;return function(o,a){if(r===b)throw new Error("Generator is already running");if(r===g){if("throw"===o)throw a;return M()}for(n.method=o,n.arg=a;;){var i=n.delegate;if(i){var u=S(i,n);if(u){if(u===d)continue;return u}}if("next"===n.method)n.sent=n._sent=n.arg;else if("throw"===n.method){if(r===l)throw r=g,n.arg;n.dispatchException(n.arg)}else"return"===n.method&&n.abrupt("return",n.arg);r=b;var c=_(t,e,n);if("normal"===c.type){if(r=n.done?g:"suspendedYield",c.arg===d)continue;return{value:c.arg,done:n.done}}"throw"===c.type&&(r=g,n.method="throw",n.arg=c.arg)}}}function S(t,n){var r=n.method,o=t.iterator[r];if(o===e)return n.delegate=null,"throw"===r&&t.iterator.return&&(n.method="return",n.arg=e,S(t,n),"throw"===n.method)||"return"!==r&&(n.method="throw",n.arg=new TypeError("The iterator does not provide a '"+r+"' method")),d;var a=_(o,t.iterator,n.arg);if("throw"===a.type)return n.method="throw",n.arg=a.arg,n.delegate=null,d;var i=a.arg;return i?i.done?(n[t.resultName]=i.value,n.next=t.nextLoc,"return"!==n.method&&(n.method="next",n.arg=e),n.delegate=null,d):i:(n.method="throw",n.arg=new TypeError("iterator result is not an object"),n.delegate=null,d)}function j(t){var e={tryLoc:t[0]};1 in t&&(e.catchLoc=t[1]),2 in t&&(e.finallyLoc=t[2],e.afterLoc=t[3]),this.tryEntries.push(e)}function O(t){var e=t.completion||{};e.type="normal",delete e.arg,t.completion=e}function R(t){this.tryEntries=[{tryLoc:"root"}],t.forEach(j,this),this.reset(!0)}function A(t){if(t){var n=t[i];if(n)return n.call(t);if("function"==typeof t.next)return t;if(!isNaN(t.length)){var o=-1,a=function n(){for(;++o<t.length;)if(r.call(t,o))return n.value=t[o],n.done=!1,n;return n.value=e,n.done=!0,n};return a.next=a}}return{next:M}}function M(){return{value:e,done:!0}}return p.prototype=h,o(x,"constructor",{value:h,configurable:!0}),o(h,"constructor",{value:p,configurable:!0}),p.displayName=s(h,c,"GeneratorFunction"),t.isGeneratorFunction=function(t){var e="function"==typeof t&&t.constructor;return!!e&&(e===p||"GeneratorFunction"===(e.displayName||e.name))},t.mark=function(t){return Object.setPrototypeOf?Object.setPrototypeOf(t,h):(t.__proto__=h,s(t,c,"GeneratorFunction")),t.prototype=Object.create(x),t},t.awrap=function(t){return{__await:t}},k(E.prototype),s(E.prototype,u,(function(){return this})),t.AsyncIterator=E,t.async=function(e,n,r,o,a){void 0===a&&(a=Promise);var i=new E(f(e,n,r,o),a);return t.isGeneratorFunction(n)?i:i.next().then((function(t){return t.done?t.value:i.next()}))},k(x),s(x,c,"Generator"),s(x,i,(function(){return this})),s(x,"toString",(function(){return"[object Generator]"})),t.keys=function(t){var e=Object(t),n=[];for(var r in e)n.push(r);return n.reverse(),function t(){for(;n.length;){var r=n.pop();if(r in e)return t.value=r,t.done=!1,t}return t.done=!0,t}},t.values=A,R.prototype={constructor:R,reset:function(t){if(this.prev=0,this.next=0,this.sent=this._sent=e,this.done=!1,this.delegate=null,this.method="next",this.arg=e,this.tryEntries.forEach(O),!t)for(var n in this)"t"===n.charAt(0)&&r.call(this,n)&&!isNaN(+n.slice(1))&&(this[n]=e)},stop:function(){this.done=!0;var t=this.tryEntries[0].completion;if("throw"===t.type)throw t.arg;return this.rval},dispatchException:function(t){if(this.done)throw t;var n=this;function o(r,o){return u.type="throw",u.arg=t,n.next=r,o&&(n.method="next",n.arg=e),!!o}for(var a=this.tryEntries.length-1;a>=0;--a){var i=this.tryEntries[a],u=i.completion;if("root"===i.tryLoc)return o("end");if(i.tryLoc<=this.prev){var c=r.call(i,"catchLoc"),s=r.call(i,"finallyLoc");if(c&&s){if(this.prev<i.catchLoc)return o(i.catchLoc,!0);if(this.prev<i.finallyLoc)return o(i.finallyLoc)}else if(c){if(this.prev<i.catchLoc)return o(i.catchLoc,!0)}else{if(!s)throw new Error("try statement without catch or finally");if(this.prev<i.finallyLoc)return o(i.finallyLoc)}}}},abrupt:function(t,e){for(var n=this.tryEntries.length-1;n>=0;--n){var o=this.tryEntries[n];if(o.tryLoc<=this.prev&&r.call(o,"finallyLoc")&&this.prev<o.finallyLoc){var a=o;break}}a&&("break"===t||"continue"===t)&&a.tryLoc<=e&&e<=a.finallyLoc&&(a=null);var i=a?a.completion:{};return i.type=t,i.arg=e,a?(this.method="next",this.next=a.finallyLoc,d):this.complete(i)},complete:function(t,e){if("throw"===t.type)throw t.arg;return"break"===t.type||"continue"===t.type?this.next=t.arg:"return"===t.type?(this.rval=this.arg=t.arg,this.method="return",this.next="end"):"normal"===t.type&&e&&(this.next=e),d},finish:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var n=this.tryEntries[e];if(n.finallyLoc===t)return this.complete(n.completion,n.afterLoc),O(n),d}},catch:function(t){for(var e=this.tryEntries.length-1;e>=0;--e){var n=this.tryEntries[e];if(n.tryLoc===t){var r=n.completion;if("throw"===r.type){var o=r.arg;O(n)}return o}}throw new Error("illegal catch attempt")},delegateYield:function(t,n,r){return this.delegate={iterator:A(t),resultName:n,nextLoc:r},"next"===this.method&&(this.arg=e),d}},t})(t.exports);try{regeneratorRuntime=e}catch(t){"object"==typeof globalThis?globalThis.regeneratorRuntime=e:Function("r","regeneratorRuntime = r")(e)}},6310:(t,e,n)=>{"use strict";t.exports=n.p+"4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm"}},e={};function n(r){var o=e[r];if(void 0!==o)return o.exports;var a=e[r]={exports:{}};return t[r](a,a.exports,n),a.exports}n.g=(function(){if("object"==typeof globalThis)return globalThis;try{return this||new Function("return this")()}catch(t){if("object"==typeof window)return window}})(),(()=>{var t;n.g.importScripts&&(t=n.g.location+"");var e=n.g.document;if(!t&&e&&(e.currentScript&&(t=e.currentScript.src),!t)){var r=e.getElementsByTagName("script");r.length&&(t=r[r.length-1].src)}if(!t)throw new Error("Automatic publicPath is not supported in this browser");t=t.replace(/#.*$/,"").replace(/\?.*$/,"").replace(/\/[^\/]+$/,"/"),n.p=t+"../../"})(),(()=>{"use strict";var t=n(5318),e=t(n(7757)),r=t(n(8926)),o=new(n(6553))(self,self);self.init=(function(){var t=(0,r.default)(e.default.mark((function t(a){var i,u,c,s,f,_,l,b,g,d;return e.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return i=a.appVersion,u=a.shellVersion,self.document={baseURI:self.location.href},self.app_version=i,self.shell_version=u,self.get_location_hash=(0,r.default)(e.default.mark((function t(){return e.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",o.call(["location","hash"],[]));case 1:case"end":return t.stop()}}),t)}))),self.local_storage_get_item=(function(){var t=(0,r.default)(e.default.mark((function t(n){return e.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",o.call(["localStorage","getItem"],[n]));case 1:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}})(),self.local_storage_set_item=(function(){var t=(0,r.default)(e.default.mark((function t(n,r){return e.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",o.call(["localStorage","setItem"],[n,r]));case 1:case"end":return t.stop()}}),t)})));return function(e,n){return t.apply(this,arguments)}})(),self.local_storage_remove_item=(function(){var t=(0,r.default)(e.default.mark((function t(n){return e.default.wrap((function(t){for(;;)switch(t.prev=t.next){case 0:return t.abrupt("return",o.call(["localStorage","removeItem"],[n]));case 1:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}})(),c=n(6489),s=c.default,f=c.initialize_runtime,_=c.get_state,l=c.get_debug_state,b=c.dispatch,g=c.analytics,d=c.decode_stream,self.getState=_,self.getDebugState=l,self.dispatch=b,self.analytics=g,self.decodeStream=d,t.next=16,s(n(6310));case 16:return t.next=18,f((function(t){return o.call(["onCoreEvent"],[t])}));case 18:case"end":return t.stop()}}),t)})));return function(e){return t.apply(this,arguments)}})()})()})(); +//# sourceMappingURL=worker.js.map \ No newline at end of file diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js.map b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js.map new file mode 100644 index 000000000..e3f05c53f --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js.map @@ -0,0 +1 @@ +{"version":3,"file":"4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js","mappings":"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","sources":["webpack://stremio/./node_modules/@babel/runtime/helpers/asyncToGenerator.js","webpack://stremio/./node_modules/@babel/runtime/helpers/interopRequireDefault.js","webpack://stremio/./node_modules/@babel/runtime/helpers/typeof.js","webpack://stremio/./node_modules/@babel/runtime/regenerator/index.js","webpack://stremio/./node_modules/@stremio/stremio-core-web/bridge.js","webpack://stremio/./node_modules/@stremio/stremio-core-web/stremio_core_web.js","webpack://stremio/./node_modules/regenerator-runtime/runtime.js","webpack://stremio/webpack/bootstrap","webpack://stremio/webpack/runtime/global","webpack://stremio/webpack/runtime/publicPath","webpack://stremio/./node_modules/@stremio/stremio-core-web/worker.js"],"sourcesContent":["function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {\n try {\n var info = gen[key](arg);\n var value = info.value;\n } catch (error) {\n reject(error);\n return;\n }\n\n if (info.done) {\n resolve(value);\n } else {\n Promise.resolve(value).then(_next, _throw);\n }\n}\n\nfunction _asyncToGenerator(fn) {\n return function () {\n var self = this,\n args = arguments;\n return new Promise(function (resolve, reject) {\n var gen = fn.apply(self, args);\n\n function _next(value) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"next\", value);\n }\n\n function _throw(err) {\n asyncGeneratorStep(gen, resolve, reject, _next, _throw, \"throw\", err);\n }\n\n _next(undefined);\n });\n };\n}\n\nmodule.exports = _asyncToGenerator;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _interopRequireDefault(obj) {\n return obj && obj.__esModule ? obj : {\n \"default\": obj\n };\n}\n\nmodule.exports = _interopRequireDefault;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","function _typeof(obj) {\n \"@babel/helpers - typeof\";\n\n if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj;\n };\n\n module.exports[\"default\"] = module.exports, module.exports.__esModule = true;\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;\nmodule.exports[\"default\"] = module.exports, module.exports.__esModule = true;","module.exports = require(\"regenerator-runtime\");\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nfunction getId() {\n return Math.random().toString(32).slice(2);\n}\n\nfunction Bridge(scope, handler) {\n handler.addEventListener('message', /*#__PURE__*/function () {\n var _ref2 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee(_ref) {\n var request, id, path, args, value, data, thisArg;\n return _regenerator[\"default\"].wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n request = _ref.data.request;\n\n if (request) {\n _context.next = 3;\n break;\n }\n\n return _context.abrupt(\"return\");\n\n case 3:\n id = request.id, path = request.path, args = request.args;\n _context.prev = 4;\n value = path.reduce(function (value, prop) {\n return value[prop];\n }, scope);\n\n if (!(typeof value === 'function')) {\n _context.next = 13;\n break;\n }\n\n thisArg = path.slice(0, path.length - 1).reduce(function (value, prop) {\n return value[prop];\n }, scope);\n _context.next = 10;\n return value.apply(thisArg, args);\n\n case 10:\n data = _context.sent;\n _context.next = 16;\n break;\n\n case 13:\n _context.next = 15;\n return value;\n\n case 15:\n data = _context.sent;\n\n case 16:\n handler.postMessage({\n response: {\n id: id,\n result: {\n data: data\n }\n }\n });\n _context.next = 22;\n break;\n\n case 19:\n _context.prev = 19;\n _context.t0 = _context[\"catch\"](4);\n handler.postMessage({\n response: {\n id: id,\n result: {\n error: _context.t0\n }\n }\n });\n\n case 22:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[4, 19]]);\n }));\n\n return function (_x) {\n return _ref2.apply(this, arguments);\n };\n }());\n\n this.call = /*#__PURE__*/function () {\n var _ref3 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee2(path, args) {\n var id;\n return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n id = getId();\n return _context2.abrupt(\"return\", new Promise(function (resolve, reject) {\n var onMessage = function onMessage(_ref4) {\n var response = _ref4.data.response;\n if (!response || response.id !== id) return;\n handler.removeEventListener('message', onMessage);\n\n if ('error' in response.result) {\n reject(response.result.error);\n } else {\n resolve(response.result.data);\n }\n };\n\n handler.addEventListener('message', onMessage);\n handler.postMessage({\n request: {\n id: id,\n path: path,\n args: args\n }\n });\n }));\n\n case 2:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n\n return function (_x2, _x3) {\n return _ref3.apply(this, arguments);\n };\n }();\n}\n\nmodule.exports = Bridge;\n","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.analytics = analytics;\nexports.decode_stream = decode_stream;\nexports[\"default\"] = void 0;\nexports.dispatch = dispatch;\nexports.get_state = get_state;\nexports.initialize_runtime = initialize_runtime;\nexports.start = start;\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nvar _typeof2 = _interopRequireDefault(require(\"@babel/runtime/helpers/typeof\"));\n\nvar importMeta = {\n url: new URL('/stremio_core_web.js', document.baseURI).href\n};\nvar wasm;\nvar heap = new Array(32).fill(undefined);\nheap.push(undefined, null, true, false);\n\nfunction getObject(idx) {\n return heap[idx];\n}\n\nvar heap_next = heap.length;\n\nfunction dropObject(idx) {\n if (idx < 36) return;\n heap[idx] = heap_next;\n heap_next = idx;\n}\n\nfunction takeObject(idx) {\n var ret = getObject(idx);\n dropObject(idx);\n return ret;\n}\n\nvar cachedTextDecoder = new TextDecoder('utf-8', {\n ignoreBOM: true,\n fatal: true\n});\ncachedTextDecoder.decode();\nvar cachegetUint8Memory0 = null;\n\nfunction getUint8Memory0() {\n if (cachegetUint8Memory0 === null || cachegetUint8Memory0.buffer !== wasm.memory.buffer) {\n cachegetUint8Memory0 = new Uint8Array(wasm.memory.buffer);\n }\n\n return cachegetUint8Memory0;\n}\n\nfunction getStringFromWasm0(ptr, len) {\n return cachedTextDecoder.decode(getUint8Memory0().subarray(ptr, ptr + len));\n}\n\nfunction addHeapObject(obj) {\n if (heap_next === heap.length) heap.push(heap.length + 1);\n var idx = heap_next;\n heap_next = heap[idx];\n heap[idx] = obj;\n return idx;\n}\n\nvar WASM_VECTOR_LEN = 0;\nvar cachedTextEncoder = new TextEncoder('utf-8');\nvar encodeString = typeof cachedTextEncoder.encodeInto === 'function' ? function (arg, view) {\n return cachedTextEncoder.encodeInto(arg, view);\n} : function (arg, view) {\n var buf = cachedTextEncoder.encode(arg);\n view.set(buf);\n return {\n read: arg.length,\n written: buf.length\n };\n};\n\nfunction passStringToWasm0(arg, malloc, realloc) {\n if (realloc === undefined) {\n var buf = cachedTextEncoder.encode(arg);\n\n var _ptr = malloc(buf.length);\n\n getUint8Memory0().subarray(_ptr, _ptr + buf.length).set(buf);\n WASM_VECTOR_LEN = buf.length;\n return _ptr;\n }\n\n var len = arg.length;\n var ptr = malloc(len);\n var mem = getUint8Memory0();\n var offset = 0;\n\n for (; offset < len; offset++) {\n var code = arg.charCodeAt(offset);\n if (code > 0x7F) break;\n mem[ptr + offset] = code;\n }\n\n if (offset !== len) {\n if (offset !== 0) {\n arg = arg.slice(offset);\n }\n\n ptr = realloc(ptr, len, len = offset + arg.length * 3);\n var view = getUint8Memory0().subarray(ptr + offset, ptr + len);\n var ret = encodeString(arg, view);\n offset += ret.written;\n }\n\n WASM_VECTOR_LEN = offset;\n return ptr;\n}\n\nfunction isLikeNone(x) {\n return x === undefined || x === null;\n}\n\nvar cachegetInt32Memory0 = null;\n\nfunction getInt32Memory0() {\n if (cachegetInt32Memory0 === null || cachegetInt32Memory0.buffer !== wasm.memory.buffer) {\n cachegetInt32Memory0 = new Int32Array(wasm.memory.buffer);\n }\n\n return cachegetInt32Memory0;\n}\n\nfunction debugString(val) {\n // primitive types\n var type = (0, _typeof2[\"default\"])(val);\n\n if (type == 'number' || type == 'boolean' || val == null) {\n return \"\".concat(val);\n }\n\n if (type == 'string') {\n return \"\\\"\".concat(val, \"\\\"\");\n }\n\n if (type == 'symbol') {\n var description = val.description;\n\n if (description == null) {\n return 'Symbol';\n } else {\n return \"Symbol(\".concat(description, \")\");\n }\n }\n\n if (type == 'function') {\n var name = val.name;\n\n if (typeof name == 'string' && name.length > 0) {\n return \"Function(\".concat(name, \")\");\n } else {\n return 'Function';\n }\n } // objects\n\n\n if (Array.isArray(val)) {\n var length = val.length;\n var debug = '[';\n\n if (length > 0) {\n debug += debugString(val[0]);\n }\n\n for (var i = 1; i < length; i++) {\n debug += ', ' + debugString(val[i]);\n }\n\n debug += ']';\n return debug;\n } // Test for built-in\n\n\n var builtInMatches = /\\[object ([^\\]]+)\\]/.exec(toString.call(val));\n var className;\n\n if (builtInMatches.length > 1) {\n className = builtInMatches[1];\n } else {\n // Failed to match the standard '[object ClassName]'\n return toString.call(val);\n }\n\n if (className == 'Object') {\n // we're a user defined class or Object\n // JSON.stringify avoids problems with cycles, and is generally much\n // easier than looping through ownProperties of `val`.\n try {\n return 'Object(' + JSON.stringify(val) + ')';\n } catch (_) {\n return 'Object';\n }\n } // errors\n\n\n if (val instanceof Error) {\n return \"\".concat(val.name, \": \").concat(val.message, \"\\n\").concat(val.stack);\n } // TODO we could test for more things here, like `Set`s and `Map`s.\n\n\n return className;\n}\n\nfunction makeMutClosure(arg0, arg1, dtor, f) {\n var state = {\n a: arg0,\n b: arg1,\n cnt: 1,\n dtor: dtor\n };\n\n var real = function real() {\n // First up with a closure we increment the internal reference\n // count. This ensures that the Rust closure environment won't\n // be deallocated while we're invoking it.\n state.cnt++;\n var a = state.a;\n state.a = 0;\n\n try {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n return f.apply(void 0, [a, state.b].concat(args));\n } finally {\n if (--state.cnt === 0) {\n wasm.__wbindgen_export_2.get(state.dtor)(a, state.b);\n } else {\n state.a = a;\n }\n }\n };\n\n real.original = state;\n return real;\n}\n\nfunction __wbg_adapter_30(arg0, arg1) {\n wasm._dyn_core__ops__function__FnMut_____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h1a6784ec167a5430(arg0, arg1);\n}\n\nfunction __wbg_adapter_33(arg0, arg1, arg2) {\n wasm._dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hdf2bb55ffabdfc36(arg0, arg1, addHeapObject(arg2));\n}\n\nfunction handleError(f, args) {\n try {\n return f.apply(this, args);\n } catch (e) {\n wasm.__wbindgen_exn_store(addHeapObject(e));\n }\n}\n\nfunction getArrayU8FromWasm0(ptr, len) {\n return getUint8Memory0().subarray(ptr / 1, ptr / 1 + len);\n}\n\nfunction __wbg_adapter_70(arg0, arg1, arg2, arg3) {\n wasm.wasm_bindgen__convert__closures__invoke2_mut__h23a6b10e1d576a11(arg0, arg1, addHeapObject(arg2), addHeapObject(arg3));\n}\n/**\n*/\n\n\nfunction start() {\n wasm.start();\n}\n/**\n* @param {Function} emit_to_ui\n* @returns {Promise<void>}\n*/\n\n\nfunction initialize_runtime(emit_to_ui) {\n var ret = wasm.initialize_runtime(addHeapObject(emit_to_ui));\n return takeObject(ret);\n}\n/**\n* @param {any} field\n* @returns {any}\n*/\n\n\nfunction get_state(field) {\n var ret = wasm.get_state(addHeapObject(field));\n return takeObject(ret);\n}\n/**\n* @param {any} action\n* @param {any} field\n* @param {any} location_hash\n*/\n\n\nfunction dispatch(action, field, location_hash) {\n wasm.dispatch(addHeapObject(action), addHeapObject(field), addHeapObject(location_hash));\n}\n/**\n* @param {any} event\n* @param {any} location_hash\n*/\n\n\nfunction analytics(event, location_hash) {\n wasm.analytics(addHeapObject(event), addHeapObject(location_hash));\n}\n/**\n* @param {any} stream\n* @returns {any}\n*/\n\n\nfunction decode_stream(stream) {\n var ret = wasm.decode_stream(addHeapObject(stream));\n return takeObject(ret);\n}\n\nfunction load(_x, _x2) {\n return _load.apply(this, arguments);\n}\n\nfunction _load() {\n _load = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee(module, imports) {\n var bytes, instance;\n return _regenerator[\"default\"].wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n if (!(typeof Response === 'function' && module instanceof Response)) {\n _context.next = 23;\n break;\n }\n\n if (!(typeof WebAssembly.instantiateStreaming === 'function')) {\n _context.next = 15;\n break;\n }\n\n _context.prev = 2;\n _context.next = 5;\n return WebAssembly.instantiateStreaming(module, imports);\n\n case 5:\n return _context.abrupt(\"return\", _context.sent);\n\n case 8:\n _context.prev = 8;\n _context.t0 = _context[\"catch\"](2);\n\n if (!(module.headers.get('Content-Type') != 'application/wasm')) {\n _context.next = 14;\n break;\n }\n\n console.warn(\"`WebAssembly.instantiateStreaming` failed because your server does not serve wasm with `application/wasm` MIME type. Falling back to `WebAssembly.instantiate` which is slower. Original error:\\n\", _context.t0);\n _context.next = 15;\n break;\n\n case 14:\n throw _context.t0;\n\n case 15:\n _context.next = 17;\n return module.arrayBuffer();\n\n case 17:\n bytes = _context.sent;\n _context.next = 20;\n return WebAssembly.instantiate(bytes, imports);\n\n case 20:\n return _context.abrupt(\"return\", _context.sent);\n\n case 23:\n _context.next = 25;\n return WebAssembly.instantiate(module, imports);\n\n case 25:\n instance = _context.sent;\n\n if (!(instance instanceof WebAssembly.Instance)) {\n _context.next = 30;\n break;\n }\n\n return _context.abrupt(\"return\", {\n instance: instance,\n module: module\n });\n\n case 30:\n return _context.abrupt(\"return\", instance);\n\n case 31:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee, null, [[2, 8]]);\n }));\n return _load.apply(this, arguments);\n}\n\nfunction init(_x3) {\n return _init.apply(this, arguments);\n}\n\nfunction _init() {\n _init = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee2(input) {\n var imports, _yield$load, instance, module;\n\n return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n if (typeof input === 'undefined') {\n input = new URL('stremio_core_web_bg.wasm', importMeta.url);\n }\n\n imports = {};\n imports.wbg = {};\n\n imports.wbg.__wbg_new_693216e109162396 = function () {\n var ret = new Error();\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_stack_0ddaca5d1abfb52f = function (arg0, arg1) {\n var ret = getObject(arg1).stack;\n var ptr0 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_error_09919627ac0992f5 = function (arg0, arg1) {\n try {\n console.error(getStringFromWasm0(arg0, arg1));\n } finally {\n wasm.__wbindgen_free(arg0, arg1);\n }\n };\n\n imports.wbg.__wbindgen_object_drop_ref = function (arg0) {\n takeObject(arg0);\n };\n\n imports.wbg.__wbg_crypto_8fd02d72c4ba6c5c = function (arg0) {\n var ret = getObject(arg0).crypto;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbindgen_is_object = function (arg0) {\n var val = getObject(arg0);\n var ret = (0, _typeof2[\"default\"])(val) === 'object' && val !== null;\n return ret;\n };\n\n imports.wbg.__wbg_process_bd02d71a65cf734c = function (arg0) {\n var ret = getObject(arg0).process;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_versions_1d70d407cb23129d = function (arg0) {\n var ret = getObject(arg0).versions;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_node_0091cdf1ffa73e4d = function (arg0) {\n var ret = getObject(arg0).node;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbindgen_is_string = function (arg0) {\n var ret = typeof getObject(arg0) === 'string';\n return ret;\n };\n\n imports.wbg.__wbg_require_b06abd91965488c8 = function () {\n return handleError(function () {\n var ret = module.require;\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbindgen_is_function = function (arg0) {\n var ret = typeof getObject(arg0) === 'function';\n return ret;\n };\n\n imports.wbg.__wbindgen_string_new = function (arg0, arg1) {\n var ret = getStringFromWasm0(arg0, arg1);\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_msCrypto_7e1e6014bddd75de = function (arg0) {\n var ret = getObject(arg0).msCrypto;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_newwithlength_929232475839a482 = function (arg0) {\n var ret = new Uint8Array(arg0 >>> 0);\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbindgen_object_clone_ref = function (arg0) {\n var ret = getObject(arg0);\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_self_c6fbdfc2918d5e58 = function () {\n return handleError(function () {\n var ret = self.self;\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_window_baec038b5ab35c54 = function () {\n return handleError(function () {\n var ret = window.window;\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_globalThis_3f735a5746d41fbd = function () {\n return handleError(function () {\n var ret = globalThis.globalThis;\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_global_1bc0b39582740e95 = function () {\n return handleError(function () {\n var ret = global.global;\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbindgen_is_undefined = function (arg0) {\n var ret = getObject(arg0) === undefined;\n return ret;\n };\n\n imports.wbg.__wbg_newnoargs_be86524d73f67598 = function (arg0, arg1) {\n var ret = new Function(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_call_888d259a5fefc347 = function () {\n return handleError(function (arg0, arg1) {\n var ret = getObject(arg0).call(getObject(arg1));\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_call_346669c262382ad7 = function () {\n return handleError(function (arg0, arg1, arg2) {\n var ret = getObject(arg0).call(getObject(arg1), getObject(arg2));\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbindgen_string_get = function (arg0, arg1) {\n var obj = getObject(arg1);\n var ret = typeof obj === 'string' ? obj : undefined;\n var ptr0 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_set_82a4e8a85e31ac42 = function () {\n return handleError(function (arg0, arg1, arg2) {\n var ret = Reflect.set(getObject(arg0), getObject(arg1), getObject(arg2));\n return ret;\n }, arguments);\n };\n\n imports.wbg.__wbg_now_af172eabe2e041ad = function () {\n var ret = Date.now();\n return ret;\n };\n\n imports.wbg.__wbg_randomFillSync_f20541303a990429 = function () {\n return handleError(function (arg0, arg1, arg2) {\n getObject(arg0).randomFillSync(getArrayU8FromWasm0(arg1, arg2));\n }, arguments);\n };\n\n imports.wbg.__wbg_subarray_8b658422a224f479 = function (arg0, arg1, arg2) {\n var ret = getObject(arg0).subarray(arg1 >>> 0, arg2 >>> 0);\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_getRandomValues_f308e7233e5601b7 = function () {\n return handleError(function (arg0, arg1) {\n getObject(arg0).getRandomValues(getObject(arg1));\n }, arguments);\n };\n\n imports.wbg.__wbg_length_1eb8fc608a0d4cdb = function (arg0) {\n var ret = getObject(arg0).length;\n return ret;\n };\n\n imports.wbg.__wbindgen_memory = function () {\n var ret = wasm.memory;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_buffer_397eaa4d72ee94dd = function (arg0) {\n var ret = getObject(arg0).buffer;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_new_a7ce447f15ff496f = function (arg0) {\n var ret = new Uint8Array(getObject(arg0));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_set_969ad0a60e51d320 = function (arg0, arg1, arg2) {\n getObject(arg0).set(getObject(arg1), arg2 >>> 0);\n };\n\n imports.wbg.__wbindgen_json_serialize = function (arg0, arg1) {\n var obj = getObject(arg1);\n var ret = JSON.stringify(obj === undefined ? null : obj);\n var ptr0 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_instanceof_WorkerGlobalScope_f191ca0158f5637b = function (arg0) {\n var ret = getObject(arg0) instanceof WorkerGlobalScope;\n return ret;\n };\n\n imports.wbg.__wbg_static_accessor_app_version_0d438539d98a0943 = function (arg0) {\n var ret = self.app_version;\n var ptr0 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_static_accessor_shell_version_1f62a14e53964af1 = function (arg0) {\n var ret = self.shell_version;\n var ptr0 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_navigator_8bc0889cda8f8500 = function (arg0) {\n var ret = getObject(arg0).navigator;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_language_cd6e22892ba36a1f = function (arg0, arg1) {\n var ret = getObject(arg1).language;\n var ptr0 = isLikeNone(ret) ? 0 : passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbg_new_b1d61b5687f5e73a = function (arg0, arg1) {\n try {\n var state0 = {\n a: arg0,\n b: arg1\n };\n\n var cb0 = function cb0(arg0, arg1) {\n var a = state0.a;\n state0.a = 0;\n\n try {\n return __wbg_adapter_70(a, state0.b, arg0, arg1);\n } finally {\n state0.a = a;\n }\n };\n\n var ret = new Promise(cb0);\n return addHeapObject(ret);\n } finally {\n state0.a = state0.b = 0;\n }\n };\n\n imports.wbg.__wbindgen_json_parse = function (arg0, arg1) {\n var ret = JSON.parse(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_new_0b83d3df67ecb33e = function () {\n var ret = new Object();\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_fetch_b4e81012e07ff95a = function (arg0, arg1) {\n var ret = getObject(arg0).fetch(getObject(arg1));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_getlocationhash_97299d3c8a498b17 = function () {\n return handleError(function () {\n var ret = self.get_location_hash();\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_instanceof_Error_561efcb1265706d8 = function (arg0) {\n var ret = getObject(arg0) instanceof Error;\n return ret;\n };\n\n imports.wbg.__wbg_message_9f7d15ff97fc4102 = function (arg0) {\n var ret = getObject(arg0).message;\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_instanceof_Response_e1b11afbefa5b563 = function (arg0) {\n var ret = getObject(arg0) instanceof Response;\n return ret;\n };\n\n imports.wbg.__wbg_status_6d8bb444ddc5a7b2 = function (arg0) {\n var ret = getObject(arg0).status;\n return ret;\n };\n\n imports.wbg.__wbg_setInterval_a02797f5ab1c7eb1 = function () {\n return handleError(function (arg0, arg1, arg2) {\n var ret = getObject(arg0).setInterval(getObject(arg1), arg2);\n return ret;\n }, arguments);\n };\n\n imports.wbg.__wbg_localstorageremoveitem_8ad2d96138ff136a = function () {\n return handleError(function (arg0, arg1) {\n try {\n var ret = self.local_storage_remove_item(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n } finally {\n wasm.__wbindgen_free(arg0, arg1);\n }\n }, arguments);\n };\n\n imports.wbg.__wbg_localstoragesetitem_7d75d2eac814d3d8 = function () {\n return handleError(function (arg0, arg1, arg2, arg3) {\n try {\n var ret = self.local_storage_set_item(getStringFromWasm0(arg0, arg1), getStringFromWasm0(arg2, arg3));\n return addHeapObject(ret);\n } finally {\n wasm.__wbindgen_free(arg0, arg1);\n\n wasm.__wbindgen_free(arg2, arg3);\n }\n }, arguments);\n };\n\n imports.wbg.__wbg_localstoragegetitem_318a1e7771661e01 = function () {\n return handleError(function (arg0, arg1) {\n try {\n var ret = self.local_storage_get_item(getStringFromWasm0(arg0, arg1));\n return addHeapObject(ret);\n } finally {\n wasm.__wbindgen_free(arg0, arg1);\n }\n }, arguments);\n };\n\n imports.wbg.__wbindgen_debug_string = function (arg0, arg1) {\n var ret = debugString(getObject(arg1));\n var ptr0 = passStringToWasm0(ret, wasm.__wbindgen_malloc, wasm.__wbindgen_realloc);\n var len0 = WASM_VECTOR_LEN;\n getInt32Memory0()[arg0 / 4 + 1] = len0;\n getInt32Memory0()[arg0 / 4 + 0] = ptr0;\n };\n\n imports.wbg.__wbindgen_throw = function (arg0, arg1) {\n throw new Error(getStringFromWasm0(arg0, arg1));\n };\n\n imports.wbg.__wbg_then_8c2d62e8ae5978f7 = function (arg0, arg1, arg2) {\n var ret = getObject(arg0).then(getObject(arg1), getObject(arg2));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_then_2fcac196782070cc = function (arg0, arg1) {\n var ret = getObject(arg0).then(getObject(arg1));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbg_resolve_d23068002f584f22 = function (arg0) {\n var ret = Promise.resolve(getObject(arg0));\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbindgen_cb_drop = function (arg0) {\n var obj = takeObject(arg0).original;\n\n if (obj.cnt-- == 1) {\n obj.a = 0;\n return true;\n }\n\n var ret = false;\n return ret;\n };\n\n imports.wbg.__wbg_newwithstrandinit_9b0fa00478c37287 = function () {\n return handleError(function (arg0, arg1, arg2) {\n var ret = new Request(getStringFromWasm0(arg0, arg1), getObject(arg2));\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbg_json_88cc6d5cf8f61121 = function () {\n return handleError(function (arg0) {\n var ret = getObject(arg0).json();\n return addHeapObject(ret);\n }, arguments);\n };\n\n imports.wbg.__wbindgen_closure_wrapper4955 = function (arg0, arg1, arg2) {\n var ret = makeMutClosure(arg0, arg1, 127, __wbg_adapter_30);\n return addHeapObject(ret);\n };\n\n imports.wbg.__wbindgen_closure_wrapper5985 = function (arg0, arg1, arg2) {\n var ret = makeMutClosure(arg0, arg1, 134, __wbg_adapter_33);\n return addHeapObject(ret);\n };\n\n if (typeof input === 'string' || typeof Request === 'function' && input instanceof Request || typeof URL === 'function' && input instanceof URL) {\n input = fetch(input);\n }\n\n _context2.t0 = load;\n _context2.next = 71;\n return input;\n\n case 71:\n _context2.t1 = _context2.sent;\n _context2.t2 = imports;\n _context2.next = 75;\n return (0, _context2.t0)(_context2.t1, _context2.t2);\n\n case 75:\n _yield$load = _context2.sent;\n instance = _yield$load.instance;\n module = _yield$load.module;\n wasm = instance.exports;\n init.__wbindgen_wasm_module = module;\n\n wasm.__wbindgen_start();\n\n return _context2.abrupt(\"return\", wasm);\n\n case 82:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n return _init.apply(this, arguments);\n}\n\nvar _default = init;\nexports[\"default\"] = _default;\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nvar runtime = (function (exports) {\n \"use strict\";\n\n var Op = Object.prototype;\n var hasOwn = Op.hasOwnProperty;\n var defineProperty = Object.defineProperty || function (obj, key, desc) { obj[key] = desc.value; };\n var undefined; // More compressible than void 0.\n var $Symbol = typeof Symbol === \"function\" ? Symbol : {};\n var iteratorSymbol = $Symbol.iterator || \"@@iterator\";\n var asyncIteratorSymbol = $Symbol.asyncIterator || \"@@asyncIterator\";\n var toStringTagSymbol = $Symbol.toStringTag || \"@@toStringTag\";\n\n function define(obj, key, value) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n return obj[key];\n }\n try {\n // IE 8 has a broken Object.defineProperty that only works on DOM objects.\n define({}, \"\");\n } catch (err) {\n define = function(obj, key, value) {\n return obj[key] = value;\n };\n }\n\n function wrap(innerFn, outerFn, self, tryLocsList) {\n // If outerFn provided and outerFn.prototype is a Generator, then outerFn.prototype instanceof Generator.\n var protoGenerator = outerFn && outerFn.prototype instanceof Generator ? outerFn : Generator;\n var generator = Object.create(protoGenerator.prototype);\n var context = new Context(tryLocsList || []);\n\n // The ._invoke method unifies the implementations of the .next,\n // .throw, and .return methods.\n defineProperty(generator, \"_invoke\", { value: makeInvokeMethod(innerFn, self, context) });\n\n return generator;\n }\n exports.wrap = wrap;\n\n // Try/catch helper to minimize deoptimizations. Returns a completion\n // record like context.tryEntries[i].completion. This interface could\n // have been (and was previously) designed to take a closure to be\n // invoked without arguments, but in all the cases we care about we\n // already have an existing method we want to call, so there's no need\n // to create a new function object. We can even get away with assuming\n // the method takes exactly one argument, since that happens to be true\n // in every case, so we don't have to touch the arguments object. The\n // only additional allocation required is the completion record, which\n // has a stable shape and so hopefully should be cheap to allocate.\n function tryCatch(fn, obj, arg) {\n try {\n return { type: \"normal\", arg: fn.call(obj, arg) };\n } catch (err) {\n return { type: \"throw\", arg: err };\n }\n }\n\n var GenStateSuspendedStart = \"suspendedStart\";\n var GenStateSuspendedYield = \"suspendedYield\";\n var GenStateExecuting = \"executing\";\n var GenStateCompleted = \"completed\";\n\n // Returning this object from the innerFn has the same effect as\n // breaking out of the dispatch switch statement.\n var ContinueSentinel = {};\n\n // Dummy constructor functions that we use as the .constructor and\n // .constructor.prototype properties for functions that return Generator\n // objects. For full spec compliance, you may wish to configure your\n // minifier not to mangle the names of these two functions.\n function Generator() {}\n function GeneratorFunction() {}\n function GeneratorFunctionPrototype() {}\n\n // This is a polyfill for %IteratorPrototype% for environments that\n // don't natively support it.\n var IteratorPrototype = {};\n define(IteratorPrototype, iteratorSymbol, function () {\n return this;\n });\n\n var getProto = Object.getPrototypeOf;\n var NativeIteratorPrototype = getProto && getProto(getProto(values([])));\n if (NativeIteratorPrototype &&\n NativeIteratorPrototype !== Op &&\n hasOwn.call(NativeIteratorPrototype, iteratorSymbol)) {\n // This environment has a native %IteratorPrototype%; use it instead\n // of the polyfill.\n IteratorPrototype = NativeIteratorPrototype;\n }\n\n var Gp = GeneratorFunctionPrototype.prototype =\n Generator.prototype = Object.create(IteratorPrototype);\n GeneratorFunction.prototype = GeneratorFunctionPrototype;\n defineProperty(Gp, \"constructor\", { value: GeneratorFunctionPrototype, configurable: true });\n defineProperty(\n GeneratorFunctionPrototype,\n \"constructor\",\n { value: GeneratorFunction, configurable: true }\n );\n GeneratorFunction.displayName = define(\n GeneratorFunctionPrototype,\n toStringTagSymbol,\n \"GeneratorFunction\"\n );\n\n // Helper for defining the .next, .throw, and .return methods of the\n // Iterator interface in terms of a single ._invoke method.\n function defineIteratorMethods(prototype) {\n [\"next\", \"throw\", \"return\"].forEach(function(method) {\n define(prototype, method, function(arg) {\n return this._invoke(method, arg);\n });\n });\n }\n\n exports.isGeneratorFunction = function(genFun) {\n var ctor = typeof genFun === \"function\" && genFun.constructor;\n return ctor\n ? ctor === GeneratorFunction ||\n // For the native GeneratorFunction constructor, the best we can\n // do is to check its .name property.\n (ctor.displayName || ctor.name) === \"GeneratorFunction\"\n : false;\n };\n\n exports.mark = function(genFun) {\n if (Object.setPrototypeOf) {\n Object.setPrototypeOf(genFun, GeneratorFunctionPrototype);\n } else {\n genFun.__proto__ = GeneratorFunctionPrototype;\n define(genFun, toStringTagSymbol, \"GeneratorFunction\");\n }\n genFun.prototype = Object.create(Gp);\n return genFun;\n };\n\n // Within the body of any async function, `await x` is transformed to\n // `yield regeneratorRuntime.awrap(x)`, so that the runtime can test\n // `hasOwn.call(value, \"__await\")` to determine if the yielded value is\n // meant to be awaited.\n exports.awrap = function(arg) {\n return { __await: arg };\n };\n\n function AsyncIterator(generator, PromiseImpl) {\n function invoke(method, arg, resolve, reject) {\n var record = tryCatch(generator[method], generator, arg);\n if (record.type === \"throw\") {\n reject(record.arg);\n } else {\n var result = record.arg;\n var value = result.value;\n if (value &&\n typeof value === \"object\" &&\n hasOwn.call(value, \"__await\")) {\n return PromiseImpl.resolve(value.__await).then(function(value) {\n invoke(\"next\", value, resolve, reject);\n }, function(err) {\n invoke(\"throw\", err, resolve, reject);\n });\n }\n\n return PromiseImpl.resolve(value).then(function(unwrapped) {\n // When a yielded Promise is resolved, its final value becomes\n // the .value of the Promise<{value,done}> result for the\n // current iteration.\n result.value = unwrapped;\n resolve(result);\n }, function(error) {\n // If a rejected Promise was yielded, throw the rejection back\n // into the async generator function so it can be handled there.\n return invoke(\"throw\", error, resolve, reject);\n });\n }\n }\n\n var previousPromise;\n\n function enqueue(method, arg) {\n function callInvokeWithMethodAndArg() {\n return new PromiseImpl(function(resolve, reject) {\n invoke(method, arg, resolve, reject);\n });\n }\n\n return previousPromise =\n // If enqueue has been called before, then we want to wait until\n // all previous Promises have been resolved before calling invoke,\n // so that results are always delivered in the correct order. If\n // enqueue has not been called before, then it is important to\n // call invoke immediately, without waiting on a callback to fire,\n // so that the async generator function has the opportunity to do\n // any necessary setup in a predictable way. This predictability\n // is why the Promise constructor synchronously invokes its\n // executor callback, and why async functions synchronously\n // execute code before the first await. Since we implement simple\n // async functions in terms of async generators, it is especially\n // important to get this right, even though it requires care.\n previousPromise ? previousPromise.then(\n callInvokeWithMethodAndArg,\n // Avoid propagating failures to Promises returned by later\n // invocations of the iterator.\n callInvokeWithMethodAndArg\n ) : callInvokeWithMethodAndArg();\n }\n\n // Define the unified helper method that is used to implement .next,\n // .throw, and .return (see defineIteratorMethods).\n defineProperty(this, \"_invoke\", { value: enqueue });\n }\n\n defineIteratorMethods(AsyncIterator.prototype);\n define(AsyncIterator.prototype, asyncIteratorSymbol, function () {\n return this;\n });\n exports.AsyncIterator = AsyncIterator;\n\n // Note that simple async functions are implemented on top of\n // AsyncIterator objects; they just return a Promise for the value of\n // the final result produced by the iterator.\n exports.async = function(innerFn, outerFn, self, tryLocsList, PromiseImpl) {\n if (PromiseImpl === void 0) PromiseImpl = Promise;\n\n var iter = new AsyncIterator(\n wrap(innerFn, outerFn, self, tryLocsList),\n PromiseImpl\n );\n\n return exports.isGeneratorFunction(outerFn)\n ? iter // If outerFn is a generator, return the full iterator.\n : iter.next().then(function(result) {\n return result.done ? result.value : iter.next();\n });\n };\n\n function makeInvokeMethod(innerFn, self, context) {\n var state = GenStateSuspendedStart;\n\n return function invoke(method, arg) {\n if (state === GenStateExecuting) {\n throw new Error(\"Generator is already running\");\n }\n\n if (state === GenStateCompleted) {\n if (method === \"throw\") {\n throw arg;\n }\n\n // Be forgiving, per 25.3.3.3.3 of the spec:\n // https://people.mozilla.org/~jorendorff/es6-draft.html#sec-generatorresume\n return doneResult();\n }\n\n context.method = method;\n context.arg = arg;\n\n while (true) {\n var delegate = context.delegate;\n if (delegate) {\n var delegateResult = maybeInvokeDelegate(delegate, context);\n if (delegateResult) {\n if (delegateResult === ContinueSentinel) continue;\n return delegateResult;\n }\n }\n\n if (context.method === \"next\") {\n // Setting context._sent for legacy support of Babel's\n // function.sent implementation.\n context.sent = context._sent = context.arg;\n\n } else if (context.method === \"throw\") {\n if (state === GenStateSuspendedStart) {\n state = GenStateCompleted;\n throw context.arg;\n }\n\n context.dispatchException(context.arg);\n\n } else if (context.method === \"return\") {\n context.abrupt(\"return\", context.arg);\n }\n\n state = GenStateExecuting;\n\n var record = tryCatch(innerFn, self, context);\n if (record.type === \"normal\") {\n // If an exception is thrown from innerFn, we leave state ===\n // GenStateExecuting and loop back for another invocation.\n state = context.done\n ? GenStateCompleted\n : GenStateSuspendedYield;\n\n if (record.arg === ContinueSentinel) {\n continue;\n }\n\n return {\n value: record.arg,\n done: context.done\n };\n\n } else if (record.type === \"throw\") {\n state = GenStateCompleted;\n // Dispatch the exception by looping back around to the\n // context.dispatchException(context.arg) call above.\n context.method = \"throw\";\n context.arg = record.arg;\n }\n }\n };\n }\n\n // Call delegate.iterator[context.method](context.arg) and handle the\n // result, either by returning a { value, done } result from the\n // delegate iterator, or by modifying context.method and context.arg,\n // setting context.delegate to null, and returning the ContinueSentinel.\n function maybeInvokeDelegate(delegate, context) {\n var methodName = context.method;\n var method = delegate.iterator[methodName];\n if (method === undefined) {\n // A .throw or .return when the delegate iterator has no .throw\n // method, or a missing .next mehtod, always terminate the\n // yield* loop.\n context.delegate = null;\n\n // Note: [\"return\"] must be used for ES3 parsing compatibility.\n if (methodName === \"throw\" && delegate.iterator[\"return\"]) {\n // If the delegate iterator has a return method, give it a\n // chance to clean up.\n context.method = \"return\";\n context.arg = undefined;\n maybeInvokeDelegate(delegate, context);\n\n if (context.method === \"throw\") {\n // If maybeInvokeDelegate(context) changed context.method from\n // \"return\" to \"throw\", let that override the TypeError below.\n return ContinueSentinel;\n }\n }\n if (methodName !== \"return\") {\n context.method = \"throw\";\n context.arg = new TypeError(\n \"The iterator does not provide a '\" + methodName + \"' method\");\n }\n\n return ContinueSentinel;\n }\n\n var record = tryCatch(method, delegate.iterator, context.arg);\n\n if (record.type === \"throw\") {\n context.method = \"throw\";\n context.arg = record.arg;\n context.delegate = null;\n return ContinueSentinel;\n }\n\n var info = record.arg;\n\n if (! info) {\n context.method = \"throw\";\n context.arg = new TypeError(\"iterator result is not an object\");\n context.delegate = null;\n return ContinueSentinel;\n }\n\n if (info.done) {\n // Assign the result of the finished delegate to the temporary\n // variable specified by delegate.resultName (see delegateYield).\n context[delegate.resultName] = info.value;\n\n // Resume execution at the desired location (see delegateYield).\n context.next = delegate.nextLoc;\n\n // If context.method was \"throw\" but the delegate handled the\n // exception, let the outer generator proceed normally. If\n // context.method was \"next\", forget context.arg since it has been\n // \"consumed\" by the delegate iterator. If context.method was\n // \"return\", allow the original .return call to continue in the\n // outer generator.\n if (context.method !== \"return\") {\n context.method = \"next\";\n context.arg = undefined;\n }\n\n } else {\n // Re-yield the result returned by the delegate method.\n return info;\n }\n\n // The delegate iterator is finished, so forget it and continue with\n // the outer generator.\n context.delegate = null;\n return ContinueSentinel;\n }\n\n // Define Generator.prototype.{next,throw,return} in terms of the\n // unified ._invoke helper method.\n defineIteratorMethods(Gp);\n\n define(Gp, toStringTagSymbol, \"Generator\");\n\n // A Generator should always return itself as the iterator object when the\n // @@iterator function is called on it. Some browsers' implementations of the\n // iterator prototype chain incorrectly implement this, causing the Generator\n // object to not be returned from this call. This ensures that doesn't happen.\n // See https://github.com/facebook/regenerator/issues/274 for more details.\n define(Gp, iteratorSymbol, function() {\n return this;\n });\n\n define(Gp, \"toString\", function() {\n return \"[object Generator]\";\n });\n\n function pushTryEntry(locs) {\n var entry = { tryLoc: locs[0] };\n\n if (1 in locs) {\n entry.catchLoc = locs[1];\n }\n\n if (2 in locs) {\n entry.finallyLoc = locs[2];\n entry.afterLoc = locs[3];\n }\n\n this.tryEntries.push(entry);\n }\n\n function resetTryEntry(entry) {\n var record = entry.completion || {};\n record.type = \"normal\";\n delete record.arg;\n entry.completion = record;\n }\n\n function Context(tryLocsList) {\n // The root entry object (effectively a try statement without a catch\n // or a finally block) gives us a place to store values thrown from\n // locations where there is no enclosing try statement.\n this.tryEntries = [{ tryLoc: \"root\" }];\n tryLocsList.forEach(pushTryEntry, this);\n this.reset(true);\n }\n\n exports.keys = function(val) {\n var object = Object(val);\n var keys = [];\n for (var key in object) {\n keys.push(key);\n }\n keys.reverse();\n\n // Rather than returning an object with a next method, we keep\n // things simple and return the next function itself.\n return function next() {\n while (keys.length) {\n var key = keys.pop();\n if (key in object) {\n next.value = key;\n next.done = false;\n return next;\n }\n }\n\n // To avoid creating an additional object, we just hang the .value\n // and .done properties off the next function object itself. This\n // also ensures that the minifier will not anonymize the function.\n next.done = true;\n return next;\n };\n };\n\n function values(iterable) {\n if (iterable) {\n var iteratorMethod = iterable[iteratorSymbol];\n if (iteratorMethod) {\n return iteratorMethod.call(iterable);\n }\n\n if (typeof iterable.next === \"function\") {\n return iterable;\n }\n\n if (!isNaN(iterable.length)) {\n var i = -1, next = function next() {\n while (++i < iterable.length) {\n if (hasOwn.call(iterable, i)) {\n next.value = iterable[i];\n next.done = false;\n return next;\n }\n }\n\n next.value = undefined;\n next.done = true;\n\n return next;\n };\n\n return next.next = next;\n }\n }\n\n // Return an iterator with no values.\n return { next: doneResult };\n }\n exports.values = values;\n\n function doneResult() {\n return { value: undefined, done: true };\n }\n\n Context.prototype = {\n constructor: Context,\n\n reset: function(skipTempReset) {\n this.prev = 0;\n this.next = 0;\n // Resetting context._sent for legacy support of Babel's\n // function.sent implementation.\n this.sent = this._sent = undefined;\n this.done = false;\n this.delegate = null;\n\n this.method = \"next\";\n this.arg = undefined;\n\n this.tryEntries.forEach(resetTryEntry);\n\n if (!skipTempReset) {\n for (var name in this) {\n // Not sure about the optimal order of these conditions:\n if (name.charAt(0) === \"t\" &&\n hasOwn.call(this, name) &&\n !isNaN(+name.slice(1))) {\n this[name] = undefined;\n }\n }\n }\n },\n\n stop: function() {\n this.done = true;\n\n var rootEntry = this.tryEntries[0];\n var rootRecord = rootEntry.completion;\n if (rootRecord.type === \"throw\") {\n throw rootRecord.arg;\n }\n\n return this.rval;\n },\n\n dispatchException: function(exception) {\n if (this.done) {\n throw exception;\n }\n\n var context = this;\n function handle(loc, caught) {\n record.type = \"throw\";\n record.arg = exception;\n context.next = loc;\n\n if (caught) {\n // If the dispatched exception was caught by a catch block,\n // then let that catch block handle the exception normally.\n context.method = \"next\";\n context.arg = undefined;\n }\n\n return !! caught;\n }\n\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n var record = entry.completion;\n\n if (entry.tryLoc === \"root\") {\n // Exception thrown outside of any try block that could handle\n // it, so set the completion value of the entire function to\n // throw the exception.\n return handle(\"end\");\n }\n\n if (entry.tryLoc <= this.prev) {\n var hasCatch = hasOwn.call(entry, \"catchLoc\");\n var hasFinally = hasOwn.call(entry, \"finallyLoc\");\n\n if (hasCatch && hasFinally) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n } else if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else if (hasCatch) {\n if (this.prev < entry.catchLoc) {\n return handle(entry.catchLoc, true);\n }\n\n } else if (hasFinally) {\n if (this.prev < entry.finallyLoc) {\n return handle(entry.finallyLoc);\n }\n\n } else {\n throw new Error(\"try statement without catch or finally\");\n }\n }\n }\n },\n\n abrupt: function(type, arg) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc <= this.prev &&\n hasOwn.call(entry, \"finallyLoc\") &&\n this.prev < entry.finallyLoc) {\n var finallyEntry = entry;\n break;\n }\n }\n\n if (finallyEntry &&\n (type === \"break\" ||\n type === \"continue\") &&\n finallyEntry.tryLoc <= arg &&\n arg <= finallyEntry.finallyLoc) {\n // Ignore the finally entry if control is not jumping to a\n // location outside the try/catch block.\n finallyEntry = null;\n }\n\n var record = finallyEntry ? finallyEntry.completion : {};\n record.type = type;\n record.arg = arg;\n\n if (finallyEntry) {\n this.method = \"next\";\n this.next = finallyEntry.finallyLoc;\n return ContinueSentinel;\n }\n\n return this.complete(record);\n },\n\n complete: function(record, afterLoc) {\n if (record.type === \"throw\") {\n throw record.arg;\n }\n\n if (record.type === \"break\" ||\n record.type === \"continue\") {\n this.next = record.arg;\n } else if (record.type === \"return\") {\n this.rval = this.arg = record.arg;\n this.method = \"return\";\n this.next = \"end\";\n } else if (record.type === \"normal\" && afterLoc) {\n this.next = afterLoc;\n }\n\n return ContinueSentinel;\n },\n\n finish: function(finallyLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.finallyLoc === finallyLoc) {\n this.complete(entry.completion, entry.afterLoc);\n resetTryEntry(entry);\n return ContinueSentinel;\n }\n }\n },\n\n \"catch\": function(tryLoc) {\n for (var i = this.tryEntries.length - 1; i >= 0; --i) {\n var entry = this.tryEntries[i];\n if (entry.tryLoc === tryLoc) {\n var record = entry.completion;\n if (record.type === \"throw\") {\n var thrown = record.arg;\n resetTryEntry(entry);\n }\n return thrown;\n }\n }\n\n // The context.catch method must only be called with a location\n // argument that corresponds to a known catch block.\n throw new Error(\"illegal catch attempt\");\n },\n\n delegateYield: function(iterable, resultName, nextLoc) {\n this.delegate = {\n iterator: values(iterable),\n resultName: resultName,\n nextLoc: nextLoc\n };\n\n if (this.method === \"next\") {\n // Deliberately forget the last sent value so that we don't\n // accidentally pass it on to the delegate.\n this.arg = undefined;\n }\n\n return ContinueSentinel;\n }\n };\n\n // Regardless of whether this script is executing as a CommonJS module\n // or not, return the runtime object so that we can declare the variable\n // regeneratorRuntime in the outer scope, which allows this module to be\n // injected easily by `bin/regenerator --include-runtime script.js`.\n return exports;\n\n}(\n // If this script is executing as a CommonJS module, use module.exports\n // as the regeneratorRuntime namespace. Otherwise create a new empty\n // object. Either way, the resulting object will be used to initialize\n // the regeneratorRuntime variable at the top of this file.\n typeof module === \"object\" ? module.exports : {}\n));\n\ntry {\n regeneratorRuntime = runtime;\n} catch (accidentalStrictMode) {\n // This module should not be running in strict mode, so the above\n // assignment should always work unless something is misconfigured. Just\n // in case runtime.js accidentally runs in strict mode, in modern engines\n // we can explicitly access globalThis. In older engines we can escape\n // strict mode using a global Function call. This could conceivably fail\n // if a Content Security Policy forbids using Function, but in that case\n // the proper solution is to fix the accidental strict mode problem. If\n // you've misconfigured your bundler to force strict mode and applied a\n // CSP to forbid Function, and you're not willing to fix either of those\n // problems, please detail your unique predicament in a GitHub issue.\n if (typeof globalThis === \"object\") {\n globalThis.regeneratorRuntime = runtime;\n } else {\n Function(\"r\", \"regeneratorRuntime = r\")(runtime);\n }\n}\n","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","var scriptUrl;\nif (__webpack_require__.g.importScripts) scriptUrl = __webpack_require__.g.location + \"\";\nvar document = __webpack_require__.g.document;\nif (!scriptUrl && document) {\n\tif (document.currentScript)\n\t\tscriptUrl = document.currentScript.src\n\tif (!scriptUrl) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tif(scripts.length) scriptUrl = scripts[scripts.length - 1].src\n\t}\n}\n// When supporting browsers where an automatic publicPath is not supported you must specify an output.publicPath manually via configuration\n// or pass an empty string (\"\") and set the __webpack_public_path__ variable from your code to use your own logic.\nif (!scriptUrl) throw new Error(\"Automatic publicPath is not supported in this browser\");\nscriptUrl = scriptUrl.replace(/#.*$/, \"\").replace(/\\?.*$/, \"\").replace(/\\/[^\\/]+$/, \"/\");\n__webpack_require__.p = scriptUrl + \"../../\";","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nvar _regenerator = _interopRequireDefault(require(\"@babel/runtime/regenerator\"));\n\nvar _asyncToGenerator2 = _interopRequireDefault(require(\"@babel/runtime/helpers/asyncToGenerator\"));\n\nvar Bridge = require('./bridge');\n\nvar bridge = new Bridge(self, self);\n\nself.init = /*#__PURE__*/function () {\n var _ref2 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee5(_ref) {\n var appVersion, shellVersion, _require, initialize_api, initialize_runtime, get_state, get_debug_state, dispatch, analytics, decode_stream;\n\n return _regenerator[\"default\"].wrap(function _callee5$(_context5) {\n while (1) {\n switch (_context5.prev = _context5.next) {\n case 0:\n appVersion = _ref.appVersion, shellVersion = _ref.shellVersion;\n // TODO remove the document shim when this PR is merged\n // https://github.com/cfware/babel-plugin-bundled-import-meta/pull/26\n self.document = {\n baseURI: self.location.href\n };\n self.app_version = appVersion;\n self.shell_version = shellVersion;\n self.get_location_hash = /*#__PURE__*/(0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee() {\n return _regenerator[\"default\"].wrap(function _callee$(_context) {\n while (1) {\n switch (_context.prev = _context.next) {\n case 0:\n return _context.abrupt(\"return\", bridge.call(['location', 'hash'], []));\n\n case 1:\n case \"end\":\n return _context.stop();\n }\n }\n }, _callee);\n }));\n\n self.local_storage_get_item = /*#__PURE__*/function () {\n var _ref4 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee2(key) {\n return _regenerator[\"default\"].wrap(function _callee2$(_context2) {\n while (1) {\n switch (_context2.prev = _context2.next) {\n case 0:\n return _context2.abrupt(\"return\", bridge.call(['localStorage', 'getItem'], [key]));\n\n case 1:\n case \"end\":\n return _context2.stop();\n }\n }\n }, _callee2);\n }));\n\n return function (_x2) {\n return _ref4.apply(this, arguments);\n };\n }();\n\n self.local_storage_set_item = /*#__PURE__*/function () {\n var _ref5 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee3(key, value) {\n return _regenerator[\"default\"].wrap(function _callee3$(_context3) {\n while (1) {\n switch (_context3.prev = _context3.next) {\n case 0:\n return _context3.abrupt(\"return\", bridge.call(['localStorage', 'setItem'], [key, value]));\n\n case 1:\n case \"end\":\n return _context3.stop();\n }\n }\n }, _callee3);\n }));\n\n return function (_x3, _x4) {\n return _ref5.apply(this, arguments);\n };\n }();\n\n self.local_storage_remove_item = /*#__PURE__*/function () {\n var _ref6 = (0, _asyncToGenerator2[\"default\"])( /*#__PURE__*/_regenerator[\"default\"].mark(function _callee4(key) {\n return _regenerator[\"default\"].wrap(function _callee4$(_context4) {\n while (1) {\n switch (_context4.prev = _context4.next) {\n case 0:\n return _context4.abrupt(\"return\", bridge.call(['localStorage', 'removeItem'], [key]));\n\n case 1:\n case \"end\":\n return _context4.stop();\n }\n }\n }, _callee4);\n }));\n\n return function (_x5) {\n return _ref6.apply(this, arguments);\n };\n }();\n\n _require = require('./stremio_core_web.js'), initialize_api = _require[\"default\"], initialize_runtime = _require.initialize_runtime, get_state = _require.get_state, get_debug_state = _require.get_debug_state, dispatch = _require.dispatch, analytics = _require.analytics, decode_stream = _require.decode_stream;\n self.getState = get_state;\n self.getDebugState = get_debug_state;\n self.dispatch = dispatch;\n self.analytics = analytics;\n self.decodeStream = decode_stream;\n _context5.next = 16;\n return initialize_api(require('./stremio_core_web_bg.wasm'));\n\n case 16:\n _context5.next = 18;\n return initialize_runtime(function (event) {\n return bridge.call(['onCoreEvent'], [event]);\n });\n\n case 18:\n case \"end\":\n return _context5.stop();\n }\n }\n }, _callee5);\n }));\n\n return function (_x) {\n return _ref2.apply(this, arguments);\n };\n}();\n"],"names":["asyncGeneratorStep","gen","resolve","reject","_next","_throw","key","arg","info","value","error","done","Promise","then","module","exports","fn","self","this","args","arguments","apply","err","undefined","__esModule","obj","_typeof","Symbol","iterator","constructor","prototype","_interopRequireDefault","_regenerator","_asyncToGenerator2","scope","handler","addEventListener","_ref2","mark","_callee","_ref","request","id","path","data","thisArg","wrap","_context","prev","next","abrupt","reduce","prop","slice","length","sent","postMessage","response","result","t0","stop","_x","call","_ref3","_callee2","_context2","Math","random","toString","onMessage","_ref4","removeEventListener","_x2","_x3","Object","defineProperty","analytics","event","location_hash","wasm","addHeapObject","decode_stream","stream","takeObject","dispatch","action","field","get_state","initialize_runtime","emit_to_ui","start","_typeof2","importMeta","url","URL","document","baseURI","href","heap","Array","fill","getObject","idx","push","heap_next","ret","dropObject","cachedTextDecoder","TextDecoder","ignoreBOM","fatal","decode","cachegetUint8Memory0","getUint8Memory0","buffer","memory","Uint8Array","getStringFromWasm0","ptr","len","subarray","WASM_VECTOR_LEN","cachedTextEncoder","TextEncoder","encodeString","encodeInto","view","buf","encode","set","read","written","passStringToWasm0","malloc","realloc","_ptr","mem","offset","code","charCodeAt","isLikeNone","x","cachegetInt32Memory0","getInt32Memory0","Int32Array","debugString","val","type","concat","description","name","isArray","debug","i","className","builtInMatches","exec","JSON","stringify","_","Error","message","stack","makeMutClosure","arg0","arg1","dtor","f","state","a","b","cnt","real","_len","_key","__wbindgen_export_2","get","original","__wbg_adapter_30","_dyn_core__ops__function__FnMut_____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__h1a6784ec167a5430","__wbg_adapter_33","arg2","_dyn_core__ops__function__FnMut__A____Output___R_as_wasm_bindgen__closure__WasmClosure___describe__invoke__hdf2bb55ffabdfc36","handleError","e","__wbindgen_exn_store","getArrayU8FromWasm0","__wbg_adapter_70","arg3","wasm_bindgen__convert__closures__invoke2_mut__h23a6b10e1d576a11","load","_load","imports","bytes","instance","Response","WebAssembly","instantiateStreaming","headers","console","warn","arrayBuffer","instantiate","Instance","init","_init","input","_yield$load","wbg","__wbg_new_693216e109162396","__wbg_stack_0ddaca5d1abfb52f","ptr0","__wbindgen_malloc","__wbindgen_realloc","len0","__wbg_error_09919627ac0992f5","__wbindgen_free","__wbindgen_object_drop_ref","__wbg_crypto_8fd02d72c4ba6c5c","crypto","__wbindgen_is_object","__wbg_process_bd02d71a65cf734c","process","__wbg_versions_1d70d407cb23129d","versions","__wbg_node_0091cdf1ffa73e4d","node","__wbindgen_is_string","__wbg_require_b06abd91965488c8","require","__wbindgen_is_function","__wbindgen_string_new","__wbg_msCrypto_7e1e6014bddd75de","msCrypto","__wbg_newwithlength_929232475839a482","__wbindgen_object_clone_ref","__wbg_self_c6fbdfc2918d5e58","__wbg_window_baec038b5ab35c54","window","__wbg_globalThis_3f735a5746d41fbd","globalThis","__wbg_global_1bc0b39582740e95","g","global","__wbindgen_is_undefined","__wbg_newnoargs_be86524d73f67598","Function","__wbg_call_888d259a5fefc347","__wbg_call_346669c262382ad7","__wbindgen_string_get","__wbg_set_82a4e8a85e31ac42","Reflect","__wbg_now_af172eabe2e041ad","Date","now","__wbg_randomFillSync_f20541303a990429","randomFillSync","__wbg_subarray_8b658422a224f479","__wbg_getRandomValues_f308e7233e5601b7","getRandomValues","__wbg_length_1eb8fc608a0d4cdb","__wbindgen_memory","__wbg_buffer_397eaa4d72ee94dd","__wbg_new_a7ce447f15ff496f","__wbg_set_969ad0a60e51d320","__wbindgen_json_serialize","__wbg_instanceof_WorkerGlobalScope_f191ca0158f5637b","WorkerGlobalScope","__wbg_static_accessor_app_version_0d438539d98a0943","app_version","__wbg_static_accessor_shell_version_1f62a14e53964af1","shell_version","__wbg_navigator_8bc0889cda8f8500","navigator","__wbg_language_cd6e22892ba36a1f","language","__wbg_new_b1d61b5687f5e73a","state0","__wbindgen_json_parse","parse","__wbg_new_0b83d3df67ecb33e","__wbg_fetch_b4e81012e07ff95a","fetch","__wbg_getlocationhash_97299d3c8a498b17","get_location_hash","__wbg_instanceof_Error_561efcb1265706d8","__wbg_message_9f7d15ff97fc4102","__wbg_instanceof_Response_e1b11afbefa5b563","__wbg_status_6d8bb444ddc5a7b2","status","__wbg_setInterval_a02797f5ab1c7eb1","setInterval","__wbg_localstorageremoveitem_8ad2d96138ff136a","local_storage_remove_item","__wbg_localstoragesetitem_7d75d2eac814d3d8","local_storage_set_item","__wbg_localstoragegetitem_318a1e7771661e01","local_storage_get_item","__wbindgen_debug_string","__wbindgen_throw","__wbg_then_8c2d62e8ae5978f7","__wbg_then_2fcac196782070cc","__wbg_resolve_d23068002f584f22","__wbindgen_cb_drop","__wbg_newwithstrandinit_9b0fa00478c37287","Request","__wbg_json_88cc6d5cf8f61121","json","__wbindgen_closure_wrapper4955","__wbindgen_closure_wrapper5985","t1","t2","__wbindgen_wasm_module","__wbindgen_start","_default","runtime","Op","hasOwn","hasOwnProperty","desc","$Symbol","iteratorSymbol","asyncIteratorSymbol","asyncIterator","toStringTagSymbol","toStringTag","define","enumerable","configurable","writable","innerFn","outerFn","tryLocsList","protoGenerator","Generator","generator","create","context","Context","makeInvokeMethod","tryCatch","GenStateSuspendedStart","GenStateExecuting","GenStateCompleted","ContinueSentinel","GeneratorFunction","GeneratorFunctionPrototype","IteratorPrototype","getProto","getPrototypeOf","NativeIteratorPrototype","values","Gp","defineIteratorMethods","forEach","method","_invoke","AsyncIterator","PromiseImpl","invoke","record","__await","unwrapped","previousPromise","callInvokeWithMethodAndArg","doneResult","delegate","delegateResult","maybeInvokeDelegate","_sent","dispatchException","methodName","TypeError","resultName","nextLoc","pushTryEntry","locs","entry","tryLoc","catchLoc","finallyLoc","afterLoc","tryEntries","resetTryEntry","completion","reset","iterable","iteratorMethod","isNaN","displayName","isGeneratorFunction","genFun","ctor","setPrototypeOf","__proto__","awrap","async","iter","keys","object","reverse","pop","skipTempReset","charAt","rootRecord","rval","exception","handle","loc","caught","hasCatch","hasFinally","finallyEntry","complete","finish","thrown","delegateYield","regeneratorRuntime","accidentalStrictMode","__webpack_module_cache__","__webpack_require__","moduleId","cachedModule","__webpack_modules__","scriptUrl","importScripts","location","currentScript","src","scripts","getElementsByTagName","replace","p","bridge","_callee5","appVersion","shellVersion","_require","initialize_api","get_debug_state","_context5","_ref5","_callee3","_context3","_x4","_ref6","_callee4","_context4","_x5","getState","getDebugState","decodeStream"],"sourceRoot":""} \ No newline at end of file diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css b/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css new file mode 100644 index 000000000..857b04a72 --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css @@ -0,0 +1,70 @@ +.button-container-HNufV{cursor:pointer;outline-color:hsl(0,0%,100%);outline-offset:calc(-1 * var(--focus-outline-size));outline-width:var(--focus-outline-size)}.button-container-HNufV:focus{outline-style:solid}.button-container-HNufV.disabled{opacity:0.25;pointer-events:none} +.modal-container-jZglc{align-items:center;background-color:hsla(0,0%,0%,0.4);display:flex;justify-content:center}.modal-container-jZglc .modal-dialog-container-QgsId{background-color:hsl(0,0%,100%);display:flex;flex:none;flex-direction:column;max-height:80%;max-width:80%}.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo{align-self:flex-end;flex:none;height:2rem;margin:0.2rem 0.2rem 0 0;padding:0.5rem;width:2rem}.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo .icon-hRjWc{fill:hsla(0,0%,70%,0.9);display:block;height:100%;width:100%}.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo:focus .icon-hRjWc,.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo:hover .icon-hRjWc{fill:hsla(0,0%,80%,0.9)}.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo:focus{outline-color:hsl(0,0%,0%)}.modal-container-jZglc .modal-dialog-container-QgsId .title-container-wqhp3{color:hsla(0,0%,0%,0.9);flex:1 0 auto;font-size:1.2rem;font-weight:500;margin:0 2rem;max-height:2.4em}.modal-container-jZglc .modal-dialog-container-QgsId .modal-dialog-content-ChXwF{align-self:stretch;flex:1;margin:1.5rem 1rem 0;overflow-y:auto;padding:0 1rem}.modal-container-jZglc .modal-dialog-container-QgsId .modal-dialog-content-ChXwF:last-child{margin-bottom:2rem}.modal-container-jZglc .modal-dialog-container-QgsId .buttons-container-EJKJF{align-self:stretch;display:flex;flex:none;flex-direction:row;flex-wrap:wrap;margin:2rem 2rem 0}.modal-container-jZglc .modal-dialog-container-QgsId .buttons-container-EJKJF:last-child{margin-bottom:2rem}.action-button-bi6FL{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:1;flex-direction:row;justify-content:center;padding:1.2rem}.action-button-bi6FL:hover{background-color:hsl(147.7,68%,46.7%)}.action-button-bi6FL:focus{outline-color:hsl(0,0%,0%)}.action-button-bi6FL:not(:last-child){margin-right:1rem}.action-button-bi6FL .icon-hRjWc{fill:hsla(0,0%,100%,0.9);flex:none;height:1.2rem;margin-right:0.5rem;width:1.2rem}.action-button-bi6FL .label-_ADoX{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;font-weight:500;max-height:3.6em;text-align:center}@media only screen and (max-width:640px){.modal-container-jZglc .modal-dialog-container-QgsId{max-width:initial;position:relative;width:90%;z-index:0}.modal-container-jZglc .modal-dialog-container-QgsId .close-button-container-QrgQo{margin:0.75rem 0.75rem 0 0;padding:0.25rem;position:absolute;right:0;top:0}.modal-container-jZglc .modal-dialog-container-QgsId .title-container-wqhp3{margin:1rem 3rem 1rem 1.5rem;max-height:4.8em}.modal-container-jZglc .modal-dialog-container-QgsId .modal-dialog-content-ChXwF{margin:0 0.5rem;padding:0 0.5rem}.modal-container-jZglc .modal-dialog-container-QgsId .modal-dialog-content-ChXwF:last-child{margin-bottom:1rem}.modal-container-jZglc .modal-dialog-container-QgsId .buttons-container-EJKJF{margin:1rem 1rem 0}.modal-container-jZglc .modal-dialog-container-QgsId .buttons-container-EJKJF:last-child{margin-bottom:1rem}} +.addon-details-container-ZQqDB .title-container-fR02m{align-items:center;display:flex;flex-direction:row}.addon-details-container-ZQqDB .title-container-fR02m .icon-ScXNu,.addon-details-container-ZQqDB .title-container-fR02m .logo-BujW_{background-color:hsl(0,0%,0%);float:left;height:5rem;margin-right:1.5rem;padding:0.5rem;width:5rem}.addon-details-container-ZQqDB .title-container-fR02m .logo-BujW_{-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center}.addon-details-container-ZQqDB .title-container-fR02m .icon-ScXNu{fill:hsl(224.3,42.1%,81%)}.addon-details-container-ZQqDB .title-container-fR02m .name-container-Gfhqw{align-items:baseline;display:flex;flex-basis:0;flex-direction:row;flex-grow:1;flex-shrink:1;flex-wrap:wrap}.addon-details-container-ZQqDB .title-container-fR02m .name-container-Gfhqw .name-XNqfo{color:hsla(0,0%,0%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.6rem;margin-right:0.5rem}.addon-details-container-ZQqDB .title-container-fR02m .name-container-Gfhqw .version-w_xoN{color:hsla(0,0%,0%,0.6);flex-basis:auto;flex-grow:1;flex-shrink:1;margin-top:0.5rem}.addon-details-container-ZQqDB .section-container-l3YaI{margin-top:1rem}.addon-details-container-ZQqDB .section-container-l3YaI .section-header-bs8iy{color:hsla(0,0%,0%,0.9);font-size:1.1rem}.addon-details-container-ZQqDB .section-container-l3YaI .section-label-rYxQh{color:hsla(0,0%,0%,0.9);font-size:1.1rem;font-weight:300}.addon-details-container-ZQqDB .section-container-l3YaI .section-label-rYxQh.transport-url-label-EW7I5{-webkit-user-select:text;-moz-user-select:text;user-select:text}.addon-details-container-ZQqDB .section-container-l3YaI .section-label-rYxQh.disclaimer-label-IGdd3{font-style:italic} +.addon-details-modal-container-_bwQ0 .addon-details-container-AmNx2,.addon-details-modal-container-_bwQ0 .addon-details-message-container-VEzeN{max-width:100%;width:40rem}.addon-details-modal-container-_bwQ0 .cancel-button-luYIO .label-_ADoX,.addon-details-modal-container-_bwQ0 .install-button-XUzqz .label-_ADoX,.addon-details-modal-container-_bwQ0 .uninstall-button-X2JXr .label-_ADoX{font-size:1.2rem;font-weight:500}.addon-details-modal-container-_bwQ0 .cancel-button-luYIO:focus,.addon-details-modal-container-_bwQ0 .uninstall-button-X2JXr:focus{outline-color:hsl(0,0%,0%)}.addon-details-modal-container-_bwQ0 .cancel-button-luYIO{background-color:transparent}.addon-details-modal-container-_bwQ0 .cancel-button-luYIO:hover{background-color:hsl(0,0%,90%)}.addon-details-modal-container-_bwQ0 .cancel-button-luYIO .label-_ADoX{color:hsl(0,0%,65%)}.addon-details-modal-container-_bwQ0 .uninstall-button-X2JXr{background-color:hsl(10.8,78%,55.5%)}.addon-details-modal-container-_bwQ0 .uninstall-button-X2JXr:hover{background-color:hsl(10.8,78%,65.5%)} +.checkbox-container-heGq4.checked .icon-NUvac{fill:hsl(0,0%,100%);background-color:hsl(276.8,48%,62%)}.checkbox-container-heGq4 .icon-NUvac{fill:hsl(0,0%,100%);display:block;height:1rem;width:1rem} +.color-picker-container-deFkW{overflow:visible;text-align:center}.color-picker-container-deFkW *{overflow:visible}.color-picker-container-deFkW .a-color-picker-circle,.color-picker-container-deFkW .a-color-picker-stack:not(.a-color-picker-row-top) canvas{border:thin solid var(--color-surfacedark)}.color-picker-container-deFkW .a-color-picker-circle{box-shadow:0 0 0.2rem var(--color-surfacedark)}.color-picker-container-deFkW .a-color-picker-clipbaord{pointer-events:none} +.color-input-container-jRZsi{position:relative;z-index:0}.color-input-container-jRZsi .transparent-label-container-Tx2fI{align-items:center;border:thin solid hsla(0,0%,100%,0.2);bottom:0;display:flex;justify-content:center;left:0;padding:0 0.5rem;pointer-events:none;position:absolute;right:0;top:0;z-index:1}.color-input-container-jRZsi .transparent-label-container-Tx2fI .transparent-label-omLaY{color:hsl(0,0%,100%);flex:1;text-align:center;text-overflow:ellipsis;white-space:nowrap}.color-picker-container-C4puR{margin:1rem 0} +.label-container-iBMb9{overflow:visible;position:relative}.label-container-iBMb9 .menu-container-bfvDO{box-shadow:0 1.35rem 2.7rem hsla(0,0%,0%,0.4),0 1.1rem 0.85rem hsla(0,0%,0%,0.2);cursor:auto;overflow:visible;position:absolute;visibility:hidden;z-index:1}.label-container-iBMb9 .menu-container-bfvDO.menu-direction-top-left-KpAQN{bottom:100%;left:initial;right:0;top:initial;visibility:visible}.label-container-iBMb9 .menu-container-bfvDO.menu-direction-bottom-left-Uw06K{bottom:initial;left:initial;right:0;top:100%;visibility:visible}.label-container-iBMb9 .menu-container-bfvDO.menu-direction-top-right-jOtwq{bottom:100%;left:0;right:initial;top:initial;visibility:visible}.label-container-iBMb9 .menu-container-bfvDO.menu-direction-bottom-right-XZ9Ch{bottom:initial;left:0;right:initial;top:100%;visibility:visible} +.label-container-ZHk2S{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex-direction:row;padding:0 1rem}.label-container-ZHk2S.active .label-kz1K0{color:hsla(0,0%,100%,0.9)}.label-container-ZHk2S.active .icon-YGvLz{fill:hsla(0,0%,100%,0.9)}.label-container-ZHk2S>.label-kz1K0{color:hsla(224.3,42.1%,66%,0.9);flex:1;font-weight:500;max-height:2.4em}.label-container-ZHk2S .icon-YGvLz{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1rem;margin-left:1rem;width:1rem}.label-container-ZHk2S .menu-container-bfvDO{width:100%}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex-direction:row;padding:1rem}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o.selected .icon-YGvLz,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o.selected .icon-YGvLz{display:block}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o:focus,.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o:hover,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o:focus,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o:hover{background-color:hsl(243,24.4%,31%)}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o .label-kz1K0,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o .label-kz1K0{color:hsla(0,0%,100%,0.9);flex:1;max-height:4.8em}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o .icon-YGvLz,.menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o .icon-YGvLz{background-color:hsla(147.7,68%,41.7%,0.9);border-radius:100%;display:none;flex:none;height:0.5rem;margin-left:1rem;width:0.5rem}.modal-container-BQwj3 .menu-container-Z1Pou .no-options-container-NYx9Z,.menu-container-bfvDO .menu-container-Z1Pou .no-options-container-NYx9Z{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex-direction:row;justify-content:center;padding:1rem}.modal-container-BQwj3 .menu-container-Z1Pou .no-options-container-NYx9Z .label-kz1K0,.menu-container-bfvDO .menu-container-Z1Pou .no-options-container-NYx9Z .label-kz1K0{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.2rem;font-weight:500;text-align:center} +.background-FNyrF{fill:hsl(0,0%,100%)}.icon-XXj2q{fill:hsl(0,0%,0%)} +.meta-item-container-drt6V{overflow:visible;padding:1rem}.meta-item-container-drt6V:focus,.meta-item-container-drt6V.active,.meta-item-container-drt6V.selected,.meta-item-container-drt6V:hover{background-color:hsl(243,24.4%,36%);outline-style:none;transition:background-color 100ms ease-out}.meta-item-container-drt6V.poster-shape-poster-F_CO5 .poster-container-Fruke{padding-top:calc(100% * var(--poster-shape-ratio))}.meta-item-container-drt6V.poster-shape-square-UCby3 .poster-container-Fruke{padding-top:100%}.meta-item-container-drt6V.poster-shape-landscape-BPmb1 .poster-container-Fruke{padding-top:calc(100% * var(--landscape-shape-ratio))}.meta-item-container-drt6V .poster-container-Fruke{background-color:hsl(243,24.4%,21%);position:relative;z-index:0}.meta-item-container-drt6V .poster-container-Fruke .poster-image-layer-CdxrT{align-items:center;bottom:0;display:flex;flex-direction:row;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:-3}.meta-item-container-drt6V .poster-container-Fruke .poster-image-layer-CdxrT .poster-image-lt9zC{flex:none;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;opacity:0.9;width:100%}.meta-item-container-drt6V .poster-container-Fruke .poster-image-layer-CdxrT .placeholder-icon-uYwsv{fill:hsla(243,24.4%,36%,0.9);flex:none;height:50%;width:80%}.meta-item-container-drt6V .poster-container-Fruke .play-icon-layer-_75Lo{bottom:30%;left:0;overflow:visible;position:absolute;right:0;top:30%;z-index:-2}.meta-item-container-drt6V .poster-container-Fruke .play-icon-layer-_75Lo .play-icon-d9_ll{display:block;filter:drop-shadow(0 0 0.5rem hsl(243,24.4%,21%));height:100%;width:100%}.meta-item-container-drt6V .poster-container-Fruke .play-icon-layer-_75Lo .play-icon-d9_ll .background-FNyrF{fill:hsla(160,81.5%,46.8%,0.9)}.meta-item-container-drt6V .poster-container-Fruke .play-icon-layer-_75Lo .play-icon-d9_ll .icon-XXj2q{fill:hsla(0,0%,100%,0.9)}.meta-item-container-drt6V .poster-container-Fruke .progress-bar-layer-r81Qx{background-color:hsl(243,24.4%,31%);bottom:0;left:0;position:absolute;right:0;z-index:-1}.meta-item-container-drt6V .poster-container-Fruke .progress-bar-layer-r81Qx .progress-bar-E3QY9{background-color:hsl(276.8,48%,62%);height:0.4rem}.meta-item-container-drt6V .title-bar-container-DFXJK{align-items:center;display:flex;flex-direction:row;height:2.8rem;overflow:visible}.meta-item-container-drt6V .title-bar-container-DFXJK .title-label-dZZ_A{color:hsla(0,0%,100%,0.9);flex:1;max-height:2.4em;padding-left:0.5rem}.meta-item-container-drt6V .title-bar-container-DFXJK .title-label-dZZ_A:only-child{padding-right:0.5rem}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I{background-color:transparent;flex:none;height:2.8rem;padding:1rem 0;width:1.5rem}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .icon-IfJ81{fill:hsla(0,0%,80%,0.9);display:block;height:100%;width:100%}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO{width:auto}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO .menu-container-Z1Pou{max-width:12rem;min-width:6rem}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o{background-color:hsl(0,0%,100%);padding:0.5rem}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o:focus,.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o:hover{background-color:hsl(0,0%,85%);outline:none}.meta-item-container-drt6V .title-bar-container-DFXJK .menu-label-container-dlL1I .menu-container-bfvDO .menu-container-Z1Pou .option-container-yVj1o .label-kz1K0{color:hsla(0,0%,0%,0.9)}@media only screen and (max-width:640px){.meta-item-container-drt6V{padding:0.5rem}.meta-item-container-drt6V .title-bar-container-DFXJK{margin-top:0.5rem}} +.text-input-jR2Nr{-webkit-user-select:text;-moz-user-select:text;user-select:text}.text-input-jR2Nr::-moz-focus-inner{border:none} +.search-bar-container-TNPzI{--search-bar-size:calc(var(--horizontal-nav-bar-size) - 1.2rem);background-color:hsl(243,24.4%,31%);border-radius:var(--search-bar-size);display:flex;flex-direction:row;height:var(--search-bar-size)}.search-bar-container-TNPzI:hover{background-color:hsl(243,24.4%,36%)}.search-bar-container-TNPzI .search-input-aOiJ2{align-items:center;align-self:stretch;color:hsl(224.3,42.1%,71%);cursor:text;display:flex;flex:1;flex-direction:row;font-weight:500;padding:0 0.5rem 0 1.5rem}.search-bar-container-TNPzI .search-input-aOiJ2::-moz-placeholder{color:hsla(224.3,42.1%,71%,0.9);max-height:1.2em;opacity:1}.search-bar-container-TNPzI .search-input-aOiJ2 .placeholder-label-Irklk,.search-bar-container-TNPzI .search-input-aOiJ2::placeholder{color:hsla(224.3,42.1%,71%,0.9);max-height:1.2em;opacity:1}.search-bar-container-TNPzI .submit-button-container-jPP5J{align-items:center;display:flex;flex:none;flex-direction:row;height:var(--search-bar-size);justify-content:center;width:var(--search-bar-size)}.search-bar-container-TNPzI .submit-button-container-jPP5J:hover .icon-FT4bG{fill:hsla(222.8,100%,78%,0.9)}.search-bar-container-TNPzI .submit-button-container-jPP5J .icon-FT4bG{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.7rem;width:1.7rem} +.nav-menu-container-VSzwW{background-color:hsl(243,24.4%,16%);max-height:calc(100vh - var(--horizontal-nav-bar-size));overflow-y:auto;width:20rem}.nav-menu-container-VSzwW .user-info-container-BR8yb{display:grid;grid-template-areas:"avatar-area email-area" "avatar-area logout-button-area";grid-template-columns:7rem 1fr;grid-template-rows:50% 50%;height:7rem}.nav-menu-container-VSzwW .user-info-container-BR8yb .avatar-container-jmlBM{background-clip:content-box;background-origin:content-box;background-position:center;background-repeat:no-repeat;background-size:cover;border-radius:50%;grid-area:avatar-area;opacity:0.9;padding:1rem}.nav-menu-container-VSzwW .user-info-container-BR8yb .email-container-fvFrL{align-items:center;display:flex;flex-direction:row;grid-area:email-area;padding:1rem 1rem 0 0}.nav-menu-container-VSzwW .user-info-container-BR8yb .email-container-fvFrL .email-label-WBX2T{color:hsla(0,0%,100%,0.9);flex:1;max-height:2.4em}.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i{align-items:center;display:flex;flex-direction:row;grid-area:logout-button-area;padding:0 1rem 1rem 0}.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i:focus,.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i:hover{outline:none}.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i:focus .logout-label-dUa8B,.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i:hover .logout-label-dUa8B{color:hsla(0,0%,100%,0.9);text-decoration:underline}.nav-menu-container-VSzwW .user-info-container-BR8yb .logout-button-container-hSW_i .logout-label-dUa8B{color:hsla(0,0%,90%,0.9);flex:1;max-height:2.4em}.nav-menu-container-VSzwW .nav-menu-section-oMELF{border-top:thin solid hsla(0,0%,100%,0.2)}.nav-menu-container-VSzwW .nav-menu-section-oMELF .nav-menu-option-container-gZ1gT{align-items:center;display:flex;flex-direction:row;height:4rem}.nav-menu-container-VSzwW .nav-menu-section-oMELF .nav-menu-option-container-gZ1gT:hover{background-color:hsl(243,24.4%,31%)}.nav-menu-container-VSzwW .nav-menu-section-oMELF .nav-menu-option-container-gZ1gT .icon-OSgm6{fill:hsla(222.8,100%,78%,0.9);flex:none;height:1.4rem;margin:1.3rem;width:1.4rem}.nav-menu-container-VSzwW .nav-menu-section-oMELF .nav-menu-option-container-gZ1gT .nav-menu-option-label-XNuY6{color:hsla(0,0%,100%,0.9);flex:1;max-height:2.4em;padding-right:1.3rem}.nav-menu-container-VSzwW .nav-menu-section-oMELF .nav-menu-option-container-gZ1gT .nav-menu-option-label-XNuY6:only-child{padding-left:1.3rem}@media only screen and (max-width:640px){.nav-menu-container-VSzwW{max-height:calc(100vh - var(--horizontal-nav-bar-size) - var(--vertical-nav-bar-size) - 1rem)}} +.horizontal-nav-bar-container-jFw5Y{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex-direction:row;height:var(--horizontal-nav-bar-size);overflow:visible;padding-right:1rem}.horizontal-nav-bar-container-jFw5Y .logo-container-fnFzY{align-items:center;display:flex;flex:none;height:var(--horizontal-nav-bar-size);justify-content:center;width:var(--vertical-nav-bar-size)}.horizontal-nav-bar-container-jFw5Y .logo-container-fnFzY .logo-RVSxt{flex:none;height:2.5rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:2.5rem}.horizontal-nav-bar-container-jFw5Y .spacing-jzj7t{flex:1 0 0}.horizontal-nav-bar-container-jFw5Y .title-_UxXH{color:hsla(222.8,100%,78%,0.9);flex:4 0 0;font-size:1.2rem;font-style:normal;font-weight:500;letter-spacing:0.01rem;padding:0 1rem;text-overflow:ellipsis;white-space:nowrap}.horizontal-nav-bar-container-jFw5Y .title-_UxXH+.spacing-jzj7t{display:none}.horizontal-nav-bar-container-jFw5Y .search-bar-NopQ6{flex:2 0 9.5rem;max-width:30rem}.horizontal-nav-bar-container-jFw5Y .search-bar-NopQ6+.spacing-jzj7t{max-width:11rem}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB{align-items:center;display:flex;flex:none;height:var(--horizontal-nav-bar-size);justify-content:center;width:var(--horizontal-nav-bar-size)}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB.back-button-container-K9AwF{height:var(--horizontal-nav-bar-size);width:var(--vertical-nav-bar-size)}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB:hover{background-color:hsl(243,24.4%,31%)}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB.active{background-color:hsl(243,24.4%,36%)}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB.active .icon-wrBcp{fill:hsla(0,0%,100%,0.9)}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB .icon-wrBcp{fill:hsla(222.8,100%,78%,0.9);flex:none;height:1.7rem;width:1.7rem}@media only screen and (max-width:640px){.horizontal-nav-bar-container-jFw5Y{justify-content:space-between;padding-right:0}.horizontal-nav-bar-container-jFw5Y .logo-container-fnFzY{width:var(--horizontal-nav-bar-size)}.horizontal-nav-bar-container-jFw5Y .search-bar-NopQ6{margin:0 0.5rem}.horizontal-nav-bar-container-jFw5Y .button-container-B23qB:not(.back-button-container-K9AwF):not(.menu-button-container-WWcwa),.horizontal-nav-bar-container-jFw5Y .spacing-jzj7t{display:none}} +.nav-tab-button-container-r8HUb{align-items:center;background-color:hsl(243,24.4%,16%);display:flex;flex-direction:column;justify-content:center}.nav-tab-button-container-r8HUb:hover{background-color:hsl(243,24.4%,31%)}.nav-tab-button-container-r8HUb.selected{background-color:hsl(224.3,42.1%,41%)}.nav-tab-button-container-r8HUb.selected:hover{background-color:hsl(224.3,42.1%,46%)}.nav-tab-button-container-r8HUb.selected .icon-vxKmB{fill:hsla(0,0%,100%,0.9)}.nav-tab-button-container-r8HUb.selected .label-mc9eB{color:hsla(0,0%,100%,0.9)}.nav-tab-button-container-r8HUb .icon-vxKmB,.nav-tab-button-container-r8HUb .logo-ST06l{fill:hsla(226.6,37.2%,61.9%,0.9);flex:none;height:1.7rem;margin-bottom:0.5rem;width:1.7rem}.nav-tab-button-container-r8HUb .label-mc9eB{color:hsla(224.3,42.1%,66%,0.9);flex:none;font-size:0.9rem;font-weight:500;letter-spacing:0.01rem;max-height:2.4em;padding:0 0.2rem;text-align:center} +.vertical-nav-bar-container-AsGLM{background-color:hsl(243,24.4%,16%);overflow-y:auto;scrollbar-width:none;width:var(--vertical-nav-bar-size)}.vertical-nav-bar-container-AsGLM::-webkit-scrollbar{display:none}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6{height:var(--vertical-nav-bar-size);width:var(--vertical-nav-bar-size)}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6:first-child{margin-top:1rem}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6:last-child{margin-bottom:1rem}@media only screen and (max-width:640px){.vertical-nav-bar-container-AsGLM{display:flex;flex-direction:row;height:var(--vertical-nav-bar-size);justify-content:space-between;overflow-x:auto;overflow-y:hidden;width:100%}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6{flex:none}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6:first-child{margin-top:0}.vertical-nav-bar-container-AsGLM .nav-tab-button-noMv6:last-child{margin-bottom:0}} +.main-nav-bars-container-fA7pO{position:relative;z-index:0}.main-nav-bars-container-fA7pO .horizontal-nav-bar-x5sxp{left:0;position:absolute;right:0;top:0;z-index:1}.main-nav-bars-container-fA7pO .vertical-nav-bar-JNw53{bottom:0;left:0;position:absolute;top:var(--horizontal-nav-bar-size);z-index:1}.main-nav-bars-container-fA7pO .nav-content-container-VHwOU{bottom:0;left:var(--vertical-nav-bar-size);position:absolute;right:0;top:var(--horizontal-nav-bar-size);z-index:0}@media only screen and (max-width:640px){.main-nav-bars-container-fA7pO .nav-content-container-VHwOU{bottom:var(--vertical-nav-bar-size);left:0}.main-nav-bars-container-fA7pO .vertical-nav-bar-JNw53{top:initial}} +.share-prompt-container-YsJwl .buttons-container-Oc7PG{display:flex;flex-direction:row}.share-prompt-container-YsJwl .buttons-container-Oc7PG .button-container-oMOnv{align-items:center;display:flex;flex:1;flex-direction:row;justify-content:center;padding:1rem}.share-prompt-container-YsJwl .buttons-container-Oc7PG .button-container-oMOnv:not(:last-child){margin-right:1rem}.share-prompt-container-YsJwl .buttons-container-Oc7PG .button-container-oMOnv .icon-FVvQH{fill:hsla(0,0%,100%,0.9);flex:none;height:1.2rem;margin-right:1rem}.share-prompt-container-YsJwl .buttons-container-Oc7PG .button-container-oMOnv .label-iOGrs{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;font-weight:500;max-height:2.4em;text-align:center}.share-prompt-container-YsJwl .buttons-container-Oc7PG .facebook-button-KaNwb:focus,.share-prompt-container-YsJwl .buttons-container-Oc7PG .twitter-button-pJka2:focus{outline-color:hsl(0,0%,0%)}.share-prompt-container-YsJwl .buttons-container-Oc7PG .facebook-button-KaNwb{background-color:var(--color-facebook)}.share-prompt-container-YsJwl .buttons-container-Oc7PG .twitter-button-pJka2{background-color:var(--color-twitter)}.share-prompt-container-YsJwl .url-container-fMSp4{background-color:hsl(0,0%,85%);display:flex;flex-direction:row;margin-top:1rem}.share-prompt-container-YsJwl .url-container-fMSp4 .url-text-input-Yka4x{align-self:stretch;color:hsl(0,0%,0%);flex:1;font-size:1.1rem;padding:1rem;text-align:center}.share-prompt-container-YsJwl .url-container-fMSp4 .copy-button-ShwCB{align-items:center;align-self:stretch;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;justify-content:center;padding:1rem;width:8rem}.share-prompt-container-YsJwl .url-container-fMSp4 .copy-button-ShwCB:hover{background-color:hsl(147.7,68%,46.7%)}.share-prompt-container-YsJwl .url-container-fMSp4 .copy-button-ShwCB:focus{outline-color:hsl(0,0%,0%)}.share-prompt-container-YsJwl .url-container-fMSp4 .copy-button-ShwCB .icon-FVvQH{fill:hsla(0,0%,100%,0.9);flex:none;height:1.2rem;margin-right:0.5rem;width:1.2rem}.share-prompt-container-YsJwl .url-container-fMSp4 .copy-button-ShwCB .label-iOGrs{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;max-height:2.4em} +.action-button-container-TmbQ2{background-color:hsla(0,0%,100%,0.2);display:flex;flex-direction:column;justify-content:center}.action-button-container-TmbQ2:focus,.action-button-container-TmbQ2:hover{background-color:hsl(147.7,68%,41.7%)}.action-button-container-TmbQ2 .icon-container-hvLw4{align-self:stretch;flex:0 0 50%;padding-top:15%}.action-button-container-TmbQ2 .icon-container-hvLw4:only-child{padding:5% 0}.action-button-container-TmbQ2 .icon-container-hvLw4 .icon-DG4TM{fill:hsla(0,0%,100%,0.9);display:block;height:100%;width:100%}.action-button-container-TmbQ2 .label-container-eh2bk{align-items:center;align-self:stretch;display:flex;flex:0 0 50%;flex-direction:row}.action-button-container-TmbQ2 .label-container-eh2bk .label-YhHvD{color:hsla(0,0%,100%,0.9);flex:1;font-weight:500;max-height:2.4em;padding:0 0.2rem;text-align:center}@media only screen and (max-width:640px){.action-button-container-TmbQ2{flex-direction:row;padding:0 1rem}.action-button-container-TmbQ2 .icon-container-hvLw4{align-self:center;flex:none;height:2rem;margin-right:0.5rem;padding-top:0;width:2rem}.action-button-container-TmbQ2 .icon-container-hvLw4:only-child{margin-right:0;padding:0}.action-button-container-TmbQ2 .label-container-eh2bk{flex:1}} +.meta-links-container-wSrm1 .label-container-zWFke{color:hsla(0,0%,60%,0.9);font-weight:500;margin-bottom:0.2rem;text-transform:uppercase}.meta-links-container-wSrm1 .links-container-o4RUG{display:flex;flex-direction:row;flex-wrap:wrap}.meta-links-container-wSrm1 .links-container-o4RUG .link-container-HUDqV{background-color:hsla(0,0%,100%,0.2);border:var(--focus-outline-size) solid transparent;border-radius:2rem;color:hsla(0,0%,85%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;margin-bottom:0.2rem;margin-right:0.5rem;padding:0.3rem 0.5rem;text-overflow:ellipsis;white-space:nowrap}.meta-links-container-wSrm1 .links-container-o4RUG .link-container-HUDqV:focus,.meta-links-container-wSrm1 .links-container-o4RUG .link-container-HUDqV:hover{background-color:hsla(0,0%,100%,0.3)}.meta-links-container-wSrm1 .links-container-o4RUG .link-container-HUDqV:focus{border-color:hsl(0,0%,100%);outline:none} +.meta-preview-placeholder-container-AQ4ld{display:flex;flex-direction:column;padding:2rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb{align-self:stretch;flex:1}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .logo-container-g5eNB{background-color:var(--color-placeholder-background);height:8rem;max-width:100%;width:20rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .duration-release-info-container-lNaI6{display:flex;flex-direction:row;flex-wrap:wrap;margin:1rem 0}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .duration-release-info-container-lNaI6 .duration-container-x2E01{background-color:var(--color-placeholder-background);flex-basis:5rem;height:1.4rem;margin-right:1rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .duration-release-info-container-lNaI6 .release-info-container-PEmeu{background-color:var(--color-placeholder-background);flex-basis:5rem;height:1.4rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .description-container-yGOO4{margin:1rem 0}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .description-container-yGOO4 .description-label-container-G_0pj{background-color:var(--color-placeholder-background)}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .description-container-yGOO4 .description-label-container-G_0pj:first-child{height:1.4rem;max-width:80%;width:20rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .description-container-yGOO4 .description-label-container-G_0pj:nth-child(2){height:4.6rem;margin-top:1rem;max-width:80%;width:26rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .genres-container-v3H7A{margin:1rem 0}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .genres-container-v3H7A .genres-header-container-lsPLU{background-color:var(--color-placeholder-background);height:1.6rem;max-width:100%;width:6.5rem}.meta-preview-placeholder-container-AQ4ld .meta-info-container-pEOFb .genres-container-v3H7A .genre-label-container-z7kU8{background-color:var(--color-placeholder-background);height:1.2rem;margin-top:0.2rem;max-width:100%;width:10rem}.meta-preview-placeholder-container-AQ4ld .action-buttons-container-U3sbl{display:flex;flex-direction:row;flex-wrap:wrap;max-height:6rem}.meta-preview-placeholder-container-AQ4ld .action-buttons-container-U3sbl .action-button-container-xJmjB{background-color:var(--color-placeholder-background);flex:none;height:6rem;margin-right:2rem;width:6rem}.meta-preview-placeholder-container-AQ4ld .action-buttons-container-U3sbl .action-button-container-xJmjB:last-child{margin-right:0}.meta-preview-placeholder-container-AQ4ld .action-buttons-container-U3sbl .action-button-container-xJmjB .action-button-icon-E7Epc{background-color:var(--color-placeholder-background);height:2rem;margin:1rem 2rem 0;width:2rem}.meta-preview-placeholder-container-AQ4ld .action-buttons-container-U3sbl .action-button-container-xJmjB .action-button-label-R7UPL{background-color:var(--color-placeholder-background);height:1.2rem;margin:0.9rem 1rem;width:4rem} +.meta-preview-container-bgBNf{display:flex;flex-direction:column;position:relative;z-index:0}.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .logo-X9v1A,.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .logo-placeholder-kIy0x{background-color:hsla(0,0%,50%,0.1);height:8rem;width:100%}.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .runtime-release-info-container-lXo3K{justify-content:space-evenly}.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .release-info-label-XmqSY,.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .runtime-label-B29EN{margin:1rem 0.4rem}.meta-preview-container-bgBNf.compact-Wbl4Q .meta-info-container-tlmcb .description-container-eSGft{max-height:none}.meta-preview-container-bgBNf.compact-Wbl4Q .action-buttons-container-qQrnO{justify-content:space-evenly;padding:0}.meta-preview-container-bgBNf.compact-Wbl4Q .action-buttons-container-qQrnO .action-button-R44aX:not(:last-child){margin-right:0}.meta-preview-container-bgBNf .background-image-layer-GstuA{bottom:-10px;left:-10px;position:absolute;right:-10px;top:-10px;z-index:-1}.meta-preview-container-bgBNf .background-image-layer-GstuA:after{background:hsla(243,24.4%,11%,0.6);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.meta-preview-container-bgBNf .background-image-layer-GstuA .background-image-B0d6i{display:block;filter:blur(5px);height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;opacity:0.9;width:100%}.meta-preview-container-bgBNf .meta-info-container-tlmcb{align-self:stretch;flex:1;overflow-y:auto;padding:0 2rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb:not(:hover){scrollbar-color:transparent transparent}.meta-preview-container-bgBNf .meta-info-container-tlmcb:not(:hover)::-webkit-scrollbar-thumb,.meta-preview-container-bgBNf .meta-info-container-tlmcb:not(:hover)::-webkit-scrollbar-track{background-color:transparent}.meta-preview-container-bgBNf .meta-info-container-tlmcb .logo-X9v1A,.meta-preview-container-bgBNf .meta-info-container-tlmcb .logo-placeholder-kIy0x{display:block;margin:2rem 0;max-width:100%}.meta-preview-container-bgBNf .meta-info-container-tlmcb .logo-X9v1A{height:8rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center}.meta-preview-container-bgBNf .meta-info-container-tlmcb .logo-placeholder-kIy0x{color:hsla(0,0%,100%,0.9);font-size:1.7rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;margin-top:1rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .release-info-label-XmqSY,.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .runtime-label-B29EN{color:hsla(0,0%,100%,0.9);flex:0 1 auto;font-size:1.4rem;margin-bottom:0.5rem;margin-right:2rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7{align-items:center;background-color:hsla(0,0%,100%,0.2);border:var(--focus-outline-size) solid transparent;border-radius:2.5rem;display:flex;flex:0 1 auto;flex-direction:row;margin-bottom:0.5rem;padding:0.3rem 1rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7:focus,.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7:hover{background-color:hsla(0,0%,100%,0.3)}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7:focus{border:var(--focus-outline-size) solid hsl(0,0%,100%);outline:none}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7 .icon-MBu8k{fill:hsla(0,0%,75%,0.9);flex:none;height:1.1rem;margin-right:1rem;width:3rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .runtime-release-info-container-lXo3K .imdb-button-container-qCbl7 .label-_DfnK{color:hsla(0,0%,100%,0.9);flex:0 1 auto;font-size:1.6rem;font-weight:500;max-height:1.2em}.meta-preview-container-bgBNf .meta-info-container-tlmcb .name-container-HsS4c{color:hsla(0,0%,100%,0.9);font-size:1.5rem;margin-top:1rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .description-container-eSGft{color:hsla(0,0%,100%,0.9);font-size:1.1rem;line-height:1.5em;margin-top:1rem;max-height:6em}.meta-preview-container-bgBNf .meta-info-container-tlmcb .meta-links-mTHUo{margin-top:1rem}.meta-preview-container-bgBNf .action-buttons-container-qQrnO{align-self:stretch;display:flex;flex:none;flex-direction:row;flex-wrap:wrap;max-height:10rem;padding:0 2rem}.meta-preview-container-bgBNf .action-buttons-container-qQrnO .action-button-R44aX{flex:none;height:6rem;margin:2rem 0;width:6rem}.meta-preview-container-bgBNf .action-buttons-container-qQrnO .action-button-R44aX:not(:last-child){margin-right:2rem}.share-prompt-F8qOC{width:24rem}@media only screen and (max-width:640px){.meta-preview-container-bgBNf .meta-info-container-tlmcb{padding:0 1.5rem}.meta-preview-container-bgBNf .meta-info-container-tlmcb .logo-X9v1A{margin:1em 0}.meta-preview-container-bgBNf .action-buttons-container-qQrnO{flex-wrap:nowrap;overflow-x:visible;padding:0 1.5rem;scrollbar-width:none}.meta-preview-container-bgBNf .action-buttons-container-qQrnO::-webkit-scrollbar{display:none}.meta-preview-container-bgBNf .action-buttons-container-qQrnO .action-button-R44aX{height:4rem;margin:1rem 0;max-width:60%;width:auto}.meta-preview-container-bgBNf .action-buttons-container-qQrnO .action-button-R44aX:not(:last-child){margin-right:1rem}.share-prompt-F8qOC{width:100%}} +.meta-row-placeholder-container-wpHNk .header-container-GCHdB{align-items:center;display:flex;flex-direction:row;justify-content:flex-end;margin-bottom:1rem;padding:0 1rem}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .title-container-Bjp93{color:var(--color-placeholder-text);flex:1;font-size:1.8rem;max-height:2.4em}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .title-container-Bjp93:empty{background:linear-gradient(to right,var(--color-placeholder-background) 0 40%,transparent 40% 100%);height:1.2em}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .see-all-container-FnlIf{align-items:center;display:flex;flex:none;flex-direction:row;max-width:12rem;padding:0.2rem}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .see-all-container-FnlIf:focus{background-color:var(--color-placeholder-background);outline:none}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .see-all-container-FnlIf .label-dU3S2{color:var(--color-placeholder-text);flex:0 1 auto;font-size:1.3rem;font-weight:500;max-height:1.2em;text-transform:uppercase}.meta-row-placeholder-container-wpHNk .header-container-GCHdB .see-all-container-FnlIf .icon-FLhtv{fill:var(--color-placeholder-text);flex:none;height:1.3rem;margin-left:0.5rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx{align-items:stretch;display:flex;flex-direction:row}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY{flex:1;margin:1rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY:not(:first-child){margin-left:1.5rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY .poster-container-RlQMV{background-color:var(--color-placeholder-background);padding-bottom:calc(100% * var(--poster-shape-ratio))}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY .title-bar-container-YJZrl{align-items:center;display:flex;flex-direction:row;height:2.8rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY .title-bar-container-YJZrl .title-label-Ka1vs{background-color:var(--color-placeholder-background);flex:none;height:1.2rem;width:60%}@media only screen and (max-width:640px){.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY{margin:0.5rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY:not(:first-child){margin-left:0.5rem}.meta-row-placeholder-container-wpHNk .meta-items-container-dbGXx .meta-item-IegjY .title-bar-container-YJZrl{margin-top:0.5rem}} +.meta-row-container-ucOuu{overflow:visible}.meta-row-container-ucOuu .header-container-RherZ{align-items:center;display:flex;flex-direction:row;justify-content:flex-end;margin-bottom:1rem;padding:0 1rem}.meta-row-container-ucOuu .header-container-RherZ .title-container-SJ0nR{color:hsla(222.8,100%,78%,0.9);flex:1;font-size:1.8rem;max-height:2.4em}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b{align-items:center;display:flex;flex:none;flex-direction:row;max-width:12rem;padding:0.2rem}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b:focus{background-color:hsl(243,24.4%,36%);outline:none}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b:hover .label-isJw8{color:hsla(222.8,100%,83%,0.9)}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b:hover .icon-PO0GH{fill:hsla(222.8,100%,83%,0.9)}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b .label-isJw8{color:hsla(222.8,100%,78%,0.9);flex:0 1 auto;font-size:1.3rem;font-weight:500;max-height:1.2em;text-transform:uppercase}.meta-row-container-ucOuu .header-container-RherZ .see-all-container-HlJ4b .icon-PO0GH{fill:hsla(222.8,100%,78%,0.9);flex:none;height:1.3rem;margin-left:0.5rem}.meta-row-container-ucOuu .message-container-bIcjN{color:hsla(222.8,100%,78%,0.9);font-size:1.3rem;max-height:3.6em;padding:0 1rem}.meta-row-container-ucOuu .meta-items-container-TqzFs{align-items:stretch;display:flex;flex-direction:row;overflow:visible}.meta-row-container-ucOuu .meta-items-container-TqzFs .meta-item-x28TU:not(:first-child){margin-left:0.5rem}.meta-row-container-ucOuu .meta-items-container-TqzFs .meta-item-x28TU.poster-shape-poster-B1QR0{flex:calc(1 / var(--poster-shape-ratio))}.meta-row-container-ucOuu .meta-items-container-TqzFs .meta-item-x28TU.poster-shape-square-m5r_O{flex:1}.meta-row-container-ucOuu .meta-items-container-TqzFs .meta-item-x28TU.poster-shape-landscape-_FSOH{flex:calc(1 / var(--landscape-shape-ratio))}@media only screen and (max-width:640px){.meta-row-container-ucOuu .header-container-RherZ{padding:0 0.5rem}.meta-row-container-ucOuu .header-container-RherZ .title-container-SJ0nR{margin-right:0.5rem;text-overflow:ellipsis;white-space:nowrap}.meta-row-container-ucOuu .meta-items-container-TqzFs .meta-item-x28TU:not(:first-child){margin-left:0}} +.pagination-input-container-vXhi6{display:flex;flex-direction:row}.pagination-input-container-vXhi6 .next-button-container-zNwG6,.pagination-input-container-vXhi6 .prev-button-container-qmJ1m{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex:none;justify-content:center}.pagination-input-container-vXhi6 .next-button-container-zNwG6 .icon-UoyQ9,.pagination-input-container-vXhi6 .prev-button-container-qmJ1m .icon-UoyQ9{fill:hsla(224.3,42.1%,66%,0.9);display:block}.pagination-input-container-vXhi6 .label-container-VwInD{align-items:center;align-self:stretch;background-color:hsl(243,24.4%,16%);display:flex;flex:1;justify-content:center}.pagination-input-container-vXhi6 .label-container-VwInD .label-cJKC1{color:hsla(224.3,42.1%,66%,0.9);flex:none;font-weight:500;max-width:3rem;min-width:1.2rem;text-align:center;text-overflow:ellipsis;white-space:nowrap} +.search-bar-container-Vb_fz{align-items:center;background-color:var(--color-placeholder-background);border:var(--focus-outline-size) solid transparent;border-radius:3.5rem;display:flex;flex-direction:row;height:3.5rem;padding:0 1rem}.search-bar-container-Vb_fz .search-input-BWyeG{color:var(--color-placeholder-text);flex:1;font-size:1.1rem;margin-right:1rem;max-height:1.2em}.search-bar-container-Vb_fz .icon-poa62{fill:var(--color-placeholder-background);flex:none;height:1.5rem;width:1.5rem} +.search-bar-container-MpNBA{align-items:center;background-color:hsl(243,24.4%,21%);border:var(--focus-outline-size) solid transparent;border-radius:3.5rem;cursor:text;display:flex;flex-direction:row;height:3.5rem;padding:0 1rem}.search-bar-container-MpNBA:focus-within,.search-bar-container-MpNBA:hover{background-color:hsl(243,24.4%,26%)}.search-bar-container-MpNBA:focus-within{border:var(--focus-outline-size) solid hsl(0,0%,100%)}.search-bar-container-MpNBA .search-input-ge2wu{color:hsl(0,0%,100%);flex:1;font-size:1.1rem;margin-right:1rem}.search-bar-container-MpNBA .search-input-ge2wu::-moz-placeholder{color:hsla(224.3,42.1%,71%,0.9);max-height:1.2em;opacity:1}.search-bar-container-MpNBA .search-input-ge2wu::placeholder{color:hsla(224.3,42.1%,71%,0.9);max-height:1.2em;opacity:1}.search-bar-container-MpNBA .icon-Z_Hni{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.5rem;width:1.5rem} +.warning-container-FIITF{align-items:center;background-color:hsl(42,100%,39.9%);display:flex;flex-direction:row;padding:0.5rem 1rem}.warning-container-FIITF .warning-statement-I7pdD{color:hsla(0,0%,100%,0.9);flex:1;font-size:1.2rem;margin-right:1rem;max-height:2.4em}.warning-container-FIITF .warning-button-zlx_V{flex:none;max-width:8rem}.warning-container-FIITF .warning-button-zlx_V:not(:last-child){margin-right:1rem}.warning-container-FIITF .warning-button-zlx_V:hover .warning-label-XJnBc{text-decoration:underline}.warning-container-FIITF .warning-button-zlx_V .warning-label-XJnBc{color:hsla(0,0%,100%,0.9);font-size:1.2rem;max-height:1.2em} +html.active-slider-within-lQFc1{cursor:-webkit-grabbing;cursor:grabbing}html.active-slider-within-lQFc1 body{pointer-events:none}.slider-container-aRzVq{cursor:pointer;overflow:visible;position:relative;z-index:0}.slider-container-aRzVq.active .track-before-FwOXh,.slider-container-aRzVq:hover .track-before-FwOXh{background-color:hsl(275.1,33%,63%)}.slider-container-aRzVq.disabled{pointer-events:none}.slider-container-aRzVq.disabled .track-jWhBI{background-color:hsl(0,0%,50%)}.slider-container-aRzVq.disabled .track-before-FwOXh{background-color:hsl(0,0%,75%)}.slider-container-aRzVq.disabled .thumb-tfDk6{fill:hsl(0,0%,75%)}.slider-container-aRzVq .layer-FqnD7{align-items:center;bottom:0;display:flex;flex-direction:row;left:0;overflow:visible;position:absolute;right:0;top:0;z-index:0}.slider-container-aRzVq .track-jWhBI{background-color:hsl(275.1,33%,23%);flex:1;height:var(--track-size)}.slider-container-aRzVq .track-before-FwOXh{background-color:hsl(275.1,33%,53%);flex:none;height:var(--track-size)}.slider-container-aRzVq .thumb-tfDk6{fill:hsl(0,0%,100%);flex:none;height:var(--thumb-size);transform:translateX(-50%);width:var(--thumb-size)} +.toast-item-container-nG0uk{background-color:hsl(0,0%,95%);box-shadow:0 0.3rem 0.5rem hsla(0,0%,0%,0.4),0 0.6rem 1rem hsla(0,0%,0%,0.2);display:flex;flex-direction:row;margin-bottom:1rem;overflow:visible;pointer-events:auto;width:25rem}.toast-item-container-nG0uk.success-eIDTa .icon-container-rjAiH{background-color:hsl(147.7,68%,41.7%)}.toast-item-container-nG0uk.success-eIDTa .icon-container-rjAiH .icon-Y4I_O{fill:hsla(0,0%,100%,0.9)}.toast-item-container-nG0uk.error-quyOd .icon-container-rjAiH{background-color:hsl(10.8,78%,55.5%)}.toast-item-container-nG0uk.error-quyOd .icon-container-rjAiH .icon-Y4I_O{fill:hsla(0,0%,100%,0.9)}.toast-item-container-nG0uk .icon-container-rjAiH{align-self:stretch;flex:none;padding:0.5rem;width:2.5rem}.toast-item-container-nG0uk .icon-container-rjAiH .icon-Y4I_O{fill:hsla(0,0%,0%,0.9);display:block;height:100%;width:100%}.toast-item-container-nG0uk .info-container-xD9V6{align-self:stretch;flex:1;padding:1rem}.toast-item-container-nG0uk .info-container-xD9V6 .title-container-VFReJ{font-size:1.2rem}.toast-item-container-nG0uk .info-container-xD9V6 .title-container-VFReJ:not(:last-child){margin-bottom:0.2rem}.toast-item-container-nG0uk .info-container-xD9V6 .message-container-znkCj{font-size:1.1rem}.toast-item-container-nG0uk .close-button-container-YtyYE{align-self:flex-start;flex:none;height:2rem;margin:0.2rem;padding:0.5rem;width:2rem}.toast-item-container-nG0uk .close-button-container-YtyYE:hover{background-color:hsl(0,0%,85%)}.toast-item-container-nG0uk .close-button-container-YtyYE .icon-Y4I_O{display:block;height:100%;width:100%} +.addon-container-lC5KN{align-items:flex-start;background-color:hsl(243,24.4%,21%);cursor:inherit;display:flex;flex-direction:row;padding:1.5rem}.addon-container-lC5KN .logo-container-ZcSSC{background-color:hsl(243,24.4%,26%);flex:none;height:6rem;width:6rem}.addon-container-lC5KN .logo-container-ZcSSC .logo-WrsGF{display:block;height:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;padding:0.5rem;width:100%}.addon-container-lC5KN .logo-container-ZcSSC .icon-GxVbY{fill:hsl(224.3,42.1%,81%);display:block;height:100%;padding:1rem;width:100%}.addon-container-lC5KN .info-container-AdMB6{align-items:baseline;display:flex;flex-basis:0;flex-direction:row;flex-grow:1;flex-shrink:1;flex-wrap:wrap;padding:0 0.5rem}.addon-container-lC5KN .info-container-AdMB6 .name-container-qIAg8{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.6rem;max-height:3.6em;padding:0 0.5rem}.addon-container-lC5KN .info-container-AdMB6 .version-container-zdPyN{color:hsla(0,0%,100%,0.6);flex-basis:auto;flex-grow:1;flex-shrink:1;margin-top:0.5rem;max-height:2.4em;padding:0 0.5rem}.addon-container-lC5KN .info-container-AdMB6 .types-container-DaOrg{color:hsla(0,0%,100%,0.4);flex-basis:100%;flex-grow:0;flex-shrink:0;margin-top:0.5rem;max-height:2.4em;padding:0 0.5rem;text-transform:capitalize}.addon-container-lC5KN .info-container-AdMB6 .description-container-v7Jhe{color:hsla(0,0%,100%,0.9);flex-basis:100%;flex-grow:0;flex-shrink:0;margin-top:0.5rem;max-height:4.8em;padding:0 0.5rem}.addon-container-lC5KN .buttons-container-g0xXr{display:flex;flex:none;flex-direction:column;gap:1rem;width:17rem}.addon-container-lC5KN .buttons-container-g0xXr .action-buttons-container-xMVmz{align-items:center;display:flex;flex:auto;flex-direction:row;gap:1rem}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ,.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5,.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP,.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo{align-items:center;display:flex;flex:auto;flex-direction:row;gap:1rem;height:4rem;justify-content:center;padding:0 1rem}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ .icon-GxVbY,.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5 .icon-GxVbY,.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .icon-GxVbY,.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo .icon-GxVbY{flex:none;height:2rem;width:2rem}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ .label-OnWh2,.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5 .label-OnWh2,.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .label-OnWh2,.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo .label-OnWh2{flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.2rem;font-weight:500;max-height:2.4em;text-align:center}.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5{background-color:hsl(147.7,68%,41.7%)}.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5:hover{background-color:hsl(147.7,68%,51.7%)}.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5 .label-OnWh2{color:hsl(0,0%,100%)}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ{background-color:hsl(147.7,68%,41.7%);flex:none}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ:hover{background-color:hsl(147.7,68%,51.7%)}.addon-container-lC5KN .buttons-container-g0xXr .configure-button-container-VwVAQ .icon-GxVbY{fill:hsl(0,0%,100%)}.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo{outline-color:hsl(243,24.4%,36%);outline-style:solid}.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo:hover{background-color:hsl(243,24.4%,31%)}.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo .label-OnWh2{color:hsla(0,0%,100%,0.9)}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP:hover .icon-GxVbY{fill:hsl(224.3,42.1%,71%)}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP:hover .label-OnWh2{color:hsl(224.3,42.1%,76%);text-decoration:underline}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .icon-GxVbY{fill:hsla(224.3,42.1%,61%,0.6)}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .label-OnWh2{color:hsla(224.3,42.1%,66%,0.9)}@media only screen and (max-width:640px){.addon-container-lC5KN{flex-wrap:wrap}.addon-container-lC5KN .info-container-AdMB6{margin-left:0.5rem;padding:0}.addon-container-lC5KN .buttons-container-g0xXr{align-items:center;display:flex;flex:0 1 100%;flex-direction:row;justify-content:space-between;margin-top:1rem;width:auto}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP{flex:none}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .icon-GxVbY{margin-right:0}.addon-container-lC5KN .buttons-container-g0xXr .share-button-container-s3gwP .label-OnWh2{display:none}.addon-container-lC5KN .buttons-container-g0xXr .install-button-container-yfcq5,.addon-container-lC5KN .buttons-container-g0xXr .uninstall-button-container-oV4Yo{flex-basis:100%;margin-right:1rem}} +.addons-container-ogGYu{background-color:hsl(243,24.4%,11%);height:100%;width:100%}.addons-container-ogGYu .addons-content-zhFBl{align-self:stretch;display:flex;flex-direction:column;height:100%;width:100%}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1{align-self:stretch;display:flex;flex:none;flex-direction:row;justify-content:space-between;overflow:visible;padding:1.5rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;height:3.5rem;justify-content:center;margin-right:1.5rem;padding:0 1rem;width:10rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT:hover{background-color:hsl(147.7,68%,51.7%)}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT:focus{outline-color:hsl(0,0%,100%)}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT .icon-HsyZS{fill:hsl(0,0%,100%);flex:none;height:1.2rem;margin-right:1rem;width:1.2rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT .add-button-label-NN6bu{color:hsl(0,0%,100%);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;max-height:2.4em}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .select-input-container-KqG8N{flex-basis:15rem;flex-grow:0;flex-shrink:1;height:3.5rem;margin-right:1.5rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .select-input-container-KqG8N .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .spacing-wH1w5{flex:1}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .search-bar-k7MXd{flex-basis:18rem;flex-grow:0;flex-shrink:1}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .filter-button-lLJ1X{align-items:center;background-color:hsl(243,24.4%,21%);display:none;flex:none;height:3.5rem;justify-content:center;width:3.5rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .filter-button-lLJ1X .filter-icon-LUDTS{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.4rem;width:1.4rem}.addons-container-ogGYu .addons-content-zhFBl .message-container-GBw0P{align-self:stretch;color:hsl(0,0%,100%);flex:1;font-size:2rem;padding:0 1.5rem}.addons-container-ogGYu .addons-content-zhFBl .addons-list-container-Ovr2Z{align-self:stretch;flex:1;overflow-y:auto;padding:0 1.5rem}.addons-container-ogGYu .addons-content-zhFBl .addons-list-container-Ovr2Z .addon-whmdO{margin-bottom:1.5rem}.filters-modal-w6oWY .modal-dialog-container-QgsId{overflow:visible}.filters-modal-w6oWY .modal-dialog-container-QgsId .modal-dialog-content-ChXwF{display:flex;flex-direction:column;overflow:visible}.filters-modal-w6oWY .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-container-KqG8N{height:3.5rem}.filters-modal-w6oWY .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-container-KqG8N:not(:last-child){margin-bottom:1rem}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF{width:30rem}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF .notice-UQkO1{color:hsla(0,0%,0%,0.9);font-size:1rem;margin-bottom:1.5rem}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF .addon-url-input-ucetZ{color:hsl(0,0%,50%);outline:var(--focus-outline-size) solid hsl(0,0%,85%);outline-offset:calc(-1 * var(--focus-outline-size));padding:1rem;width:100%}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF .addon-url-input-ucetZ:hover{outline-color:hsl(0,0%,95%)}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF .addon-url-input-ucetZ:focus{outline-color:hsl(0,0%,0%)}.add-addon-modal-container-KR5ny .cancel-button-R2AxR{background-color:transparent}.add-addon-modal-container-KR5ny .cancel-button-R2AxR:hover{background-color:hsl(0,0%,90%)}.add-addon-modal-container-KR5ny .cancel-button-R2AxR:focus{outline-color:hsl(0,0%,0%)}.add-addon-modal-container-KR5ny .cancel-button-R2AxR .label-_ADoX{color:hsl(0,0%,65%)}.share-modal-container-DkzPM .modal-dialog-content-ChXwF{width:30rem}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g{align-items:center;display:flex;flex-direction:row}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .icon-HsyZS,.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .logo-PmYDP{float:left;height:5rem;margin-right:1.5rem;padding:0.5rem;width:5rem}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .logo-PmYDP{-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .icon-HsyZS{fill:hsl(224.3,42.1%,81%)}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .name-container-m_Sz0{align-items:baseline;display:flex;flex-basis:0;flex-direction:row;flex-grow:1;flex-shrink:1;flex-wrap:wrap}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .name-container-m_Sz0 .name-YD0xd{color:hsla(0,0%,0%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.6rem;margin-right:0.5rem}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .title-container-La49g .name-container-m_Sz0 .version-wuAFB{color:hsla(0,0%,0%,0.6);flex-basis:auto;flex-grow:1;flex-shrink:1;margin-top:0.5rem}.share-modal-container-DkzPM .modal-dialog-content-ChXwF .share-prompt-container-vaK4P{margin-top:1rem}@media only screen and (max-width:640px){.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .add-button-container-SkafT{bottom:calc(3rem + var(--horizontal-nav-bar-size));box-shadow:0 1.35rem 2.7rem hsla(0,0%,0%,0.4),0 1.1rem 0.85rem hsla(0,0%,0%,0.2);position:fixed;right:0}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .select-input-container-KqG8N,.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .spacing-wH1w5{display:none}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .search-bar-k7MXd{flex-basis:100%;margin-right:1rem}.addons-container-ogGYu .addons-content-zhFBl .selectable-inputs-container-tUul1 .filter-button-lLJ1X{display:flex}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF,.share-modal-container-DkzPM .modal-dialog-content-ChXwF{width:auto}.add-addon-modal-container-KR5ny .modal-dialog-content-ChXwF .notice-UQkO1{margin-bottom:1rem}} +.board-container-DTN_b{display:flex;flex-direction:column;height:100%;width:100%}.board-container-DTN_b .board-content-container-ToQTz{align-self:stretch;background-color:hsl(243,24.4%,11%);flex:1}.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1{height:100%;overflow-y:auto;width:100%}.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-CoJrZ{margin:4rem 2rem}.board-container-DTN_b .board-warning-container-a4m04{align-self:stretch;flex:none}@media only screen and (max-width:2200px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+10),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+10),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+10),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+10),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+9){display:none}}@media only screen and (max-width:1900px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+9),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+8){display:none}}@media only screen and (max-width:1600px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+8),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+7){display:none}}@media only screen and (max-width:1300px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+7),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+6){display:none}}@media only screen and (max-width:1000px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+6),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+5){display:none}}@media only screen and (max-width:800px){.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+5),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+4){display:none}}@media only screen and (max-width:640px){.board-container-DTN_b{position:relative;z-index:0}.board-container-DTN_b .board-content-container-ToQTz:only-child .board-content-nPWv1{height:100%}.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1{height:calc(100% - 4rem)}.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-CoJrZ{margin:2rem 1rem}.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-IegjY:nth-child(n+3),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-landscape-FRGXx .meta-item-x28TU:nth-child(n+3),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-IegjY:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-poster-QPQqC .meta-item-x28TU:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-IegjY:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .board-row-square-pgaZ3 .meta-item-x28TU:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-IegjY:nth-child(n+4),.board-container-DTN_b .board-content-container-ToQTz .board-content-nPWv1 .continue-watching-row-ZiNSa .meta-item-x28TU:nth-child(n+4){display:none}.board-container-DTN_b .board-warning-container-a4m04{bottom:var(--vertical-nav-bar-size);height:4rem;left:0;position:absolute;right:0}} +.discover-container-L6OGL{background-color:hsl(243,24.4%,11%);height:100%;width:100%}.discover-container-L6OGL .discover-content-CRsRg{display:flex;flex-direction:row;height:100%;width:100%}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T{align-self:stretch;display:flex;flex:1;flex-direction:column}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50{align-self:stretch;display:flex;flex:none;flex-direction:row;overflow:visible;padding:1.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe{flex:0 1 15rem;height:3.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe:not(:first-child){margin-left:1.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe:nth-child(n+4){display:none}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe:nth-child(n+4)~.filter-container-BVkqT{display:flex}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .filter-container-BVkqT{align-items:center;background-color:hsl(243,24.4%,21%);display:none;flex:none;height:3.5rem;justify-content:center;margin-left:1.5rem;width:3.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .filter-container-BVkqT .filter-icon-zlFnX{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.4rem;width:1.4rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .missing-addon-warning-container-IXGuv{align-items:center;align-self:stretch;display:flex;flex:none;flex-direction:column;padding:0 1.5rem 1.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .missing-addon-warning-container-IXGuv .warning-label-f19Jg{color:hsla(0,0%,100%,0.9);flex:none;font-size:1.4rem;margin-bottom:1rem;max-height:2.4em;text-align:center}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .missing-addon-warning-container-IXGuv .install-button-SmJe1{background-color:hsl(147.7,68%,41.7%);flex:none;max-width:15rem;min-width:10rem;padding:1rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .missing-addon-warning-container-IXGuv .install-button-SmJe1:hover{background-color:hsl(147.7,68%,46.7%)}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .missing-addon-warning-container-IXGuv .install-button-SmJe1 .label-ToW4S{color:hsla(0,0%,100%,0.9);font-weight:500;max-height:2.4em;text-align:center}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .message-container-Zv9eF{align-items:center;align-self:stretch;display:flex;flex:0 1 auto;flex-direction:column;overflow-y:auto;padding:0 1.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .message-container-Zv9eF:first-child{padding:4rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .message-container-Zv9eF .image-txC9E{flex:none;height:12rem;margin-bottom:1rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .message-container-Zv9eF .message-label-mRyRX{color:hsla(222.8,100%,78%,0.9);flex:none;font-size:2.5rem;text-align:center}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-gap:0.5rem;align-items:center;align-self:stretch;display:grid;flex:1;grid-auto-rows:-webkit-max-content;grid-auto-rows:max-content;margin-right:1.5rem;overflow-y:auto;padding:0 1.5rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz .meta-item-placeholder-wxG4I{padding:1rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz .meta-item-placeholder-wxG4I .poster-container-Dch4R{background-color:var(--color-placeholder-background);padding-bottom:calc(100% * var(--poster-shape-ratio))}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz .meta-item-placeholder-wxG4I .title-bar-container-dtDnk{align-items:center;display:flex;flex-direction:row;height:2.8rem}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz .meta-item-placeholder-wxG4I .title-bar-container-dtDnk .title-label-vHdQd{background-color:var(--color-placeholder-background);flex:none;height:1.2rem;width:60%}.discover-container-L6OGL .discover-content-CRsRg .meta-preview-container-CoWs5{align-self:stretch;background-color:hsl(243,24.4%,6%);flex:none;width:28rem}.selectable-inputs-modal-ChpOa .modal-dialog-container-QgsId,.selectable-inputs-modal-ChpOa .modal-dialog-container-QgsId .modal-dialog-content-ChXwF{overflow:visible}.selectable-inputs-modal-ChpOa .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-CHDbe{height:3.5rem}.selectable-inputs-modal-ChpOa .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-CHDbe:not(:last-child){margin-bottom:1rem}.selectable-inputs-modal-ChpOa .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-CHDbe .menu-container-Z1Pou{max-height:calc(3.2rem * 4);overflow:auto}.modal-container-BQwj3 .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow-y:auto;scrollbar-color:hsl(0,0%,80%) hsl(0,0%,95%);width:15rem}.modal-container-BQwj3 .menu-container-Z1Pou ::-webkit-scrollbar-thumb{background-color:hsl(0,0%,80%)}.modal-container-BQwj3 .menu-container-Z1Pou ::-webkit-scrollbar-thumb:hover{background-color:hsl(0,0%,85%)}.modal-container-BQwj3 .menu-container-Z1Pou ::-webkit-scrollbar-track{background-color:hsl(0,0%,95%)}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o{background:none}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o:focus,.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o:hover{background-color:hsl(0,0%,90%)}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o:focus{outline-color:hsl(243,24.4%,11%)}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o .label-kz1K0{color:hsla(243,24.4%,11%,0.9)}.modal-container-BQwj3 .menu-container-Z1Pou .option-container-yVj1o .icon-YGvLz{fill:hsla(243,24.4%,11%,0.9)}@media only screen and (min-width:2800px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(10,1fr)}}@media only screen and (max-width:2800px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(9,1fr)}}@media only screen and (max-width:2500px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(8,1fr)}}@media only screen and (max-width:2200px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(7,1fr)}}@media only screen and (max-width:1900px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(6,1fr)}}@media only screen and (max-width:1600px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(5,1fr)}}@media only screen and (max-width:1300px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(4,1fr)}}@media only screen and (max-width:1000px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(5,1fr);margin-right:0}.discover-container-L6OGL .discover-content-CRsRg .meta-preview-container-CoWs5{display:none}}@media only screen and (max-width:800px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(4,1fr);margin-right:0}.discover-container-L6OGL .discover-content-CRsRg .meta-preview-container-CoWs5{display:none}}@media only screen and (max-width:640px){.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50{justify-content:space-between}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe:nth-child(n+3){display:none}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .selectable-inputs-container-IRz50 .select-input-CHDbe:nth-child(n+3)~.filter-container-BVkqT{display:flex}.discover-container-L6OGL .discover-content-CRsRg .catalog-container-VNK_T .meta-items-container-n8vNz{grid-template-columns:repeat(3,1fr)}} +.not-found-container-Q1qsP{background-color:hsl(243,24.4%,11%);display:flex;flex-direction:column;height:100%;width:100%}.not-found-container-Q1qsP .nav-bar-Eu3_y{align-self:stretch;flex:none}.not-found-container-Q1qsP .not-found-content-z_Eza{align-items:center;align-self:stretch;display:flex;flex:1;flex-direction:column;justify-content:center}.not-found-container-Q1qsP .not-found-content-z_Eza .not-found-image-Qab4G{flex:none;height:12rem;margin-bottom:1rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.not-found-container-Q1qsP .not-found-content-z_Eza .not-found-label-mmwyZ{color:hsla(222.8,100%,78%,0.9);flex:none;font-size:2.5rem;max-height:3.6em;max-width:60%;text-align:center} +.library-container-zM_bj{background-color:hsl(243,24.4%,11%);height:100%;width:100%}.library-container-zM_bj .library-content-PgX4O{display:flex;flex-direction:column;height:100%;width:100%}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or{align-self:stretch;display:flex;flex:none;flex-direction:row;overflow:visible;padding:1.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .select-input-container-H1VZ1{flex-basis:15rem;flex-grow:0;flex-shrink:1;height:3.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .select-input-container-H1VZ1:not(:last-child){margin-right:1.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .select-input-container-H1VZ1 .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .filter-container-oRBlw{align-items:center;background-color:hsl(243,24.4%,21%);display:none;flex:none;height:3.5rem;justify-content:center;width:3.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .filter-container-oRBlw .filter-icon-ZhMyS{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.4rem;width:1.4rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .spacing-Rdiyt{flex:1}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv{flex:none;height:3.5rem;margin-left:1.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv.pagination-input-placeholder-vZeuq{pointer-events:none}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv.pagination-input-placeholder-vZeuq .next-button-container-zNwG6 .icon-UoyQ9,.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv.pagination-input-placeholder-vZeuq .prev-button-container-qmJ1m .icon-UoyQ9{fill:hsla(0,0%,50%,0.9)}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv.pagination-input-placeholder-vZeuq .label-cJKC1{color:hsla(0,0%,50%,0.9)}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv .next-button-container-zNwG6,.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv .prev-button-container-qmJ1m{height:3.5rem;width:3.5rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv .next-button-container-zNwG6 .icon-UoyQ9,.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv .prev-button-container-qmJ1m .icon-UoyQ9{height:1rem;width:1rem}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv .label-cJKC1{width:3rem}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t{align-items:center;align-self:stretch;display:flex;flex:0 1 auto;flex-direction:column;overflow-y:auto;padding:0 1.5rem}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t:first-child{padding:4rem}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t.no-user-message-container-KMLpE .login-button-container-RoEh7{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;justify-content:center;margin-bottom:1rem;min-height:4rem;padding:0.5rem 1rem;width:20rem}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t.no-user-message-container-KMLpE .login-button-container-RoEh7:hover{background-color:hsl(147.7,68%,46.7%)}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t.no-user-message-container-KMLpE .login-button-container-RoEh7 .label-QqYmf{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.2rem;font-weight:700;max-height:4.8em;text-align:center}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t .image-csRHm{flex:none;height:12rem;margin-bottom:1rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.library-container-zM_bj .library-content-PgX4O .message-container-MhY5t .message-label-UExl3{color:hsla(222.8,100%,78%,0.9);flex:none;font-size:2.5rem;text-align:center}.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-gap:0.5rem;align-items:center;align-self:stretch;display:grid;flex:1;grid-auto-rows:-webkit-max-content;grid-auto-rows:max-content;overflow-y:auto;padding:0 1.5rem}.selectable-inputs-modal-rHlo7 .modal-dialog-container-QgsId,.selectable-inputs-modal-rHlo7 .modal-dialog-container-QgsId .modal-dialog-content-ChXwF{overflow:visible}.selectable-inputs-modal-rHlo7 .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-container-H1VZ1{height:3.5rem}.selectable-inputs-modal-rHlo7 .modal-dialog-container-QgsId .modal-dialog-content-ChXwF .select-input-container-H1VZ1:not(:last-child){margin-bottom:1rem}@media only screen and (min-width:2200px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(10,1fr)}}@media only screen and (max-width:2200px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(9,1fr)}}@media only screen and (max-width:1900px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(8,1fr)}}@media only screen and (max-width:1600px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(7,1fr)}}@media only screen and (max-width:1300px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(6,1fr)}}@media only screen and (max-width:1000px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(5,1fr)}}@media only screen and (max-width:800px){.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(4,1fr)}}@media only screen and (max-width:640px){.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or{justify-content:space-between}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .select-input-container-H1VZ1,.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .spacing-Rdiyt{display:none}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .pagination-input-DvMtv{margin-left:0}.library-container-zM_bj .library-content-PgX4O .selectable-inputs-container-hR3or .filter-container-oRBlw{display:flex}.library-container-zM_bj .library-content-PgX4O .meta-items-container-IKrND{grid-template-columns:repeat(3,1fr)}} +.stream-placeholder-container-T1nxv{align-items:center;display:flex;flex-direction:row;padding:0.5rem 1rem}.stream-placeholder-container-T1nxv .addon-container-pm1P0{flex:none}.stream-placeholder-container-T1nxv .addon-container-pm1P0 .addon-name-zAOKP{background-color:var(--color-placeholder-background);height:2rem;width:5rem}.stream-placeholder-container-T1nxv .info-container-Z1Dl6{flex:1;margin:0.5rem 1rem}.stream-placeholder-container-T1nxv .info-container-Z1Dl6 .description-container-ZOMcn{background-color:var(--color-placeholder-background);height:1.2rem}.stream-placeholder-container-T1nxv .info-container-Z1Dl6 .description-container-ZOMcn:first-child{width:80%}.stream-placeholder-container-T1nxv .info-container-Z1Dl6 .description-container-ZOMcn:nth-child(2){margin-top:0.5rem;width:40%}.stream-placeholder-container-T1nxv .play-icon-MXqj3{flex:none;height:5rem;width:3.5rem}.stream-placeholder-container-T1nxv .play-icon-MXqj3 .background-FNyrF{fill:none}.stream-placeholder-container-T1nxv .play-icon-MXqj3 .icon-XXj2q{fill:var(--color-placeholder-background)} +.stream-container-JPdah{align-items:center;display:flex;flex-direction:row;flex-wrap:wrap;padding:0.5rem 1rem}.stream-container-JPdah:focus,.stream-container-JPdah:hover{background-color:hsl(243,24.4%,21%)}.stream-container-JPdah:focus .play-icon-w1yb5 .background-FNyrF,.stream-container-JPdah.selected .play-icon-w1yb5 .background-FNyrF,.stream-container-JPdah:hover .play-icon-w1yb5 .background-FNyrF{fill:hsla(160,81.5%,46.8%,0.9)}.stream-container-JPdah:focus .play-icon-w1yb5 .icon-XXj2q,.stream-container-JPdah.selected .play-icon-w1yb5 .icon-XXj2q,.stream-container-JPdah:hover .play-icon-w1yb5 .icon-XXj2q{fill:hsla(0,0%,100%,0.9)}.stream-container-JPdah .addon-name-container-IZ2De,.stream-container-JPdah .thumbnail-container-ptbAk{flex:none}.stream-container-JPdah .addon-name-container-IZ2De .thumbnail-whoms,.stream-container-JPdah .thumbnail-container-ptbAk .thumbnail-whoms{display:block;height:5rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:5rem}.stream-container-JPdah .addon-name-container-IZ2De .placeholder-icon-znYz0,.stream-container-JPdah .thumbnail-container-ptbAk .placeholder-icon-znYz0{fill:hsla(224.3,42.1%,81%,0.9);display:block;height:5rem;padding:0.5rem;width:5rem}.stream-container-JPdah .addon-name-container-IZ2De .addon-name-tC8PX,.stream-container-JPdah .thumbnail-container-ptbAk .addon-name-tC8PX{color:hsla(0,0%,100%,0.9);font-size:1.1rem;max-height:3.6em;text-align:center;width:5rem}.stream-container-JPdah .info-container-TihQo{color:hsla(0,0%,100%,0.9);flex:1;margin:0.5rem 1rem;max-height:3.6em;white-space:pre}.stream-container-JPdah .play-icon-w1yb5{flex:none;height:5rem;width:3.5rem}.stream-container-JPdah .play-icon-w1yb5 .background-FNyrF{fill:none}.stream-container-JPdah .play-icon-w1yb5 .icon-XXj2q{fill:hsla(0,0%,50%,0.9)}.stream-container-JPdah .progress-bar-container-ADRp_{background-color:hsl(243,24.4%,31%);flex:0 0 100%}.stream-container-JPdah .progress-bar-container-ADRp_ .progress-bar-XrEBL{background-color:hsl(276.8,48%,62%);height:0.5rem}@media only screen and (max-width:640px){.stream-container-JPdah:hover,.stream-containerfocus-xiWVj{background-color:hsla(0,0%,100%,0.2)}.stream-container-JPdah .addon-name-container-IZ2De .addon-name-tC8PX,.stream-container-JPdah .thumbnail-container-ptbAk .addon-name-tC8PX{font-weight:500}.stream-container-JPdah .play-icon-w1yb5 .icon-XXj2q{fill:hsla(0,0%,100%,0.9)}} +.streams-list-container-xYMJo{display:flex;flex-direction:column}.streams-list-container-xYMJo .message-container-f9_L4{align-items:center;align-self:stretch;display:flex;flex:0 1 auto;flex-direction:column;overflow-y:auto;padding:1rem 1rem 0}.streams-list-container-xYMJo .message-container-f9_L4 .image-rIyu6{flex:none;height:10rem;margin-bottom:1rem;max-width:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:10rem}.streams-list-container-xYMJo .message-container-f9_L4 .label-luvnO{color:hsla(222.8,100%,78%,0.9);flex:none;font-size:1.4rem;text-align:center}.streams-list-container-xYMJo .select-input-container-irGn_{background:none;flex:0 0 auto;height:3.5rem;margin:1em 1em 0}.streams-list-container-xYMJo .select-input-container-irGn_:focus,.streams-list-container-xYMJo .select-input-container-irGn_.active,.streams-list-container-xYMJo .select-input-container-irGn_:hover{background-color:hsl(243,24.4%,21%)}.streams-list-container-xYMJo .select-input-container-irGn_>.label-kz1K0{color:hsla(0,0%,100%,0.9)}.streams-list-container-xYMJo .select-input-container-irGn_>.icon-YGvLz{fill:hsla(0,0%,100%,0.9)}.streams-list-container-xYMJo .select-input-container-irGn_ .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}.streams-list-container-xYMJo .streams-container-bbSc4{align-self:stretch;flex:0 1 auto;margin-top:1rem;overflow-y:auto}.streams-list-container-xYMJo .install-button-container-Q60yJ{align-items:center;align-self:stretch;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;justify-content:center;margin:1rem;padding:1.5rem 1rem}.streams-list-container-xYMJo .install-button-container-Q60yJ:focus,.streams-list-container-xYMJo .install-button-container-Q60yJ:hover{background-color:hsl(147.7,68%,46.7%)}.streams-list-container-xYMJo .install-button-container-Q60yJ .icon-SoFgF{fill:hsla(0,0%,100%,0.9);flex:none;height:2rem;margin-right:1rem;width:2rem}.streams-list-container-xYMJo .install-button-container-Q60yJ .label-luvnO{color:hsla(0,0%,100%,0.9);flex:0 1 auto;font-size:1.5rem;font-weight:500;max-height:3.6em;text-align:center}@media only screen and (max-width:640px){.streams-list-container-xYMJo{overflow:visible}.streams-list-container-xYMJo .streams-container-bbSc4{margin-top:0;scrollbar-color:hsla(0,0%,100%,0.2) transparent}.streams-list-container-xYMJo .streams-container-bbSc4::-webkit-scrollbar-thumb{background-color:hsla(0,0%,100%,0.2)}.streams-list-container-xYMJo .streams-container-bbSc4::-webkit-scrollbar-track{background-color:transparent}} +.seasons-bar-placeholder-container-M81RN{display:flex;flex-direction:row;justify-content:space-between;padding:1rem}.seasons-bar-placeholder-container-M81RN .next-season-button-oGnlT,.seasons-bar-placeholder-container-M81RN .prev-season-button-TCbOq{align-items:center;display:flex;flex:none;flex-direction:row;height:3.5rem;padding:0.5rem;width:6.5rem}.seasons-bar-placeholder-container-M81RN .next-season-button-oGnlT>:first-child,.seasons-bar-placeholder-container-M81RN .prev-season-button-TCbOq>:first-child{margin-right:0.5rem}.seasons-bar-placeholder-container-M81RN .next-season-button-oGnlT .icon-UzQjF,.seasons-bar-placeholder-container-M81RN .prev-season-button-TCbOq .icon-UzQjF{fill:var(--color-placeholder-background);display:block;flex:none;height:1.5rem;width:1.5rem}.seasons-bar-placeholder-container-M81RN .next-season-button-oGnlT .label-lmBnj,.seasons-bar-placeholder-container-M81RN .prev-season-button-TCbOq .label-lmBnj{color:var(--color-placeholder-text);flex:1;font-weight:500;max-height:1.2em;text-align:center}.seasons-bar-placeholder-container-M81RN .seasons-popup-label-container-r2UDB{align-items:center;display:flex;flex:0 1 auto;flex-direction:row;margin:0 1rem}.seasons-bar-placeholder-container-M81RN .seasons-popup-label-container-r2UDB .seasons-popup-label-xBinL{color:var(--color-placeholder-text);font-weight:500;max-height:1.2em}.seasons-bar-placeholder-container-M81RN .seasons-popup-label-container-r2UDB .seasons-popup-icon-p1T5d{fill:var(--color-placeholder-background);flex:none;height:1rem;margin-left:1rem;width:1rem} +.seasons-bar-container-nOZjG{display:flex;flex-direction:row;justify-content:space-between;overflow:visible;padding:1rem}.seasons-bar-container-nOZjG .next-season-button-RrYAq,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ{align-items:center;display:flex;flex:none;flex-direction:row;height:3.5rem;padding:0.5rem;width:6.5rem}.seasons-bar-container-nOZjG .next-season-button-RrYAq:focus .label-uJbfD,.seasons-bar-container-nOZjG .next-season-button-RrYAq:hover .label-uJbfD,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ:focus .label-uJbfD,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ:hover .label-uJbfD{color:hsla(0,0%,85%,0.9)}.seasons-bar-container-nOZjG .next-season-button-RrYAq:focus .icon-_ZBEE,.seasons-bar-container-nOZjG .next-season-button-RrYAq:hover .icon-_ZBEE,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ:focus .icon-_ZBEE,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ:hover .icon-_ZBEE{fill:hsla(0,0%,85%,0.9)}.seasons-bar-container-nOZjG .next-season-button-RrYAq:focus,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ:focus{background-color:hsla(0,0%,100%,0.1)}.seasons-bar-container-nOZjG .next-season-button-RrYAq>:first-child,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ>:first-child{margin-right:0.5rem}.seasons-bar-container-nOZjG .next-season-button-RrYAq .label-uJbfD,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ .label-uJbfD{color:hsla(0,0%,75%,0.9);flex:1;font-weight:500;max-height:1.2em;text-align:center}.seasons-bar-container-nOZjG .next-season-button-RrYAq .icon-_ZBEE,.seasons-bar-container-nOZjG .prev-season-button-bs1GQ .icon-_ZBEE{fill:hsla(0,0%,75%,0.9);flex:none;height:1.5rem;width:1.5rem}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4{background:none;flex:0 1 auto;height:3.5rem}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4:focus,.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4.active,.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4:hover{background-color:hsl(243,24.4%,21%)}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4>.label-kz1K0{color:hsla(0,0%,100%,0.9)}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4>.icon-YGvLz{fill:hsla(0,0%,100%,0.9)}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4 .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}@media only screen and (max-width:640px){.seasons-bar-container-nOZjG{padding-top:0}.seasons-bar-container-nOZjG .seasons-popup-label-container-fZcu4 .menu-container-Z1Pou{max-height:calc(3.2rem * 3)}} +.video-placeholder-container-uDsav{align-items:center;display:flex;flex-direction:row;padding:0.5rem 1rem}.video-placeholder-container-uDsav .info-container-KTKtT{display:flex;flex:1;flex-direction:column;height:3rem;justify-content:space-between;margin:0.5rem 1rem}.video-placeholder-container-uDsav .info-container-KTKtT .name-container-Jvesr{background:var(--color-placeholder-background);height:1.2rem;width:80%}.video-placeholder-container-uDsav .info-container-KTKtT .released-container-uoc4E{background:var(--color-placeholder-background);height:1rem} +.video-container-UBBpR{display:flex;flex-direction:row;flex-wrap:wrap;padding:0.5rem 1rem}.video-container-UBBpR:focus,.video-container-UBBpR.active,.video-container-UBBpR:hover{background-color:hsl(243,24.4%,21%)}.video-container-UBBpR .thumbnail-container-n_jp7{flex:none}.video-container-UBBpR .thumbnail-container-n_jp7 .thumbnail-MiS3K{display:block;height:5rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:7.5rem}.video-container-UBBpR .thumbnail-container-n_jp7 .placeholder-icon-LzVIO{fill:hsl(0,0%,100%);background-color:hsla(0,0%,100%,0.4);display:block;height:5rem;opacity:0.25;padding:1rem;width:7.5rem}.video-container-UBBpR .info-container-szYxP{align-self:stretch;display:flex;flex:1;flex-direction:column;justify-content:space-between;margin:0.5rem 1rem}.video-container-UBBpR .info-container-szYxP:first-child{height:3rem}.video-container-UBBpR .info-container-szYxP:first-child .title-container-EMXpV{max-height:1.2em}.video-container-UBBpR .info-container-szYxP .title-container-EMXpV{color:hsla(0,0%,100%,0.9);max-height:2.4em}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua{align-items:center;display:flex;flex-direction:row;justify-content:flex-end}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .released-container-zA91y{color:hsla(0,0%,50%,0.9);flex:1;font-size:0.8rem;font-weight:500;margin-right:0.5rem;padding:0.2rem 0;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd{display:flex;flex:0 1 auto;flex-direction:row}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd>:nth-child(2){margin-left:0.5rem}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .upcoming-container-ASE1L,.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .watched-container-LCso2{flex:none;max-width:10rem;padding:0.2rem 0.4rem}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .upcoming-container-ASE1L:not(:only-child),.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .watched-container-LCso2:not(:only-child){max-width:5rem}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .upcoming-container-ASE1L .flag-label-dIdBb,.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .watched-container-LCso2 .flag-label-dIdBb{color:hsla(243,24.4%,21%,0.9);font-size:0.8rem;font-weight:500;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .upcoming-container-ASE1L{background-color:hsl(160,81.5%,46.8%)}.video-container-UBBpR .info-container-szYxP .flex-row-container-ExEua .upcoming-watched-container-y_ijd .watched-container-LCso2{background-color:hsl(42,100%,54.9%)}.video-container-UBBpR .progress-bar-container-gMpiB{background-color:hsl(243,24.4%,31%);flex:0 0 100%}.video-container-UBBpR .progress-bar-container-gMpiB .progress-bar-Yhl4z{background-color:hsl(276.8,48%,62%);height:0.5rem}.video-container-UBBpR .menu-container-bfvDO{max-width:calc(90% - 1.5rem)}.video-container-UBBpR .menu-container-bfvDO .context-menu-content-MGBhW{--spatial-navigation-contain:contain;background-color:hsl(243,24.4%,16%)}.video-container-UBBpR .menu-container-bfvDO .context-menu-content-MGBhW .context-menu-option-container-VlNjD{align-items:center;display:flex;flex-direction:row;padding:0.5rem 1rem}.video-container-UBBpR .menu-container-bfvDO .context-menu-content-MGBhW .context-menu-option-container-VlNjD:focus,.video-container-UBBpR .menu-container-bfvDO .context-menu-content-MGBhW .context-menu-option-container-VlNjD:hover{background-color:hsl(243,24.4%,21%)}.video-container-UBBpR .menu-container-bfvDO .context-menu-content-MGBhW .context-menu-option-container-VlNjD .context-menu-option-label-hOUnH{color:hsla(0,0%,100%,0.9);font-size:1rem;max-height:2.4em}@media only screen and (max-width:640px){.video-container-UBBpR:focus,.video-container-UBBpR.active,.video-container-UBBpR:hover{background-color:hsla(0,0%,100%,0.2)}.video-container-UBBpR .menu-container-bfvDO.menu-direction-bottom-left-Uw06K,.video-container-UBBpR .menu-container-bfvDO.menu-direction-top-left-KpAQN{right:1.5rem}.video-container-UBBpR .menu-container-bfvDO.menu-direction-bottom-right-XZ9Ch,.video-container-UBBpR .menu-container-bfvDO.menu-direction-top-right-jOtwq{left:1.5rem}.video-container-UBBpR .menu-container-bfvDO.menu-direction-top-left-KpAQN,.video-container-UBBpR .menu-container-bfvDO.menu-direction-top-right-jOtwq{bottom:90%}.video-container-UBBpR .menu-container-bfvDO.menu-direction-bottom-left-Uw06K,.video-container-UBBpR .menu-container-bfvDO.menu-direction-bottom-right-XZ9Ch{top:90%}} +.videos-list-container-NepX5{display:flex;flex-direction:column}.videos-list-container-NepX5 .message-container-_hhmQ{align-items:center;align-self:stretch;display:flex;flex:1;flex-direction:column;overflow-y:auto;padding:2rem}.videos-list-container-NepX5 .message-container-_hhmQ .image-_xAbP{flex:none;height:10rem;margin-bottom:1rem;max-width:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:10rem}.videos-list-container-NepX5 .message-container-_hhmQ .label-Ff1_X{color:hsla(222.8,100%,78%,0.9);flex:none;font-size:1.4rem;text-align:center}.videos-list-container-NepX5 .seasons-bar-Ma8vp{align-self:stretch;flex:none}.videos-list-container-NepX5 .search-bar-mZHWa{align-self:stretch;flex:none;margin:0 1.5rem 1rem}.videos-list-container-NepX5 .search-bar-mZHWa:first-child{margin-top:1rem}.videos-list-container-NepX5 .videos-container-msX8s{align-self:stretch;flex:1;overflow-y:auto}@media only screen and (max-width:640px){.videos-list-container-NepX5{overflow:visible}} +.metadetails-container-K_Dqa{background-color:hsl(243,24.4%,11%);display:flex;flex-direction:column;height:100%;width:100%}.metadetails-container-K_Dqa .nav-bar-MH6Vk{align-self:stretch;flex:none}.metadetails-container-K_Dqa .metadetails-content-Uz5EV{align-self:stretch;display:flex;flex:1;flex-direction:row;position:relative;z-index:0}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .vertical-nav-bar-B39nq{--vertical-nav-bar-size:6rem;flex:none}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .background-image-layer-wJa90{bottom:0;left:0;position:absolute;right:0;top:0;z-index:-1}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .background-image-layer-wJa90:after{background:hsla(243,24.4%,11%,0.7);bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .background-image-layer-wJa90 .background-image-tSjYu{display:block;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:top left;object-position:top left;opacity:0.9;width:100%}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .meta-message-container-MJZN5{align-items:center;align-self:stretch;display:flex;flex:0 1 30rem;flex-direction:column;padding:2rem}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .meta-message-container-MJZN5 .image-R1LcJ{flex:none;height:12rem;margin-bottom:1rem;max-width:100%;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .meta-message-container-MJZN5 .message-label-Uz4_P{align-self:stretch;color:hsla(222.8,100%,78%,0.9);flex:none;font-size:2rem;text-align:center}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .meta-preview-ES0h3{align-self:stretch;flex:0 1 40rem}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .spacing-rgIYg{flex:1}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .streams-list-Y1lCM,.metadetails-container-K_Dqa .metadetails-content-Uz5EV .videos-list-nE0LJ{align-self:stretch;background-color:hsla(0,0%,0%,0.7);flex:0 0 26.5rem}.meta-extension-modal-container-gHjqy .modal-dialog-container-QgsId{height:80%;width:80%}.meta-extension-modal-container-gHjqy .modal-dialog-container-QgsId .title-container-wqhp3{max-height:1.2em}.meta-extension-modal-container-gHjqy .modal-dialog-container-QgsId .meta-extension-modal-iframe-GGHlm{height:100%;width:100%}@media only screen and (max-width:640px){.metadetails-container-K_Dqa{position:relative;z-index:0}.metadetails-container-K_Dqa .metadetails-content-Uz5EV{display:block;overflow-y:auto;position:static;z-index:initial}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .spacing-rgIYg{display:none}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .background-image-layer-wJa90{top:var(--horizontal-nav-bar-size)}.metadetails-container-K_Dqa .metadetails-content-Uz5EV .streams-list-Y1lCM,.metadetails-container-K_Dqa .metadetails-content-Uz5EV .videos-list-nE0LJ{background-color:transparent}} +.search-container-uXEFf{background-color:hsl(243,24.4%,11%);height:100%;width:100%}.search-container-uXEFf .search-content-LX6un{height:100%;overflow-y:auto;width:100%}.search-container-uXEFf .search-content-LX6un .search-row-EQLaD{margin:4rem 2rem}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM{align-content:flex-start;align-items:flex-start;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:flex-start;padding:4rem}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM .search-hint-container-kd8iX{align-items:center;display:flex;flex:0 0 50%;flex-direction:column;justify-content:center;margin-bottom:4rem;padding:0 2rem}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM .search-hint-container-kd8iX .icon-fOZZl{fill:hsla(0,0%,100%,0.9);flex:none;height:6rem;margin-bottom:2rem;width:6rem}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM .search-hint-container-kd8iX .label-l6wxz{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.2rem;text-align:center}.search-container-uXEFf .search-content-LX6un .message-container-YAunr{align-items:center;display:flex;flex-direction:column;padding:4rem}.search-container-uXEFf .search-content-LX6un .message-container-YAunr .image-Xuwya{flex:none;height:12rem;margin-bottom:1rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.search-container-uXEFf .search-content-LX6un .message-container-YAunr .message-label-K8LPz{color:hsla(222.8,100%,78%,0.9);flex:0 1 auto;font-size:2.5rem;text-align:center}@media only screen and (max-width:2200px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+9),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+9),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+10),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+10),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+10),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+10){display:none}}@media only screen and (max-width:1900px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+8),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+8),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+9),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+9),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+9),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+9){display:none}}@media only screen and (max-width:1600px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+7),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+7),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+8),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+8),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+8),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+8){display:none}}@media only screen and (max-width:1300px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+6),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+6),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+7),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+7),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+7),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+7){display:none}}@media only screen and (max-width:1000px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+5),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+5),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+6),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+6),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+6),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+6){display:none}}@media only screen and (max-width:800px){.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-IegjY:nth-child(n+4),.search-container-uXEFf .search-content-LX6un .search-row-landscape-o3Lfv .meta-item-x28TU:nth-child(n+4),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+5),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+5),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+5),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+5){display:none}}@media only screen and (max-width:640px){.search-container-uXEFf .search-content-LX6un .search-row-EQLaD{margin:2rem 1rem}.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-IegjY:nth-child(n+4),.search-container-uXEFf .search-content-LX6un .search-row-poster-m7CUE .meta-item-x28TU:nth-child(n+4),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-IegjY:nth-child(n+4),.search-container-uXEFf .search-content-LX6un .search-row-square-VesJA .meta-item-x28TU:nth-child(n+4){display:none}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM{padding:4rem 2rem}.search-container-uXEFf .search-content-LX6un .search-hints-container-FHpPM .search-hint-container-kd8iX{padding:0 1.5rem}} +.settings-container-b0DCu{background-color:hsl(243,24.4%,11%);height:100%;width:100%}.settings-container-b0DCu .settings-content-lLXmk{display:flex;flex-direction:row;height:100%;width:100%}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D{align-self:stretch;display:flex;flex:none;flex-direction:column;padding:3rem;width:20rem}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .side-menu-button-vbkJ1{align-self:stretch;color:hsla(224.3,42.1%,66%,0.9);flex:none;font-size:1.1rem;padding:1rem}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .side-menu-button-vbkJ1.selected-yhdng{background-color:hsl(243,24.4%,21%);color:hsla(0,0%,100%,0.9)}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .side-menu-button-vbkJ1:hover{background-color:hsl(243,24.4%,26%)}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .spacing-fpLUM{flex:1}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .version-info-label-uMkm7{color:hsla(224.3,42.1%,66%,0.9);flex:0 1 auto;margin:0.5rem 0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe{align-self:stretch;flex:1;overflow-y:auto;padding:0 2rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ{display:flex;flex-direction:column;overflow:visible;padding:3rem 0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ:not(:last-child){border-bottom:thin solid hsla(224.3,42.1%,66%,0.9)}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .section-title-Nt71Z{align-self:stretch;color:hsla(0,0%,100%,0.9);flex:none;font-size:1.8rem;line-height:3.4rem;margin-bottom:1rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv{align-items:center;align-self:stretch;display:flex;flex:none;flex-direction:row;margin-bottom:2rem;max-width:35rem;overflow:visible}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv:last-child{margin-bottom:0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc{height:6rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .avatar-container-YWq9E{align-self:stretch;background-clip:content-box;background-origin:content-box;background-position:center;background-repeat:no-repeat;background-size:cover;border-radius:50%;flex:none;margin-right:1rem;opacity:0.9;width:6rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM{align-self:stretch;display:flex;flex:1;flex-direction:column;padding:1rem 0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .email-label-container-oVmiO,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2{align-items:center;display:flex;flex-direction:row}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .email-label-container-oVmiO{flex:1 0 auto}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .email-label-container-oVmiO .email-label-Q__sJ{color:hsla(0,0%,100%,0.9);flex:1;font-size:1.1rem;max-height:2.4em}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2{flex:0 1 50%}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2:focus,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2:hover{outline:none}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2:focus .logout-label-zo4ES,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2:hover .logout-label-zo4ES{color:hsla(0,0%,100%,0.9);text-decoration:underline}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .email-logout-container-kYQDM .logout-button-container-jLrU2 .logout-label-zo4ES{color:hsla(0,0%,75%,0.9);flex:1;max-height:1.2em}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .user-panel-container-kkrJG{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;height:3.5rem;margin-left:1rem;width:10rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .user-panel-container-kkrJG:hover{background-color:hsl(147.7,68%,46.7%)}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv.user-info-option-container-oRLJc .user-panel-container-kkrJG .user-panel-label-beAQl{color:hsla(0,0%,100%,0.9);flex:1;font-weight:500;max-height:2.4em;padding:0 0.5rem;text-align:center}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-name-container-exGMI{align-items:center;display:flex;flex:1 1 50%;flex-direction:row}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT .icon-REQkK,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-name-container-exGMI .icon-REQkK{fill:hsla(0,0%,100%,0.9);flex:none;height:1.5rem;margin-right:0.5rem;width:1.5rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT .label-FFamJ,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-name-container-exGMI .label-FFamJ{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;line-height:1.5rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-name-container-exGMI{justify-content:flex-start;margin-right:2rem;padding:1rem 1rem 1rem 0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT{padding:1rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.button-container-ENMae{background-color:hsl(147.7,68%,41.7%);justify-content:center}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.button-container-ENMae:hover{background-color:hsl(147.7,68%,46.7%)}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.button-container-ENMae .label-FFamJ{font-weight:500}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.multiselect-container-w0c9l>.label-kz1K0{line-height:1.5rem;max-height:1.5rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.multiselect-container-w0c9l .menu-container-Z1Pou{max-height:calc(3.2rem * 7);overflow:auto}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.link-container-ERYsD{flex:0 1 auto;padding:1rem 0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.link-container-ERYsD:hover .label-FFamJ{text-decoration:underline}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.checkbox-container-R9LLN{justify-content:center}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.checkbox-container-R9LLN .icon-NUvac{height:1.5rem;width:1.5rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.color-input-container-WclA_{padding:1.75rem 1rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.info-container-wfFcS{justify-content:center}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.info-container-wfFcS.selectable-eucrJ,.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.info-container-wfFcS.selectable-eucrJ .label-FFamJ{-webkit-user-select:text;-moz-user-select:text;user-select:text}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.configure-input-container-PMyIY{padding:0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.configure-input-container-PMyIY .label-FFamJ{flex-grow:1;padding:0 1rem;text-overflow:ellipsis;white-space:pre}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.configure-input-container-PMyIY .configure-button-container-xGFgg{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;height:3rem;justify-content:center;width:3rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.configure-input-container-PMyIY .configure-button-container-xGFgg:hover{background-color:hsl(147.7,68%,46.7%)}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.configure-input-container-PMyIY .configure-button-container-xGFgg .icon-REQkK{fill:hsla(0,0%,100%,0.9);flex:none;height:1rem;margin:0;width:1rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.shortcut-container-ZSm5O{justify-content:center;overflow:visible;padding:0}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.shortcut-container-ZSm5O kbd{background-color:hsl(243,24.4%,21%);border-radius:0.25em;box-shadow:0 4px 0 1px hsla(243,24.4%,21%,0.4);color:hsla(224.3,42.1%,66%,0.9);flex:0 1 auto;font-weight:500;height:2.5rem;line-height:2.5rem;min-width:2.5rem;padding:0 1rem}.settings-container-b0DCu .settings-content-lLXmk .sections-container-EUKAe .section-container-twzKQ .option-container-EGlcv .option-input-container-NPgpT.shortcut-container-ZSm5O .label-FFamJ{color:hsla(224.3,42.1%,66%,0.9);margin:0 1rem;white-space:nowrap}.configure-server-url-modal-container-vSL44 .modal-dialog-content-ChXwF{width:30rem}.configure-server-url-modal-container-vSL44 .modal-dialog-content-ChXwF .server-url-input-Dfazw{color:hsl(0,0%,50%);outline:var(--focus-outline-size) solid hsl(0,0%,85%);outline-offset:calc(-1 * var(--focus-outline-size));padding:1rem;width:100%}.configure-server-url-modal-container-vSL44 .modal-dialog-content-ChXwF .server-url-input-Dfazw:hover{outline-color:hsl(0,0%,95%)}.configure-server-url-modal-container-vSL44 .modal-dialog-content-ChXwF .server-url-input-Dfazw:focus{outline-color:hsl(0,0%,0%)}.configure-server-url-modal-container-vSL44 .cancel-button-iydew{background-color:transparent}.configure-server-url-modal-container-vSL44 .cancel-button-iydew:hover{background-color:hsl(0,0%,90%)}.configure-server-url-modal-container-vSL44 .cancel-button-iydew:focus{outline-color:hsl(0,0%,0%)}.configure-server-url-modal-container-vSL44 .cancel-button-iydew .label-_ADoX{color:hsl(0,0%,65%)}@media only screen and (max-width:640px){.settings-container-b0DCu .settings-content-lLXmk{flex-direction:column-reverse}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D{padding:0 1rem;width:100%}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .side-menu-button-vbkJ1{display:none}.settings-container-b0DCu .settings-content-lLXmk .side-menu-container-NG17D .version-info-label-uMkm7{text-align:end;width:100%}.configure-server-url-modal-container-vSL44 .modal-dialog-content-ChXwF{width:auto}} +.buffering-loader-container-P7S0m{align-items:center;display:flex;justify-content:center}.buffering-loader-container-P7S0m .buffering-loader-fMSpb{flex:none;height:17rem;width:17rem} +.seek-bar-container-JGGTa{align-items:center;display:flex;flex-direction:row}.seek-bar-container-JGGTa.active .slider-hBDOf:not(.disabled) .thumb-tfDk6,.seek-bar-container-JGGTa:hover .slider-hBDOf:not(.disabled) .thumb-tfDk6{fill:hsl(0,0%,100%)}.seek-bar-container-JGGTa:hover .slider-hBDOf:not(.disabled) .track-before-FwOXh{transition:background-color 0s 100ms}.seek-bar-container-JGGTa:hover .slider-hBDOf:not(.disabled) .thumb-tfDk6{transition:fill 0s 100ms}.seek-bar-container-JGGTa .label-QFbsS{color:hsl(0,0%,100%);direction:rtl;flex:none;max-width:5rem;text-align:left;text-overflow:ellipsis;white-space:nowrap}.seek-bar-container-JGGTa .slider-hBDOf{align-self:stretch;flex:1;margin:0 var(--thumb-size)}.seek-bar-container-JGGTa .slider-hBDOf .thumb-tfDk6{fill:transparent} +.volume-slider-G_xAt:not(.disabled) .track-jWhBI{background-color:hsl(0,0%,50%)}.volume-slider-G_xAt:not(.disabled) .track-before-FwOXh{background-color:hsl(0,0%,90%)}.volume-slider-G_xAt:not(.disabled).active .track-before-FwOXh,.volume-slider-G_xAt:not(.disabled):hover .track-before-FwOXh{background-color:hsl(0,0%,100%)} +.control-bar-container-xsWA7{padding:0 1.5rem}.control-bar-container-xsWA7 .seek-bar-I7WeY{--track-size:0.5rem;--thumb-size:1.5rem;height:2.5rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU{align-items:center;display:flex;flex-direction:row}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-button-FQUsj{align-items:center;display:flex;flex:none;height:4rem;justify-content:center;width:4rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-button-FQUsj.disabled .icon-qy6I6{fill:hsl(0,0%,75%)}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-button-FQUsj .icon-qy6I6{fill:hsl(0,0%,100%);flex:none;height:2rem;width:3rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .volume-slider-U9jfo{--track-size:0.4rem;--thumb-size:1.3rem;flex:0 1 16rem;height:4rem;margin:0 1rem;min-width:10rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .spacing-p8NJQ{flex:1}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-button-h0MWd{align-items:center;display:none;flex:none;height:4rem;justify-content:center;width:4rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-button-h0MWd .icon-qy6I6{fill:hsl(0,0%,100%);flex:none;height:2rem;width:3rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-container-M6L0_{display:flex;flex:none;flex-direction:row}@media only screen and (max-width:640px){.control-bar-container-xsWA7{padding:0}.control-bar-container-xsWA7 .seek-bar-I7WeY{margin:0 1.5rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU{overflow:visible;padding:0 0.5rem;position:relative}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .volume-slider-U9jfo{display:none}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-button-h0MWd{display:flex}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-container-M6L0_{background-color:hsl(243,24.4%,16%);bottom:4.5rem;box-shadow:0 1.35rem 2.7rem hsla(0,0%,0%,0.4),0 1.1rem 0.85rem hsla(0,0%,0%,0.2);flex-direction:column;padding:0.5rem;position:absolute;right:0.15rem}.control-bar-container-xsWA7 .control-bar-buttons-container-SWhkU .control-bar-buttons-menu-container-M6L0_:not(.open){display:none}} +.next-video-popup-container-H4wnL{-webkit-animation:slide-fade-in-rk2M8 0.5s ease-in;animation:slide-fade-in-rk2M8 0.5s ease-in;display:flex;flex-direction:row;height:16rem;width:40rem}@-webkit-keyframes slide-fade-in-rk2M8{0%{opacity:0;transform:translateX(calc(40rem + 2rem))}to{opacity:1;transform:translateX(0)}}@keyframes slide-fade-in-rk2M8{0%{opacity:0;transform:translateX(calc(40rem + 2rem))}to{opacity:1;transform:translateX(0)}}.next-video-popup-container-H4wnL .poster-container-tXZjA{align-items:center;background-color:hsl(243,24.4%,21%);display:flex;flex:1 1 40%;justify-content:center}.next-video-popup-container-H4wnL .poster-container-tXZjA .poster-image-2D6wg{flex:none;height:100%;-o-object-fit:cover;object-fit:cover;-o-object-position:center;object-position:center;width:100%}.next-video-popup-container-H4wnL .poster-container-tXZjA .placeholder-icon-fu1rK{fill:hsla(243,24.4%,36%,0.9);flex:none;height:50%;width:80%}.next-video-popup-container-H4wnL .info-container-KLOMx{display:flex;flex:1 1 70%;flex-direction:column}.next-video-popup-container-H4wnL .info-container-KLOMx .details-container-bUOTZ{flex:auto;padding:1.5rem}.next-video-popup-container-H4wnL .info-container-KLOMx .details-container-bUOTZ .name-sIiDL{align-self:stretch;color:hsla(0,0%,100%,0.9);flex:none;font-weight:600;margin-bottom:0.5rem;max-height:2.4em}.next-video-popup-container-H4wnL .info-container-KLOMx .details-container-bUOTZ .description-gIXiC{color:hsla(0,0%,100%,0.5)}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ{display:flex;flex-direction:row}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .spacing-iFwsN{flex:0 0 50%}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t{align-items:center;display:flex;flex:0 0 50%;flex-direction:row;height:3.5rem;justify-content:center}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t.play-button-Dluk6{background-color:hsl(147.7,68%,41.7%)}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t.play-button-Dluk6 .icon-N3Ewm{fill:hsla(0,0%,100%,0.9)}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t.play-button-Dluk6 .label-zOq_w{color:hsla(0,0%,100%,0.9)}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t.play-button-Dluk6:focus,.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t.play-button-Dluk6:hover{background-color:hsl(147.7,68%,46.7%)}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t .icon-N3Ewm{fill:hsla(224.3,42.1%,66%,0.9);flex:none;height:1.4rem;margin-right:1rem;width:1.4rem}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t .label-zOq_w{color:hsla(224.3,42.1%,66%,0.9);flex:none;font-size:1.1rem;font-weight:500;max-height:2.4em}.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t:focus,.next-video-popup-container-H4wnL .info-container-KLOMx .buttons-container-iYrpZ .button-container-i4F7t:hover{background-color:hsl(243,24.4%,31%)} +.info-menu-container-R1QKH{width:30rem}.info-menu-container-R1QKH .stream-MY2Oy{pointer-events:none} +.option-container-m_jZq{align-items:center;display:flex;flex-direction:row;height:4rem}.option-container-m_jZq .icon-krR0X{fill:hsla(0,0%,100%,0.9);flex:none;height:1.4rem;margin:1.3rem;width:1.4rem}.option-container-m_jZq .label-cmqqu{color:hsla(0,0%,100%,0.9);flex:1;font-weight:400;max-height:2.4em}.option-container-m_jZq:hover{background-color:hsl(243,24.4%,31%)}.option-container-m_jZq.disabled{opacity:0.5} +.options-menu-container-qlzLt{width:15rem} +.videos-menu-container-ATzKq{width:30rem} +.discrete-input-container-CMThy.disabled .header-n0jWL{color:hsla(0,0%,75%,0.9)}.discrete-input-container-CMThy.disabled .input-container-TNuI2{opacity:0.4}.discrete-input-container-CMThy .header-n0jWL{color:hsla(0,0%,100%,0.9);margin-bottom:0.5rem;max-height:2.4em}.discrete-input-container-CMThy .input-container-TNuI2{align-items:center;background:hsl(243,24.4%,21%);display:flex;flex-direction:row}.discrete-input-container-CMThy .input-container-TNuI2 .button-container-ciSB5{background-color:hsl(243,24.4%,31%);flex:none;height:3rem;padding:1rem;width:3rem}.discrete-input-container-CMThy .input-container-TNuI2 .button-container-ciSB5 .icon-JDltr{fill:hsla(0,0%,100%,0.9);display:block;height:100%;width:100%}.discrete-input-container-CMThy .input-container-TNuI2 .option-label-tjeeT{color:hsla(0,0%,100%,0.9);flex:1;font-weight:500;max-height:2.4em;text-align:center} +.subtitles-menu-container-PxBRZ{display:flex;flex-direction:row;height:23rem}.subtitles-menu-container-PxBRZ .languages-container-NS7H9,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS,.subtitles-menu-container-PxBRZ .variants-container-XglzH{align-self:stretch;display:flex;flex:none;flex-direction:column}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-header-jGNcK,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .settings-header-eaWnm,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-header-TsVSR,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-header-jGNcK,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .settings-header-eaWnm,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-header-TsVSR,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-header-jGNcK,.subtitles-menu-container-PxBRZ .variants-container-XglzH .settings-header-eaWnm,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-header-TsVSR{align-self:stretch;color:hsla(0,0%,100%,0.9);flex:none;font-weight:600;margin:1rem;max-height:2.4em}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B{align-self:stretch;flex:1;overflow-y:auto}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA{align-items:center;display:flex;flex-direction:row;padding:1rem 1.5rem}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA:hover,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA:hover,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA:hover,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA:hover,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA:hover,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9.selected,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9:hover,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA.selected,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA:hover{background-color:hsl(243,24.4%,21%)}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA .variant-label-opjnP,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA .variant-label-opjnP,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA .variant-label-opjnP,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA .variant-label-opjnP,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA .variant-label-opjnP,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9 .language-label-FjjqA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9 .variant-label-opjnP,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA .language-label-FjjqA,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA .variant-label-opjnP{color:hsla(0,0%,100%,0.9);flex:1;font-size:1.1rem;max-height:2.4em}.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .languages-list-sxIwI .variant-option-t7_LA .icon-I1Ruh,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .languages-container-NS7H9 .variants-list-yZo6B .variant-option-t7_LA .icon-I1Ruh,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .languages-list-sxIwI .variant-option-t7_LA .icon-I1Ruh,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .variants-list-yZo6B .variant-option-t7_LA .icon-I1Ruh,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .variants-container-XglzH .languages-list-sxIwI .variant-option-t7_LA .icon-I1Ruh,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .language-option-O1Yr9 .icon-I1Ruh,.subtitles-menu-container-PxBRZ .variants-container-XglzH .variants-list-yZo6B .variant-option-t7_LA .icon-I1Ruh{background-color:hsla(147.7,68%,41.7%,0.9);border-radius:100%;flex:none;height:0.5rem;margin-left:1rem;width:0.5rem}.subtitles-menu-container-PxBRZ .languages-container-NS7H9,.subtitles-menu-container-PxBRZ .variants-container-XglzH{width:12rem}.subtitles-menu-container-PxBRZ .variants-container-XglzH .no-variants-container-q6u1Q{align-self:stretch;flex:1;padding:1rem}.subtitles-menu-container-PxBRZ .variants-container-XglzH .no-variants-container-q6u1Q .no-variants-label-RmDKZ{color:hsla(0,0%,75%,0.9);font-weight:500;max-height:4.8em}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS{width:16rem}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .spacing-AWJpt{flex:1}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .discrete-input-fXELp{margin:0 1.5rem 1rem}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .advanced-button-YGN5T{align-self:flex-end;color:hsla(0,0%,100%,0.9);flex:none;margin:0 1.5rem 1rem;max-width:calc(100% - 3rem);text-overflow:ellipsis;white-space:nowrap}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .advanced-button-YGN5T:hover{text-decoration:underline}.subtitles-menu-container-PxBRZ .subtitles-settings-container-LhRGS .advanced-button-YGN5T.disabled{color:hsla(0,0%,75%,0.9)} +.option-_O96j{align-items:center;display:flex;flex-direction:row;padding:0 1.5em}.option-_O96j.selected{background-color:hsl(243,24.4%,21%)}.option-_O96j.selected .icon-kqaPF{display:block}.option-_O96j:focus,.option-_O96j:hover{background-color:hsl(243,24.4%,31%)}.option-_O96j .label-FEOiu{color:hsla(0,0%,100%,0.9);flex:1;font-weight:400}.option-_O96j .icon-kqaPF{background-color:hsla(147.7,68%,41.7%,0.9);border-radius:100%;display:none;flex:none;height:0.5rem;margin-left:1rem;width:0.5rem} +.speed-menu-container-ABjzc{overflow:visible!important;width:12rem}.speed-menu-container-ABjzc .title-Hu2Dm{align-self:stretch;color:hsla(0,0%,100%,0.9);flex:none;font-weight:600;margin:1rem;max-height:2.4em}.speed-menu-container-ABjzc .options-container-DNn3D{flex:0 1 auto;max-height:calc(3.2rem * 8);overflow-y:auto}.speed-menu-container-ABjzc .options-container-DNn3D .option-GcPlB{height:3.2rem} +.video-container-v9_vA .video-tkpQm{height:100%;width:100%}.video-container-v9_vA .video-tkpQm *{font-size:inherit} +html:not(.active-slider-within-lQFc1) .player-container-wIELK.immersed-Y0hn1{cursor:none}html:not(.active-slider-within-lQFc1) .player-container-wIELK.immersed-Y0hn1 .control-bar-layer-m2jto,html:not(.active-slider-within-lQFc1) .player-container-wIELK.immersed-Y0hn1 .menu-layer-HZFG9,html:not(.active-slider-within-lQFc1) .player-container-wIELK.immersed-Y0hn1 .nav-bar-layer-r9HT5{opacity:0;transition:opacity 200ms}.player-container-wIELK{background-color:hsl(0,0%,0%);height:100%;position:relative;width:100%;z-index:0}.player-container-wIELK .layer-qalDW{bottom:0;left:0;position:absolute;right:0;top:0;z-index:0}.player-container-wIELK .layer-qalDW.error-layer-RCEZC{align-items:center;background-color:hsl(0,0%,0%);display:flex;flex-direction:column;justify-content:center}.player-container-wIELK .layer-qalDW.error-layer-RCEZC .error-label-FPIMw{color:hsla(0,0%,100%,0.9);flex:0 1 auto;font-size:2rem;max-height:4.8em;padding:0 8rem;text-align:center}.player-container-wIELK .layer-qalDW.error-layer-RCEZC .playlist-button-CB2WC{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex:none;flex-direction:row;height:3.5rem;margin-top:1.5rem;max-width:16rem;padding:0.5rem 1rem}.player-container-wIELK .layer-qalDW.error-layer-RCEZC .playlist-button-CB2WC:focus,.player-container-wIELK .layer-qalDW.error-layer-RCEZC .playlist-button-CB2WC:hover{background-color:hsl(147.7,68%,46.7%)}.player-container-wIELK .layer-qalDW.error-layer-RCEZC .playlist-button-CB2WC .icon-aMPEE{fill:hsla(0,0%,100%,0.9);flex:none;height:1.5rem;margin-right:1rem;width:1.5rem}.player-container-wIELK .layer-qalDW.error-layer-RCEZC .playlist-button-CB2WC .label-njZqk{color:hsla(0,0%,100%,0.9);flex:1;font-size:1.1rem;font-weight:500;max-height:2.4em;text-align:center}.player-container-wIELK .layer-qalDW.nav-bar-layer-r9HT5{background:transparent;bottom:initial;overflow:visible}.player-container-wIELK .layer-qalDW.nav-bar-layer-r9HT5:before{box-shadow:0 0 8rem 6rem hsl(0,0%,0%);content:"";left:0;position:absolute;right:0;top:0;z-index:-1}.player-container-wIELK .layer-qalDW.nav-bar-layer-r9HT5 .button-container-B23qB:hover{background:transparent}.player-container-wIELK .layer-qalDW.nav-bar-layer-r9HT5 .button-container-B23qB .icon-wrBcp{fill:hsl(0,0%,100%)}.player-container-wIELK .layer-qalDW.nav-bar-layer-r9HT5 .title-_UxXH{color:hsl(0,0%,100%)}.player-container-wIELK .layer-qalDW.control-bar-layer-m2jto{overflow:visible;top:initial}.player-container-wIELK .layer-qalDW.control-bar-layer-m2jto:before{bottom:0;box-shadow:0 0 8rem 8rem hsl(0,0%,0%);content:"";left:0;position:absolute;right:0;z-index:-1}.player-container-wIELK .layer-qalDW.menu-layer-HZFG9{background-color:hsl(243,24.4%,16%);bottom:8rem;box-shadow:0 1.35rem 2.7rem hsla(0,0%,0%,0.4),0 1.1rem 0.85rem hsla(0,0%,0%,0.2);left:initial;max-height:calc(100% - 13.5rem);max-width:calc(100% - 4rem);overflow:auto;right:2rem;top:initial} +.consent-checkbox-container-WV60T{align-items:center;display:flex;flex-direction:row;padding:0.5rem 1rem}.consent-checkbox-container-WV60T:focus{background-color:hsla(0,0%,100%,0.2);outline:none}.consent-checkbox-container-WV60T .icon-NUvac{fill:hsl(0,0%,50%);flex:none;height:1.2rem;width:1.2rem}.consent-checkbox-container-WV60T .label-l3LSw{color:hsla(0,0%,75%,0.9);flex:1;font-size:0.9rem;margin-left:0.5rem}.consent-checkbox-container-WV60T .label-l3LSw .link-UppYg{color:hsla(0,0%,100%,0.9);font-size:0.9rem}.consent-checkbox-container-WV60T .label-l3LSw .link-UppYg:hover{text-decoration:underline} +.password-reset-modal-container-KzJPQ .modal-dialog-content-ChXwF{width:30rem}.password-reset-modal-container-KzJPQ .modal-dialog-content-ChXwF .credentials-text-input-ncrIR{color:hsl(0,0%,50%);outline:var(--focus-outline-size) solid hsla(0,0%,85%,0.9);outline-offset:calc(-1 * var(--focus-outline-size));padding:1rem;width:100%}.password-reset-modal-container-KzJPQ .modal-dialog-content-ChXwF .credentials-text-input-ncrIR:hover{outline-color:hsla(0,0%,95%,0.9)}.password-reset-modal-container-KzJPQ .modal-dialog-content-ChXwF .credentials-text-input-ncrIR:focus{outline-color:hsla(0,0%,0%,0.9)}.password-reset-modal-container-KzJPQ .error-message-DkekN{color:hsla(42,100%,54.9%,0.9);font-size:1.1rem;margin-top:2rem;text-align:center}.password-reset-modal-container-KzJPQ .cancel-button-AneJE{background-color:transparent}.password-reset-modal-container-KzJPQ .cancel-button-AneJE:hover{background-color:hsl(0,0%,90%)}.password-reset-modal-container-KzJPQ .cancel-button-AneJE:focus{outline-color:hsla(0,0%,0%,0.9)}.password-reset-modal-container-KzJPQ .cancel-button-AneJE .label-_ADoX{color:hsla(0,0%,55%,0.9)}@media only screen and (max-width:640px){.password-reset-modal-container-KzJPQ .modal-dialog-content-ChXwF{width:auto}} +.intro-container-tkNS6{background:linear-gradient(hsla(243,24.4%,6%,0.8),hsla(243,24.4%,6%,0.8)),url(../../4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg);background-origin:border-box;background-position:center;background-repeat:no-repeat;background-size:cover;display:flex;flex-direction:row;height:100%;justify-content:center;overflow-y:auto;width:100%}.intro-container-tkNS6 .form-container-HMlEh{flex:none;margin:auto;padding:2rem 0;width:28rem}.intro-container-tkNS6 .form-container-HMlEh .logo-container-W49kt{align-items:center;display:flex;flex-direction:row;justify-content:center;margin-bottom:3rem}.intro-container-tkNS6 .form-container-HMlEh .logo-container-W49kt .logo-WJ36F{flex:none;height:4rem;margin-right:1rem;opacity:0.9;width:4rem}.intro-container-tkNS6 .form-container-HMlEh .logo-container-W49kt .name-BNo9R{fill:hsla(0,0%,55%,0.9);flex:none;height:4rem;width:8rem}.intro-container-tkNS6 .form-container-HMlEh .form-button-vyqqj{align-items:center;display:flex;flex-direction:row;justify-content:center;padding:0.5rem 1rem}.intro-container-tkNS6 .form-container-HMlEh .form-button-vyqqj .icon-L_6b6{fill:hsla(0,0%,100%,0.9);flex:none;height:2rem;margin-right:1rem;width:1rem}.intro-container-tkNS6 .form-container-HMlEh .form-button-vyqqj .label-uHD7L{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;font-weight:500;text-align:center}.intro-container-tkNS6 .form-container-HMlEh .facebook-button-LZ_kG{background:var(--color-facebook);margin:1rem 0;min-height:4.5rem}.intro-container-tkNS6 .form-container-HMlEh .facebook-button-LZ_kG .label-uHD7L{font-size:1.2rem}.intro-container-tkNS6 .form-container-HMlEh .login-form-button-DqJUV{color:hsla(0,0%,65%,0.9);display:block;margin:1rem 0;text-align:center}.intro-container-tkNS6 .form-container-HMlEh .login-form-button-DqJUV:hover .login-label-AelYq{text-decoration:underline}.intro-container-tkNS6 .form-container-HMlEh .login-form-button-DqJUV:focus{background-color:hsla(0,0%,100%,0.2);outline:none}.intro-container-tkNS6 .form-container-HMlEh .login-form-button-DqJUV .login-label-AelYq{color:hsla(160,81.5%,51.8%,0.9);font-weight:500}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz{border-bottom:thin solid hsla(0,0%,75%,0.9);color:hsl(0,0%,100%);display:block;margin:1rem 0;padding:1rem;width:100%}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz:hover{background-color:hsla(0,0%,100%,0.2)}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz:focus{border-bottom-color:hsla(222.8,100%,78%,0.9)}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz:focus::-moz-placeholder{color:hsla(222.8,100%,78%,0.9)}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz:focus::placeholder{color:hsla(222.8,100%,78%,0.9)}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz::-moz-placeholder{color:hsla(0,0%,65%,0.9)}.intro-container-tkNS6 .form-container-HMlEh .credentials-text-input-QMCZz::placeholder{color:hsla(0,0%,65%,0.9)}.intro-container-tkNS6 .form-container-HMlEh .forgot-password-link-container-ygZqb{display:flex;flex-direction:row;justify-content:flex-end;margin:1rem 0;text-align:right}.intro-container-tkNS6 .form-container-HMlEh .forgot-password-link-container-ygZqb .forgot-password-link-NxNUD{color:hsla(0,0%,90%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;padding:0.5rem 1rem}.intro-container-tkNS6 .form-container-HMlEh .forgot-password-link-container-ygZqb .forgot-password-link-NxNUD:hover{color:hsla(222.8,100%,78%,0.9);text-decoration:underline}.intro-container-tkNS6 .form-container-HMlEh .forgot-password-link-container-ygZqb .forgot-password-link-NxNUD:focus{background-color:hsla(0,0%,100%,0.2);outline:none}.intro-container-tkNS6 .form-container-HMlEh .error-message-cKdzB{color:hsla(42,100%,54.9%,0.9);margin:1rem 0;padding:0 1rem;text-align:center}.intro-container-tkNS6 .form-container-HMlEh .submit-button-x3L8z{background-color:hsl(147.7,68%,41.7%);margin:1rem 0;min-height:4rem}.intro-container-tkNS6 .form-container-HMlEh .submit-button-x3L8z:hover{background-color:hsl(147.7,68%,46.7%)}.intro-container-tkNS6 .form-container-HMlEh .submit-button-x3L8z .label-uHD7L{font-size:1.2rem}.intro-container-tkNS6 .form-container-HMlEh .guest-login-button-D8DWZ,.intro-container-tkNS6 .form-container-HMlEh .signup-form-button-UGmSk{margin-top:1rem;padding:1rem}.intro-container-tkNS6 .form-container-HMlEh .guest-login-button-D8DWZ:hover .label-uHD7L,.intro-container-tkNS6 .form-container-HMlEh .signup-form-button-UGmSk:hover .label-uHD7L{text-decoration:underline}.intro-container-tkNS6 .form-container-HMlEh .guest-login-button-D8DWZ:focus,.intro-container-tkNS6 .form-container-HMlEh .signup-form-button-UGmSk:focus{background-color:hsla(0,0%,100%,0.2);outline:none}.loading-modal-container-eLyTm{align-items:center;background-color:hsla(0,0%,0%,0.4);display:flex;justify-content:center}.loading-modal-container-eLyTm .loader-container-oe8rU{align-items:center;background-color:hsl(0,0%,100%);display:flex;flex:none;flex-direction:column;justify-content:center;padding:2rem}@-webkit-keyframes flash-wUFXY{0%{opacity:0.4}to{opacity:1}}@keyframes flash-wUFXY{0%{opacity:0.4}to{opacity:1}}.loading-modal-container-eLyTm .loader-container-oe8rU .icon-L_6b6{fill:hsla(0,0%,0%,0.9);-webkit-animation:flash-wUFXY 1s linear infinite alternate;animation:flash-wUFXY 1s linear infinite alternate;flex:none;height:5rem;margin-bottom:1rem;width:5rem}.loading-modal-container-eLyTm .loader-container-oe8rU .label-uHD7L{-webkit-animation:flash-wUFXY 1s linear infinite alternate;animation:flash-wUFXY 1s linear infinite alternate;color:hsla(0,0%,0%,0.9);font-size:2rem}@media only screen and (max-width:640px){.intro-container-tkNS6 .form-container-HMlEh{flex:0 1 auto;padding:2rem 1.5rem;width:100%}} +.error-container-OJnoc{align-items:center;display:flex;flex-direction:column;justify-content:center}.error-container-OJnoc .error-image-qU9Qo{flex:none;height:12rem;margin-bottom:1rem;-o-object-fit:contain;object-fit:contain;-o-object-position:center;object-position:center;opacity:0.9;width:12rem}.error-container-OJnoc .error-message-kW59Z{color:hsla(0,0%,100%,0.9);flex:none;font-size:2rem;max-height:3.6em;padding:0 3rem;text-align:center}.error-container-OJnoc .buttons-container-tQonN{align-items:center;align-self:stretch;display:flex;flex:none;flex-direction:row;flex-wrap:wrap;justify-content:center;margin:0 2rem}.error-container-OJnoc .buttons-container-tQonN .button-container-vLSQK{align-items:center;background-color:hsl(147.7,68%,41.7%);display:flex;flex-basis:auto;flex-direction:row;flex-grow:0;flex-shrink:1;height:3rem;justify-content:center;margin:2rem 1rem 0;min-width:8rem;padding:0 1rem}.error-container-OJnoc .buttons-container-tQonN .button-container-vLSQK:hover{background-color:hsl(147.7,68%,46.7%)}.error-container-OJnoc .buttons-container-tQonN .button-container-vLSQK.disabled{background-color:hsl(0,0%,50%)}.error-container-OJnoc .buttons-container-tQonN .button-container-vLSQK .label-Up_te{color:hsla(0,0%,100%,0.9);flex-basis:auto;flex-grow:0;flex-shrink:1;font-size:1.1rem;font-weight:500;max-height:2.4em;text-align:center} +@font-face{font-family:Roboto;font-style:italic;font-weight:300;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:italic;font-weight:400;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:italic;font-weight:500;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-MediumItalic.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:italic;font-weight:700;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:normal;font-weight:300;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:normal;font-weight:400;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Regular.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:normal;font-weight:500;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf) format("truetype")}@font-face{font-family:Roboto;font-style:normal;font-weight:700;src:url(../../4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf) format("truetype")}.animation-fade-in{-webkit-animation-duration:100ms;animation-duration:100ms;-webkit-animation-timing-function:ease-in-out;animation-timing-function:ease-in-out}.animation-fade-in{-webkit-animation-name:fade-in-pFkt_;animation-name:fade-in-pFkt_}@-webkit-keyframes fade-in-pFkt_{0%{opacity:0.6;transform:translateY(0.2vh)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-pFkt_{0%{opacity:0.6;transform:translateY(0.2vh)}to{opacity:1;transform:translateY(0)}}.routes-container{position:relative;z-index:0}.routes-container .route-container{bottom:0;left:0;position:absolute;right:0;top:0;z-index:0}.routes-container .route-container:not(:last-child){display:none}.routes-container .route-container .route-content{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:0}.routes-container .route-container .modals-container{height:0;width:0}.routes-container .route-container .modals-container .modal-container{bottom:0;left:0;overflow:hidden;position:absolute;right:0;top:0;z-index:1}:root{--landscape-shape-ratio:0.5625;--poster-shape-ratio:1.464;--scroll-bar-size:6px;--horizontal-nav-bar-size:4rem;--vertical-nav-bar-size:5.2rem;--focus-outline-size:2px;--color-facebook:#4267b2;--color-twitter:#1DA1F2;--color-placeholder:#60606080;--color-placeholder-text:hsla(0,0%,75%,0.5);--color-placeholder-background:hsla(0,0%,50%,0.2)}*{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;box-shadow:none;box-sizing:border-box;font-family:inherit;font-size:1rem;line-height:1.2em;list-style:none;margin:0;outline:none;overflow:hidden;padding:0;scrollbar-color:hsl(222.8,100%,78%) hsl(243,24.4%,11%);scrollbar-width:thin;text-decoration:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;word-break:break-word}::-webkit-scrollbar{height:var(--scroll-bar-size);width:var(--scroll-bar-size)}::-webkit-scrollbar-thumb{background-color:hsl(222.8,100%,78%)}::-webkit-scrollbar-thumb:hover{background-color:hsl(222.8,100%,83%)}::-webkit-scrollbar-track{background-color:hsl(243,24.4%,11%)}svg{overflow:visible}html{font-family:Roboto,"sans-serif";min-height:480px;min-width:640px;overflow:auto}html,html body{height:100%;width:100%}html body #app{height:100%;position:relative;width:100%;z-index:0}html body #app .toasts-container-oKECy{bottom:calc(1.2 * var(--horizontal-nav-bar-size));left:auto;overflow-y:auto;padding:0 calc(0.5 * var(--horizontal-nav-bar-size));pointer-events:none;position:absolute;right:0;scrollbar-width:none;top:calc(1.2 * var(--horizontal-nav-bar-size));z-index:1}html body #app .toasts-container-oKECy::-webkit-scrollbar{display:none}html body #app .router-_65XU{height:100%;width:100%}html body #app .error-container-VZXwH,html body #app .loader-container-vwvnb{background-color:hsl(243,24.4%,11%);height:100%;width:100%}@media only screen and (min-width:2800px){html{font-size:18px}}@media only screen and (max-width:2800px){html{font-size:16px}}@media only screen and (max-width:2200px){html{font-size:15px}}@media only screen and (max-width:1600px){html{font-size:14px}}@media only screen and (max-width:1000px){html{min-height:inherit;min-width:inherit}} + +/*# sourceMappingURL=main.css.map*/ \ No newline at end of file diff --git a/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css.map b/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css.map new file mode 100644 index 000000000..6050a6947 --- /dev/null +++ b/4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css.map @@ -0,0 +1 @@ +{"version":3,"file":"4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css","mappings":"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","sources":["webpack://stremio/./src/common/Button/styles.less","webpack://stremio/./src/common/ModalDialog/styles.less","webpack://stremio/./src/common/AddonDetailsModal/AddonDetails/styles.less","webpack://stremio/./src/common/AddonDetailsModal/styles.less","webpack://stremio/./src/common/Checkbox/styles.less","webpack://stremio/./src/common/ColorInput/ColorPicker/styles.less","webpack://stremio/./src/common/ColorInput/styles.less","webpack://stremio/./src/common/Popup/styles.less","webpack://stremio/./src/common/Multiselect/styles.less","webpack://stremio/./src/common/PlayIconCircleCentered/styles.less","webpack://stremio/./src/common/MetaItem/styles.less","webpack://stremio/./src/common/TextInput/styles.less","webpack://stremio/./src/common/NavBar/HorizontalNavBar/SearchBar/styles.less","webpack://stremio/./src/common/NavBar/HorizontalNavBar/NavMenu/styles.less","webpack://stremio/./src/common/NavBar/HorizontalNavBar/styles.less","webpack://stremio/./src/common/NavBar/VerticalNavBar/NavTabButton/styles.less","webpack://stremio/./src/common/NavBar/VerticalNavBar/styles.less","webpack://stremio/./src/common/MainNavBars/styles.less","webpack://stremio/./src/common/SharePrompt/styles.less","webpack://stremio/./src/common/MetaPreview/ActionButton/styles.less","webpack://stremio/./src/common/MetaPreview/MetaLinks/styles.less","webpack://stremio/./src/common/MetaPreview/MetaPreviewPlaceholder/styles.less","webpack://stremio/./src/common/MetaPreview/styles.less","webpack://stremio/./src/common/MetaRow/MetaRowPlaceholder/styles.less","webpack://stremio/./src/common/MetaRow/styles.less","webpack://stremio/./src/common/PaginationInput/styles.less","webpack://stremio/./src/common/SearchBar/SearchBarPlaceholder/styles.less","webpack://stremio/./src/common/SearchBar/styles.less","webpack://stremio/./src/common/StreamingServerWarning/styles.less","webpack://stremio/./src/common/Slider/styles.less","webpack://stremio/./src/common/Toast/ToastItem/styles.less","webpack://stremio/./src/routes/Addons/Addon/styles.less","webpack://stremio/./src/routes/Addons/styles.less","webpack://stremio/./src/routes/Board/styles.less","webpack://stremio/./src/routes/Discover/styles.less","webpack://stremio/./src/routes/NotFound/styles.less","webpack://stremio/./src/routes/Library/styles.less","webpack://stremio/./src/routes/MetaDetails/StreamsList/Stream/StreamPlaceholder/styles.less","webpack://stremio/./src/routes/MetaDetails/StreamsList/Stream/styles.less","webpack://stremio/./src/routes/MetaDetails/StreamsList/styles.less","webpack://stremio/./src/routes/MetaDetails/VideosList/SeasonsBar/SeasonsBarPlaceholder/styles.less","webpack://stremio/./src/routes/MetaDetails/VideosList/SeasonsBar/styles.less","webpack://stremio/./src/routes/MetaDetails/VideosList/Video/VideoPlaceholder/styles.less","webpack://stremio/./src/routes/MetaDetails/VideosList/Video/styles.less","webpack://stremio/./src/routes/MetaDetails/VideosList/styles.less","webpack://stremio/./src/routes/MetaDetails/styles.less","webpack://stremio/./src/routes/Search/styles.less","webpack://stremio/./src/routes/Settings/styles.less","webpack://stremio/./src/routes/Player/BufferingLoader/styles.less","webpack://stremio/./src/routes/Player/ControlBar/SeekBar/styles.less","webpack://stremio/./src/routes/Player/ControlBar/VolumeSlider/styles.less","webpack://stremio/./src/routes/Player/ControlBar/styles.less","webpack://stremio/./src/routes/Player/NextVideoPopup/styles.less","webpack://stremio/./src/routes/Player/InfoMenu/styles.less","webpack://stremio/./src/routes/Player/OptionsMenu/Option/styles.less","webpack://stremio/./src/routes/Player/OptionsMenu/styles.less","webpack://stremio/./src/routes/Player/VideosMenu/styles.less","webpack://stremio/./src/routes/Player/SubtitlesMenu/DiscreteSelectInput/styles.less","webpack://stremio/./src/routes/Player/SubtitlesMenu/styles.less","webpack://stremio/./src/routes/Player/SpeedMenu/Option/styles.less","webpack://stremio/./src/routes/Player/SpeedMenu/styles.less","webpack://stremio/./src/routes/Player/Video/styles.less","webpack://stremio/./src/routes/Player/styles.less","webpack://stremio/./src/routes/Intro/ConsentCheckbox/styles.less","webpack://stremio/./src/routes/Intro/PasswordResetModal/styles.less","webpack://stremio/./src/routes/Intro/styles.less","webpack://stremio/./src/App/ErrorDialog/styles.less","webpack://stremio/./src/common/roboto.css","webpack://stremio/./src/App/styles.less","webpack://stremio/./src/common/animations.less","webpack://stremio/./src/router/styles.css"],"sourcesContent":["// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.button-container {\n outline-width: var(--focus-outline-size);\n outline-color: @color-surface-light5;\n outline-offset: calc(-1 * var(--focus-outline-size));\n cursor: pointer;\n\n &:focus {\n outline-style: solid;\n }\n\n &:global(.disabled) {\n pointer-events: none;\n opacity: 0.25;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.modal-container {\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: @color-background-dark5-40;\n\n .modal-dialog-container {\n flex: none;\n display: flex;\n flex-direction: column;\n max-width: 80%;\n max-height: 80%;\n background-color: @color-surface-light5;\n\n .close-button-container {\n flex: none;\n align-self: flex-end;\n width: 2rem;\n height: 2rem;\n margin: 0.2rem 0.2rem 0 0;\n padding: 0.5rem;\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n fill: @color-surface-dark1-90;\n }\n\n &:hover, &:focus {\n .icon {\n fill: @color-surface-light1-90;\n }\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n }\n\n .title-container {\n flex: 1 0 auto;\n max-height: 2.4em;\n margin: 0 2rem;\n font-size: 1.2rem;\n font-weight: 500;\n color: @color-background-dark5-90;\n }\n\n .modal-dialog-content {\n flex: 1;\n align-self: stretch;\n margin: 1.5rem 1rem 0;\n padding: 0 1rem;\n overflow-y: auto;\n\n &:last-child {\n margin-bottom: 2rem;\n }\n }\n\n .buttons-container {\n flex: none;\n align-self: stretch;\n margin: 2rem 2rem 0;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n\n &:last-child {\n margin-bottom: 2rem;\n }\n }\n }\n}\n\n.action-button {\n flex: 1;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n padding: 1.2rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n\n &:not(:last-child) {\n margin-right: 1rem;\n }\n\n .icon {\n flex: none;\n width: 1.2rem;\n height: 1.2rem;\n margin-right: .5rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 3.6em;\n font-size: 1.1rem;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .modal-container {\n .modal-dialog-container {\n position: relative;\n width: 90%;\n max-width: initial;\n z-index: 0;\n\n .close-button-container {\n position: absolute;\n top: 0;\n right: 0;\n margin: 0.75rem 0.75rem 0 0;\n padding: 0.25rem;\n }\n\n .title-container {\n max-height: 4.8em;\n margin: 1rem 3rem 1rem 1.5rem;\n }\n\n .modal-dialog-content {\n margin: 0 0.5rem;\n padding: 0 0.5rem;\n\n &:last-child {\n margin-bottom: 1rem;\n }\n }\n\n .buttons-container {\n margin: 1rem 1rem 0;\n\n &:last-child {\n margin-bottom: 1rem;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.addon-details-container {\n .title-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n\n .logo, .icon {\n float: left;\n width: 5rem;\n height: 5rem;\n margin-right: 1.5rem;\n padding: 0.5rem;\n background-color: @color-background-dark5;\n }\n\n .logo {\n object-fit: contain;\n object-position: center;\n }\n\n .icon {\n fill: @color-secondaryvariant1-light3;\n }\n\n .name-container {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: 0;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: baseline;\n \n .name {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n margin-right: 0.5rem;\n font-size: 1.6rem;\n color: @color-background-dark5-90;\n }\n \n .version {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: auto;\n margin-top: 0.5rem;\n color: @color-background-dark5-60;\n }\n }\n }\n\n .section-container {\n margin-top: 1rem;\n\n .section-header {\n font-size: 1.1rem;\n color: @color-background-dark5-90;\n }\n\n .section-label {\n font-size: 1.1rem;\n font-weight: 300;\n color: @color-background-dark5-90;\n\n &.transport-url-label {\n user-select: text;\n }\n\n &.disclaimer-label {\n font-style: italic;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:import('~stremio/common/ModalDialog/styles.less') {\n label: label;\n}\n\n.addon-details-modal-container {\n .addon-details-container, .addon-details-message-container {\n width: 40rem;\n max-width: 100%;\n }\n\n .install-button, .uninstall-button, .cancel-button {\n .label {\n font-size: 1.2rem;\n font-weight: 500;\n }\n }\n\n .uninstall-button, .cancel-button {\n &:focus {\n outline-color: @color-background-dark5;\n }\n }\n\n .cancel-button {\n background-color: transparent;\n\n &:hover {\n background-color: @color-surface-light3;\n }\n\n .label {\n color: @color-surface-dark2;\n }\n }\n\n .uninstall-button {\n background-color: @color-accent2;\n\n &:hover {\n background-color: @color-accent2-light2;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.checkbox-container {\n &:global(.checked) {\n .icon {\n fill: @color-surface-light5;\n background-color: @color-primaryvariant1;\n }\n }\n\n .icon {\n display: block;\n width: 1rem;\n height: 1rem;\n fill: @color-surface-light5;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.color-picker-container {\n overflow: visible;\n text-align: center;\n\n * {\n overflow: visible;\n }\n\n :global(.a-color-picker-stack):not(:global(.a-color-picker-row-top)) canvas, :global(.a-color-picker-circle) {\n border: solid thin var(--color-surfacedark);\n }\n\n :global(.a-color-picker-circle) {\n box-shadow: 0 0 .2rem var(--color-surfacedark);\n }\n\n :global(.a-color-picker-clipbaord) {\n pointer-events: none;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.color-input-container {\n position: relative;\n z-index: 0;\n\n .transparent-label-container {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1;\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 0 0.5rem;\n border: thin solid @color-surface-light5-20;\n pointer-events: none;\n\n .transparent-label {\n flex: 1;\n text-align: center;\n color: @color-surface-light5;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n}\n\n.color-picker-container {\n margin: 1rem 0;\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.label-container {\n position: relative;\n overflow: visible;\n\n .menu-container {\n position: absolute;\n z-index: 1;\n overflow: visible;\n visibility: hidden;\n box-shadow: 0 1.35rem 2.7rem @color-background-dark5-40,\n 0 1.1rem 0.85rem @color-background-dark5-20;\n cursor: auto;\n\n &.menu-direction-top-left {\n top: initial;\n right: 0;\n bottom: 100%;\n left: initial;\n visibility: visible;\n }\n\n &.menu-direction-bottom-left {\n top: 100%;\n right: 0;\n bottom: initial;\n left: initial;\n visibility: visible;\n }\n\n &.menu-direction-top-right {\n top: initial;\n right: initial;\n bottom: 100%;\n left: 0;\n visibility: visible;\n }\n\n &.menu-direction-bottom-right {\n top: 100%;\n right: initial;\n bottom: initial;\n left: 0;\n visibility: visible;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Popup/styles.less') {\n popup-menu-container: menu-container;\n}\n\n.label-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0 1rem;\n background-color: @color-background;\n\n &:global(.active) {\n .label {\n color: @color-surface-light5-90;\n }\n\n .icon {\n fill: @color-surface-light5-90;\n }\n }\n\n >.label {\n flex: 1;\n max-height: 2.4em;\n font-weight: 500;\n color: @color-secondaryvariant1-90;\n }\n\n .icon {\n flex: none;\n width: 1rem;\n height: 1rem;\n margin-left: 1rem;\n fill: @color-secondaryvariant1-90;\n }\n\n .popup-menu-container {\n width: 100%;\n }\n}\n\n.modal-container, .popup-menu-container {\n .menu-container {\n .option-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 1rem;\n background-color: @color-background;\n\n &:global(.selected) {\n .icon {\n display: block;\n }\n }\n\n &:hover, &:focus {\n background-color: @color-background-light2;\n }\n\n .label {\n flex: 1;\n max-height: 4.8em;\n color: @color-surface-light5-90;\n }\n\n .icon {\n flex: none;\n display: none;\n width: 0.5rem;\n height: 0.5rem;\n border-radius: 100%;\n margin-left: 1rem;\n background-color: @color-accent3-90;\n }\n }\n\n .no-options-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n padding: 1rem;\n background-color: @color-background;\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n font-size: 1.2rem;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.background {\n fill: @color-surface-light5;\n}\n\n.icon {\n fill: @color-background-dark5;\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Popup/styles.less') {\n popup-menu-container: menu-container;\n}\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n multiselect-option-container: option-container;\n multiselect-option-label: label;\n}\n\n:import('~stremio/common/PlayIconCircleCentered/styles.less') {\n play-icon-circle-centered-background: background;\n play-icon-circle-centered-icon: icon;\n}\n\n.meta-item-container {\n padding: 1rem;\n overflow: visible;\n\n &:hover, &:focus, &:global(.active), &:global(.selected) {\n outline-style: none;\n background-color: @color-background-light3;\n transition: background-color 100ms ease-out;\n }\n\n &.poster-shape-poster {\n .poster-container {\n padding-top: calc(100% * var(--poster-shape-ratio));\n }\n }\n\n &.poster-shape-square {\n .poster-container {\n padding-top: 100%;\n }\n }\n\n &.poster-shape-landscape {\n .poster-container {\n padding-top: calc(100% * var(--landscape-shape-ratio));\n }\n }\n\n .poster-container {\n position: relative;\n z-index: 0;\n background-color: @color-background;\n\n .poster-image-layer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -3;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n\n .poster-image {\n flex: none;\n width: 100%;\n height: 100%;\n object-position: center;\n object-fit: cover;\n opacity: 0.9;\n }\n\n .placeholder-icon {\n flex: none;\n width: 80%;\n height: 50%;\n fill: @color-background-light3-90;\n }\n }\n\n .play-icon-layer {\n position: absolute;\n top: 30%;\n right: 0;\n bottom: 30%;\n left: 0;\n z-index: -2;\n overflow: visible;\n\n .play-icon {\n display: block;\n width: 100%;\n height: 100%;\n filter: drop-shadow(0 0 0.5rem @color-background);\n\n .play-icon-circle-centered-background {\n fill: @color-accent4-90;\n }\n\n .play-icon-circle-centered-icon {\n fill: @color-surface-light5-90;\n }\n }\n }\n\n .progress-bar-layer {\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n background-color: @color-background-light2;\n\n .progress-bar {\n height: 0.4rem;\n background-color: @color-primaryvariant1;\n }\n }\n }\n\n .title-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 2.8rem;\n overflow: visible;\n\n .title-label {\n flex: 1;\n max-height: 2.4em;\n padding-left: 0.5rem;\n color: @color-surface-light5-90;\n\n &:only-child {\n padding-right: 0.5rem;\n }\n }\n\n .menu-label-container {\n flex: none;\n width: 1.5rem;\n height: 2.8rem;\n padding: 1rem 0;\n background-color: transparent;\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n fill: @color-surface-light1-90;\n }\n\n .popup-menu-container {\n width: auto;\n\n .multiselect-menu-container {\n min-width: 6rem;\n max-width: 12rem;\n\n .multiselect-option-container {\n padding: 0.5rem;\n background-color: @color-surface-light5;\n\n &:hover, &:focus {\n outline: none;\n background-color: @color-surface-light2;\n }\n\n .multiselect-option-label {\n color: @color-background-dark5-90;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .meta-item-container {\n padding: 0.5rem;\n\n .title-bar-container {\n margin-top: 0.5rem;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.text-input {\n user-select: text;\n\n &::-moz-focus-inner {\n border: none;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.search-bar-container {\n --search-bar-size: calc(var(--horizontal-nav-bar-size) - 1.2rem);\n display: flex;\n flex-direction: row;\n height: var(--search-bar-size);\n border-radius: var(--search-bar-size);\n background-color: @color-background-light2;\n\n &:hover {\n background-color: @color-background-light3;\n }\n\n .search-input {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0 0.5rem 0 1.5rem;\n font-weight: 500;\n color: @color-secondaryvariant1-light1;\n cursor: text;\n\n &::placeholder, .placeholder-label {\n max-height: 1.2em;\n opacity: 1;\n color: @color-secondaryvariant1-light1-90;\n }\n }\n\n .submit-button-container {\n flex: none;\n display: flex;\n flex-direction: row;\n justify-content: center;\n align-items: center;\n width: var(--search-bar-size);\n height: var(--search-bar-size);\n\n &:hover {\n .icon {\n fill: @color-secondaryvariant2-light1-90;\n }\n }\n\n .icon {\n flex: none;\n width: 1.7rem;\n height: 1.7rem;\n fill: @color-secondaryvariant1-90;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.nav-menu-container {\n width: 20rem;\n max-height: calc(100vh - var(--horizontal-nav-bar-size));\n overflow-y: auto;\n background-color: @color-background-dark1;\n\n .user-info-container {\n display: grid;\n height: 7rem;\n grid-template-columns: 7rem 1fr;\n grid-template-rows: 50% 50%;\n grid-template-areas:\n \"avatar-area email-area\"\n \"avatar-area logout-button-area\";\n\n .avatar-container {\n grid-area: avatar-area;\n padding: 1rem;\n border-radius: 50%;\n background-size: cover;\n background-repeat: no-repeat;\n background-position: center;\n background-origin: content-box;\n background-clip: content-box;\n opacity: 0.9;\n }\n\n .email-container {\n grid-area: email-area;\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 1rem 1rem 0 0;\n\n .email-label {\n flex: 1;\n max-height: 2.4em;\n color: @color-surface-light5-90;\n }\n }\n\n .logout-button-container {\n grid-area: logout-button-area;\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0 1rem 1rem 0;\n\n &:hover, &:focus {\n outline: none;\n\n .logout-label {\n color: @color-surface-light5-90;\n text-decoration: underline;\n }\n }\n\n .logout-label {\n flex: 1;\n max-height: 2.4em;\n color: @color-surface-light3-90;\n }\n }\n }\n\n .nav-menu-section {\n border-top: thin solid @color-surface-light5-20;\n\n .nav-menu-option-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 4rem;\n\n &:hover {\n background-color: @color-background-light2;\n }\n\n .icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n margin: 1.3rem;\n fill: @color-secondaryvariant2-light1-90;\n }\n\n .nav-menu-option-label {\n flex: 1;\n max-height: 2.4em;\n padding-right: 1.3rem;\n color: @color-surface-light5-90;\n\n &:only-child {\n padding-left: 1.3rem;\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .nav-menu-container {\n max-height: calc(100vh - var(--horizontal-nav-bar-size) - var(--vertical-nav-bar-size) - 1rem);\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.horizontal-nav-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: var(--horizontal-nav-bar-size);\n padding-right: 1rem;\n background-color: @color-background;\n overflow: visible;\n\n .logo-container {\n flex: none;\n display: flex;\n align-items: center;\n justify-content: center;\n width: var(--vertical-nav-bar-size);\n height: var(--horizontal-nav-bar-size);\n\n .logo {\n flex: none;\n width: 2.5rem;\n height: 2.5rem;\n object-position: center;\n object-fit: contain;\n opacity: 0.9;\n }\n }\n\n .spacing {\n flex: 1 0 0;\n }\n\n .title {\n flex: 4 0 0;\n padding: 0 1rem;\n font-size: 1.2rem;\n font-style: normal;\n font-weight: 500;\n letter-spacing: 0.01rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: @color-secondaryvariant2-light1-90;\n\n &+.spacing {\n display: none;\n }\n }\n\n .search-bar {\n flex: 2 0 9.5rem;\n max-width: 30rem;\n\n &+.spacing {\n max-width: 11rem;\n }\n }\n\n .button-container {\n flex: none;\n display: flex;\n align-items: center;\n justify-content: center;\n width: var(--horizontal-nav-bar-size);\n height: var(--horizontal-nav-bar-size);\n\n &.back-button-container {\n width: var(--vertical-nav-bar-size);\n height: var(--horizontal-nav-bar-size);\n }\n\n &:hover {\n background-color: @color-background-light2;\n }\n\n &:global(.active) {\n background-color: @color-background-light3;\n\n .icon {\n fill: @color-surface-light5-90;\n }\n }\n\n .icon {\n flex: none;\n width: 1.7rem;\n height: 1.7rem;\n fill: @color-secondaryvariant2-light1-90;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .horizontal-nav-bar-container {\n justify-content: space-between;\n padding-right: 0;\n\n .logo-container {\n width: var(--horizontal-nav-bar-size);\n }\n\n .search-bar {\n margin: 0 0.5rem;\n }\n\n .spacing {\n display: none;\n }\n\n .button-container:not(.back-button-container):not(.menu-button-container) {\n display: none;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.nav-tab-button-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: @color-background-dark1;\n\n &:hover {\n background-color: @color-background-light2;\n }\n\n &:global(.selected) {\n background-color: @color-secondaryvariant1-dark5;\n\n &:hover {\n background-color: @color-secondaryvariant1-dark4;\n }\n\n .icon {\n fill: @color-surface-light5-90;\n }\n\n .label {\n color: @color-surface-light5-90;\n }\n }\n\n .icon, .logo {\n flex: none;\n width: 1.7rem;\n height: 1.7rem;\n margin-bottom: 0.5rem;\n fill: @color-secondary-light5-90;\n }\n\n .label {\n flex: none;\n max-height: 2.4em;\n padding: 0 0.2rem;\n font-size: 0.9rem;\n font-weight: 500;\n letter-spacing: 0.01rem;\n text-align: center;\n color: @color-secondaryvariant1-90;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.vertical-nav-bar-container {\n width: var(--vertical-nav-bar-size);\n background-color: @color-background-dark1;\n overflow-y: auto;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n .nav-tab-button {\n width: var(--vertical-nav-bar-size);\n height: var(--vertical-nav-bar-size);\n\n &:first-child {\n margin-top: 1rem;\n }\n\n &:last-child {\n margin-bottom: 1rem;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .vertical-nav-bar-container {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n height: var(--vertical-nav-bar-size);\n width: 100%;\n overflow-y: hidden;\n overflow-x: auto;\n\n .nav-tab-button {\n flex: none;\n\n &:first-child {\n margin-top: 0;\n }\n \n &:last-child {\n margin-bottom: 0;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.main-nav-bars-container {\n position: relative;\n z-index: 0;\n\n .horizontal-nav-bar {\n position: absolute;\n top: 0;\n right: 0;\n left: 0;\n z-index: 1;\n }\n\n .vertical-nav-bar {\n position: absolute;\n top: var(--horizontal-nav-bar-size);\n bottom: 0;\n left: 0;\n z-index: 1;\n }\n\n .nav-content-container {\n position: absolute;\n top: var(--horizontal-nav-bar-size);\n right: 0;\n bottom: 0;\n left: var(--vertical-nav-bar-size);\n z-index: 0;\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .main-nav-bars-container {\n .nav-content-container {\n left: 0;\n bottom: var(--vertical-nav-bar-size);\n }\n\n .vertical-nav-bar {\n top: initial;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.share-prompt-container {\n .buttons-container {\n display: flex;\n flex-direction: row;\n\n .button-container {\n flex: 1;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n padding: 1rem;\n\n &:not(:last-child) {\n margin-right: 1rem;\n }\n\n .icon {\n flex: none;\n height: 1.2rem;\n margin-right: 1rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 2.4em;\n font-size: 1.1rem;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n\n .facebook-button, .twitter-button {\n &:focus {\n outline-color: @color-background-dark5;\n }\n }\n\n .facebook-button {\n background-color: var(--color-facebook);\n }\n\n .twitter-button {\n background-color: var(--color-twitter);\n }\n }\n\n .url-container {\n display: flex;\n flex-direction: row;\n margin-top: 1rem;\n background-color: @color-surface-light2;\n\n .url-text-input {\n flex: 1;\n align-self: stretch;\n padding: 1rem;\n font-size: 1.1rem;\n text-align: center;\n color: @color-background-dark5;\n }\n\n .copy-button {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n width: 8rem;\n padding: 1rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n\n .icon {\n flex: none;\n width: 1.2rem;\n height: 1.2rem;\n margin-right: 0.5rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 2.4em;\n font-size: 1.1rem;\n color: @color-surface-light5-90;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.action-button-container {\n display: flex;\n flex-direction: column;\n justify-content: center;\n background-color: @color-surface-light5-20;\n\n &:hover, &:focus {\n background-color: @color-accent3;\n }\n\n .icon-container {\n flex: 0 0 50%;\n align-self: stretch;\n padding-top: 15%;\n\n &:only-child {\n padding: 5% 0;\n }\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n fill: @color-surface-light5-90;\n }\n }\n\n .label-container {\n flex: 0 0 50%;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n align-items: center;\n\n .label {\n flex: 1;\n font-weight: 500;\n max-height: 2.4em;\n padding: 0 0.2rem;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .action-button-container {\n flex-direction: row;\n padding: 0 1rem;\n\n .icon-container {\n flex: none;\n align-self: center;\n height: 2rem;\n width: 2rem;\n padding-top: 0;\n margin-right: 0.5rem;\n\n &:only-child {\n padding: 0;\n margin-right: 0;\n }\n }\n\n .label-container {\n flex: 1;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.meta-links-container {\n .label-container {\n margin-bottom: 0.2rem;\n text-transform: uppercase;\n font-weight: 500;\n color: @color-surface-dark3-90;\n }\n\n .links-container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n\n .link-container {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n margin-right: 0.5rem;\n margin-bottom: 0.2rem;\n padding: 0.3rem 0.5rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n border-radius: 2rem;\n border: var(--focus-outline-size) solid transparent;\n color: @color-surface-light2-90;\n background-color: @color-surface-light5-20;\n\n &:hover, &:focus {\n background-color: @color-surface-light5-30;\n }\n\n &:focus {\n outline: none;\n border-color: @color-surface-light5;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.meta-preview-placeholder-container {\n display: flex;\n flex-direction: column;\n padding: 2rem;\n\n .meta-info-container {\n flex: 1;\n align-self: stretch;\n\n .logo-container {\n width: 20rem;\n height: 8rem;\n max-width: 100%;\n background-color: var(--color-placeholder-background);\n }\n\n .duration-release-info-container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n margin: 1rem 0;\n\n .duration-container {\n flex-basis: 5rem;\n height: 1.4rem;\n margin-right: 1rem;\n background-color: var(--color-placeholder-background);\n }\n\n .release-info-container {\n flex-basis: 5rem;\n height: 1.4rem;\n background-color: var(--color-placeholder-background);\n }\n }\n\n .description-container {\n margin: 1rem 0;\n\n .description-label-container {\n background-color: var(--color-placeholder-background);\n\n &:nth-child(1) {\n width: 20rem;\n height: 1.4rem;\n max-width: 80%;\n }\n\n &:nth-child(2) {\n width: 26rem;\n height: 4.6rem;\n max-width: 80%;\n margin-top: 1rem;\n }\n }\n }\n\n .genres-container {\n margin: 1rem 0;\n\n .genres-header-container {\n width: 6.5rem;\n height: 1.6rem;\n max-width: 100%;\n background-color: var(--color-placeholder-background);\n }\n\n .genre-label-container {\n width: 10rem;\n height: 1.2rem;\n max-width: 100%;\n margin-top: 0.2rem;\n background-color: var(--color-placeholder-background);\n }\n }\n }\n\n .action-buttons-container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n max-height: 6rem;\n\n .action-button-container {\n flex: none;\n width: 6rem;\n height: 6rem;\n margin-right: 2rem;\n background-color: var(--color-placeholder-background);\n\n &:last-child {\n margin-right: 0;\n }\n\n .action-button-icon {\n width: 2rem;\n height: 2rem;\n margin: 1rem 2rem 0 2rem;\n background-color: var(--color-placeholder-background);\n }\n\n .action-button-label {\n width: 4rem;\n height: 1.2rem;\n margin: 0.9rem 1rem;\n background-color: var(--color-placeholder-background);\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.meta-preview-container {\n position: relative;\n z-index: 0;\n display: flex;\n flex-direction: column;\n\n &.compact {\n .meta-info-container {\n .logo, .logo-placeholder {\n width: 100%;\n height: 8rem;\n background-color: @color-surface-dark5-10;\n }\n\n .runtime-release-info-container {\n justify-content: space-evenly;\n\n .runtime-label, .release-info-label {\n margin: 1rem 0.4rem;\n }\n }\n\n .description-container {\n max-height: none;\n }\n }\n\n .action-buttons-container {\n justify-content: space-evenly;\n padding: 0;\n\n .action-button:not(:last-child) {\n margin-right: 0;\n }\n }\n }\n\n .background-image-layer {\n position: absolute;\n top: -10px;\n right: -10px;\n bottom: -10px;\n left: -10px;\n z-index: -1;\n\n &::after {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1;\n background: @color-background-dark2-60;\n content: \"\";\n }\n\n .background-image {\n display: block;\n width: 100%;\n height: 100%;\n object-fit: cover;\n object-position: center;\n opacity: 0.9;\n filter: blur(5px);\n }\n }\n\n .meta-info-container {\n flex: 1;\n align-self: stretch;\n padding: 0 2rem;\n overflow-y: auto;\n\n &:not(:hover) {\n scrollbar-color: transparent transparent;\n\n &::-webkit-scrollbar-thumb, &::-webkit-scrollbar-track {\n background-color: transparent;\n }\n }\n\n .logo, .logo-placeholder {\n display: block;\n max-width: 100%;\n margin: 2rem 0;\n }\n\n .logo {\n height: 8rem;\n object-fit: contain;\n object-position: center;\n }\n\n .logo-placeholder {\n font-size: 1.7rem;\n color: @color-surface-light5-90;\n }\n\n .runtime-release-info-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n flex-wrap: wrap;\n margin-top: 1rem;\n\n .runtime-label, .release-info-label {\n flex: 0 1 auto;\n margin-right: 2rem;\n margin-bottom: 0.5rem;\n font-size: 1.4rem;\n color: @color-surface-light5-90;\n }\n\n .imdb-button-container {\n flex: 0 1 auto;\n display: flex;\n flex-direction: row;\n align-items: center;\n margin-bottom: 0.5rem;\n padding: 0.3rem 1rem;\n border-radius: 2.5rem;\n border: var(--focus-outline-size) solid transparent;\n background-color: @color-surface-light5-20;\n\n &:hover, &:focus {\n background-color: @color-surface-light5-30;\n }\n\n &:focus {\n outline: none;\n border: var(--focus-outline-size) solid @color-surface-light5;\n }\n\n .icon {\n flex: none;\n width: 3rem;\n height: 1.1rem;\n margin-right: 1rem;\n fill: @color-surface-90;\n }\n\n .label {\n flex: 0 1 auto;\n max-height: 1.2em;\n font-size: 1.6rem;\n font-weight: 500;\n color: @color-surface-light5-90;\n }\n }\n }\n\n .name-container {\n margin-top: 1rem;\n font-size: 1.5rem;\n color: @color-surface-light5-90;\n }\n\n .description-container {\n max-height: 6em;\n margin-top: 1rem;\n font-size: 1.1rem;\n line-height: 1.5em;\n color: @color-surface-light5-90;\n }\n\n .meta-links {\n margin-top: 1rem;\n }\n }\n\n .action-buttons-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n max-height: 10rem;\n padding: 0 2rem;\n\n .action-button {\n flex: none;\n width: 6rem;\n height: 6rem;\n margin: 2rem 0;\n\n &:not(:last-child) {\n margin-right: 2rem;\n }\n }\n }\n}\n\n.share-prompt {\n width: 24rem;\n}\n\n@media only screen and (max-width: @minimum) {\n .meta-preview-container {\n .meta-info-container {\n padding: 0 1.5rem;\n\n .logo {\n margin: 1em 0;\n }\n }\n\n .action-buttons-container {\n flex-wrap: nowrap;\n padding: 0 1.5rem;\n overflow-x: visible;\n scrollbar-width: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n\n .action-button {\n width: auto;\n height: 4rem;\n max-width: 60%;\n margin: 1rem 0;\n\n &:not(:last-child) {\n margin-right: 1rem;\n }\n }\n }\n }\n\n .share-prompt {\n width: 100%;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.meta-row-placeholder-container {\n .header-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n padding: 0 1rem;\n margin-bottom: 1rem;\n\n .title-container {\n flex: 1;\n max-height: 2.4em;\n font-size: 1.8rem;\n color: var(--color-placeholder-text);\n\n &:empty {\n height: 1.2em;\n background: linear-gradient(to right, var(--color-placeholder-background) 0 40%, transparent 40% 100%);\n }\n }\n\n .see-all-container {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n max-width: 12rem;\n padding: 0.2rem;\n\n &:focus {\n outline: none;\n background-color: var(--color-placeholder-background);\n }\n\n .label {\n flex: 0 1 auto;\n max-height: 1.2em;\n font-size: 1.3rem;\n font-weight: 500;\n text-transform: uppercase;\n color: var(--color-placeholder-text);\n }\n\n .icon {\n flex: none;\n height: 1.3rem;\n margin-left: 0.5rem;\n fill: var(--color-placeholder-text);\n }\n }\n }\n\n .meta-items-container {\n display: flex;\n flex-direction: row;\n align-items: stretch;\n\n .meta-item {\n flex: 1;\n margin: 1rem;\n\n &:not(:first-child) {\n margin-left: 1.5rem;\n }\n\n .poster-container {\n padding-bottom: calc(100% * var(--poster-shape-ratio));\n background-color: var(--color-placeholder-background);\n }\n\n .title-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 2.8rem;\n\n .title-label {\n flex: none;\n width: 60%;\n height: 1.2rem;\n background-color: var(--color-placeholder-background);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .meta-row-placeholder-container {\n .meta-items-container {\n .meta-item {\n margin: 0.5rem;\n\n &:not(:first-child) {\n margin-left: 0.5rem;\n }\n\n .title-bar-container {\n margin-top: 0.5rem;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.meta-row-container {\n overflow: visible;\n\n .header-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n padding: 0 1rem;\n margin-bottom: 1rem;\n\n .title-container {\n flex: 1;\n max-height: 2.4em;\n font-size: 1.8rem;\n color: @color-secondaryvariant2-light1-90;\n }\n\n .see-all-container {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n max-width: 12rem;\n padding: 0.2rem;\n\n &:focus {\n outline: none;\n background-color: @color-background-light3;\n }\n\n &:hover {\n .label {\n color: @color-secondaryvariant2-light2-90;\n }\n\n .icon {\n fill: @color-secondaryvariant2-light2-90;\n }\n }\n\n .label {\n flex: 0 1 auto;\n max-height: 1.2em;\n font-size: 1.3rem;\n font-weight: 500;\n text-transform: uppercase;\n color: @color-secondaryvariant2-light1-90;\n }\n\n .icon {\n flex: none;\n height: 1.3rem;\n margin-left: 0.5rem;\n fill: @color-secondaryvariant2-light1-90;\n }\n }\n }\n\n .message-container {\n max-height: 3.6em;\n padding: 0 1rem;\n font-size: 1.3rem;\n color: @color-secondaryvariant2-light1-90;\n }\n\n .meta-items-container {\n display: flex;\n flex-direction: row;\n align-items: stretch;\n overflow: visible;\n\n .meta-item {\n &:not(:first-child) {\n margin-left: 0.5rem;\n }\n\n &.poster-shape-poster {\n flex: calc(1 / var(--poster-shape-ratio));\n }\n\n &.poster-shape-square {\n flex: 1;\n }\n\n &.poster-shape-landscape {\n flex: calc(1 / var(--landscape-shape-ratio));\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .meta-row-container {\n .header-container {\n padding: 0 0.5rem;\n\n .title-container {\n margin-right: 0.5rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n }\n\n .meta-items-container {\n .meta-item {\n &:not(:first-child) {\n margin-left: 0;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.pagination-input-container {\n display: flex;\n flex-direction: row;\n\n .prev-button-container, .next-button-container {\n flex: none;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: @color-background;\n\n .icon {\n display: block;\n fill: @color-secondaryvariant1-90;\n }\n }\n\n .label-container {\n flex: 1;\n align-self: stretch;\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: @color-background-dark1;\n\n .label {\n flex: none;\n min-width: 1.2rem;\n max-width: 3rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n text-align: center;\n font-weight: 500;\n color: @color-secondaryvariant1-90;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.search-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 3.5rem;\n padding: 0 1rem;\n border-radius: 3.5rem;\n border: var(--focus-outline-size) solid transparent;\n background-color: var(--color-placeholder-background);\n\n .search-input {\n flex: 1;\n max-height: 1.2em;\n margin-right: 1rem;\n font-size: 1.1rem;\n color: var(--color-placeholder-text);\n }\n\n .icon {\n flex: none;\n width: 1.5rem;\n height: 1.5rem;\n fill: var(--color-placeholder-background);\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.search-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 3.5rem;\n padding: 0 1rem;\n border-radius: 3.5rem;\n border: var(--focus-outline-size) solid transparent;\n background-color: @color-background;\n cursor: text;\n\n &:hover, &:focus-within {\n background-color: @color-background-light1;\n }\n\n &:focus-within {\n border: var(--focus-outline-size) solid @color-surface-light5;\n }\n\n .search-input {\n flex: 1;\n margin-right: 1rem;\n font-size: 1.1rem;\n color: @color-surface-light5;\n\n &::placeholder {\n max-height: 1.2em;\n opacity: 1;\n color: @color-secondaryvariant1-light1-90;\n }\n }\n\n .icon {\n flex: none;\n width: 1.5rem;\n height: 1.5rem;\n fill: @color-secondaryvariant1-90;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.warning-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5rem 1rem;\n background-color: @color-accent5-dark3;\n\n .warning-statement {\n flex: 1;\n margin-right: 1rem;\n font-size: 1.2rem;\n max-height: 2.4em;\n color: @color-surface-light5-90;\n }\n\n .warning-button {\n flex: none;\n max-width: 8rem;\n\n &:not(:last-child) {\n margin-right: 1rem;\n }\n\n &:hover {\n .warning-label {\n text-decoration: underline;\n }\n }\n\n .warning-label {\n font-size: 1.2rem;\n max-height: 1.2em;\n color: @color-surface-light5-90;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\nhtml.active-slider-within {\n cursor: grabbing;\n\n body {\n pointer-events: none;\n }\n}\n\n.slider-container {\n position: relative;\n z-index: 0;\n overflow: visible;\n cursor: pointer;\n\n &:hover, &:global(.active) {\n .track-before {\n background-color: @color-primary-light5;\n }\n }\n\n &:global(.disabled) {\n pointer-events: none;\n\n .track {\n background-color: @color-surface-dark5;\n }\n\n .track-before {\n background-color: @color-surface;\n }\n\n .thumb {\n fill: @color-surface;\n }\n }\n\n .layer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 0;\n display: flex;\n flex-direction: row;\n align-items: center;\n overflow: visible;\n }\n\n .track {\n flex: 1;\n height: var(--track-size);\n background-color: @color-primary-dark3;\n }\n\n .track-before {\n flex: none;\n height: var(--track-size);\n background-color: @color-primary-light3;\n }\n\n .thumb {\n flex: none;\n width: var(--thumb-size);\n height: var(--thumb-size);\n transform: translateX(-50%);\n fill: @color-surface-light5;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.toast-item-container {\n display: flex;\n flex-direction: row;\n width: 25rem;\n margin-bottom: 1rem;\n background-color: @color-surface-light4;\n overflow: visible;\n box-shadow: 0 0.3rem 0.5rem @color-background-dark5-40,\n 0 0.6rem 1rem @color-background-dark5-20;\n pointer-events: auto;\n\n &.success {\n .icon-container {\n background-color: @color-accent3;\n\n .icon {\n fill: @color-surface-light5-90;\n }\n }\n }\n\n &.error {\n .icon-container {\n background-color: @color-accent2;\n\n .icon {\n fill: @color-surface-light5-90;\n }\n }\n }\n\n .icon-container {\n flex: none;\n align-self: stretch;\n width: 2.5rem;\n padding: 0.5rem;\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n fill: @color-background-dark5-90;\n }\n }\n\n .info-container {\n flex: 1;\n align-self: stretch;\n padding: 1rem;\n\n .title-container {\n font-size: 1.2rem;\n\n &:not(:last-child) {\n margin-bottom: 0.2rem;\n }\n }\n\n .message-container {\n font-size: 1.1rem;\n }\n }\n\n .close-button-container {\n flex: none;\n align-self: flex-start;\n width: 2rem;\n height: 2rem;\n margin: 0.2rem;\n padding: 0.5rem;\n\n &:hover {\n background-color: @color-surface-light2;\n }\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.addon-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n padding: 1.5rem;\n background-color: @color-background;\n cursor: inherit;\n\n .logo-container {\n flex: none;\n width: 6rem;\n height: 6rem;\n background-color: @color-background-light1;\n\n .logo {\n display: block;\n width: 100%;\n height: 100%;\n padding: 0.5rem;\n object-fit: contain;\n object-position: center;\n }\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n padding: 1rem;\n fill: @color-secondaryvariant1-light3;\n }\n }\n\n .info-container {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: 0;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: baseline;\n padding: 0 0.5rem;\n\n .name-container {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n padding: 0 0.5rem;\n max-height: 3.6em;\n font-size: 1.6rem;\n color: @color-surface-light5-90;\n }\n\n .version-container {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: auto;\n margin-top: 0.5rem;\n padding: 0 0.5rem;\n max-height: 2.4em;\n color: @color-surface-light5-60;\n }\n\n .types-container {\n flex-grow: 0;\n flex-shrink: 0;\n flex-basis: 100%;\n margin-top: 0.5rem;\n padding: 0 0.5rem;\n max-height: 2.4em;\n color: @color-surface-light5-40;\n text-transform: capitalize;\n }\n\n .description-container {\n flex-grow: 0;\n flex-shrink: 0;\n flex-basis: 100%;\n margin-top: 0.5rem;\n padding: 0 0.5rem;\n max-height: 4.8em;\n color: @color-surface-light5-90;\n }\n }\n\n .buttons-container {\n flex: none;\n display: flex;\n flex-direction: column;\n gap: 1rem;\n width: 17rem;\n\n .action-buttons-container {\n flex: auto;\n display: flex;\n flex-direction: row;\n align-items: center;\n gap: 1rem;\n }\n\n .install-button-container, .configure-button-container, .uninstall-button-container, .share-button-container {\n flex: auto;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n gap: 1rem;\n height: 4rem;\n padding: 0 1rem;\n\n .icon {\n flex: none;\n width: 2rem;\n height: 2rem;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 2.4em;\n font-size: 1.2rem;\n font-weight: 500;\n text-align: center;\n }\n }\n\n .install-button-container {\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light2;\n }\n\n .label {\n color: @color-surface-light5;\n }\n }\n\n .configure-button-container {\n flex: none;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light2;\n }\n\n .icon {\n fill: @color-surface-light5;\n }\n }\n\n .uninstall-button-container {\n outline-color: @color-background-light3;\n outline-style: solid;\n\n &:hover {\n background-color: @color-background-light2;\n }\n\n .label {\n color: @color-surface-light5-90;\n }\n }\n\n .share-button-container {\n &:hover {\n .icon {\n fill: @color-secondaryvariant1-light1;\n }\n\n .label {\n text-decoration: underline;\n color: @color-secondaryvariant1-light2;\n }\n }\n\n .icon {\n fill: @color-secondaryvariant1-dark1-60;\n }\n\n .label {\n color: @color-secondaryvariant1-90;\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .addon-container {\n flex-wrap: wrap;\n\n .info-container {\n margin-left: 0.5rem;\n padding: 0;\n }\n\n .buttons-container {\n flex: 0 1 100%;\n width: auto;\n margin-top: 1rem;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n\n .share-button-container {\n flex: none;\n\n .icon {\n margin-right: 0;\n }\n\n .label {\n display: none;\n }\n }\n\n .install-button-container, .uninstall-button-container {\n flex-basis: 100%;\n margin-right: 1rem;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n share-modal-content: modal-dialog-content;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n addon-modal-content: modal-dialog-content;\n cancel-button-label: label;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n filters-modal-container: modal-dialog-container;\n filters-modal-content: modal-dialog-content;\n}\n\n.addons-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .addons-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n align-self: stretch;\n\n .selectable-inputs-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding: 1.5rem;\n overflow: visible;\n\n .add-button-container {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n width: 10rem;\n height: 3.5rem;\n margin-right: 1.5rem;\n padding: 0 1rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light2;\n }\n\n &:focus {\n outline-color: @color-surface-light5;\n }\n\n .icon {\n flex: none;\n width: 1.2rem;\n height: 1.2rem;\n margin-right: 1rem;\n fill: @color-surface-light5;\n }\n\n .add-button-label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 2.4em;\n font-size: 1.1rem;\n color: @color-surface-light5;\n }\n }\n\n .select-input-container {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: 15rem;\n height: 3.5rem;\n margin-right: 1.5rem;\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n\n .spacing {\n flex: 1;\n }\n\n .search-bar {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: 18rem;\n }\n\n .filter-button {\n flex: none;\n display: none;\n align-items: center;\n justify-content: center;\n width: 3.5rem;\n height: 3.5rem;\n background-color: @color-background;\n\n .filter-icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n fill: @color-secondaryvariant1-90;\n }\n }\n }\n\n .message-container {\n flex: 1;\n align-self: stretch;\n padding: 0 1.5rem;\n font-size: 2rem;\n color: @color-surface-light5;\n }\n\n .addons-list-container {\n flex: 1;\n align-self: stretch;\n padding: 0 1.5rem;\n overflow-y: auto;\n\n .addon {\n margin-bottom: 1.5rem;\n }\n }\n }\n}\n\n.filters-modal {\n .filters-modal-container {\n overflow: visible;\n\n .filters-modal-content {\n display: flex;\n flex-direction: column;\n overflow: visible;\n\n .select-input-container {\n height: 3.5rem;\n\n &:not(:last-child) {\n margin-bottom: 1rem;\n }\n }\n }\n }\n}\n\n.add-addon-modal-container {\n .addon-modal-content {\n width: 30rem;\n\n .notice {\n margin-bottom: 1.5rem;\n font-size: 1rem;\n color: @color-background-dark5-90;\n }\n\n .addon-url-input {\n width: 100%;\n padding: 1rem;\n color: @color-surface-dark5;\n outline: var(--focus-outline-size) solid @color-surface-light2;\n outline-offset: calc(-1 * var(--focus-outline-size));\n\n &:hover {\n outline-color: @color-surface-light4;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n }\n }\n\n .cancel-button {\n background-color: transparent;\n\n &:hover {\n background-color: @color-surface-light3;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n\n .cancel-button-label {\n color: @color-surface-dark2;\n }\n }\n}\n\n.share-modal-container {\n .share-modal-content {\n width: 30rem;\n\n .title-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n\n .logo, .icon {\n float: left;\n width: 5rem;\n height: 5rem;\n margin-right: 1.5rem;\n padding: 0.5rem;\n }\n\n .logo {\n object-fit: contain;\n object-position: center;\n }\n\n .icon {\n fill: @color-secondaryvariant1-light3;\n }\n\n .name-container {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: 0;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: baseline;\n\n .name {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n margin-right: 0.5rem;\n font-size: 1.6rem;\n color: @color-background-dark5-90;\n }\n\n .version {\n flex-grow: 1;\n flex-shrink: 1;\n flex-basis: auto;\n margin-top: 0.5rem;\n color: @color-background-dark5-60;\n }\n }\n }\n\n .share-prompt-container {\n margin-top: 1rem;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .addons-container {\n .addons-content {\n .selectable-inputs-container {\n .add-button-container {\n position: fixed;\n right: 0;\n bottom: calc(3rem + var(--horizontal-nav-bar-size));\n box-shadow: 0 1.35rem 2.7rem @color-background-dark5-40,\n 0 1.1rem 0.85rem @color-background-dark5-20;\n }\n\n .select-input-container {\n display: none;\n }\n\n .spacing {\n display: none;\n }\n\n .search-bar {\n flex-basis: 100%;\n margin-right: 1rem;\n }\n\n .filter-button {\n display: flex;\n }\n }\n }\n }\n\n .share-modal-container {\n .share-modal-content {\n width: auto;\n }\n }\n\n .add-addon-modal-container {\n .addon-modal-content {\n width: auto;\n\n .notice {\n margin-bottom: 1rem;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/MetaRow/styles.less') {\n meta-item: meta-item;\n}\n\n:import('~stremio/common/MetaRow/MetaRowPlaceholder/styles.less') {\n meta-item-placeholder: meta-item;\n}\n\n.board-container {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n\n .board-content-container {\n flex: 1;\n align-self: stretch;\n background-color: @color-background-dark2;\n\n .board-content {\n width: 100%;\n height: 100%;\n overflow-y: auto;\n\n .board-row {\n margin: 4rem 2rem;\n }\n }\n }\n\n .board-warning-container {\n flex: none;\n align-self: stretch;\n }\n}\n\n@media only screen and (max-width: @large) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+10) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+9) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @normal) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+9) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+8) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @medium) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+8) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+7) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @small) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+7) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+6) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xsmall) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+6) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+5) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xxsmall) {\n .board-container {\n .board-content-container {\n .board-content {\n .board-row-poster, .board-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+5) {\n display: none;\n }\n }\n }\n\n .board-row-landscape, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+4) {\n display: none;\n }\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .board-container {\n position: relative;\n z-index: 0;\n\n .board-content-container {\n &:only-child {\n .board-content {\n height: 100%;\n }\n }\n \n .board-content {\n height: calc(100% - 4rem);\n\n .board-row {\n margin: 2rem 1rem;\n }\n\n .board-row-poster, .board-row-square, .continue-watching-row {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+4) {\n display: none;\n }\n }\n }\n\n .board-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+3) {\n display: none;\n }\n }\n }\n }\n }\n \n .board-warning-container {\n position: absolute;\n left: 0;\n right: 0;\n bottom: var(--vertical-nav-bar-size);\n height: 4rem;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n multiselect-modal-container: modal-container;\n multiselect-option-container: option-container;\n multiselect-icon: icon;\n multiselect-label: label;\n}\n\n:import('~stremio/common/PaginationInput/styles.less') {\n pagination-prev-button-container: prev-button-container;\n pagination-next-button-container: next-button-container;\n pagination-button-icon: icon;\n pagination-label: label;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n selectable-inputs-modal-container: modal-dialog-container;\n selectable-inputs-modal-content: modal-dialog-content;\n}\n\n.discover-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .discover-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: row;\n\n .catalog-container {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n\n .selectable-inputs-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n padding: 1.5rem;\n overflow: visible;\n\n .select-input {\n flex: 0 1 15rem;\n height: 3.5rem;\n\n &:not(:first-child) {\n margin-left: 1.5rem;\n }\n\n &:nth-child(n+4) {\n display: none;\n\n &~.filter-container {\n display: flex;\n }\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n\n .filter-container {\n flex: none;\n display: none;\n align-items: center;\n justify-content: center;\n width: 3.5rem;\n height: 3.5rem;\n margin-left: 1.5rem;\n background-color: @color-background;\n\n .filter-icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n fill: @color-secondaryvariant1-90;\n }\n }\n }\n\n .missing-addon-warning-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 0 1.5rem 1.5rem 1.5rem;\n\n .warning-label {\n flex: none;\n max-height: 2.4em;\n margin-bottom: 1rem;\n font-size: 1.4rem;\n text-align: center;\n color: @color-surface-light5-90;\n }\n\n .install-button {\n flex: none;\n min-width: 10rem;\n max-width: 15rem;\n padding: 1rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .label {\n max-height: 2.4em;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n }\n\n .message-container {\n flex: 0 1 auto;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 0 1.5rem;\n overflow-y: auto;\n\n &:first-child {\n padding: 4rem;\n }\n\n .image {\n flex: none;\n width: 12rem;\n height: 12rem;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .message-label {\n flex: none;\n font-size: 2.5rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n .meta-items-container {\n flex: 1;\n align-self: stretch;\n display: grid;\n grid-auto-rows: max-content;\n align-items: center;\n grid-gap: 0.5rem;\n margin-right: 1.5rem;\n padding: 0 1.5rem;\n overflow-y: auto;\n\n .meta-item-placeholder {\n padding: 1rem;\n\n .poster-container {\n padding-bottom: calc(100% * var(--poster-shape-ratio));\n background-color: var(--color-placeholder-background);\n }\n\n .title-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 2.8rem;\n\n .title-label {\n flex: none;\n width: 60%;\n height: 1.2rem;\n background-color: var(--color-placeholder-background);\n }\n }\n }\n }\n }\n\n .meta-preview-container {\n flex: none;\n align-self: stretch;\n width: 28rem;\n background-color: @color-background-dark3;\n }\n }\n}\n\n.selectable-inputs-modal {\n .selectable-inputs-modal-container {\n overflow: visible;\n\n .selectable-inputs-modal-content {\n overflow: visible;\n\n .select-input {\n height: 3.5rem;\n\n &:not(:last-child) {\n margin-bottom: 1rem;\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 4);\n overflow: auto;\n }\n }\n }\n }\n}\n\n.multiselect-modal-container {\n .multiselect-menu-container {\n width: 15rem;\n max-height: calc(3.2rem * 7);\n overflow-y: auto;\n scrollbar-color: @color-surface-light1 @color-surface-light4;\n\n ::-webkit-scrollbar-thumb {\n background-color: @color-surface-light1;\n\n &:hover {\n background-color: @color-surface-light2;\n }\n }\n\n ::-webkit-scrollbar-track {\n background-color: @color-surface-light4;\n }\n\n .multiselect-option-container {\n background: none;\n\n &:hover, &:focus {\n background-color: @color-surface-light3;\n }\n\n &:focus {\n outline-color: @color-background-dark2;\n }\n\n .multiselect-label {\n color: @color-background-dark2-90;\n }\n\n .multiselect-icon {\n fill: @color-background-dark2-90;\n }\n }\n }\n}\n\n@media only screen and (min-width: @xxlarge) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(10, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xxlarge) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(9, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xlarge) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(8, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @large) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(7, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @normal) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(6, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @medium) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(5, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @small) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(4, 1fr);\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xsmall) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(5, 1fr);\n margin-right: 0;\n }\n }\n\n .meta-preview-container {\n display: none;\n }\n }\n }\n}\n\n@media only screen and (max-width: @xxsmall) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .meta-items-container {\n grid-template-columns: repeat(4, 1fr);\n margin-right: 0;\n }\n }\n\n .meta-preview-container {\n display: none;\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .discover-container {\n .discover-content {\n .catalog-container {\n .selectable-inputs-container {\n justify-content: space-between;\n\n .select-input {\n &:nth-child(n+3) {\n display: none;\n\n &~.filter-container {\n display: flex;\n }\n }\n }\n }\n\n .meta-items-container {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.not-found-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .nav-bar {\n flex: none;\n align-self: stretch;\n }\n\n .not-found-content {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n\n .not-found-image {\n flex: none;\n width: 12rem;\n height: 12rem;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .not-found-label {\n flex: none;\n font-size: 2.5rem;\n max-height: 3.6em;\n max-width: 60%;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n}\n\n:import('~stremio/common/PaginationInput/styles.less') {\n pagination-prev-button-container: prev-button-container;\n pagination-next-button-container: next-button-container;\n pagination-button-icon: icon;\n pagination-label: label;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n selectable-inputs-modal-container: modal-dialog-container;\n selectable-inputs-modal-content: modal-dialog-content;\n}\n\n.library-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .library-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n\n .selectable-inputs-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n padding: 1.5rem;\n overflow: visible;\n\n .select-input-container {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: 15rem;\n height: 3.5rem;\n\n &:not(:last-child) {\n margin-right: 1.5rem;\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n\n .filter-container {\n flex: none;\n display: none;\n align-items: center;\n justify-content: center;\n width: 3.5rem;\n height: 3.5rem;\n background-color: @color-background;\n\n .filter-icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n fill: @color-secondaryvariant1-90;\n }\n }\n\n .spacing {\n flex: 1;\n }\n\n .pagination-input {\n flex: none;\n height: 3.5rem;\n margin-left: 1.5rem;\n\n &.pagination-input-placeholder {\n pointer-events: none;\n\n .pagination-prev-button-container, .pagination-next-button-container {\n .pagination-button-icon {\n fill: @color-surface-dark5-90;\n }\n }\n\n .pagination-label {\n color: @color-surface-dark5-90;\n }\n }\n\n .pagination-prev-button-container, .pagination-next-button-container {\n width: 3.5rem;\n height: 3.5rem;\n\n .pagination-button-icon {\n width: 1rem;\n height: 1rem;\n }\n }\n\n .pagination-label {\n width: 3rem;\n }\n }\n }\n\n .message-container {\n flex: 0 1 auto;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 0 1.5rem;\n overflow-y: auto;\n\n &:first-child {\n padding: 4rem;\n }\n\n &.no-user-message-container {\n .login-button-container {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n width: 20rem;\n min-height: 4rem;\n padding: 0.5rem 1rem;\n margin-bottom: 1rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 4.8em;\n font-size: 1.2rem;\n font-weight: 700;\n color: @color-surface-light5-90;\n text-align: center;\n }\n }\n }\n\n .image {\n flex: none;\n width: 12rem;\n height: 12rem;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .message-label {\n flex: none;\n font-size: 2.5rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n .meta-items-container {\n flex: 1;\n align-self: stretch;\n display: grid;\n grid-auto-rows: max-content;\n align-items: center;\n grid-gap: 0.5rem;\n padding: 0 1.5rem;\n overflow-y: auto;\n }\n }\n}\n\n.selectable-inputs-modal {\n .selectable-inputs-modal-container {\n overflow: visible;\n\n .selectable-inputs-modal-content {\n overflow: visible;\n\n .select-input-container {\n height: 3.5rem;\n\n &:not(:last-child) {\n margin-bottom: 1rem;\n }\n }\n }\n }\n}\n\n@media only screen and (min-width: @large) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(10, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @large) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(9, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @normal) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(8, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @medium) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(7, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @small) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(6, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @xsmall) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(5, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @xxsmall) {\n .library-container {\n .library-content {\n .meta-items-container {\n grid-template-columns: repeat(4, 1fr);\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .library-container {\n .library-content {\n .selectable-inputs-container {\n justify-content: space-between;\n\n .select-input-container {\n display: none;\n }\n\n .spacing {\n display: none;\n }\n\n .pagination-input {\n margin-left: 0;\n }\n\n .filter-container {\n display: flex;\n }\n }\n\n .meta-items-container {\n grid-template-columns: repeat(3, 1fr);\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n:import('~stremio/common/PlayIconCircleCentered/styles.less') {\n play-icon-circle-centered-background: background;\n play-icon-circle-centered-icon: icon;\n}\n\n.stream-placeholder-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5rem 1rem;\n\n .addon-container {\n flex: none;\n\n .addon-name {\n width: 5rem;\n height: 2rem;\n background-color: var(--color-placeholder-background);\n }\n }\n\n .info-container {\n flex: 1;\n margin: 0.5rem 1rem;\n\n .description-container {\n height: 1.2rem;\n background-color: var(--color-placeholder-background);\n\n &:nth-child(1) {\n width: 80%;\n }\n\n &:nth-child(2) {\n width: 40%;\n margin-top: 0.5rem;\n }\n }\n }\n\n .play-icon {\n flex: none;\n width: 3.5rem;\n height: 5rem;\n\n .play-icon-circle-centered-background {\n fill: none;\n }\n\n .play-icon-circle-centered-icon {\n fill: var(--color-placeholder-background);\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/PlayIconCircleCentered/styles.less') {\n play-icon-circle-centered-background: background;\n play-icon-circle-centered-icon: icon;\n}\n\n.stream-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n flex-wrap: wrap;\n padding: 0.5rem 1rem;\n\n &:hover, &:focus {\n background-color: @color-background;\n }\n\n &:hover, &:focus, &:global(.selected) {\n .play-icon {\n .play-icon-circle-centered-background {\n fill: @color-accent4-90;\n }\n\n .play-icon-circle-centered-icon {\n fill: @color-surface-light5-90;\n }\n }\n }\n\n .thumbnail-container, .addon-name-container {\n flex: none;\n\n .thumbnail {\n display: block;\n width: 5rem;\n height: 5rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .placeholder-icon {\n display: block;\n width: 5rem;\n height: 5rem;\n padding: 0.5rem;\n fill: @color-secondaryvariant1-light3-90;\n }\n\n .addon-name {\n width: 5rem;\n max-height: 3.6em;\n font-size: 1.1rem;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n\n .info-container {\n flex: 1;\n max-height: 3.6em;\n margin: 0.5rem 1rem;\n white-space: pre;\n color: @color-surface-light5-90;\n }\n\n .play-icon {\n flex: none;\n width: 3.5rem;\n height: 5rem;\n\n .play-icon-circle-centered-background {\n fill: none;\n }\n\n .play-icon-circle-centered-icon {\n fill: @color-surface-dark5-90;\n }\n }\n\n .progress-bar-container {\n flex: 0 0 100%;\n background-color: @color-background-light2;\n\n .progress-bar {\n height: 0.5rem;\n background-color: @color-primaryvariant1;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .stream-container {\n &:hover, &focus {\n background-color: @color-surface-light5-20;\n }\n\n .thumbnail-container, .addon-name-container {\n .addon-name {\n font-weight: 500;\n }\n }\n\n .play-icon {\n .play-icon-circle-centered-icon {\n fill: @color-surface-light5-90;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n multiselect-label: label;\n multiselect-icon: icon;\n}\n\n.streams-list-container {\n display: flex;\n flex-direction: column;\n\n .message-container {\n flex: 0 1 auto;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 1rem 1rem 0;\n overflow-y: auto;\n\n .image {\n flex: none;\n width: 10rem;\n height: 10rem;\n max-width: 100%;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .label {\n flex: none;\n font-size: 1.4rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n .select-input-container {\n flex: 0 0 auto;\n height: 3.5rem;\n margin: 1em 1em 0 1em;\n background: none;\n\n &:hover, &:focus, &:global(.active) {\n background-color: @color-background;\n }\n\n & >.multiselect-label {\n color: @color-surface-light5-90;\n }\n\n & >.multiselect-icon {\n fill: @color-surface-light5-90;\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n\n .streams-container {\n flex: 0 1 auto;\n align-self: stretch;\n margin-top: 1rem;\n overflow-y: auto;\n }\n\n .install-button-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n margin: 1rem;\n padding: 1.5rem 1rem;\n background-color: @color-accent3;\n\n &:hover, &:focus {\n background-color: @color-accent3-light1;\n }\n\n .icon {\n flex: none;\n width: 2rem;\n height: 2rem;\n margin-right: 1rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex: 0 1 auto;\n font-size: 1.5rem;\n font-weight: 500;\n max-height: 3.6em;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .streams-list-container {\n overflow: visible;\n\n .streams-container {\n margin-top: 0;\n scrollbar-color: @color-surface-light5-20 transparent;\n\n &::-webkit-scrollbar-thumb {\n background-color: @color-surface-light5-20;\n }\n\n &::-webkit-scrollbar-track {\n background-color: transparent;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.seasons-bar-placeholder-container {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding: 1rem;\n\n .prev-season-button, .next-season-button {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n width: 6.5rem;\n height: 3.5rem;\n padding: 0.5rem;\n\n &>:first-child {\n margin-right: 0.5rem;\n }\n\n .icon {\n flex: none;\n display: block;\n width: 1.5rem;\n height: 1.5rem;\n fill: var(--color-placeholder-background);\n }\n\n .label {\n flex: 1;\n max-height: 1.2em;\n font-weight: 500;\n text-align: center;\n color: var(--color-placeholder-text);\n }\n }\n\n .seasons-popup-label-container {\n flex: 0 1 auto;\n display: flex;\n flex-direction: row;\n align-items: center;\n margin: 0 1rem;\n\n .seasons-popup-label {\n max-height: 1.2em;\n font-weight: 500;\n color: var(--color-placeholder-text);\n }\n\n .seasons-popup-icon {\n flex: none;\n width: 1rem;\n height: 1rem;\n margin-left: 1rem;\n fill: var(--color-placeholder-background);\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n multiselect-label: label;\n multiselect-icon: icon;\n}\n\n.seasons-bar-container {\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n padding: 1rem;\n overflow: visible;\n\n .prev-season-button, .next-season-button {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n width: 6.5rem;\n height: 3.5rem;\n padding: 0.5rem;\n\n &:hover, &:focus {\n .label {\n color: @color-surface-light2-90;\n }\n\n .icon {\n fill: @color-surface-light2-90;\n }\n }\n\n &:focus {\n background-color: @color-surface-light5-10;\n }\n\n &>:first-child {\n margin-right: 0.5rem;\n }\n\n .label {\n flex: 1;\n max-height: 1.2em;\n font-weight: 500;\n text-align: center;\n color: @color-surface-90;\n }\n\n .icon {\n flex: none;\n width: 1.5rem;\n height: 1.5rem;\n fill: @color-surface-90;\n }\n }\n\n .seasons-popup-label-container {\n flex: 0 1 auto;\n height: 3.5rem;\n background: none;\n\n &:hover, &:focus, &:global(.active) {\n background-color: @color-background;\n }\n\n &>.multiselect-label {\n color: @color-surface-light5-90;\n }\n\n &>.multiselect-icon {\n fill: @color-surface-light5-90;\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .seasons-bar-container {\n padding-top: 0;\n\n .seasons-popup-label-container {\n .multiselect-menu-container {\n max-height: calc(3.2rem * 3);\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.video-placeholder-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5rem 1rem;\n\n .info-container {\n flex: 1;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n height: 3rem;\n margin: 0.5rem 1rem;\n\n .name-container {\n width: 80%;\n height: 1.2rem;\n background: var(--color-placeholder-background);\n }\n\n .released-container {\n height: 1rem;\n background: var(--color-placeholder-background);\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Popup/styles.less') {\n context-menu-container: menu-container;\n menu-direction-top-left: menu-direction-top-left;\n menu-direction-bottom-left: menu-direction-bottom-left;\n menu-direction-top-right: menu-direction-top-right;\n menu-direction-bottom-right: menu-direction-bottom-right;\n}\n\n.video-container {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n padding: 0.5rem 1rem;\n\n &:hover,\n &:focus,\n &:global(.active) {\n background-color: @color-background;\n }\n\n .thumbnail-container {\n flex: none;\n\n .thumbnail {\n display: block;\n width: 7.5rem;\n height: 5rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .placeholder-icon {\n display: block;\n width: 7.5rem;\n height: 5rem;\n padding: 1rem;\n fill: @color-surface-light5;\n background-color: @color-surface-light5-40;\n opacity: 0.25;\n }\n }\n\n .info-container {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n margin: 0.5rem 1rem;\n\n &:first-child {\n height: 3rem;\n\n .title-container {\n max-height: 1.2em;\n }\n }\n\n .title-container {\n max-height: 2.4em;\n color: @color-surface-light5-90;\n }\n\n .flex-row-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: flex-end;\n\n .released-container {\n flex: 1;\n margin-right: 0.5rem;\n padding: 0.2rem 0;\n font-size: 0.8rem;\n font-weight: 500;\n white-space: nowrap;\n text-overflow: ellipsis;\n text-transform: uppercase;\n color: @color-surface-dark5-90;\n }\n\n .upcoming-watched-container {\n flex: 0 1 auto;\n display: flex;\n flex-direction: row;\n\n &>:nth-child(2) {\n margin-left: 0.5rem;\n }\n\n .upcoming-container,\n .watched-container {\n flex: none;\n padding: 0.2rem 0.4rem;\n max-width: 10rem;\n\n &:not(:only-child) {\n max-width: 5rem;\n }\n\n .flag-label {\n font-size: 0.8rem;\n font-weight: 500;\n white-space: nowrap;\n text-overflow: ellipsis;\n text-transform: uppercase;\n color: @color-background-90;\n }\n }\n\n .upcoming-container {\n background-color: @color-accent4;\n }\n\n .watched-container {\n background-color: @color-accent5;\n }\n }\n }\n }\n\n .progress-bar-container {\n flex: 0 0 100%;\n background-color: @color-background-light2;\n\n .progress-bar {\n height: 0.5rem;\n background-color: @color-primaryvariant1;\n }\n }\n\n .context-menu-container {\n max-width: calc(90% - 1.5rem);\n\n .context-menu-content {\n --spatial-navigation-contain: contain;\n background-color: @color-background-dark1;\n\n .context-menu-option-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5rem 1rem;\n\n &:hover,\n &:focus {\n background-color: @color-background;\n }\n\n .context-menu-option-label {\n font-size: 1rem;\n max-height: 2.4em;\n color: @color-surface-light5-90;\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .video-container {\n\n &:hover,\n &:focus,\n &:global(.active) {\n background-color: @color-surface-light5-20;\n }\n\n .context-menu-container {\n\n &.menu-direction-top-left,\n &.menu-direction-bottom-left {\n right: 1.5rem;\n }\n\n &.menu-direction-top-right,\n &.menu-direction-bottom-right {\n left: 1.5rem;\n }\n\n &.menu-direction-top-left,\n &.menu-direction-top-right {\n bottom: 90%;\n }\n\n &.menu-direction-bottom-left,\n &.menu-direction-bottom-right {\n top: 90%;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.videos-list-container {\n display: flex;\n flex-direction: column;\n\n .message-container {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 2rem;\n overflow-y: auto;\n\n .image {\n flex: none;\n width: 10rem;\n height: 10rem;\n max-width: 100%;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .label {\n flex: none;\n font-size: 1.4rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n .seasons-bar {\n flex: none;\n align-self: stretch;\n }\n\n .search-bar {\n flex: none;\n align-self: stretch;\n margin: 0 1.5rem 1rem 1.5rem;\n\n &:first-child {\n margin-top: 1rem;\n }\n }\n\n .videos-container {\n flex: 1;\n align-self: stretch;\n overflow-y: auto;\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .videos-list-container {\n overflow: visible;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/MetaPreview/styles.less') {\n meta-info-container: meta-info-container;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n modal-dialog-container: modal-dialog-container;\n title-modal-container: title-container;\n}\n\n.metadetails-container {\n display: flex;\n flex-direction: column;\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .nav-bar {\n flex: none;\n align-self: stretch;\n }\n\n .metadetails-content {\n flex: 1;\n align-self: stretch;\n position: relative;\n z-index: 0;\n display: flex;\n flex-direction: row;\n\n .vertical-nav-bar {\n --vertical-nav-bar-size: 6rem;\n flex: none;\n }\n\n .background-image-layer {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n\n &::after {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1;\n background: @color-background-dark2-70;\n content: \"\";\n }\n\n .background-image {\n display: block;\n width: 100%;\n height: 100%;\n object-fit: cover;\n object-position: top left;\n opacity: 0.9;\n }\n }\n\n .meta-message-container {\n flex: 0 1 30rem;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 2rem;\n\n .image {\n flex: none;\n width: 12rem;\n height: 12rem;\n max-width: 100%;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .message-label {\n flex: none;\n align-self: stretch;\n font-size: 2rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n .meta-preview {\n flex: 0 1 40rem;\n align-self: stretch;\n }\n\n .spacing {\n flex: 1;\n }\n\n .videos-list, .streams-list {\n flex: 0 0 26.5rem;\n align-self: stretch;\n background-color: @color-background-dark5-70;\n }\n }\n}\n\n.meta-extension-modal-container {\n .modal-dialog-container {\n width: 80%;\n height: 80%;\n\n .title-modal-container {\n max-height: 1.2em;\n }\n\n .meta-extension-modal-iframe {\n width: 100%;\n height: 100%;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .metadetails-container {\n position: relative;\n z-index: 0;\n\n .metadetails-content {\n display: block;\n position: static;\n z-index: initial;\n overflow-y: auto;\n\n .spacing {\n display: none;\n }\n\n .background-image-layer {\n top: var(--horizontal-nav-bar-size);\n }\n\n .videos-list, .streams-list {\n background-color: transparent;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/MetaRow/styles.less') {\n meta-item: meta-item;\n}\n\n:import('~stremio/common/MetaRow/MetaRowPlaceholder/styles.less') {\n meta-item-placeholder: meta-item;\n}\n\n.search-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .search-content {\n width: 100%;\n height: 100%;\n overflow-y: auto;\n\n .search-row {\n margin: 4rem 2rem;\n }\n\n .search-hints-container {\n display: flex;\n flex-direction: row;\n align-items: flex-start;\n justify-content: flex-start;\n align-content: flex-start;\n flex-wrap: wrap;\n padding: 4rem;\n\n .search-hint-container {\n flex: 0 0 50%;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 0 2rem;\n margin-bottom: 4rem;\n\n .icon {\n flex: none;\n width: 6rem;\n height: 6rem;\n margin-bottom: 2rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n font-size: 1.2rem;\n color: @color-surface-light5-90;\n text-align: center;\n }\n }\n }\n\n .message-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: 4rem;\n\n .image {\n flex: none;\n width: 12rem;\n height: 12rem;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .message-label {\n flex: 0 1 auto;\n font-size: 2.5rem;\n text-align: center;\n color: @color-secondaryvariant2-light1-90;\n }\n }\n }\n}\n\n@media only screen and (max-width: @large) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+10) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+9) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @normal) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+9) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+8) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @medium) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+8) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+7) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @small) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+7) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+6) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xsmall) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+6) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+5) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @xxsmall) {\n .search-container {\n .search-content {\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+5) {\n display: none;\n }\n }\n }\n\n .search-row-landscape {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+4) {\n display: none;\n }\n }\n }\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .search-container {\n .search-content {\n .search-row {\n margin: 2rem 1rem;\n }\n\n .search-row-poster, .search-row-square {\n .meta-item, .meta-item-placeholder {\n &:nth-child(n+4) {\n display: none;\n }\n }\n }\n\n .search-hints-container {\n padding: 4rem 2rem;\n\n .search-hint-container {\n padding: 0 1.5rem;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/Checkbox/styles.less') {\n checkbox-icon: icon;\n}\n\n:import('~stremio/common/Multiselect/styles.less') {\n multiselect-menu-container: menu-container;\n multiselect-label: label;\n}\n\n:import('~stremio/common/ModalDialog/styles.less') {\n configure-server-url-modal-content: modal-dialog-content;\n cancel-button-label: label;\n}\n\n.settings-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n\n .settings-content {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: row;\n\n .side-menu-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n width: 20rem;\n padding: 3rem;\n\n .side-menu-button {\n flex: none;\n align-self: stretch;\n padding: 1rem;\n font-size: 1.1rem;\n color: @color-secondaryvariant1-90;\n\n &.selected {\n background-color: @color-background;\n color: @color-surface-light5-90;\n }\n\n &:hover {\n background-color: @color-background-light1;\n }\n }\n\n .spacing {\n flex: 1;\n }\n\n .version-info-label {\n flex: 0 1 auto;\n margin: 0.5rem 0;\n color: @color-secondaryvariant1-90;\n }\n }\n\n .sections-container {\n flex: 1;\n align-self: stretch;\n padding: 0 2rem;\n overflow-y: auto;\n\n .section-container {\n display: flex;\n flex-direction: column;\n padding: 3rem 0;\n overflow: visible;\n\n &:not(:last-child) {\n border-bottom: thin solid @color-secondaryvariant1-90;\n }\n\n .section-title {\n flex: none;\n align-self: stretch;\n font-size: 1.8rem;\n line-height: 3.4rem;\n margin-bottom: 1rem;\n color: @color-surface-light5-90;\n }\n\n .option-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: row;\n align-items: center;\n max-width: 35rem;\n margin-bottom: 2rem;\n overflow: visible;\n\n &:last-child {\n margin-bottom: 0;\n }\n\n &.user-info-option-container {\n height: 6rem;\n\n .avatar-container {\n flex: none;\n align-self: stretch;\n width: 6rem;\n margin-right: 1rem;\n border-radius: 50%;\n background-size: cover;\n background-repeat: no-repeat;\n background-position: center;\n background-origin: content-box;\n background-clip: content-box;\n opacity: 0.9;\n }\n\n .email-logout-container {\n flex: 1;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n padding: 1rem 0;\n\n .email-label-container, .logout-button-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n }\n\n .email-label-container {\n flex: 1 0 auto;\n\n .email-label {\n flex: 1;\n font-size: 1.1rem;\n max-height: 2.4em;\n color: @color-surface-light5-90;\n }\n }\n\n .logout-button-container {\n flex: 0 1 50%;\n\n &:hover, &:focus {\n outline: none;\n\n .logout-label {\n color: @color-surface-light5-90;\n text-decoration: underline;\n }\n }\n\n .logout-label {\n flex: 1;\n max-height: 1.2em;\n color: @color-surface-90;\n }\n }\n }\n\n .user-panel-container {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n width: 10rem;\n height: 3.5rem;\n margin-left: 1rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .user-panel-label {\n flex: 1;\n max-height: 2.4em;\n padding: 0 0.5rem;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n }\n\n .option-name-container, .option-input-container {\n flex: 1 1 50%;\n display: flex;\n flex-direction: row;\n align-items: center;\n\n .icon {\n flex: none;\n width: 1.5rem;\n height: 1.5rem;\n margin-right: 0.5rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n line-height: 1.5rem;\n color: @color-surface-light5-90;\n }\n }\n\n .option-name-container {\n justify-content: flex-start;\n padding: 1rem 1rem 1rem 0;\n margin-right: 2rem;\n }\n\n .option-input-container {\n padding: 1rem;\n\n &.button-container {\n justify-content: center;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .label {\n font-weight: 500;\n }\n }\n\n &.multiselect-container {\n >.multiselect-label {\n line-height: 1.5rem;\n max-height: 1.5rem;\n }\n\n .multiselect-menu-container {\n max-height: calc(3.2rem * 7);\n overflow: auto;\n }\n }\n\n &.link-container {\n flex: 0 1 auto;\n padding: 1rem 0;\n\n &:hover {\n .label {\n text-decoration: underline;\n }\n }\n }\n\n &.checkbox-container {\n justify-content: center;\n\n .checkbox-icon {\n width: 1.5rem;\n height: 1.5rem;\n }\n }\n\n &.color-input-container {\n padding: 1.75rem 1rem;\n }\n\n &.info-container {\n justify-content: center;\n\n &.selectable {\n user-select: text;\n\n .label {\n user-select: text;\n }\n }\n }\n\n &.configure-input-container {\n padding: 0;\n\n .label {\n flex-grow: 1;\n white-space: pre;\n text-overflow: ellipsis;\n padding: 0 1rem;\n }\n\n .configure-button-container {\n flex: none;\n width: 3rem;\n height: 3rem;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .icon {\n flex: none;\n width: 1rem;\n height: 1rem;\n margin: 0;\n fill: @color-surface-light5-90;\n }\n }\n }\n\n &.shortcut-container {\n justify-content: center;\n padding: 0;\n overflow: visible;\n\n kbd {\n flex: 0 1 auto;\n height: 2.5rem;\n min-width: 2.5rem;\n line-height: 2.5rem;\n padding: 0 1rem;\n font-weight: 500;\n color: @color-secondaryvariant1-90;\n border-radius: 0.25em;\n box-shadow: 0 4px 0 1px @color-background-40;\n background-color: @color-background;\n }\n\n .label {\n margin: 0 1rem;\n white-space: nowrap;\n color: @color-secondaryvariant1-90;\n }\n }\n }\n }\n }\n }\n }\n}\n\n.configure-server-url-modal-container {\n .configure-server-url-modal-content {\n width: 30rem;\n\n .server-url-input {\n width: 100%;\n padding: 1rem;\n color: @color-surface-dark5;\n outline: var(--focus-outline-size) solid @color-surface-light2;\n outline-offset: calc(-1 * var(--focus-outline-size));\n\n &:hover {\n outline-color: @color-surface-light4;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n }\n }\n\n .cancel-button {\n background-color: transparent;\n\n &:hover {\n background-color: @color-surface-light3;\n }\n\n &:focus {\n outline-color: @color-background-dark5;\n }\n\n .cancel-button-label {\n color: @color-surface-dark2;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .settings-container {\n .settings-content {\n flex-direction: column-reverse;\n\n .side-menu-container {\n width: 100%;\n padding: 0 1rem;\n\n .side-menu-button {\n display: none;\n }\n\n .version-info-label {\n width: 100%;\n text-align: end;\n }\n }\n }\n }\n\n .configure-server-url-modal-container {\n .configure-server-url-modal-content {\n width: auto;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.buffering-loader-container {\n display: flex;\n align-items: center;\n justify-content: center;\n\n .buffering-loader {\n flex: none;\n width: 17rem;\n height: 17rem;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:import('~stremio/common/Slider/styles.less') {\n slider-track-before: track-before;\n slider-thumb: thumb;\n}\n\n.seek-bar-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n\n &:hover, &:global(.active) {\n .slider:not(:global(.disabled)) {\n .slider-thumb {\n fill: @color-surface-light5;\n }\n }\n }\n\n &:hover {\n .slider:not(:global(.disabled)) {\n .slider-track-before {\n transition: background-color 0s 100ms;\n }\n\n .slider-thumb {\n transition: fill 0s 100ms;\n }\n }\n }\n\n .label {\n flex: none;\n max-width: 5rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n direction: rtl;\n text-align: left;\n color: @color-surface-light5;\n }\n\n .slider {\n flex: 1;\n align-self: stretch;\n margin: 0 var(--thumb-size);\n\n .slider-thumb {\n fill: transparent;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:import('~stremio/common/Slider/styles.less') {\n slider-track: track;\n slider-track-before: track-before;\n}\n\n.volume-slider:not(:global(.disabled)) {\n .slider-track {\n background-color: @color-surface-dark5;\n }\n\n .slider-track-before {\n background-color: @color-surface-light3;\n }\n\n &:hover, &:global(.active) {\n .slider-track-before {\n background-color: @color-surface-light5;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.control-bar-container {\n padding: 0 1.5rem;\n\n .seek-bar {\n --track-size: 0.5rem;\n --thumb-size: 1.5rem;\n\n height: 2.5rem;\n }\n\n .control-bar-buttons-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n\n .control-bar-button {\n flex: none;\n width: 4rem;\n height: 4rem;\n display: flex;\n justify-content: center;\n align-items: center;\n\n &:global(.disabled) {\n .icon {\n fill: @color-surface;\n }\n }\n\n .icon {\n flex: none;\n width: 3rem;\n height: 2rem;\n fill: @color-surface-light5;\n }\n }\n\n .volume-slider {\n --track-size: 0.4rem;\n --thumb-size: 1.3rem;\n\n flex: 0 1 16rem;\n min-width: 10rem;\n height: 4rem;\n margin: 0 1rem;\n }\n\n .spacing {\n flex: 1;\n }\n\n .control-bar-buttons-menu-button {\n flex: none;\n width: 4rem;\n height: 4rem;\n display: none;\n justify-content: center;\n align-items: center;\n\n .icon {\n flex: none;\n width: 3rem;\n height: 2rem;\n fill: @color-surface-light5;\n }\n }\n\n .control-bar-buttons-menu-container {\n flex: none;\n display: flex;\n flex-direction: row;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .control-bar-container {\n padding: 0;\n\n .seek-bar {\n margin: 0 1.5rem;\n }\n\n .control-bar-buttons-container {\n position: relative;\n padding: 0 0.5rem;\n overflow: visible;\n\n .volume-slider {\n display: none;\n }\n\n .control-bar-buttons-menu-button {\n display: flex;\n }\n\n .control-bar-buttons-menu-container {\n position: absolute;\n right: 0.15rem;\n bottom: 4.5rem;\n flex-direction: column;\n padding: 0.5rem;\n background-color: @color-background-dark1;\n box-shadow: 0 1.35rem 2.7rem @color-background-dark5-40,\n 0 1.1rem 0.85rem @color-background-dark5-20;\n\n &:not(:global(.open)) {\n display: none;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.next-video-popup-container {\n display: flex;\n flex-direction: row;\n height: 16rem;\n width: 40rem;\n animation: slide-fade-in 0.5s ease-in;\n\n @keyframes slide-fade-in {\n 0% {\n opacity: 0;\n transform: translateX(calc(40rem + 2rem));\n }\n\n 100% {\n opacity: 1;\n transform: translateX(0);\n }\n }\n\n .poster-container {\n flex: 1 1 40%;\n display: flex;\n justify-content: center;\n align-items: center;\n background-color: @color-background;\n\n .poster-image {\n flex: none;\n width: 100%;\n height: 100%;\n object-position: center;\n object-fit: cover;\n }\n\n .placeholder-icon {\n flex: none;\n width: 80%;\n height: 50%;\n fill: @color-background-light3-90;\n }\n }\n\n .info-container {\n flex: 1 1 70%;\n display: flex;\n flex-direction: column;\n\n .details-container {\n flex: auto;\n padding: 1.5rem 1.5rem;\n\n .name {\n flex: none;\n align-self: stretch;\n max-height: 2.4em;\n font-weight: 600;\n margin-bottom: 0.5rem;\n color: @color-surface-light5-90;\n }\n\n .description {\n color: @color-surface-light5-50;\n }\n }\n\n .buttons-container {\n display: flex;\n flex-direction: row;\n\n .spacing {\n flex: 0 0 50%;\n }\n\n .button-container {\n flex: 0 0 50%;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n height: 3.5rem;\n\n &.play-button {\n background-color: @color-accent3;\n\n .icon {\n fill: @color-surface-light5-90;\n }\n\n .label {\n color: @color-surface-light5-90;\n }\n\n &:hover, &:focus {\n background-color: @color-accent3-light1;\n }\n }\n\n .icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n margin-right: 1rem;\n fill: @color-secondaryvariant1-90;\n }\n\n .label {\n flex: none;\n max-height: 2.4em;\n font-size: 1.1rem;\n font-weight: 500;\n color: @color-secondaryvariant1-90;\n }\n\n &:hover, &:focus {\n background-color: @color-background-light2;\n }\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.info-menu-container {\n width: 30rem;\n\n .stream {\n pointer-events: none;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.option-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 4rem;\n\n .icon {\n flex: none;\n width: 1.4rem;\n height: 1.4rem;\n margin: 1.3rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex: 1;\n max-height: 2.4em;\n font-weight: 400;\n color: @color-surface-light5-90;\n }\n\n &:hover {\n background-color: @color-background-light2;\n }\n\n &:global(.disabled) {\n opacity: 0.5;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.options-menu-container {\n width: 15rem;\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.videos-menu-container {\n width: 30rem;\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.discrete-input-container {\n &:global(.disabled) {\n .header {\n color: @color-surface-90;\n }\n\n .input-container {\n opacity: 0.4;\n }\n }\n\n .header {\n max-height: 2.4em;\n margin-bottom: 0.5rem;\n color: @color-surface-light5-90;\n }\n\n .input-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n background: @color-background;\n\n .button-container {\n flex: none;\n width: 3rem;\n height: 3rem;\n padding: 1rem;\n background-color: @color-background-light2;\n\n .icon {\n display: block;\n width: 100%;\n height: 100%;\n fill: @color-surface-light5-90;\n }\n }\n\n .option-label {\n flex: 1;\n max-height: 2.4em;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.subtitles-menu-container {\n height: 23rem;\n display: flex;\n flex-direction: row;\n\n .languages-container, .variants-container, .subtitles-settings-container {\n flex: none;\n align-self: stretch;\n display: flex;\n flex-direction: column;\n\n .languages-header, .variants-header, .settings-header {\n flex: none;\n align-self: stretch;\n max-height: 2.4em;\n margin: 1rem;\n font-weight: 600;\n color: @color-surface-light5-90;\n }\n\n .languages-list, .variants-list {\n flex: 1;\n align-self: stretch;\n overflow-y: auto;\n\n .language-option, .variant-option {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 1rem 1.5rem;\n\n &:global(.selected), &:hover {\n background-color: @color-background;\n }\n\n .language-label, .variant-label {\n flex: 1;\n max-height: 2.4em;\n font-size: 1.1rem;\n color: @color-surface-light5-90;\n }\n\n .icon {\n flex: none;\n width: 0.5rem;\n height: 0.5rem;\n border-radius: 100%;\n margin-left: 1rem;\n background-color: @color-accent3-90;\n }\n }\n }\n }\n\n .languages-container {\n width: 12rem;\n }\n\n .variants-container {\n width: 12rem;\n\n .no-variants-container {\n flex: 1;\n align-self: stretch;\n padding: 1rem;\n\n .no-variants-label {\n max-height: 4.8em;\n font-weight: 500;\n color: @color-surface-90;\n }\n }\n }\n\n .subtitles-settings-container {\n width: 16rem;\n\n .spacing {\n flex: 1;\n }\n\n .discrete-input {\n margin: 0 1.5rem 1rem;\n }\n\n .advanced-button {\n flex: none;\n align-self: flex-end;\n max-width: calc(100% - 3rem);\n margin: 0 1.5rem 1rem;\n white-space: nowrap;\n text-overflow: ellipsis;\n color: @color-surface-light5-90;\n\n &:hover {\n text-decoration: underline;\n }\n\n &:global(.disabled) {\n color: @color-surface-90;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.option {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0 1.5em;\n \n &:global(.selected) {\n background-color: @color-background;\n\n .icon {\n display: block;\n }\n }\n\n &:hover, &:focus {\n background-color: @color-background-light2;\n }\n\n .label {\n flex: 1;\n font-weight: 400;\n color: @color-surface-light5-90;\n }\n\n .icon {\n flex: none;\n display: none;\n width: 0.5rem;\n height: 0.5rem;\n border-radius: 100%;\n margin-left: 1rem;\n background-color: @color-accent3-90;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.speed-menu-container {\n width: 12rem;\n overflow: visible !important;\n\n .title {\n flex: none;\n align-self: stretch;\n max-height: 2.4em;\n font-weight: 600;\n color: @color-surface-light5-90;\n margin: 1rem;\n }\n\n .options-container {\n flex: 0 1 auto;\n max-height: calc(3.2rem * 8);\n overflow-y: auto;\n \n .option {\n height: 3.2rem;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n.video-container {\n .video {\n width: 100%;\n height: 100%;\n\n * {\n font-size: inherit;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:import('~stremio/common/Slider/styles.less') {\n active-slider-within: active-slider-within;\n}\n\n:import('~stremio/common/NavBar/HorizontalNavBar/styles.less') {\n nav-bar-button-container: button-container;\n nav-bar-title: title;\n nav-bar-icon: icon;\n}\n\nhtml:not(.active-slider-within) {\n .player-container.immersed {\n cursor: none;\n\n .nav-bar-layer, .control-bar-layer, .menu-layer {\n opacity: 0;\n transition: opacity 200ms;\n }\n }\n}\n\n.player-container {\n position: relative;\n z-index: 0;\n width: 100%;\n height: 100%;\n background-color: @color-background-dark5;\n\n .layer {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n z-index: 0;\n\n &.error-layer {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n background-color: @color-background-dark5;\n\n .error-label {\n flex: 0 1 auto;\n padding: 0 8rem;\n max-height: 4.8em;\n font-size: 2rem;\n color: @color-surface-light5-90;\n text-align: center;\n }\n\n .playlist-button {\n flex: none;\n display: flex;\n flex-direction: row;\n align-items: center;\n height: 3.5rem;\n max-width: 16rem;\n margin-top: 1.5rem;\n padding: 0.5rem 1rem;\n background-color: @color-accent3;\n\n &:hover, &:focus {\n background-color: @color-accent3-light1;\n }\n\n .icon {\n flex: none;\n width: 1.5rem;\n height: 1.5rem;\n margin-right: 1rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex: 1;\n max-height: 2.4em;\n font-size: 1.1rem;\n font-weight: 500;\n color: @color-surface-light5-90;\n text-align: center;\n }\n }\n }\n\n &.nav-bar-layer {\n bottom: initial;\n background: transparent;\n overflow: visible;\n\n &::before {\n position: absolute;\n right: 0;\n top: 0;\n left: 0;\n z-index: -1;\n box-shadow: 0 0 8rem 6rem @color-background-dark5;\n content: \"\";\n }\n\n .nav-bar-button-container {\n &:hover {\n background: transparent;\n }\n\n .nav-bar-icon {\n fill: @color-surface-light5;\n }\n }\n\n .nav-bar-title {\n color: @color-surface-light5;\n }\n }\n\n &.control-bar-layer {\n top: initial;\n overflow: visible;\n\n &::before {\n position: absolute;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: -1;\n box-shadow: 0 0 8rem 8rem @color-background-dark5;\n content: \"\";\n }\n }\n\n &.menu-layer {\n top: initial;\n left: initial;\n right: 2rem;\n bottom: 8rem;\n max-height: calc(100% - 13.5rem);\n max-width: calc(100% - 4rem);\n background-color: @color-background-dark1;\n box-shadow: 0 1.35rem 2.7rem @color-background-dark5-40,\n 0 1.1rem 0.85rem @color-background-dark5-20;\n overflow: auto;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:import('~stremio/common/Checkbox/styles.less') {\n checkbox-icon: icon;\n}\n\n.consent-checkbox-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n padding: 0.5rem 1rem;\n\n &:focus {\n outline: none;\n background-color: @color-surface-light5-20;\n }\n\n .checkbox-icon {\n flex: none;\n width: 1.2rem;\n height: 1.2rem;\n fill: @color-surface-dark5;\n }\n\n .label {\n flex: 1;\n margin-left: 0.5rem;\n font-size: 0.9rem;\n color: @color-surface-90;\n\n .link {\n font-size: 0.9rem;\n color: @color-surface-light5-90;\n\n &:hover {\n text-decoration: underline;\n }\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n:import('~stremio/common/ModalDialog/styles.less') {\n password-reset-modal-content: modal-dialog-content;\n cancel-button-label: label;\n}\n\n.password-reset-modal-container {\n .password-reset-modal-content {\n width: 30rem;\n\n .credentials-text-input {\n width: 100%;\n padding: 1rem;\n color: @color-surface-dark5;\n outline: var(--focus-outline-size) solid @color-surface-light2-90;\n outline-offset: calc(-1 * var(--focus-outline-size));\n\n &:hover {\n outline-color: @color-surface-light4-90;\n }\n\n &:focus {\n outline-color: @color-background-dark5-90;\n }\n }\n }\n\n .error-message {\n font-size: 1.1rem;\n margin-top: 2rem;\n text-align: center;\n color: @color-accent5-90;\n }\n\n .cancel-button {\n background-color: transparent;\n\n &:hover {\n background-color: @color-surface-light3;\n }\n\n &:focus {\n outline-color: @color-background-dark5-90;\n }\n\n .cancel-button-label {\n color: @color-surface-dark4-90;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .password-reset-modal-container {\n .password-reset-modal-content {\n width: auto;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n@import (reference) '~stremio/common/screen-sizes.less';\n\n.intro-container {\n display: flex;\n flex-direction: row;\n justify-content: center;\n width: 100%;\n height: 100%;\n background:\n linear-gradient(@color-background-dark3-80, @color-background-dark3-80),\n url('/images/intro_background.jpg');\n background-size: cover;\n background-repeat: no-repeat;\n background-position: center;\n background-origin: border-box;\n overflow-y: auto;\n\n .form-container {\n flex: none;\n width: 28rem;\n margin: auto;\n padding: 2rem 0;\n\n .logo-container {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n margin-bottom: 3rem;\n\n .logo {\n flex: none;\n width: 4rem;\n height: 4rem;\n margin-right: 1rem;\n opacity: 0.9;\n }\n\n .name {\n flex: none;\n width: 8rem;\n height: 4rem;\n fill: @color-surface-dark4-90;\n }\n }\n\n .form-button {\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n padding: 0.5rem 1rem;\n\n .icon {\n flex: none;\n width: 1rem;\n height: 2rem;\n margin-right: 1rem;\n fill: @color-surface-light5-90;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n font-size: 1.1rem;\n font-weight: 500;\n color: @color-surface-light5-90;\n text-align: center;\n }\n }\n\n .facebook-button {\n min-height: 4.5rem;\n margin: 1rem 0;\n background: var(--color-facebook);\n\n .label {\n font-size: 1.2rem;\n }\n }\n\n .login-form-button {\n display: block;\n margin: 1rem 0;\n text-align: center;\n color: @color-surface-dark2-90;\n\n &:hover {\n .login-label {\n text-decoration: underline;\n }\n }\n\n &:focus {\n outline: none;\n background-color: @color-surface-light5-20;\n }\n\n .login-label {\n font-weight: 500;\n color: @color-accent4-light1-90;\n }\n }\n\n .credentials-text-input {\n display: block;\n width: 100%;\n margin: 1rem 0;\n padding: 1rem;\n border-bottom: thin solid @color-surface-90;\n color: @color-surface-light5;\n\n &:hover {\n background-color: @color-surface-light5-20;\n }\n\n &:focus {\n border-bottom-color: @color-secondaryvariant2-light1-90;\n\n &::placeholder {\n color: @color-secondaryvariant2-light1-90;\n }\n }\n\n &::placeholder {\n color: @color-surface-dark2-90;\n }\n }\n\n .forgot-password-link-container {\n display: flex;\n flex-direction: row;\n justify-content: flex-end;\n margin: 1rem 0;\n text-align: right;\n\n .forgot-password-link {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n padding: 0.5rem 1rem;\n color: @color-surface-light3-90;\n\n &:hover {\n text-decoration: underline;\n color: @color-secondaryvariant2-light1-90;\n }\n\n &:focus {\n outline: none;\n background-color: @color-surface-light5-20;\n }\n }\n }\n\n .error-message {\n margin: 1rem 0;\n padding: 0 1rem;\n text-align: center;\n color: @color-accent5-90;\n }\n\n .submit-button {\n min-height: 4rem;\n margin: 1rem 0;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n .label {\n font-size: 1.2rem;\n }\n }\n\n .guest-login-button, .signup-form-button {\n margin-top: 1rem;\n padding: 1rem;\n\n &:hover {\n .label {\n text-decoration: underline;\n }\n }\n\n &:focus {\n outline: none;\n background-color: @color-surface-light5-20;\n }\n }\n }\n}\n\n.loading-modal-container {\n display: flex;\n align-items: center;\n justify-content: center;\n background-color: @color-background-dark5-40;\n\n .loader-container {\n flex: none;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n padding: 2rem;\n background-color: @color-surface-light5;\n\n @keyframes flash {\n 0% {\n opacity: 0.4;\n }\n\n 100% {\n opacity: 1.0;\n }\n }\n\n .icon {\n flex: none;\n width: 5rem;\n height: 5rem;\n margin-bottom: 1rem;\n fill: @color-background-dark5-90;\n animation: 1s linear infinite alternate flash;\n }\n\n .label {\n font-size: 2rem;\n color: @color-background-dark5-90;\n animation: 1s linear infinite alternate flash;\n }\n }\n}\n\n@media only screen and (max-width: @minimum) {\n .intro-container {\n .form-container {\n flex: 0 1 auto;\n width: 100%;\n padding: 2rem 1.5rem;\n }\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n.error-container {\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n\n .error-image {\n flex: none;\n width: 12rem;\n height: 12rem;\n margin-bottom: 1rem;\n object-fit: contain;\n object-position: center;\n opacity: 0.9;\n }\n\n .error-message {\n flex: none;\n padding: 0 3rem;\n font-size: 2rem;\n max-height: 3.6em;\n text-align: center;\n color: @color-surface-light5-90;\n }\n\n .buttons-container {\n flex: none;\n align-self: stretch;\n margin: 0 2rem;\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n align-items: center;\n justify-content: center;\n\n .button-container {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n display: flex;\n flex-direction: row;\n align-items: center;\n justify-content: center;\n margin: 2rem 1rem 0;\n padding: 0 1rem;\n min-width: 8rem;\n height: 3rem;\n background-color: @color-accent3;\n\n &:hover {\n background-color: @color-accent3-light1;\n }\n\n &:global(.disabled) {\n background-color: @color-surface-dark5;\n }\n\n .label {\n flex-grow: 0;\n flex-shrink: 1;\n flex-basis: auto;\n max-height: 2.4em;\n font-size: 1.1rem;\n font-weight: 500;\n text-align: center;\n color: @color-surface-light5-90;\n }\n }\n }\n}","@font-face {\n font-family: 'Roboto';\n font-style: italic;\n font-weight: 300;\n src: url('/fonts/Roboto-LightItalic.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: italic;\n font-weight: 400;\n src: url('/fonts/Roboto-RegularItalic.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: italic;\n font-weight: 500;\n src: url('/fonts/Roboto-MediumItalic.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: italic;\n font-weight: 700;\n src: url('/fonts/Roboto-BoldItalic.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: normal;\n font-weight: 300;\n src: url('/fonts/Roboto-Light.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: normal;\n font-weight: 400;\n src: url('/fonts/Roboto-Regular.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: normal;\n font-weight: 500;\n src: url('/fonts/Roboto-Medium.ttf') format('truetype');\n}\n\n@font-face {\n font-family: 'Roboto';\n font-style: normal;\n font-weight: 700;\n src: url('/fonts/Roboto-Bold.ttf') format('truetype');\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n@import (inline, once, css) '~stremio/common/roboto.css';\n@import (reference) '~stremio/common/screen-sizes.less';\n@import (reference) '~@stremio/stremio-colors/less/stremio-colors.less';\n\n:global {\n @import (once, less) '~stremio/common/animations.less';\n @import (once, less) '~stremio-router/styles.css';\n}\n\n:root {\n --landscape-shape-ratio: 0.5625;\n --poster-shape-ratio: 1.464;\n --scroll-bar-size: 6px;\n --horizontal-nav-bar-size: 4rem;\n --vertical-nav-bar-size: 5.2rem;\n --focus-outline-size: 2px;\n --color-facebook: #4267b2;\n --color-twitter: #1DA1F2;\n --color-placeholder: #60606080;\n --color-placeholder-text: @color-surface-50;\n --color-placeholder-background: @color-surface-dark5-20;\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: border-box;\n font-size: 1rem;\n line-height: 1.2em;\n font-family: inherit;\n border: none;\n outline: none;\n list-style: none;\n user-select: none;\n text-decoration: none;\n appearance: none;\n background: none;\n box-shadow: none;\n overflow: hidden;\n word-break: break-word;\n scrollbar-width: thin;\n scrollbar-color: @color-secondaryvariant2-light1 @color-background-dark2;\n}\n\n::-webkit-scrollbar {\n width: var(--scroll-bar-size);\n height: var(--scroll-bar-size);\n}\n\n::-webkit-scrollbar-thumb {\n background-color: @color-secondaryvariant2-light1;\n\n &:hover {\n background-color: @color-secondaryvariant2-light2;\n }\n}\n\n::-webkit-scrollbar-track {\n background-color: @color-background-dark2;\n}\n\nsvg {\n overflow: visible;\n}\n\nhtml {\n width: 100%;\n height: 100%;\n min-width: 640px;\n min-height: 480px;\n font-family: 'Roboto', 'sans-serif';\n overflow: auto;\n\n body {\n width: 100%;\n height: 100%;\n\n :global(#app) {\n position: relative;\n z-index: 0;\n width: 100%;\n height: 100%;\n\n .toasts-container {\n position: absolute;\n top: calc(1.2 * var(--horizontal-nav-bar-size));\n right: 0;\n bottom: calc(1.2 * var(--horizontal-nav-bar-size));\n left: auto;\n z-index: 1;\n padding: 0 calc(0.5 * var(--horizontal-nav-bar-size));\n overflow-y: auto;\n scrollbar-width: none;\n pointer-events: none;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n .router {\n width: 100%;\n height: 100%;\n }\n\n .loader-container, .error-container {\n width: 100%;\n height: 100%;\n background-color: @color-background-dark2;\n }\n }\n }\n}\n\n@media only screen and (min-width: @xxlarge) {\n html {\n font-size: 18px;\n }\n}\n\n@media only screen and (max-width: @xxlarge) {\n html {\n font-size: 16px;\n }\n}\n\n@media only screen and (max-width: @large) {\n html {\n font-size: 15px;\n }\n}\n\n@media only screen and (max-width: @medium) {\n html {\n font-size: 14px;\n }\n}\n\n@media only screen and (max-width: @xsmall) {\n html {\n min-width: inherit;\n min-height: inherit;\n }\n}","// Copyright (C) 2017-2022 Smart code 203358507\n\n:global(.animation-fade-in) {\n :local {\n animation-name: fade-in;\n }\n\n animation-timing-function: ease-in-out;\n animation-duration: 100ms;\n}\n\n@keyframes fade-in {\n 0% {\n opacity: 0.6;\n transform: translateY(0.2vh);\n }\n\n 100% {\n opacity: 1;\n transform: translateY(0);\n }\n}","/* Copyright (C) 2017-2022 Smart code 203358507 */\n\n.routes-container {\n position: relative;\n z-index: 0;\n}\n\n.routes-container .route-container {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 0;\n}\n\n.routes-container .route-container:not(:last-child) {\n display: none;\n}\n\n.routes-container .route-container .route-content {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 0;\n overflow: hidden;\n}\n\n.routes-container .route-container .modals-container {\n width: 0;\n height: 0;\n}\n\n.routes-container .route-container .modals-container .modal-container {\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1;\n overflow: hidden;\n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 000000000..ee09fc7d9 --- /dev/null +++ b/index.html @@ -0,0 +1 @@ +<!doctype html><html><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,minimum-scale=1"><meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-title" content="Stremio"><link rel="icon" type="image/png" sizes="96x96" href="4ffa1a051cd42350e1948a517da3018721508d5d/favicons/icon-96.png"><link rel="manifest" href="4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json"/><meta name="theme-color" content="rgb(42, 40, 67)"><link rel="apple-touch-icon" href="4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png"><title>Stremio - Freedom to Stream
\ No newline at end of file diff --git a/service-worker.js b/service-worker.js new file mode 100644 index 000000000..a3f51a950 --- /dev/null +++ b/service-worker.js @@ -0,0 +1,2 @@ +if(!self.define){let a,d={};const e=(e,f)=>(e=new URL(e+".js",f).href,d[e]||new Promise((d=>{if("document"in self){const a=document.createElement("script");a.src=e,a.onload=d,document.head.appendChild(a)}else a=e,importScripts(e),d()})).then((()=>{let a=d[e];if(!a)throw new Error(`Module ${e} didn’t register its module`);return a})));self.define=(f,i)=>{const o=a||("document"in self?document.currentScript.src:"")||location.href;if(d[o])return;let c={};const r=a=>e(a,o),s={module:{uri:o},exports:c,require:r};d[o]=Promise.all(f.map((a=>s[a]||r(a)))).then((a=>(i(...a),c)))}}define(["./workbox-ad8011fb"],(function(a){"use strict";self.skipWaiting(),a.clientsClaim(),a.precacheAndRoute([{url:"4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm",revision:"90ddd0e7dc0630f671a24f775e151622"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/favicons/favicon.ico",revision:"73f6cce044fafd48bf447d80487f5a63"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/favicons/icon-96.png",revision:"de1c79ffc899cb64fbaf6a6d17d364a5"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf",revision:"e07df86cef2e721115583d61d1fb68a6"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf",revision:"5b44818d2b9eda3e23cd5edd7b49b7d5"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf",revision:"88823c2015ffd5fa89d567e17297a137"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf",revision:"a3ce4440f2abf76f4a1b14b83920138c"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf",revision:"58aef543c97bbaf6a9896e8484456d98"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-MediumItalic.ttf",revision:"cf23e1bb619029496260760b72aebd30"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Regular.ttf",revision:"11eabca2251325cfc5589c9c6fb57b46"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf",revision:"a720f17aa773e493a7ebf8b08459e66c"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/anonymous.png",revision:"3c24e42de8822c3e2dc0c20a04cb18c2"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/default_avatar.png",revision:"e574e5a876fb07bb28b07dd60bd63429"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/empty.png",revision:"ff850d70fd43d29b6d8c7055f33d8dbb"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png",revision:"f91415b051185986aedf4187c90ea6f7"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x512.png",revision:"5a446747b1843c1aac2c386b1005ab78"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg",revision:"96ccc21bab56c04153a6400842b8a9dd"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x192.png",revision:"73f3a1cb7aeabde43ba2ed935fde06b1"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x512.png",revision:"88f79bb79e6039edee6367ffa081aa06"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/images/stremio_symbol.png",revision:"9d75b8169c82b11f5399be4129e7757f"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json",revision:"1577e844d5f40d9886332544c3e3a684"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js",revision:"2dd28c355d7aefde2433ff7d4d4f6898"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js",revision:"8ec37357385f3ef75665f629d9a6ae79"},{url:"4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css",revision:"d5dc93d258ae7fd1cb16399ae542910a"},{url:"index.html",revision:"0d4e91074aacc03826865b7f1008cb15"}],{})})); +//# sourceMappingURL=service-worker.js.map diff --git a/service-worker.js.map b/service-worker.js.map new file mode 100644 index 000000000..386886731 --- /dev/null +++ b/service-worker.js.map @@ -0,0 +1 @@ +{"version":3,"file":"service-worker.js","sources":["../../../../../tmp/ac0164418884d87574bd8d399d09b905/service-worker.js"],"sourcesContent":["import {clientsClaim as workbox_core_clientsClaim} from '/home/runner/work/stremio-web/stremio-web/node_modules/workbox-core/clientsClaim.mjs';\nimport {precacheAndRoute as workbox_precaching_precacheAndRoute} from '/home/runner/work/stremio-web/stremio-web/node_modules/workbox-precaching/precacheAndRoute.mjs';/**\n * Welcome to your Workbox-powered service worker!\n *\n * You'll need to register this file in your web app.\n * See https://goo.gl/nhQhGp\n *\n * The rest of the code is auto-generated. Please don't update this file\n * directly; instead, make changes to your Workbox build configuration\n * and re-run your build process.\n * See https://goo.gl/2aRDsh\n */\n\n\n\n\n\n\n\n\nself.skipWaiting();\n\nworkbox_core_clientsClaim();\n\n\n/**\n * The precacheAndRoute() method efficiently caches and responds to\n * requests for URLs in the manifest.\n * See https://goo.gl/S9QRab\n */\nworkbox_precaching_precacheAndRoute([\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/binaries/stremio_core_web_bg.wasm\",\n \"revision\": \"90ddd0e7dc0630f671a24f775e151622\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/favicons/favicon.ico\",\n \"revision\": \"73f6cce044fafd48bf447d80487f5a63\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/favicons/icon-96.png\",\n \"revision\": \"de1c79ffc899cb64fbaf6a6d17d364a5\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Bold.ttf\",\n \"revision\": \"e07df86cef2e721115583d61d1fb68a6\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-BoldItalic.ttf\",\n \"revision\": \"5b44818d2b9eda3e23cd5edd7b49b7d5\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Light.ttf\",\n \"revision\": \"88823c2015ffd5fa89d567e17297a137\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-LightItalic.ttf\",\n \"revision\": \"a3ce4440f2abf76f4a1b14b83920138c\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Medium.ttf\",\n \"revision\": \"58aef543c97bbaf6a9896e8484456d98\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-MediumItalic.ttf\",\n \"revision\": \"cf23e1bb619029496260760b72aebd30\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-Regular.ttf\",\n \"revision\": \"11eabca2251325cfc5589c9c6fb57b46\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/fonts/Roboto-RegularItalic.ttf\",\n \"revision\": \"a720f17aa773e493a7ebf8b08459e66c\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/anonymous.png\",\n \"revision\": \"3c24e42de8822c3e2dc0c20a04cb18c2\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/default_avatar.png\",\n \"revision\": \"e574e5a876fb07bb28b07dd60bd63429\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/empty.png\",\n \"revision\": \"ff850d70fd43d29b6d8c7055f33d8dbb\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x192.png\",\n \"revision\": \"f91415b051185986aedf4187c90ea6f7\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/icon_x512.png\",\n \"revision\": \"5a446747b1843c1aac2c386b1005ab78\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/intro_background.jpg\",\n \"revision\": \"96ccc21bab56c04153a6400842b8a9dd\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x192.png\",\n \"revision\": \"73f3a1cb7aeabde43ba2ed935fde06b1\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/maskable_icon_x512.png\",\n \"revision\": \"88f79bb79e6039edee6367ffa081aa06\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/images/stremio_symbol.png\",\n \"revision\": \"9d75b8169c82b11f5399be4129e7757f\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/manifest.json\",\n \"revision\": \"1577e844d5f40d9886332544c3e3a684\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/scripts/main.js\",\n \"revision\": \"2dd28c355d7aefde2433ff7d4d4f6898\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/scripts/worker.js\",\n \"revision\": \"8ec37357385f3ef75665f629d9a6ae79\"\n },\n {\n \"url\": \"4ffa1a051cd42350e1948a517da3018721508d5d/styles/main.css\",\n \"revision\": \"d5dc93d258ae7fd1cb16399ae542910a\"\n },\n {\n \"url\": \"index.html\",\n \"revision\": \"0d4e91074aacc03826865b7f1008cb15\"\n }\n], {});\n\n\n\n\n\n\n\n\n"],"names":["self","skipWaiting","workbox_core_clientsClaim","workbox_precaching_precacheAndRoute","url","revision"],"mappings":"0nBAoBAA,KAAKC,cAELC,EAAAA,eAQAC,EAAAA,iBAAoC,CAClC,CACEC,IAAO,6EACKC,SAAA,oCAEd,CACED,IAAO,gEACKC,SAAA,oCAEd,CACED,IAAO,gEACKC,SAAA,oCAEd,CACED,IAAO,iEACKC,SAAA,oCAEd,CACED,IAAO,uEACKC,SAAA,oCAEd,CACED,IAAO,kEACKC,SAAA,oCAEd,CACED,IAAO,wEACKC,SAAA,oCAEd,CACED,IAAO,mEACKC,SAAA,oCAEd,CACED,IAAO,yEACKC,SAAA,oCAEd,CACED,IAAO,oEACKC,SAAA,oCAEd,CACED,IAAO,0EACKC,SAAA,oCAEd,CACED,IAAO,gEACKC,SAAA,oCAEd,CACED,IAAO,qEACKC,SAAA,oCAEd,CACED,IAAO,4DACKC,SAAA,oCAEd,CACED,IAAO,gEACKC,SAAA,oCAEd,CACED,IAAO,gEACKC,SAAA,oCAEd,CACED,IAAO,uEACKC,SAAA,oCAEd,CACED,IAAO,yEACKC,SAAA,oCAEd,CACED,IAAO,yEACKC,SAAA,oCAEd,CACED,IAAO,qEACKC,SAAA,oCAEd,CACED,IAAO,yDACKC,SAAA,oCAEd,CACED,IAAO,2DACKC,SAAA,oCAEd,CACED,IAAO,6DACKC,SAAA,oCAEd,CACED,IAAO,2DACKC,SAAA,oCAEd,CACED,IAAO,aACKC,SAAA,qCAEb"} \ No newline at end of file diff --git a/workbox-ad8011fb.js b/workbox-ad8011fb.js new file mode 100644 index 000000000..b46b84b52 --- /dev/null +++ b/workbox-ad8011fb.js @@ -0,0 +1,2 @@ +define(["exports"],(function(t){"use strict";try{self["workbox:core:6.5.3"]&&_()}catch(t){}const e=(t,...e)=>{let s=t;return e.length>0&&(s+=` :: ${JSON.stringify(e)}`),s};class s extends Error{constructor(t,s){super(e(t,s)),this.name=t,this.details=s}}try{self["workbox:routing:6.5.3"]&&_()}catch(t){}const n=t=>t&&"object"==typeof t?t:{handle:t};class i{constructor(t,e,s="GET"){this.handler=n(e),this.match=t,this.method=s}setCatchHandler(t){this.catchHandler=n(t)}}class r extends i{constructor(t,e,s){super((({url:e})=>{const s=t.exec(e.href);if(s&&(e.origin===location.origin||0===s.index))return s.slice(1)}),e,s)}}class o{constructor(){this.t=new Map,this.i=new Map}get routes(){return this.t}addFetchListener(){self.addEventListener("fetch",(t=>{const{request:e}=t,s=this.handleRequest({request:e,event:t});s&&t.respondWith(s)}))}addCacheListener(){self.addEventListener("message",(t=>{if(t.data&&"CACHE_URLS"===t.data.type){const{payload:e}=t.data,s=Promise.all(e.urlsToCache.map((e=>{"string"==typeof e&&(e=[e]);const s=new Request(...e);return this.handleRequest({request:s,event:t})})));t.waitUntil(s),t.ports&&t.ports[0]&&s.then((()=>t.ports[0].postMessage(!0)))}}))}handleRequest({request:t,event:e}){const s=new URL(t.url,location.href);if(!s.protocol.startsWith("http"))return;const n=s.origin===location.origin,{params:i,route:r}=this.findMatchingRoute({event:e,request:t,sameOrigin:n,url:s});let o=r&&r.handler;const c=t.method;if(!o&&this.i.has(c)&&(o=this.i.get(c)),!o)return;let a;try{a=o.handle({url:s,request:t,event:e,params:i})}catch(t){a=Promise.reject(t)}const h=r&&r.catchHandler;return a instanceof Promise&&(this.o||h)&&(a=a.catch((async n=>{if(h)try{return await h.handle({url:s,request:t,event:e,params:i})}catch(t){t instanceof Error&&(n=t)}if(this.o)return this.o.handle({url:s,request:t,event:e});throw n}))),a}findMatchingRoute({url:t,sameOrigin:e,request:s,event:n}){const i=this.t.get(s.method)||[];for(const r of i){let i;const o=r.match({url:t,sameOrigin:e,request:s,event:n});if(o)return i=o,(Array.isArray(i)&&0===i.length||o.constructor===Object&&0===Object.keys(o).length||"boolean"==typeof o)&&(i=void 0),{route:r,params:i}}return{}}setDefaultHandler(t,e="GET"){this.i.set(e,n(t))}setCatchHandler(t){this.o=n(t)}registerRoute(t){this.t.has(t.method)||this.t.set(t.method,[]),this.t.get(t.method).push(t)}unregisterRoute(t){if(!this.t.has(t.method))throw new s("unregister-route-but-not-found-with-method",{method:t.method});const e=this.t.get(t.method).indexOf(t);if(!(e>-1))throw new s("unregister-route-route-not-registered");this.t.get(t.method).splice(e,1)}}let c;const a={googleAnalytics:"googleAnalytics",precache:"precache-v2",prefix:"workbox",runtime:"runtime",suffix:"undefined"!=typeof registration?registration.scope:""},h=t=>[a.prefix,t,a.suffix].filter((t=>t&&t.length>0)).join("-"),u=t=>t||h(a.precache),l=t=>t||h(a.runtime);function f(t,e){const s=e();return t.waitUntil(s),s}try{self["workbox:precaching:6.5.3"]&&_()}catch(t){}function w(t){if(!t)throw new s("add-to-cache-list-unexpected-type",{entry:t});if("string"==typeof t){const e=new URL(t,location.href);return{cacheKey:e.href,url:e.href}}const{revision:e,url:n}=t;if(!n)throw new s("add-to-cache-list-unexpected-type",{entry:t});if(!e){const t=new URL(n,location.href);return{cacheKey:t.href,url:t.href}}const i=new URL(n,location.href),r=new URL(n,location.href);return i.searchParams.set("__WB_REVISION__",e),{cacheKey:i.href,url:r.href}}class d{constructor(){this.updatedURLs=[],this.notUpdatedURLs=[],this.handlerWillStart=async({request:t,state:e})=>{e&&(e.originalRequest=t)},this.cachedResponseWillBeUsed=async({event:t,state:e,cachedResponse:s})=>{if("install"===t.type&&e&&e.originalRequest&&e.originalRequest instanceof Request){const t=e.originalRequest.url;s?this.notUpdatedURLs.push(t):this.updatedURLs.push(t)}return s}}}class p{constructor({precacheController:t}){this.cacheKeyWillBeUsed=async({request:t,params:e})=>{const s=(null==e?void 0:e.cacheKey)||this.h.getCacheKeyForURL(t.url);return s?new Request(s,{headers:t.headers}):t},this.h=t}}let y;async function g(t,e){let n=null;if(t.url){n=new URL(t.url).origin}if(n!==self.location.origin)throw new s("cross-origin-copy-response",{origin:n});const i=t.clone(),r={headers:new Headers(i.headers),status:i.status,statusText:i.statusText},o=e?e(r):r,c=function(){if(void 0===y){const t=new Response("");if("body"in t)try{new Response(t.body),y=!0}catch(t){y=!1}y=!1}return y}()?i.body:await i.blob();return new Response(c,o)}function R(t,e){const s=new URL(t);for(const t of e)s.searchParams.delete(t);return s.href}class m{constructor(){this.promise=new Promise(((t,e)=>{this.resolve=t,this.reject=e}))}}const v=new Set;try{self["workbox:strategies:6.5.3"]&&_()}catch(t){}function q(t){return"string"==typeof t?new Request(t):t}class U{constructor(t,e){this.u={},Object.assign(this,e),this.event=e.event,this.l=t,this.p=new m,this.g=[],this.R=[...t.plugins],this.m=new Map;for(const t of this.R)this.m.set(t,{});this.event.waitUntil(this.p.promise)}async fetch(t){const{event:e}=this;let n=q(t);if("navigate"===n.mode&&e instanceof FetchEvent&&e.preloadResponse){const t=await e.preloadResponse;if(t)return t}const i=this.hasCallback("fetchDidFail")?n.clone():null;try{for(const t of this.iterateCallbacks("requestWillFetch"))n=await t({request:n.clone(),event:e})}catch(t){if(t instanceof Error)throw new s("plugin-error-request-will-fetch",{thrownErrorMessage:t.message})}const r=n.clone();try{let t;t=await fetch(n,"navigate"===n.mode?void 0:this.l.fetchOptions);for(const s of this.iterateCallbacks("fetchDidSucceed"))t=await s({event:e,request:r,response:t});return t}catch(t){throw i&&await this.runCallbacks("fetchDidFail",{error:t,event:e,originalRequest:i.clone(),request:r.clone()}),t}}async fetchAndCachePut(t){const e=await this.fetch(t),s=e.clone();return this.waitUntil(this.cachePut(t,s)),e}async cacheMatch(t){const e=q(t);let s;const{cacheName:n,matchOptions:i}=this.l,r=await this.getCacheKey(e,"read"),o=Object.assign(Object.assign({},i),{cacheName:n});s=await caches.match(r,o);for(const t of this.iterateCallbacks("cachedResponseWillBeUsed"))s=await t({cacheName:n,matchOptions:i,cachedResponse:s,request:r,event:this.event})||void 0;return s}async cachePut(t,e){const n=q(t);var i;await(i=0,new Promise((t=>setTimeout(t,i))));const r=await this.getCacheKey(n,"write");if(!e)throw new s("cache-put-with-no-response",{url:(o=r.url,new URL(String(o),location.href).href.replace(new RegExp(`^${location.origin}`),""))});var o;const c=await this.v(e);if(!c)return!1;const{cacheName:a,matchOptions:h}=this.l,u=await self.caches.open(a),l=this.hasCallback("cacheDidUpdate"),f=l?await async function(t,e,s,n){const i=R(e.url,s);if(e.url===i)return t.match(e,n);const r=Object.assign(Object.assign({},n),{ignoreSearch:!0}),o=await t.keys(e,r);for(const e of o)if(i===R(e.url,s))return t.match(e,n)}(u,r.clone(),["__WB_REVISION__"],h):null;try{await u.put(r,l?c.clone():c)}catch(t){if(t instanceof Error)throw"QuotaExceededError"===t.name&&await async function(){for(const t of v)await t()}(),t}for(const t of this.iterateCallbacks("cacheDidUpdate"))await t({cacheName:a,oldResponse:f,newResponse:c.clone(),request:r,event:this.event});return!0}async getCacheKey(t,e){const s=`${t.url} | ${e}`;if(!this.u[s]){let n=t;for(const t of this.iterateCallbacks("cacheKeyWillBeUsed"))n=q(await t({mode:e,request:n,event:this.event,params:this.params}));this.u[s]=n}return this.u[s]}hasCallback(t){for(const e of this.l.plugins)if(t in e)return!0;return!1}async runCallbacks(t,e){for(const s of this.iterateCallbacks(t))await s(e)}*iterateCallbacks(t){for(const e of this.l.plugins)if("function"==typeof e[t]){const s=this.m.get(e),n=n=>{const i=Object.assign(Object.assign({},n),{state:s});return e[t](i)};yield n}}waitUntil(t){return this.g.push(t),t}async doneWaiting(){let t;for(;t=this.g.shift();)await t}destroy(){this.p.resolve(null)}async v(t){let e=t,s=!1;for(const t of this.iterateCallbacks("cacheWillUpdate"))if(e=await t({request:this.request,response:e,event:this.event})||void 0,s=!0,!e)break;return s||e&&200!==e.status&&(e=void 0),e}}class L extends class{constructor(t={}){this.cacheName=l(t.cacheName),this.plugins=t.plugins||[],this.fetchOptions=t.fetchOptions,this.matchOptions=t.matchOptions}handle(t){const[e]=this.handleAll(t);return e}handleAll(t){t instanceof FetchEvent&&(t={event:t,request:t.request});const e=t.event,s="string"==typeof t.request?new Request(t.request):t.request,n="params"in t?t.params:void 0,i=new U(this,{event:e,request:s,params:n}),r=this.q(i,s,e);return[r,this.U(r,i,s,e)]}async q(t,e,n){let i;await t.runCallbacks("handlerWillStart",{event:n,request:e});try{if(i=await this.L(e,t),!i||"error"===i.type)throw new s("no-response",{url:e.url})}catch(s){if(s instanceof Error)for(const r of t.iterateCallbacks("handlerDidError"))if(i=await r({error:s,event:n,request:e}),i)break;if(!i)throw s}for(const s of t.iterateCallbacks("handlerWillRespond"))i=await s({event:n,request:e,response:i});return i}async U(t,e,s,n){let i,r;try{i=await t}catch(r){}try{await e.runCallbacks("handlerDidRespond",{event:n,request:s,response:i}),await e.doneWaiting()}catch(t){t instanceof Error&&(r=t)}if(await e.runCallbacks("handlerDidComplete",{event:n,request:s,response:i,error:r}),e.destroy(),r)throw r}}{constructor(t={}){t.cacheName=u(t.cacheName),super(t),this._=!1!==t.fallbackToNetwork,this.plugins.push(L.copyRedirectedCacheableResponsesPlugin)}async L(t,e){const s=await e.cacheMatch(t);return s||(e.event&&"install"===e.event.type?await this.C(t,e):await this.O(t,e))}async O(t,e){let n;const i=e.params||{};if(!this._)throw new s("missing-precache-entry",{cacheName:this.cacheName,url:t.url});{const s=i.integrity,r=t.integrity,o=!r||r===s;n=await e.fetch(new Request(t,{integrity:"no-cors"!==t.mode?r||s:void 0})),s&&o&&"no-cors"!==t.mode&&(this.N(),await e.cachePut(t,n.clone()))}return n}async C(t,e){this.N();const n=await e.fetch(t);if(!await e.cachePut(t,n.clone()))throw new s("bad-precaching-response",{url:t.url,status:n.status});return n}N(){let t=null,e=0;for(const[s,n]of this.plugins.entries())n!==L.copyRedirectedCacheableResponsesPlugin&&(n===L.defaultPrecacheCacheabilityPlugin&&(t=s),n.cacheWillUpdate&&e++);0===e?this.plugins.push(L.defaultPrecacheCacheabilityPlugin):e>1&&null!==t&&this.plugins.splice(t,1)}}L.defaultPrecacheCacheabilityPlugin={cacheWillUpdate:async({response:t})=>!t||t.status>=400?null:t},L.copyRedirectedCacheableResponsesPlugin={cacheWillUpdate:async({response:t})=>t.redirected?await g(t):t};class b{constructor({cacheName:t,plugins:e=[],fallbackToNetwork:s=!0}={}){this.k=new Map,this.K=new Map,this.T=new Map,this.l=new L({cacheName:u(t),plugins:[...e,new p({precacheController:this})],fallbackToNetwork:s}),this.install=this.install.bind(this),this.activate=this.activate.bind(this)}get strategy(){return this.l}precache(t){this.addToCacheList(t),this.W||(self.addEventListener("install",this.install),self.addEventListener("activate",this.activate),this.W=!0)}addToCacheList(t){const e=[];for(const n of t){"string"==typeof n?e.push(n):n&&void 0===n.revision&&e.push(n.url);const{cacheKey:t,url:i}=w(n),r="string"!=typeof n&&n.revision?"reload":"default";if(this.k.has(i)&&this.k.get(i)!==t)throw new s("add-to-cache-list-conflicting-entries",{firstEntry:this.k.get(i),secondEntry:t});if("string"!=typeof n&&n.integrity){if(this.T.has(t)&&this.T.get(t)!==n.integrity)throw new s("add-to-cache-list-conflicting-integrities",{url:i});this.T.set(t,n.integrity)}if(this.k.set(i,t),this.K.set(i,r),e.length>0){const t=`Workbox is precaching URLs without revision info: ${e.join(", ")}\nThis is generally NOT safe. Learn more at https://bit.ly/wb-precache`;console.warn(t)}}}install(t){return f(t,(async()=>{const e=new d;this.strategy.plugins.push(e);for(const[e,s]of this.k){const n=this.T.get(s),i=this.K.get(e),r=new Request(e,{integrity:n,cache:i,credentials:"same-origin"});await Promise.all(this.strategy.handleAll({params:{cacheKey:s},request:r,event:t}))}const{updatedURLs:s,notUpdatedURLs:n}=e;return{updatedURLs:s,notUpdatedURLs:n}}))}activate(t){return f(t,(async()=>{const t=await self.caches.open(this.strategy.cacheName),e=await t.keys(),s=new Set(this.k.values()),n=[];for(const i of e)s.has(i.url)||(await t.delete(i),n.push(i.url));return{deletedURLs:n}}))}getURLsToCacheKeys(){return this.k}getCachedURLs(){return[...this.k.keys()]}getCacheKeyForURL(t){const e=new URL(t,location.href);return this.k.get(e.href)}getIntegrityForCacheKey(t){return this.T.get(t)}async matchPrecache(t){const e=t instanceof Request?t.url:t,s=this.getCacheKeyForURL(e);if(s){return(await self.caches.open(this.strategy.cacheName)).match(s)}}createHandlerBoundToURL(t){const e=this.getCacheKeyForURL(t);if(!e)throw new s("non-precached-url",{url:t});return s=>(s.request=new Request(t),s.params=Object.assign({cacheKey:e},s.params),this.strategy.handle(s))}}let C;const E=()=>(C||(C=new b),C);class O extends i{constructor(t,e){super((({request:s})=>{const n=t.getURLsToCacheKeys();for(const i of function*(t,{ignoreURLParametersMatching:e=[/^utm_/,/^fbclid$/],directoryIndex:s="index.html",cleanURLs:n=!0,urlManipulation:i}={}){const r=new URL(t,location.href);r.hash="",yield r.href;const o=function(t,e=[]){for(const s of[...t.searchParams.keys()])e.some((t=>t.test(s)))&&t.searchParams.delete(s);return t}(r,e);if(yield o.href,s&&o.pathname.endsWith("/")){const t=new URL(o.href);t.pathname+=s,yield t.href}if(n){const t=new URL(o.href);t.pathname+=".html",yield t.href}if(i){const t=i({url:r});for(const e of t)yield e.href}}(s.url,e)){const e=n.get(i);if(e){return{cacheKey:e,integrity:t.getIntegrityForCacheKey(e)}}}}),t.strategy)}}function x(t){const e=E();!function(t,e,n){let a;if("string"==typeof t){const s=new URL(t,location.href);a=new i((({url:t})=>t.href===s.href),e,n)}else if(t instanceof RegExp)a=new r(t,e,n);else if("function"==typeof t)a=new i(t,e,n);else{if(!(t instanceof i))throw new s("unsupported-route-type",{moduleName:"workbox-routing",funcName:"registerRoute",paramName:"capture"});a=t}(c||(c=new o,c.addFetchListener(),c.addCacheListener()),c).registerRoute(a)}(new O(e,t))}t.clientsClaim=function(){self.addEventListener("activate",(()=>self.clients.claim()))},t.precacheAndRoute=function(t,e){!function(t){E().precache(t)}(t),x(e)}})); +//# sourceMappingURL=workbox-ad8011fb.js.map diff --git a/workbox-ad8011fb.js.map b/workbox-ad8011fb.js.map new file mode 100644 index 000000000..4b355edbb --- /dev/null +++ b/workbox-ad8011fb.js.map @@ -0,0 +1 @@ +{"version":3,"file":"workbox-ad8011fb.js","sources":["node_modules/workbox-core/_version.js","node_modules/workbox-core/_private/logger.js","node_modules/workbox-core/models/messages/messageGenerator.js","node_modules/workbox-core/_private/WorkboxError.js","node_modules/workbox-routing/_version.js","node_modules/workbox-routing/utils/constants.js","node_modules/workbox-routing/utils/normalizeHandler.js","node_modules/workbox-routing/Route.js","node_modules/workbox-routing/RegExpRoute.js","node_modules/workbox-routing/Router.js","node_modules/workbox-routing/utils/getOrCreateDefaultRouter.js","node_modules/workbox-core/_private/cacheNames.js","node_modules/workbox-core/_private/waitUntil.js","node_modules/workbox-precaching/_version.js","node_modules/workbox-precaching/utils/createCacheKey.js","node_modules/workbox-precaching/utils/PrecacheInstallReportPlugin.js","node_modules/workbox-precaching/utils/PrecacheCacheKeyPlugin.js","node_modules/workbox-core/_private/canConstructResponseFromBodyStream.js","node_modules/workbox-core/copyResponse.js","node_modules/workbox-core/_private/cacheMatchIgnoreParams.js","node_modules/workbox-core/_private/Deferred.js","node_modules/workbox-core/models/quotaErrorCallbacks.js","node_modules/workbox-strategies/_version.js","node_modules/workbox-strategies/StrategyHandler.js","node_modules/workbox-core/_private/timeout.js","node_modules/workbox-core/_private/getFriendlyURL.js","node_modules/workbox-core/_private/executeQuotaErrorCallbacks.js","node_modules/workbox-precaching/PrecacheStrategy.js","node_modules/workbox-strategies/Strategy.js","node_modules/workbox-precaching/PrecacheController.js","node_modules/workbox-precaching/utils/getOrCreatePrecacheController.js","node_modules/workbox-precaching/PrecacheRoute.js","node_modules/workbox-precaching/utils/generateURLVariations.js","node_modules/workbox-precaching/utils/removeIgnoredSearchParams.js","node_modules/workbox-precaching/addRoute.js","node_modules/workbox-routing/registerRoute.js","node_modules/workbox-core/clientsClaim.js","node_modules/workbox-precaching/precacheAndRoute.js","node_modules/workbox-precaching/precache.js"],"sourcesContent":["\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:core:6.5.3'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst logger = (process.env.NODE_ENV === 'production'\n ? null\n : (() => {\n // Don't overwrite this value if it's already set.\n // See https://github.com/GoogleChrome/workbox/pull/2284#issuecomment-560470923\n if (!('__WB_DISABLE_DEV_LOGS' in self)) {\n self.__WB_DISABLE_DEV_LOGS = false;\n }\n let inGroup = false;\n const methodToColorMap = {\n debug: `#7f8c8d`,\n log: `#2ecc71`,\n warn: `#f39c12`,\n error: `#c0392b`,\n groupCollapsed: `#3498db`,\n groupEnd: null, // No colored prefix on groupEnd\n };\n const print = function (method, args) {\n if (self.__WB_DISABLE_DEV_LOGS) {\n return;\n }\n if (method === 'groupCollapsed') {\n // Safari doesn't print all console.groupCollapsed() arguments:\n // https://bugs.webkit.org/show_bug.cgi?id=182754\n if (/^((?!chrome|android).)*safari/i.test(navigator.userAgent)) {\n console[method](...args);\n return;\n }\n }\n const styles = [\n `background: ${methodToColorMap[method]}`,\n `border-radius: 0.5em`,\n `color: white`,\n `font-weight: bold`,\n `padding: 2px 0.5em`,\n ];\n // When in a group, the workbox prefix is not displayed.\n const logPrefix = inGroup ? [] : ['%cworkbox', styles.join(';')];\n console[method](...logPrefix, ...args);\n if (method === 'groupCollapsed') {\n inGroup = true;\n }\n if (method === 'groupEnd') {\n inGroup = false;\n }\n };\n // eslint-disable-next-line @typescript-eslint/ban-types\n const api = {};\n const loggerMethods = Object.keys(methodToColorMap);\n for (const key of loggerMethods) {\n const method = key;\n api[method] = (...args) => {\n print(method, args);\n };\n }\n return api;\n })());\nexport { logger };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messages } from './messages.js';\nimport '../../_version.js';\nconst fallback = (code, ...args) => {\n let msg = code;\n if (args.length > 0) {\n msg += ` :: ${JSON.stringify(args)}`;\n }\n return msg;\n};\nconst generatorFunction = (code, details = {}) => {\n const message = messages[code];\n if (!message) {\n throw new Error(`Unable to find message for code '${code}'.`);\n }\n return message(details);\n};\nexport const messageGenerator = process.env.NODE_ENV === 'production' ? fallback : generatorFunction;\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { messageGenerator } from '../models/messages/messageGenerator.js';\nimport '../_version.js';\n/**\n * Workbox errors should be thrown with this class.\n * This allows use to ensure the type easily in tests,\n * helps developers identify errors from workbox\n * easily and allows use to optimise error\n * messages correctly.\n *\n * @private\n */\nclass WorkboxError extends Error {\n /**\n *\n * @param {string} errorCode The error code that\n * identifies this particular error.\n * @param {Object=} details Any relevant arguments\n * that will help developers identify issues should\n * be added as a key on the context object.\n */\n constructor(errorCode, details) {\n const message = messageGenerator(errorCode, details);\n super(message);\n this.name = errorCode;\n this.details = details;\n }\n}\nexport { WorkboxError };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:routing:6.5.3'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The default HTTP method, 'GET', used when there's no specific method\n * configured for a route.\n *\n * @type {string}\n *\n * @private\n */\nexport const defaultMethod = 'GET';\n/**\n * The list of valid HTTP methods associated with requests that could be routed.\n *\n * @type {Array}\n *\n * @private\n */\nexport const validMethods = [\n 'DELETE',\n 'GET',\n 'HEAD',\n 'PATCH',\n 'POST',\n 'PUT',\n];\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport '../_version.js';\n/**\n * @param {function()|Object} handler Either a function, or an object with a\n * 'handle' method.\n * @return {Object} An object with a handle method.\n *\n * @private\n */\nexport const normalizeHandler = (handler) => {\n if (handler && typeof handler === 'object') {\n if (process.env.NODE_ENV !== 'production') {\n assert.hasMethod(handler, 'handle', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'handler',\n });\n }\n return handler;\n }\n else {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(handler, 'function', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'handler',\n });\n }\n return { handle: handler };\n }\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport { defaultMethod, validMethods } from './utils/constants.js';\nimport { normalizeHandler } from './utils/normalizeHandler.js';\nimport './_version.js';\n/**\n * A `Route` consists of a pair of callback functions, \"match\" and \"handler\".\n * The \"match\" callback determine if a route should be used to \"handle\" a\n * request by returning a non-falsy value if it can. The \"handler\" callback\n * is called when there is a match and should return a Promise that resolves\n * to a `Response`.\n *\n * @memberof workbox-routing\n */\nclass Route {\n /**\n * Constructor for Route class.\n *\n * @param {workbox-routing~matchCallback} match\n * A callback function that determines whether the route matches a given\n * `fetch` event by returning a non-falsy value.\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resolving to a Response.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n */\n constructor(match, handler, method = defaultMethod) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(match, 'function', {\n moduleName: 'workbox-routing',\n className: 'Route',\n funcName: 'constructor',\n paramName: 'match',\n });\n if (method) {\n assert.isOneOf(method, validMethods, { paramName: 'method' });\n }\n }\n // These values are referenced directly by Router so cannot be\n // altered by minificaton.\n this.handler = normalizeHandler(handler);\n this.match = match;\n this.method = method;\n }\n /**\n *\n * @param {workbox-routing-handlerCallback} handler A callback\n * function that returns a Promise resolving to a Response\n */\n setCatchHandler(handler) {\n this.catchHandler = normalizeHandler(handler);\n }\n}\nexport { Route };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { Route } from './Route.js';\nimport './_version.js';\n/**\n * RegExpRoute makes it easy to create a regular expression based\n * {@link workbox-routing.Route}.\n *\n * For same-origin requests the RegExp only needs to match part of the URL. For\n * requests against third-party servers, you must define a RegExp that matches\n * the start of the URL.\n *\n * @memberof workbox-routing\n * @extends workbox-routing.Route\n */\nclass RegExpRoute extends Route {\n /**\n * If the regular expression contains\n * [capture groups]{@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp#grouping-back-references},\n * the captured values will be passed to the\n * {@link workbox-routing~handlerCallback} `params`\n * argument.\n *\n * @param {RegExp} regExp The regular expression to match against URLs.\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n */\n constructor(regExp, handler, method) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(regExp, RegExp, {\n moduleName: 'workbox-routing',\n className: 'RegExpRoute',\n funcName: 'constructor',\n paramName: 'pattern',\n });\n }\n const match = ({ url }) => {\n const result = regExp.exec(url.href);\n // Return immediately if there's no match.\n if (!result) {\n return;\n }\n // Require that the match start at the first character in the URL string\n // if it's a cross-origin request.\n // See https://github.com/GoogleChrome/workbox/issues/281 for the context\n // behind this behavior.\n if (url.origin !== location.origin && result.index !== 0) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`The regular expression '${regExp.toString()}' only partially matched ` +\n `against the cross-origin URL '${url.toString()}'. RegExpRoute's will only ` +\n `handle cross-origin requests if they match the entire URL.`);\n }\n return;\n }\n // If the route matches, but there aren't any capture groups defined, then\n // this will return [], which is truthy and therefore sufficient to\n // indicate a match.\n // If there are capture groups, then it will return their values.\n return result.slice(1);\n };\n super(match, handler, method);\n }\n}\nexport { RegExpRoute };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { defaultMethod } from './utils/constants.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { normalizeHandler } from './utils/normalizeHandler.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport './_version.js';\n/**\n * The Router can be used to process a `FetchEvent` using one or more\n * {@link workbox-routing.Route}, responding with a `Response` if\n * a matching route exists.\n *\n * If no route matches a given a request, the Router will use a \"default\"\n * handler if one is defined.\n *\n * Should the matching Route throw an error, the Router will use a \"catch\"\n * handler if one is defined to gracefully deal with issues and respond with a\n * Request.\n *\n * If a request matches multiple routes, the **earliest** registered route will\n * be used to respond to the request.\n *\n * @memberof workbox-routing\n */\nclass Router {\n /**\n * Initializes a new Router.\n */\n constructor() {\n this._routes = new Map();\n this._defaultHandlerMap = new Map();\n }\n /**\n * @return {Map>} routes A `Map` of HTTP\n * method name ('GET', etc.) to an array of all the corresponding `Route`\n * instances that are registered.\n */\n get routes() {\n return this._routes;\n }\n /**\n * Adds a fetch event listener to respond to events when a route matches\n * the event's request.\n */\n addFetchListener() {\n // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705\n self.addEventListener('fetch', ((event) => {\n const { request } = event;\n const responsePromise = this.handleRequest({ request, event });\n if (responsePromise) {\n event.respondWith(responsePromise);\n }\n }));\n }\n /**\n * Adds a message event listener for URLs to cache from the window.\n * This is useful to cache resources loaded on the page prior to when the\n * service worker started controlling it.\n *\n * The format of the message data sent from the window should be as follows.\n * Where the `urlsToCache` array may consist of URL strings or an array of\n * URL string + `requestInit` object (the same as you'd pass to `fetch()`).\n *\n * ```\n * {\n * type: 'CACHE_URLS',\n * payload: {\n * urlsToCache: [\n * './script1.js',\n * './script2.js',\n * ['./script3.js', {mode: 'no-cors'}],\n * ],\n * },\n * }\n * ```\n */\n addCacheListener() {\n // See https://github.com/Microsoft/TypeScript/issues/28357#issuecomment-436484705\n self.addEventListener('message', ((event) => {\n // event.data is type 'any'\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n if (event.data && event.data.type === 'CACHE_URLS') {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { payload } = event.data;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Caching URLs from the window`, payload.urlsToCache);\n }\n const requestPromises = Promise.all(payload.urlsToCache.map((entry) => {\n if (typeof entry === 'string') {\n entry = [entry];\n }\n const request = new Request(...entry);\n return this.handleRequest({ request, event });\n // TODO(philipwalton): TypeScript errors without this typecast for\n // some reason (probably a bug). The real type here should work but\n // doesn't: `Array | undefined>`.\n })); // TypeScript\n event.waitUntil(requestPromises);\n // If a MessageChannel was used, reply to the message on success.\n if (event.ports && event.ports[0]) {\n void requestPromises.then(() => event.ports[0].postMessage(true));\n }\n }\n }));\n }\n /**\n * Apply the routing rules to a FetchEvent object to get a Response from an\n * appropriate Route's handler.\n *\n * @param {Object} options\n * @param {Request} options.request The request to handle.\n * @param {ExtendableEvent} options.event The event that triggered the\n * request.\n * @return {Promise|undefined} A promise is returned if a\n * registered route can handle the request. If there is no matching\n * route and there's no `defaultHandler`, `undefined` is returned.\n */\n handleRequest({ request, event, }) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(request, Request, {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'handleRequest',\n paramName: 'options.request',\n });\n }\n const url = new URL(request.url, location.href);\n if (!url.protocol.startsWith('http')) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Workbox Router only supports URLs that start with 'http'.`);\n }\n return;\n }\n const sameOrigin = url.origin === location.origin;\n const { params, route } = this.findMatchingRoute({\n event,\n request,\n sameOrigin,\n url,\n });\n let handler = route && route.handler;\n const debugMessages = [];\n if (process.env.NODE_ENV !== 'production') {\n if (handler) {\n debugMessages.push([`Found a route to handle this request:`, route]);\n if (params) {\n debugMessages.push([\n `Passing the following params to the route's handler:`,\n params,\n ]);\n }\n }\n }\n // If we don't have a handler because there was no matching route, then\n // fall back to defaultHandler if that's defined.\n const method = request.method;\n if (!handler && this._defaultHandlerMap.has(method)) {\n if (process.env.NODE_ENV !== 'production') {\n debugMessages.push(`Failed to find a matching route. Falling ` +\n `back to the default handler for ${method}.`);\n }\n handler = this._defaultHandlerMap.get(method);\n }\n if (!handler) {\n if (process.env.NODE_ENV !== 'production') {\n // No handler so Workbox will do nothing. If logs is set of debug\n // i.e. verbose, we should print out this information.\n logger.debug(`No route found for: ${getFriendlyURL(url)}`);\n }\n return;\n }\n if (process.env.NODE_ENV !== 'production') {\n // We have a handler, meaning Workbox is going to handle the route.\n // print the routing details to the console.\n logger.groupCollapsed(`Router is responding to: ${getFriendlyURL(url)}`);\n debugMessages.forEach((msg) => {\n if (Array.isArray(msg)) {\n logger.log(...msg);\n }\n else {\n logger.log(msg);\n }\n });\n logger.groupEnd();\n }\n // Wrap in try and catch in case the handle method throws a synchronous\n // error. It should still callback to the catch handler.\n let responsePromise;\n try {\n responsePromise = handler.handle({ url, request, event, params });\n }\n catch (err) {\n responsePromise = Promise.reject(err);\n }\n // Get route's catch handler, if it exists\n const catchHandler = route && route.catchHandler;\n if (responsePromise instanceof Promise &&\n (this._catchHandler || catchHandler)) {\n responsePromise = responsePromise.catch(async (err) => {\n // If there's a route catch handler, process that first\n if (catchHandler) {\n if (process.env.NODE_ENV !== 'production') {\n // Still include URL here as it will be async from the console group\n // and may not make sense without the URL\n logger.groupCollapsed(`Error thrown when responding to: ` +\n ` ${getFriendlyURL(url)}. Falling back to route's Catch Handler.`);\n logger.error(`Error thrown by:`, route);\n logger.error(err);\n logger.groupEnd();\n }\n try {\n return await catchHandler.handle({ url, request, event, params });\n }\n catch (catchErr) {\n if (catchErr instanceof Error) {\n err = catchErr;\n }\n }\n }\n if (this._catchHandler) {\n if (process.env.NODE_ENV !== 'production') {\n // Still include URL here as it will be async from the console group\n // and may not make sense without the URL\n logger.groupCollapsed(`Error thrown when responding to: ` +\n ` ${getFriendlyURL(url)}. Falling back to global Catch Handler.`);\n logger.error(`Error thrown by:`, route);\n logger.error(err);\n logger.groupEnd();\n }\n return this._catchHandler.handle({ url, request, event });\n }\n throw err;\n });\n }\n return responsePromise;\n }\n /**\n * Checks a request and URL (and optionally an event) against the list of\n * registered routes, and if there's a match, returns the corresponding\n * route along with any params generated by the match.\n *\n * @param {Object} options\n * @param {URL} options.url\n * @param {boolean} options.sameOrigin The result of comparing `url.origin`\n * against the current origin.\n * @param {Request} options.request The request to match.\n * @param {Event} options.event The corresponding event.\n * @return {Object} An object with `route` and `params` properties.\n * They are populated if a matching route was found or `undefined`\n * otherwise.\n */\n findMatchingRoute({ url, sameOrigin, request, event, }) {\n const routes = this._routes.get(request.method) || [];\n for (const route of routes) {\n let params;\n // route.match returns type any, not possible to change right now.\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const matchResult = route.match({ url, sameOrigin, request, event });\n if (matchResult) {\n if (process.env.NODE_ENV !== 'production') {\n // Warn developers that using an async matchCallback is almost always\n // not the right thing to do.\n if (matchResult instanceof Promise) {\n logger.warn(`While routing ${getFriendlyURL(url)}, an async ` +\n `matchCallback function was used. Please convert the ` +\n `following route to use a synchronous matchCallback function:`, route);\n }\n }\n // See https://github.com/GoogleChrome/workbox/issues/2079\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n params = matchResult;\n if (Array.isArray(params) && params.length === 0) {\n // Instead of passing an empty array in as params, use undefined.\n params = undefined;\n }\n else if (matchResult.constructor === Object && // eslint-disable-line\n Object.keys(matchResult).length === 0) {\n // Instead of passing an empty object in as params, use undefined.\n params = undefined;\n }\n else if (typeof matchResult === 'boolean') {\n // For the boolean value true (rather than just something truth-y),\n // don't set params.\n // See https://github.com/GoogleChrome/workbox/pull/2134#issuecomment-513924353\n params = undefined;\n }\n // Return early if have a match.\n return { route, params };\n }\n }\n // If no match was found above, return and empty object.\n return {};\n }\n /**\n * Define a default `handler` that's called when no routes explicitly\n * match the incoming request.\n *\n * Each HTTP method ('GET', 'POST', etc.) gets its own default handler.\n *\n * Without a default handler, unmatched requests will go against the\n * network as if there were no service worker present.\n *\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n * @param {string} [method='GET'] The HTTP method to associate with this\n * default handler. Each method has its own default.\n */\n setDefaultHandler(handler, method = defaultMethod) {\n this._defaultHandlerMap.set(method, normalizeHandler(handler));\n }\n /**\n * If a Route throws an error while handling a request, this `handler`\n * will be called and given a chance to provide a response.\n *\n * @param {workbox-routing~handlerCallback} handler A callback\n * function that returns a Promise resulting in a Response.\n */\n setCatchHandler(handler) {\n this._catchHandler = normalizeHandler(handler);\n }\n /**\n * Registers a route with the router.\n *\n * @param {workbox-routing.Route} route The route to register.\n */\n registerRoute(route) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isType(route, 'object', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.hasMethod(route, 'match', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.isType(route.handler, 'object', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route',\n });\n assert.hasMethod(route.handler, 'handle', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route.handler',\n });\n assert.isType(route.method, 'string', {\n moduleName: 'workbox-routing',\n className: 'Router',\n funcName: 'registerRoute',\n paramName: 'route.method',\n });\n }\n if (!this._routes.has(route.method)) {\n this._routes.set(route.method, []);\n }\n // Give precedence to all of the earlier routes by adding this additional\n // route to the end of the array.\n this._routes.get(route.method).push(route);\n }\n /**\n * Unregisters a route with the router.\n *\n * @param {workbox-routing.Route} route The route to unregister.\n */\n unregisterRoute(route) {\n if (!this._routes.has(route.method)) {\n throw new WorkboxError('unregister-route-but-not-found-with-method', {\n method: route.method,\n });\n }\n const routeIndex = this._routes.get(route.method).indexOf(route);\n if (routeIndex > -1) {\n this._routes.get(route.method).splice(routeIndex, 1);\n }\n else {\n throw new WorkboxError('unregister-route-route-not-registered');\n }\n }\n}\nexport { Router };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { Router } from '../Router.js';\nimport '../_version.js';\nlet defaultRouter;\n/**\n * Creates a new, singleton Router instance if one does not exist. If one\n * does already exist, that instance is returned.\n *\n * @private\n * @return {Router}\n */\nexport const getOrCreateDefaultRouter = () => {\n if (!defaultRouter) {\n defaultRouter = new Router();\n // The helpers that use the default Router assume these listeners exist.\n defaultRouter.addFetchListener();\n defaultRouter.addCacheListener();\n }\n return defaultRouter;\n};\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst _cacheNameDetails = {\n googleAnalytics: 'googleAnalytics',\n precache: 'precache-v2',\n prefix: 'workbox',\n runtime: 'runtime',\n suffix: typeof registration !== 'undefined' ? registration.scope : '',\n};\nconst _createCacheName = (cacheName) => {\n return [_cacheNameDetails.prefix, cacheName, _cacheNameDetails.suffix]\n .filter((value) => value && value.length > 0)\n .join('-');\n};\nconst eachCacheNameDetail = (fn) => {\n for (const key of Object.keys(_cacheNameDetails)) {\n fn(key);\n }\n};\nexport const cacheNames = {\n updateDetails: (details) => {\n eachCacheNameDetail((key) => {\n if (typeof details[key] === 'string') {\n _cacheNameDetails[key] = details[key];\n }\n });\n },\n getGoogleAnalyticsName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.googleAnalytics);\n },\n getPrecacheName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.precache);\n },\n getPrefix: () => {\n return _cacheNameDetails.prefix;\n },\n getRuntimeName: (userCacheName) => {\n return userCacheName || _createCacheName(_cacheNameDetails.runtime);\n },\n getSuffix: () => {\n return _cacheNameDetails.suffix;\n },\n};\n","/*\n Copyright 2020 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A utility method that makes it easier to use `event.waitUntil` with\n * async functions and return the result.\n *\n * @param {ExtendableEvent} event\n * @param {Function} asyncFn\n * @return {Function}\n * @private\n */\nfunction waitUntil(event, asyncFn) {\n const returnPromise = asyncFn();\n event.waitUntil(returnPromise);\n return returnPromise;\n}\nexport { waitUntil };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:precaching:6.5.3'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport '../_version.js';\n// Name of the search parameter used to store revision info.\nconst REVISION_SEARCH_PARAM = '__WB_REVISION__';\n/**\n * Converts a manifest entry into a versioned URL suitable for precaching.\n *\n * @param {Object|string} entry\n * @return {string} A URL with versioning info.\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function createCacheKey(entry) {\n if (!entry) {\n throw new WorkboxError('add-to-cache-list-unexpected-type', { entry });\n }\n // If a precache manifest entry is a string, it's assumed to be a versioned\n // URL, like '/app.abcd1234.js'. Return as-is.\n if (typeof entry === 'string') {\n const urlObject = new URL(entry, location.href);\n return {\n cacheKey: urlObject.href,\n url: urlObject.href,\n };\n }\n const { revision, url } = entry;\n if (!url) {\n throw new WorkboxError('add-to-cache-list-unexpected-type', { entry });\n }\n // If there's just a URL and no revision, then it's also assumed to be a\n // versioned URL.\n if (!revision) {\n const urlObject = new URL(url, location.href);\n return {\n cacheKey: urlObject.href,\n url: urlObject.href,\n };\n }\n // Otherwise, construct a properly versioned URL using the custom Workbox\n // search parameter along with the revision info.\n const cacheKeyURL = new URL(url, location.href);\n const originalURL = new URL(url, location.href);\n cacheKeyURL.searchParams.set(REVISION_SEARCH_PARAM, revision);\n return {\n cacheKey: cacheKeyURL.href,\n url: originalURL.href,\n };\n}\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A plugin, designed to be used with PrecacheController, to determine the\n * of assets that were updated (or not updated) during the install event.\n *\n * @private\n */\nclass PrecacheInstallReportPlugin {\n constructor() {\n this.updatedURLs = [];\n this.notUpdatedURLs = [];\n this.handlerWillStart = async ({ request, state, }) => {\n // TODO: `state` should never be undefined...\n if (state) {\n state.originalRequest = request;\n }\n };\n this.cachedResponseWillBeUsed = async ({ event, state, cachedResponse, }) => {\n if (event.type === 'install') {\n if (state &&\n state.originalRequest &&\n state.originalRequest instanceof Request) {\n // TODO: `state` should never be undefined...\n const url = state.originalRequest.url;\n if (cachedResponse) {\n this.notUpdatedURLs.push(url);\n }\n else {\n this.updatedURLs.push(url);\n }\n }\n }\n return cachedResponse;\n };\n }\n}\nexport { PrecacheInstallReportPlugin };\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * A plugin, designed to be used with PrecacheController, to translate URLs into\n * the corresponding cache key, based on the current revision info.\n *\n * @private\n */\nclass PrecacheCacheKeyPlugin {\n constructor({ precacheController }) {\n this.cacheKeyWillBeUsed = async ({ request, params, }) => {\n // Params is type any, can't change right now.\n /* eslint-disable */\n const cacheKey = (params === null || params === void 0 ? void 0 : params.cacheKey) ||\n this._precacheController.getCacheKeyForURL(request.url);\n /* eslint-enable */\n return cacheKey\n ? new Request(cacheKey, { headers: request.headers })\n : request;\n };\n this._precacheController = precacheController;\n }\n}\nexport { PrecacheCacheKeyPlugin };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nlet supportStatus;\n/**\n * A utility function that determines whether the current browser supports\n * constructing a new `Response` from a `response.body` stream.\n *\n * @return {boolean} `true`, if the current browser can successfully\n * construct a `Response` from a `response.body` stream, `false` otherwise.\n *\n * @private\n */\nfunction canConstructResponseFromBodyStream() {\n if (supportStatus === undefined) {\n const testResponse = new Response('');\n if ('body' in testResponse) {\n try {\n new Response(testResponse.body);\n supportStatus = true;\n }\n catch (error) {\n supportStatus = false;\n }\n }\n supportStatus = false;\n }\n return supportStatus;\n}\nexport { canConstructResponseFromBodyStream };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { canConstructResponseFromBodyStream } from './_private/canConstructResponseFromBodyStream.js';\nimport { WorkboxError } from './_private/WorkboxError.js';\nimport './_version.js';\n/**\n * Allows developers to copy a response and modify its `headers`, `status`,\n * or `statusText` values (the values settable via a\n * [`ResponseInit`]{@link https://developer.mozilla.org/en-US/docs/Web/API/Response/Response#Syntax}\n * object in the constructor).\n * To modify these values, pass a function as the second argument. That\n * function will be invoked with a single object with the response properties\n * `{headers, status, statusText}`. The return value of this function will\n * be used as the `ResponseInit` for the new `Response`. To change the values\n * either modify the passed parameter(s) and return it, or return a totally\n * new object.\n *\n * This method is intentionally limited to same-origin responses, regardless of\n * whether CORS was used or not.\n *\n * @param {Response} response\n * @param {Function} modifier\n * @memberof workbox-core\n */\nasync function copyResponse(response, modifier) {\n let origin = null;\n // If response.url isn't set, assume it's cross-origin and keep origin null.\n if (response.url) {\n const responseURL = new URL(response.url);\n origin = responseURL.origin;\n }\n if (origin !== self.location.origin) {\n throw new WorkboxError('cross-origin-copy-response', { origin });\n }\n const clonedResponse = response.clone();\n // Create a fresh `ResponseInit` object by cloning the headers.\n const responseInit = {\n headers: new Headers(clonedResponse.headers),\n status: clonedResponse.status,\n statusText: clonedResponse.statusText,\n };\n // Apply any user modifications.\n const modifiedResponseInit = modifier ? modifier(responseInit) : responseInit;\n // Create the new response from the body stream and `ResponseInit`\n // modifications. Note: not all browsers support the Response.body stream,\n // so fall back to reading the entire body into memory as a blob.\n const body = canConstructResponseFromBodyStream()\n ? clonedResponse.body\n : await clonedResponse.blob();\n return new Response(body, modifiedResponseInit);\n}\nexport { copyResponse };\n","/*\n Copyright 2020 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nfunction stripParams(fullURL, ignoreParams) {\n const strippedURL = new URL(fullURL);\n for (const param of ignoreParams) {\n strippedURL.searchParams.delete(param);\n }\n return strippedURL.href;\n}\n/**\n * Matches an item in the cache, ignoring specific URL params. This is similar\n * to the `ignoreSearch` option, but it allows you to ignore just specific\n * params (while continuing to match on the others).\n *\n * @private\n * @param {Cache} cache\n * @param {Request} request\n * @param {Object} matchOptions\n * @param {Array} ignoreParams\n * @return {Promise}\n */\nasync function cacheMatchIgnoreParams(cache, request, ignoreParams, matchOptions) {\n const strippedRequestURL = stripParams(request.url, ignoreParams);\n // If the request doesn't include any ignored params, match as normal.\n if (request.url === strippedRequestURL) {\n return cache.match(request, matchOptions);\n }\n // Otherwise, match by comparing keys\n const keysOptions = Object.assign(Object.assign({}, matchOptions), { ignoreSearch: true });\n const cacheKeys = await cache.keys(request, keysOptions);\n for (const cacheKey of cacheKeys) {\n const strippedCacheKeyURL = stripParams(cacheKey.url, ignoreParams);\n if (strippedRequestURL === strippedCacheKeyURL) {\n return cache.match(cacheKey, matchOptions);\n }\n }\n return;\n}\nexport { cacheMatchIgnoreParams };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * The Deferred class composes Promises in a way that allows for them to be\n * resolved or rejected from outside the constructor. In most cases promises\n * should be used directly, but Deferreds can be necessary when the logic to\n * resolve a promise must be separate.\n *\n * @private\n */\nclass Deferred {\n /**\n * Creates a promise and exposes its resolve and reject functions as methods.\n */\n constructor() {\n this.promise = new Promise((resolve, reject) => {\n this.resolve = resolve;\n this.reject = reject;\n });\n }\n}\nexport { Deferred };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n// Callbacks to be executed whenever there's a quota error.\n// Can't change Function type right now.\n// eslint-disable-next-line @typescript-eslint/ban-types\nconst quotaErrorCallbacks = new Set();\nexport { quotaErrorCallbacks };\n","\"use strict\";\n// @ts-ignore\ntry {\n self['workbox:strategies:6.5.3'] && _();\n}\ncatch (e) { }\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport { cacheMatchIgnoreParams } from 'workbox-core/_private/cacheMatchIgnoreParams.js';\nimport { Deferred } from 'workbox-core/_private/Deferred.js';\nimport { executeQuotaErrorCallbacks } from 'workbox-core/_private/executeQuotaErrorCallbacks.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { timeout } from 'workbox-core/_private/timeout.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport './_version.js';\nfunction toRequest(input) {\n return typeof input === 'string' ? new Request(input) : input;\n}\n/**\n * A class created every time a Strategy instance instance calls\n * {@link workbox-strategies.Strategy~handle} or\n * {@link workbox-strategies.Strategy~handleAll} that wraps all fetch and\n * cache actions around plugin callbacks and keeps track of when the strategy\n * is \"done\" (i.e. all added `event.waitUntil()` promises have resolved).\n *\n * @memberof workbox-strategies\n */\nclass StrategyHandler {\n /**\n * Creates a new instance associated with the passed strategy and event\n * that's handling the request.\n *\n * The constructor also initializes the state that will be passed to each of\n * the plugins handling this request.\n *\n * @param {workbox-strategies.Strategy} strategy\n * @param {Object} options\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params] The return value from the\n * {@link workbox-routing~matchCallback} (if applicable).\n */\n constructor(strategy, options) {\n this._cacheKeys = {};\n /**\n * The request the strategy is performing (passed to the strategy's\n * `handle()` or `handleAll()` method).\n * @name request\n * @instance\n * @type {Request}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * The event associated with this request.\n * @name event\n * @instance\n * @type {ExtendableEvent}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * A `URL` instance of `request.url` (if passed to the strategy's\n * `handle()` or `handleAll()` method).\n * Note: the `url` param will be present if the strategy was invoked\n * from a workbox `Route` object.\n * @name url\n * @instance\n * @type {URL|undefined}\n * @memberof workbox-strategies.StrategyHandler\n */\n /**\n * A `param` value (if passed to the strategy's\n * `handle()` or `handleAll()` method).\n * Note: the `param` param will be present if the strategy was invoked\n * from a workbox `Route` object and the\n * {@link workbox-routing~matchCallback} returned\n * a truthy value (it will be that value).\n * @name params\n * @instance\n * @type {*|undefined}\n * @memberof workbox-strategies.StrategyHandler\n */\n if (process.env.NODE_ENV !== 'production') {\n assert.isInstance(options.event, ExtendableEvent, {\n moduleName: 'workbox-strategies',\n className: 'StrategyHandler',\n funcName: 'constructor',\n paramName: 'options.event',\n });\n }\n Object.assign(this, options);\n this.event = options.event;\n this._strategy = strategy;\n this._handlerDeferred = new Deferred();\n this._extendLifetimePromises = [];\n // Copy the plugins list (since it's mutable on the strategy),\n // so any mutations don't affect this handler instance.\n this._plugins = [...strategy.plugins];\n this._pluginStateMap = new Map();\n for (const plugin of this._plugins) {\n this._pluginStateMap.set(plugin, {});\n }\n this.event.waitUntil(this._handlerDeferred.promise);\n }\n /**\n * Fetches a given request (and invokes any applicable plugin callback\n * methods) using the `fetchOptions` (for non-navigation requests) and\n * `plugins` defined on the `Strategy` object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - `requestWillFetch()`\n * - `fetchDidSucceed()`\n * - `fetchDidFail()`\n *\n * @param {Request|string} input The URL or request to fetch.\n * @return {Promise}\n */\n async fetch(input) {\n const { event } = this;\n let request = toRequest(input);\n if (request.mode === 'navigate' &&\n event instanceof FetchEvent &&\n event.preloadResponse) {\n const possiblePreloadResponse = (await event.preloadResponse);\n if (possiblePreloadResponse) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Using a preloaded navigation response for ` +\n `'${getFriendlyURL(request.url)}'`);\n }\n return possiblePreloadResponse;\n }\n }\n // If there is a fetchDidFail plugin, we need to save a clone of the\n // original request before it's either modified by a requestWillFetch\n // plugin or before the original request's body is consumed via fetch().\n const originalRequest = this.hasCallback('fetchDidFail')\n ? request.clone()\n : null;\n try {\n for (const cb of this.iterateCallbacks('requestWillFetch')) {\n request = await cb({ request: request.clone(), event });\n }\n }\n catch (err) {\n if (err instanceof Error) {\n throw new WorkboxError('plugin-error-request-will-fetch', {\n thrownErrorMessage: err.message,\n });\n }\n }\n // The request can be altered by plugins with `requestWillFetch` making\n // the original request (most likely from a `fetch` event) different\n // from the Request we make. Pass both to `fetchDidFail` to aid debugging.\n const pluginFilteredRequest = request.clone();\n try {\n let fetchResponse;\n // See https://github.com/GoogleChrome/workbox/issues/1796\n fetchResponse = await fetch(request, request.mode === 'navigate' ? undefined : this._strategy.fetchOptions);\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Network request for ` +\n `'${getFriendlyURL(request.url)}' returned a response with ` +\n `status '${fetchResponse.status}'.`);\n }\n for (const callback of this.iterateCallbacks('fetchDidSucceed')) {\n fetchResponse = await callback({\n event,\n request: pluginFilteredRequest,\n response: fetchResponse,\n });\n }\n return fetchResponse;\n }\n catch (error) {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`Network request for ` +\n `'${getFriendlyURL(request.url)}' threw an error.`, error);\n }\n // `originalRequest` will only exist if a `fetchDidFail` callback\n // is being used (see above).\n if (originalRequest) {\n await this.runCallbacks('fetchDidFail', {\n error: error,\n event,\n originalRequest: originalRequest.clone(),\n request: pluginFilteredRequest.clone(),\n });\n }\n throw error;\n }\n }\n /**\n * Calls `this.fetch()` and (in the background) runs `this.cachePut()` on\n * the response generated by `this.fetch()`.\n *\n * The call to `this.cachePut()` automatically invokes `this.waitUntil()`,\n * so you do not have to manually call `waitUntil()` on the event.\n *\n * @param {Request|string} input The request or URL to fetch and cache.\n * @return {Promise}\n */\n async fetchAndCachePut(input) {\n const response = await this.fetch(input);\n const responseClone = response.clone();\n void this.waitUntil(this.cachePut(input, responseClone));\n return response;\n }\n /**\n * Matches a request from the cache (and invokes any applicable plugin\n * callback methods) using the `cacheName`, `matchOptions`, and `plugins`\n * defined on the strategy object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - cacheKeyWillByUsed()\n * - cachedResponseWillByUsed()\n *\n * @param {Request|string} key The Request or URL to use as the cache key.\n * @return {Promise} A matching response, if found.\n */\n async cacheMatch(key) {\n const request = toRequest(key);\n let cachedResponse;\n const { cacheName, matchOptions } = this._strategy;\n const effectiveRequest = await this.getCacheKey(request, 'read');\n const multiMatchOptions = Object.assign(Object.assign({}, matchOptions), { cacheName });\n cachedResponse = await caches.match(effectiveRequest, multiMatchOptions);\n if (process.env.NODE_ENV !== 'production') {\n if (cachedResponse) {\n logger.debug(`Found a cached response in '${cacheName}'.`);\n }\n else {\n logger.debug(`No cached response found in '${cacheName}'.`);\n }\n }\n for (const callback of this.iterateCallbacks('cachedResponseWillBeUsed')) {\n cachedResponse =\n (await callback({\n cacheName,\n matchOptions,\n cachedResponse,\n request: effectiveRequest,\n event: this.event,\n })) || undefined;\n }\n return cachedResponse;\n }\n /**\n * Puts a request/response pair in the cache (and invokes any applicable\n * plugin callback methods) using the `cacheName` and `plugins` defined on\n * the strategy object.\n *\n * The following plugin lifecycle methods are invoked when using this method:\n * - cacheKeyWillByUsed()\n * - cacheWillUpdate()\n * - cacheDidUpdate()\n *\n * @param {Request|string} key The request or URL to use as the cache key.\n * @param {Response} response The response to cache.\n * @return {Promise} `false` if a cacheWillUpdate caused the response\n * not be cached, and `true` otherwise.\n */\n async cachePut(key, response) {\n const request = toRequest(key);\n // Run in the next task to avoid blocking other cache reads.\n // https://github.com/w3c/ServiceWorker/issues/1397\n await timeout(0);\n const effectiveRequest = await this.getCacheKey(request, 'write');\n if (process.env.NODE_ENV !== 'production') {\n if (effectiveRequest.method && effectiveRequest.method !== 'GET') {\n throw new WorkboxError('attempt-to-cache-non-get-request', {\n url: getFriendlyURL(effectiveRequest.url),\n method: effectiveRequest.method,\n });\n }\n // See https://github.com/GoogleChrome/workbox/issues/2818\n const vary = response.headers.get('Vary');\n if (vary) {\n logger.debug(`The response for ${getFriendlyURL(effectiveRequest.url)} ` +\n `has a 'Vary: ${vary}' header. ` +\n `Consider setting the {ignoreVary: true} option on your strategy ` +\n `to ensure cache matching and deletion works as expected.`);\n }\n }\n if (!response) {\n if (process.env.NODE_ENV !== 'production') {\n logger.error(`Cannot cache non-existent response for ` +\n `'${getFriendlyURL(effectiveRequest.url)}'.`);\n }\n throw new WorkboxError('cache-put-with-no-response', {\n url: getFriendlyURL(effectiveRequest.url),\n });\n }\n const responseToCache = await this._ensureResponseSafeToCache(response);\n if (!responseToCache) {\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Response '${getFriendlyURL(effectiveRequest.url)}' ` +\n `will not be cached.`, responseToCache);\n }\n return false;\n }\n const { cacheName, matchOptions } = this._strategy;\n const cache = await self.caches.open(cacheName);\n const hasCacheUpdateCallback = this.hasCallback('cacheDidUpdate');\n const oldResponse = hasCacheUpdateCallback\n ? await cacheMatchIgnoreParams(\n // TODO(philipwalton): the `__WB_REVISION__` param is a precaching\n // feature. Consider into ways to only add this behavior if using\n // precaching.\n cache, effectiveRequest.clone(), ['__WB_REVISION__'], matchOptions)\n : null;\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Updating the '${cacheName}' cache with a new Response ` +\n `for ${getFriendlyURL(effectiveRequest.url)}.`);\n }\n try {\n await cache.put(effectiveRequest, hasCacheUpdateCallback ? responseToCache.clone() : responseToCache);\n }\n catch (error) {\n if (error instanceof Error) {\n // See https://developer.mozilla.org/en-US/docs/Web/API/DOMException#exception-QuotaExceededError\n if (error.name === 'QuotaExceededError') {\n await executeQuotaErrorCallbacks();\n }\n throw error;\n }\n }\n for (const callback of this.iterateCallbacks('cacheDidUpdate')) {\n await callback({\n cacheName,\n oldResponse,\n newResponse: responseToCache.clone(),\n request: effectiveRequest,\n event: this.event,\n });\n }\n return true;\n }\n /**\n * Checks the list of plugins for the `cacheKeyWillBeUsed` callback, and\n * executes any of those callbacks found in sequence. The final `Request`\n * object returned by the last plugin is treated as the cache key for cache\n * reads and/or writes. If no `cacheKeyWillBeUsed` plugin callbacks have\n * been registered, the passed request is returned unmodified\n *\n * @param {Request} request\n * @param {string} mode\n * @return {Promise}\n */\n async getCacheKey(request, mode) {\n const key = `${request.url} | ${mode}`;\n if (!this._cacheKeys[key]) {\n let effectiveRequest = request;\n for (const callback of this.iterateCallbacks('cacheKeyWillBeUsed')) {\n effectiveRequest = toRequest(await callback({\n mode,\n request: effectiveRequest,\n event: this.event,\n // params has a type any can't change right now.\n params: this.params, // eslint-disable-line\n }));\n }\n this._cacheKeys[key] = effectiveRequest;\n }\n return this._cacheKeys[key];\n }\n /**\n * Returns true if the strategy has at least one plugin with the given\n * callback.\n *\n * @param {string} name The name of the callback to check for.\n * @return {boolean}\n */\n hasCallback(name) {\n for (const plugin of this._strategy.plugins) {\n if (name in plugin) {\n return true;\n }\n }\n return false;\n }\n /**\n * Runs all plugin callbacks matching the given name, in order, passing the\n * given param object (merged ith the current plugin state) as the only\n * argument.\n *\n * Note: since this method runs all plugins, it's not suitable for cases\n * where the return value of a callback needs to be applied prior to calling\n * the next callback. See\n * {@link workbox-strategies.StrategyHandler#iterateCallbacks}\n * below for how to handle that case.\n *\n * @param {string} name The name of the callback to run within each plugin.\n * @param {Object} param The object to pass as the first (and only) param\n * when executing each callback. This object will be merged with the\n * current plugin state prior to callback execution.\n */\n async runCallbacks(name, param) {\n for (const callback of this.iterateCallbacks(name)) {\n // TODO(philipwalton): not sure why `any` is needed. It seems like\n // this should work with `as WorkboxPluginCallbackParam[C]`.\n await callback(param);\n }\n }\n /**\n * Accepts a callback and returns an iterable of matching plugin callbacks,\n * where each callback is wrapped with the current handler state (i.e. when\n * you call each callback, whatever object parameter you pass it will\n * be merged with the plugin's current state).\n *\n * @param {string} name The name fo the callback to run\n * @return {Array}\n */\n *iterateCallbacks(name) {\n for (const plugin of this._strategy.plugins) {\n if (typeof plugin[name] === 'function') {\n const state = this._pluginStateMap.get(plugin);\n const statefulCallback = (param) => {\n const statefulParam = Object.assign(Object.assign({}, param), { state });\n // TODO(philipwalton): not sure why `any` is needed. It seems like\n // this should work with `as WorkboxPluginCallbackParam[C]`.\n return plugin[name](statefulParam);\n };\n yield statefulCallback;\n }\n }\n }\n /**\n * Adds a promise to the\n * [extend lifetime promises]{@link https://w3c.github.io/ServiceWorker/#extendableevent-extend-lifetime-promises}\n * of the event event associated with the request being handled (usually a\n * `FetchEvent`).\n *\n * Note: you can await\n * {@link workbox-strategies.StrategyHandler~doneWaiting}\n * to know when all added promises have settled.\n *\n * @param {Promise} promise A promise to add to the extend lifetime promises\n * of the event that triggered the request.\n */\n waitUntil(promise) {\n this._extendLifetimePromises.push(promise);\n return promise;\n }\n /**\n * Returns a promise that resolves once all promises passed to\n * {@link workbox-strategies.StrategyHandler~waitUntil}\n * have settled.\n *\n * Note: any work done after `doneWaiting()` settles should be manually\n * passed to an event's `waitUntil()` method (not this handler's\n * `waitUntil()` method), otherwise the service worker thread my be killed\n * prior to your work completing.\n */\n async doneWaiting() {\n let promise;\n while ((promise = this._extendLifetimePromises.shift())) {\n await promise;\n }\n }\n /**\n * Stops running the strategy and immediately resolves any pending\n * `waitUntil()` promises.\n */\n destroy() {\n this._handlerDeferred.resolve(null);\n }\n /**\n * This method will call cacheWillUpdate on the available plugins (or use\n * status === 200) to determine if the Response is safe and valid to cache.\n *\n * @param {Request} options.request\n * @param {Response} options.response\n * @return {Promise}\n *\n * @private\n */\n async _ensureResponseSafeToCache(response) {\n let responseToCache = response;\n let pluginsUsed = false;\n for (const callback of this.iterateCallbacks('cacheWillUpdate')) {\n responseToCache =\n (await callback({\n request: this.request,\n response: responseToCache,\n event: this.event,\n })) || undefined;\n pluginsUsed = true;\n if (!responseToCache) {\n break;\n }\n }\n if (!pluginsUsed) {\n if (responseToCache && responseToCache.status !== 200) {\n responseToCache = undefined;\n }\n if (process.env.NODE_ENV !== 'production') {\n if (responseToCache) {\n if (responseToCache.status !== 200) {\n if (responseToCache.status === 0) {\n logger.warn(`The response for '${this.request.url}' ` +\n `is an opaque response. The caching strategy that you're ` +\n `using will not cache opaque responses by default.`);\n }\n else {\n logger.debug(`The response for '${this.request.url}' ` +\n `returned a status code of '${response.status}' and won't ` +\n `be cached as a result.`);\n }\n }\n }\n }\n }\n return responseToCache;\n }\n}\nexport { StrategyHandler };\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Returns a promise that resolves and the passed number of milliseconds.\n * This utility is an async/await-friendly version of `setTimeout`.\n *\n * @param {number} ms\n * @return {Promise}\n * @private\n */\nexport function timeout(ms) {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\nconst getFriendlyURL = (url) => {\n const urlObj = new URL(String(url), location.href);\n // See https://github.com/GoogleChrome/workbox/issues/2323\n // We want to include everything, except for the origin if it's same-origin.\n return urlObj.href.replace(new RegExp(`^${location.origin}`), '');\n};\nexport { getFriendlyURL };\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from '../_private/logger.js';\nimport { quotaErrorCallbacks } from '../models/quotaErrorCallbacks.js';\nimport '../_version.js';\n/**\n * Runs all of the callback functions, one at a time sequentially, in the order\n * in which they were registered.\n *\n * @memberof workbox-core\n * @private\n */\nasync function executeQuotaErrorCallbacks() {\n if (process.env.NODE_ENV !== 'production') {\n logger.log(`About to run ${quotaErrorCallbacks.size} ` +\n `callbacks to clean up caches.`);\n }\n for (const callback of quotaErrorCallbacks) {\n await callback();\n if (process.env.NODE_ENV !== 'production') {\n logger.log(callback, 'is complete.');\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.log('Finished running callbacks.');\n }\n}\nexport { executeQuotaErrorCallbacks };\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { copyResponse } from 'workbox-core/copyResponse.js';\nimport { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { Strategy } from 'workbox-strategies/Strategy.js';\nimport './_version.js';\n/**\n * A {@link workbox-strategies.Strategy} implementation\n * specifically designed to work with\n * {@link workbox-precaching.PrecacheController}\n * to both cache and fetch precached assets.\n *\n * Note: an instance of this class is created automatically when creating a\n * `PrecacheController`; it's generally not necessary to create this yourself.\n *\n * @extends workbox-strategies.Strategy\n * @memberof workbox-precaching\n */\nclass PrecacheStrategy extends Strategy {\n /**\n *\n * @param {Object} [options]\n * @param {string} [options.cacheName] Cache name to store and retrieve\n * requests. Defaults to the cache names provided by\n * {@link workbox-core.cacheNames}.\n * @param {Array} [options.plugins] {@link https://developers.google.com/web/tools/workbox/guides/using-plugins|Plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * {@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters|init}\n * of all fetch() requests made by this strategy.\n * @param {Object} [options.matchOptions] The\n * {@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions|CacheQueryOptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to\n * get the response from the network if there's a precache miss.\n */\n constructor(options = {}) {\n options.cacheName = cacheNames.getPrecacheName(options.cacheName);\n super(options);\n this._fallbackToNetwork =\n options.fallbackToNetwork === false ? false : true;\n // Redirected responses cannot be used to satisfy a navigation request, so\n // any redirected response must be \"copied\" rather than cloned, so the new\n // response doesn't contain the `redirected` flag. See:\n // https://bugs.chromium.org/p/chromium/issues/detail?id=669363&desc=2#c1\n this.plugins.push(PrecacheStrategy.copyRedirectedCacheableResponsesPlugin);\n }\n /**\n * @private\n * @param {Request|string} request A request to run this strategy for.\n * @param {workbox-strategies.StrategyHandler} handler The event that\n * triggered the request.\n * @return {Promise}\n */\n async _handle(request, handler) {\n const response = await handler.cacheMatch(request);\n if (response) {\n return response;\n }\n // If this is an `install` event for an entry that isn't already cached,\n // then populate the cache.\n if (handler.event && handler.event.type === 'install') {\n return await this._handleInstall(request, handler);\n }\n // Getting here means something went wrong. An entry that should have been\n // precached wasn't found in the cache.\n return await this._handleFetch(request, handler);\n }\n async _handleFetch(request, handler) {\n let response;\n const params = (handler.params || {});\n // Fall back to the network if we're configured to do so.\n if (this._fallbackToNetwork) {\n if (process.env.NODE_ENV !== 'production') {\n logger.warn(`The precached response for ` +\n `${getFriendlyURL(request.url)} in ${this.cacheName} was not ` +\n `found. Falling back to the network.`);\n }\n const integrityInManifest = params.integrity;\n const integrityInRequest = request.integrity;\n const noIntegrityConflict = !integrityInRequest || integrityInRequest === integrityInManifest;\n // Do not add integrity if the original request is no-cors\n // See https://github.com/GoogleChrome/workbox/issues/3096\n response = await handler.fetch(new Request(request, {\n integrity: request.mode !== 'no-cors'\n ? integrityInRequest || integrityInManifest\n : undefined,\n }));\n // It's only \"safe\" to repair the cache if we're using SRI to guarantee\n // that the response matches the precache manifest's expectations,\n // and there's either a) no integrity property in the incoming request\n // or b) there is an integrity, and it matches the precache manifest.\n // See https://github.com/GoogleChrome/workbox/issues/2858\n // Also if the original request users no-cors we don't use integrity.\n // See https://github.com/GoogleChrome/workbox/issues/3096\n if (integrityInManifest &&\n noIntegrityConflict &&\n request.mode !== 'no-cors') {\n this._useDefaultCacheabilityPluginIfNeeded();\n const wasCached = await handler.cachePut(request, response.clone());\n if (process.env.NODE_ENV !== 'production') {\n if (wasCached) {\n logger.log(`A response for ${getFriendlyURL(request.url)} ` +\n `was used to \"repair\" the precache.`);\n }\n }\n }\n }\n else {\n // This shouldn't normally happen, but there are edge cases:\n // https://github.com/GoogleChrome/workbox/issues/1441\n throw new WorkboxError('missing-precache-entry', {\n cacheName: this.cacheName,\n url: request.url,\n });\n }\n if (process.env.NODE_ENV !== 'production') {\n const cacheKey = params.cacheKey || (await handler.getCacheKey(request, 'read'));\n // Workbox is going to handle the route.\n // print the routing details to the console.\n logger.groupCollapsed(`Precaching is responding to: ` + getFriendlyURL(request.url));\n logger.log(`Serving the precached url: ${getFriendlyURL(cacheKey instanceof Request ? cacheKey.url : cacheKey)}`);\n logger.groupCollapsed(`View request details here.`);\n logger.log(request);\n logger.groupEnd();\n logger.groupCollapsed(`View response details here.`);\n logger.log(response);\n logger.groupEnd();\n logger.groupEnd();\n }\n return response;\n }\n async _handleInstall(request, handler) {\n this._useDefaultCacheabilityPluginIfNeeded();\n const response = await handler.fetch(request);\n // Make sure we defer cachePut() until after we know the response\n // should be cached; see https://github.com/GoogleChrome/workbox/issues/2737\n const wasCached = await handler.cachePut(request, response.clone());\n if (!wasCached) {\n // Throwing here will lead to the `install` handler failing, which\n // we want to do if *any* of the responses aren't safe to cache.\n throw new WorkboxError('bad-precaching-response', {\n url: request.url,\n status: response.status,\n });\n }\n return response;\n }\n /**\n * This method is complex, as there a number of things to account for:\n *\n * The `plugins` array can be set at construction, and/or it might be added to\n * to at any time before the strategy is used.\n *\n * At the time the strategy is used (i.e. during an `install` event), there\n * needs to be at least one plugin that implements `cacheWillUpdate` in the\n * array, other than `copyRedirectedCacheableResponsesPlugin`.\n *\n * - If this method is called and there are no suitable `cacheWillUpdate`\n * plugins, we need to add `defaultPrecacheCacheabilityPlugin`.\n *\n * - If this method is called and there is exactly one `cacheWillUpdate`, then\n * we don't have to do anything (this might be a previously added\n * `defaultPrecacheCacheabilityPlugin`, or it might be a custom plugin).\n *\n * - If this method is called and there is more than one `cacheWillUpdate`,\n * then we need to check if one is `defaultPrecacheCacheabilityPlugin`. If so,\n * we need to remove it. (This situation is unlikely, but it could happen if\n * the strategy is used multiple times, the first without a `cacheWillUpdate`,\n * and then later on after manually adding a custom `cacheWillUpdate`.)\n *\n * See https://github.com/GoogleChrome/workbox/issues/2737 for more context.\n *\n * @private\n */\n _useDefaultCacheabilityPluginIfNeeded() {\n let defaultPluginIndex = null;\n let cacheWillUpdatePluginCount = 0;\n for (const [index, plugin] of this.plugins.entries()) {\n // Ignore the copy redirected plugin when determining what to do.\n if (plugin === PrecacheStrategy.copyRedirectedCacheableResponsesPlugin) {\n continue;\n }\n // Save the default plugin's index, in case it needs to be removed.\n if (plugin === PrecacheStrategy.defaultPrecacheCacheabilityPlugin) {\n defaultPluginIndex = index;\n }\n if (plugin.cacheWillUpdate) {\n cacheWillUpdatePluginCount++;\n }\n }\n if (cacheWillUpdatePluginCount === 0) {\n this.plugins.push(PrecacheStrategy.defaultPrecacheCacheabilityPlugin);\n }\n else if (cacheWillUpdatePluginCount > 1 && defaultPluginIndex !== null) {\n // Only remove the default plugin; multiple custom plugins are allowed.\n this.plugins.splice(defaultPluginIndex, 1);\n }\n // Nothing needs to be done if cacheWillUpdatePluginCount is 1\n }\n}\nPrecacheStrategy.defaultPrecacheCacheabilityPlugin = {\n async cacheWillUpdate({ response }) {\n if (!response || response.status >= 400) {\n return null;\n }\n return response;\n },\n};\nPrecacheStrategy.copyRedirectedCacheableResponsesPlugin = {\n async cacheWillUpdate({ response }) {\n return response.redirected ? await copyResponse(response) : response;\n },\n};\nexport { PrecacheStrategy };\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { StrategyHandler } from './StrategyHandler.js';\nimport './_version.js';\n/**\n * An abstract base class that all other strategy classes must extend from:\n *\n * @memberof workbox-strategies\n */\nclass Strategy {\n /**\n * Creates a new instance of the strategy and sets all documented option\n * properties as public instance properties.\n *\n * Note: if a custom strategy class extends the base Strategy class and does\n * not need more than these properties, it does not need to define its own\n * constructor.\n *\n * @param {Object} [options]\n * @param {string} [options.cacheName] Cache name to store and retrieve\n * requests. Defaults to the cache names provided by\n * {@link workbox-core.cacheNames}.\n * @param {Array} [options.plugins] [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * to use in conjunction with this caching strategy.\n * @param {Object} [options.fetchOptions] Values passed along to the\n * [`init`](https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters)\n * of [non-navigation](https://github.com/GoogleChrome/workbox/issues/1796)\n * `fetch()` requests made by this strategy.\n * @param {Object} [options.matchOptions] The\n * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n */\n constructor(options = {}) {\n /**\n * Cache name to store and retrieve\n * requests. Defaults to the cache names provided by\n * {@link workbox-core.cacheNames}.\n *\n * @type {string}\n */\n this.cacheName = cacheNames.getRuntimeName(options.cacheName);\n /**\n * The list\n * [Plugins]{@link https://developers.google.com/web/tools/workbox/guides/using-plugins}\n * used by this strategy.\n *\n * @type {Array}\n */\n this.plugins = options.plugins || [];\n /**\n * Values passed along to the\n * [`init`]{@link https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch#Parameters}\n * of all fetch() requests made by this strategy.\n *\n * @type {Object}\n */\n this.fetchOptions = options.fetchOptions;\n /**\n * The\n * [`CacheQueryOptions`]{@link https://w3c.github.io/ServiceWorker/#dictdef-cachequeryoptions}\n * for any `cache.match()` or `cache.put()` calls made by this strategy.\n *\n * @type {Object}\n */\n this.matchOptions = options.matchOptions;\n }\n /**\n * Perform a request strategy and returns a `Promise` that will resolve with\n * a `Response`, invoking all relevant plugin callbacks.\n *\n * When a strategy instance is registered with a Workbox\n * {@link workbox-routing.Route}, this method is automatically\n * called when the route matches.\n *\n * Alternatively, this method can be used in a standalone `FetchEvent`\n * listener by passing it to `event.respondWith()`.\n *\n * @param {FetchEvent|Object} options A `FetchEvent` or an object with the\n * properties listed below.\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params]\n */\n handle(options) {\n const [responseDone] = this.handleAll(options);\n return responseDone;\n }\n /**\n * Similar to {@link workbox-strategies.Strategy~handle}, but\n * instead of just returning a `Promise` that resolves to a `Response` it\n * it will return an tuple of `[response, done]` promises, where the former\n * (`response`) is equivalent to what `handle()` returns, and the latter is a\n * Promise that will resolve once any promises that were added to\n * `event.waitUntil()` as part of performing the strategy have completed.\n *\n * You can await the `done` promise to ensure any extra work performed by\n * the strategy (usually caching responses) completes successfully.\n *\n * @param {FetchEvent|Object} options A `FetchEvent` or an object with the\n * properties listed below.\n * @param {Request|string} options.request A request to run this strategy for.\n * @param {ExtendableEvent} options.event The event associated with the\n * request.\n * @param {URL} [options.url]\n * @param {*} [options.params]\n * @return {Array} A tuple of [response, done]\n * promises that can be used to determine when the response resolves as\n * well as when the handler has completed all its work.\n */\n handleAll(options) {\n // Allow for flexible options to be passed.\n if (options instanceof FetchEvent) {\n options = {\n event: options,\n request: options.request,\n };\n }\n const event = options.event;\n const request = typeof options.request === 'string'\n ? new Request(options.request)\n : options.request;\n const params = 'params' in options ? options.params : undefined;\n const handler = new StrategyHandler(this, { event, request, params });\n const responseDone = this._getResponse(handler, request, event);\n const handlerDone = this._awaitComplete(responseDone, handler, request, event);\n // Return an array of promises, suitable for use with Promise.all().\n return [responseDone, handlerDone];\n }\n async _getResponse(handler, request, event) {\n await handler.runCallbacks('handlerWillStart', { event, request });\n let response = undefined;\n try {\n response = await this._handle(request, handler);\n // The \"official\" Strategy subclasses all throw this error automatically,\n // but in case a third-party Strategy doesn't, ensure that we have a\n // consistent failure when there's no response or an error response.\n if (!response || response.type === 'error') {\n throw new WorkboxError('no-response', { url: request.url });\n }\n }\n catch (error) {\n if (error instanceof Error) {\n for (const callback of handler.iterateCallbacks('handlerDidError')) {\n response = await callback({ error, event, request });\n if (response) {\n break;\n }\n }\n }\n if (!response) {\n throw error;\n }\n else if (process.env.NODE_ENV !== 'production') {\n logger.log(`While responding to '${getFriendlyURL(request.url)}', ` +\n `an ${error instanceof Error ? error.toString() : ''} error occurred. Using a fallback response provided by ` +\n `a handlerDidError plugin.`);\n }\n }\n for (const callback of handler.iterateCallbacks('handlerWillRespond')) {\n response = await callback({ event, request, response });\n }\n return response;\n }\n async _awaitComplete(responseDone, handler, request, event) {\n let response;\n let error;\n try {\n response = await responseDone;\n }\n catch (error) {\n // Ignore errors, as response errors should be caught via the `response`\n // promise above. The `done` promise will only throw for errors in\n // promises passed to `handler.waitUntil()`.\n }\n try {\n await handler.runCallbacks('handlerDidRespond', {\n event,\n request,\n response,\n });\n await handler.doneWaiting();\n }\n catch (waitUntilError) {\n if (waitUntilError instanceof Error) {\n error = waitUntilError;\n }\n }\n await handler.runCallbacks('handlerDidComplete', {\n event,\n request,\n response,\n error: error,\n });\n handler.destroy();\n if (error) {\n throw error;\n }\n }\n}\nexport { Strategy };\n/**\n * Classes extending the `Strategy` based class should implement this method,\n * and leverage the {@link workbox-strategies.StrategyHandler}\n * arg to perform all fetching and cache logic, which will ensure all relevant\n * cache, cache options, fetch options and plugins are used (per the current\n * strategy instance).\n *\n * @name _handle\n * @instance\n * @abstract\n * @function\n * @param {Request} request\n * @param {workbox-strategies.StrategyHandler} handler\n * @return {Promise}\n *\n * @memberof workbox-strategies.Strategy\n */\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { assert } from 'workbox-core/_private/assert.js';\nimport { cacheNames } from 'workbox-core/_private/cacheNames.js';\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { waitUntil } from 'workbox-core/_private/waitUntil.js';\nimport { createCacheKey } from './utils/createCacheKey.js';\nimport { PrecacheInstallReportPlugin } from './utils/PrecacheInstallReportPlugin.js';\nimport { PrecacheCacheKeyPlugin } from './utils/PrecacheCacheKeyPlugin.js';\nimport { printCleanupDetails } from './utils/printCleanupDetails.js';\nimport { printInstallDetails } from './utils/printInstallDetails.js';\nimport { PrecacheStrategy } from './PrecacheStrategy.js';\nimport './_version.js';\n/**\n * Performs efficient precaching of assets.\n *\n * @memberof workbox-precaching\n */\nclass PrecacheController {\n /**\n * Create a new PrecacheController.\n *\n * @param {Object} [options]\n * @param {string} [options.cacheName] The cache to use for precaching.\n * @param {string} [options.plugins] Plugins to use when precaching as well\n * as responding to fetch events for precached assets.\n * @param {boolean} [options.fallbackToNetwork=true] Whether to attempt to\n * get the response from the network if there's a precache miss.\n */\n constructor({ cacheName, plugins = [], fallbackToNetwork = true, } = {}) {\n this._urlsToCacheKeys = new Map();\n this._urlsToCacheModes = new Map();\n this._cacheKeysToIntegrities = new Map();\n this._strategy = new PrecacheStrategy({\n cacheName: cacheNames.getPrecacheName(cacheName),\n plugins: [\n ...plugins,\n new PrecacheCacheKeyPlugin({ precacheController: this }),\n ],\n fallbackToNetwork,\n });\n // Bind the install and activate methods to the instance.\n this.install = this.install.bind(this);\n this.activate = this.activate.bind(this);\n }\n /**\n * @type {workbox-precaching.PrecacheStrategy} The strategy created by this controller and\n * used to cache assets and respond to fetch events.\n */\n get strategy() {\n return this._strategy;\n }\n /**\n * Adds items to the precache list, removing any duplicates and\n * stores the files in the\n * {@link workbox-core.cacheNames|\"precache cache\"} when the service\n * worker installs.\n *\n * This method can be called multiple times.\n *\n * @param {Array} [entries=[]] Array of entries to precache.\n */\n precache(entries) {\n this.addToCacheList(entries);\n if (!this._installAndActiveListenersAdded) {\n self.addEventListener('install', this.install);\n self.addEventListener('activate', this.activate);\n this._installAndActiveListenersAdded = true;\n }\n }\n /**\n * This method will add items to the precache list, removing duplicates\n * and ensuring the information is valid.\n *\n * @param {Array} entries\n * Array of entries to precache.\n */\n addToCacheList(entries) {\n if (process.env.NODE_ENV !== 'production') {\n assert.isArray(entries, {\n moduleName: 'workbox-precaching',\n className: 'PrecacheController',\n funcName: 'addToCacheList',\n paramName: 'entries',\n });\n }\n const urlsToWarnAbout = [];\n for (const entry of entries) {\n // See https://github.com/GoogleChrome/workbox/issues/2259\n if (typeof entry === 'string') {\n urlsToWarnAbout.push(entry);\n }\n else if (entry && entry.revision === undefined) {\n urlsToWarnAbout.push(entry.url);\n }\n const { cacheKey, url } = createCacheKey(entry);\n const cacheMode = typeof entry !== 'string' && entry.revision ? 'reload' : 'default';\n if (this._urlsToCacheKeys.has(url) &&\n this._urlsToCacheKeys.get(url) !== cacheKey) {\n throw new WorkboxError('add-to-cache-list-conflicting-entries', {\n firstEntry: this._urlsToCacheKeys.get(url),\n secondEntry: cacheKey,\n });\n }\n if (typeof entry !== 'string' && entry.integrity) {\n if (this._cacheKeysToIntegrities.has(cacheKey) &&\n this._cacheKeysToIntegrities.get(cacheKey) !== entry.integrity) {\n throw new WorkboxError('add-to-cache-list-conflicting-integrities', {\n url,\n });\n }\n this._cacheKeysToIntegrities.set(cacheKey, entry.integrity);\n }\n this._urlsToCacheKeys.set(url, cacheKey);\n this._urlsToCacheModes.set(url, cacheMode);\n if (urlsToWarnAbout.length > 0) {\n const warningMessage = `Workbox is precaching URLs without revision ` +\n `info: ${urlsToWarnAbout.join(', ')}\\nThis is generally NOT safe. ` +\n `Learn more at https://bit.ly/wb-precache`;\n if (process.env.NODE_ENV === 'production') {\n // Use console directly to display this warning without bloating\n // bundle sizes by pulling in all of the logger codebase in prod.\n console.warn(warningMessage);\n }\n else {\n logger.warn(warningMessage);\n }\n }\n }\n }\n /**\n * Precaches new and updated assets. Call this method from the service worker\n * install event.\n *\n * Note: this method calls `event.waitUntil()` for you, so you do not need\n * to call it yourself in your event handlers.\n *\n * @param {ExtendableEvent} event\n * @return {Promise}\n */\n install(event) {\n // waitUntil returns Promise\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return waitUntil(event, async () => {\n const installReportPlugin = new PrecacheInstallReportPlugin();\n this.strategy.plugins.push(installReportPlugin);\n // Cache entries one at a time.\n // See https://github.com/GoogleChrome/workbox/issues/2528\n for (const [url, cacheKey] of this._urlsToCacheKeys) {\n const integrity = this._cacheKeysToIntegrities.get(cacheKey);\n const cacheMode = this._urlsToCacheModes.get(url);\n const request = new Request(url, {\n integrity,\n cache: cacheMode,\n credentials: 'same-origin',\n });\n await Promise.all(this.strategy.handleAll({\n params: { cacheKey },\n request,\n event,\n }));\n }\n const { updatedURLs, notUpdatedURLs } = installReportPlugin;\n if (process.env.NODE_ENV !== 'production') {\n printInstallDetails(updatedURLs, notUpdatedURLs);\n }\n return { updatedURLs, notUpdatedURLs };\n });\n }\n /**\n * Deletes assets that are no longer present in the current precache manifest.\n * Call this method from the service worker activate event.\n *\n * Note: this method calls `event.waitUntil()` for you, so you do not need\n * to call it yourself in your event handlers.\n *\n * @param {ExtendableEvent} event\n * @return {Promise}\n */\n activate(event) {\n // waitUntil returns Promise\n // eslint-disable-next-line @typescript-eslint/no-unsafe-return\n return waitUntil(event, async () => {\n const cache = await self.caches.open(this.strategy.cacheName);\n const currentlyCachedRequests = await cache.keys();\n const expectedCacheKeys = new Set(this._urlsToCacheKeys.values());\n const deletedURLs = [];\n for (const request of currentlyCachedRequests) {\n if (!expectedCacheKeys.has(request.url)) {\n await cache.delete(request);\n deletedURLs.push(request.url);\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n printCleanupDetails(deletedURLs);\n }\n return { deletedURLs };\n });\n }\n /**\n * Returns a mapping of a precached URL to the corresponding cache key, taking\n * into account the revision information for the URL.\n *\n * @return {Map} A URL to cache key mapping.\n */\n getURLsToCacheKeys() {\n return this._urlsToCacheKeys;\n }\n /**\n * Returns a list of all the URLs that have been precached by the current\n * service worker.\n *\n * @return {Array} The precached URLs.\n */\n getCachedURLs() {\n return [...this._urlsToCacheKeys.keys()];\n }\n /**\n * Returns the cache key used for storing a given URL. If that URL is\n * unversioned, like `/index.html', then the cache key will be the original\n * URL with a search parameter appended to it.\n *\n * @param {string} url A URL whose cache key you want to look up.\n * @return {string} The versioned URL that corresponds to a cache key\n * for the original URL, or undefined if that URL isn't precached.\n */\n getCacheKeyForURL(url) {\n const urlObject = new URL(url, location.href);\n return this._urlsToCacheKeys.get(urlObject.href);\n }\n /**\n * @param {string} url A cache key whose SRI you want to look up.\n * @return {string} The subresource integrity associated with the cache key,\n * or undefined if it's not set.\n */\n getIntegrityForCacheKey(cacheKey) {\n return this._cacheKeysToIntegrities.get(cacheKey);\n }\n /**\n * This acts as a drop-in replacement for\n * [`cache.match()`](https://developer.mozilla.org/en-US/docs/Web/API/Cache/match)\n * with the following differences:\n *\n * - It knows what the name of the precache is, and only checks in that cache.\n * - It allows you to pass in an \"original\" URL without versioning parameters,\n * and it will automatically look up the correct cache key for the currently\n * active revision of that URL.\n *\n * E.g., `matchPrecache('index.html')` will find the correct precached\n * response for the currently active service worker, even if the actual cache\n * key is `'/index.html?__WB_REVISION__=1234abcd'`.\n *\n * @param {string|Request} request The key (without revisioning parameters)\n * to look up in the precache.\n * @return {Promise}\n */\n async matchPrecache(request) {\n const url = request instanceof Request ? request.url : request;\n const cacheKey = this.getCacheKeyForURL(url);\n if (cacheKey) {\n const cache = await self.caches.open(this.strategy.cacheName);\n return cache.match(cacheKey);\n }\n return undefined;\n }\n /**\n * Returns a function that looks up `url` in the precache (taking into\n * account revision information), and returns the corresponding `Response`.\n *\n * @param {string} url The precached URL which will be used to lookup the\n * `Response`.\n * @return {workbox-routing~handlerCallback}\n */\n createHandlerBoundToURL(url) {\n const cacheKey = this.getCacheKeyForURL(url);\n if (!cacheKey) {\n throw new WorkboxError('non-precached-url', { url });\n }\n return (options) => {\n options.request = new Request(url);\n options.params = Object.assign({ cacheKey }, options.params);\n return this.strategy.handle(options);\n };\n }\n}\nexport { PrecacheController };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { PrecacheController } from '../PrecacheController.js';\nimport '../_version.js';\nlet precacheController;\n/**\n * @return {PrecacheController}\n * @private\n */\nexport const getOrCreatePrecacheController = () => {\n if (!precacheController) {\n precacheController = new PrecacheController();\n }\n return precacheController;\n};\n","/*\n Copyright 2020 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { getFriendlyURL } from 'workbox-core/_private/getFriendlyURL.js';\nimport { Route } from 'workbox-routing/Route.js';\nimport { generateURLVariations } from './utils/generateURLVariations.js';\nimport './_version.js';\n/**\n * A subclass of {@link workbox-routing.Route} that takes a\n * {@link workbox-precaching.PrecacheController}\n * instance and uses it to match incoming requests and handle fetching\n * responses from the precache.\n *\n * @memberof workbox-precaching\n * @extends workbox-routing.Route\n */\nclass PrecacheRoute extends Route {\n /**\n * @param {PrecacheController} precacheController A `PrecacheController`\n * instance used to both match requests and respond to fetch events.\n * @param {Object} [options] Options to control how requests are matched\n * against the list of precached URLs.\n * @param {string} [options.directoryIndex=index.html] The `directoryIndex` will\n * check cache entries for a URLs ending with '/' to see if there is a hit when\n * appending the `directoryIndex` value.\n * @param {Array} [options.ignoreURLParametersMatching=[/^utm_/, /^fbclid$/]] An\n * array of regex's to remove search params when looking for a cache match.\n * @param {boolean} [options.cleanURLs=true] The `cleanURLs` option will\n * check the cache for the URL with a `.html` added to the end of the end.\n * @param {workbox-precaching~urlManipulation} [options.urlManipulation]\n * This is a function that should take a URL and return an array of\n * alternative URLs that should be checked for precache matches.\n */\n constructor(precacheController, options) {\n const match = ({ request, }) => {\n const urlsToCacheKeys = precacheController.getURLsToCacheKeys();\n for (const possibleURL of generateURLVariations(request.url, options)) {\n const cacheKey = urlsToCacheKeys.get(possibleURL);\n if (cacheKey) {\n const integrity = precacheController.getIntegrityForCacheKey(cacheKey);\n return { cacheKey, integrity };\n }\n }\n if (process.env.NODE_ENV !== 'production') {\n logger.debug(`Precaching did not find a match for ` + getFriendlyURL(request.url));\n }\n return;\n };\n super(match, precacheController.strategy);\n }\n}\nexport { PrecacheRoute };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { removeIgnoredSearchParams } from './removeIgnoredSearchParams.js';\nimport '../_version.js';\n/**\n * Generator function that yields possible variations on the original URL to\n * check, one at a time.\n *\n * @param {string} url\n * @param {Object} options\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function* generateURLVariations(url, { ignoreURLParametersMatching = [/^utm_/, /^fbclid$/], directoryIndex = 'index.html', cleanURLs = true, urlManipulation, } = {}) {\n const urlObject = new URL(url, location.href);\n urlObject.hash = '';\n yield urlObject.href;\n const urlWithoutIgnoredParams = removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching);\n yield urlWithoutIgnoredParams.href;\n if (directoryIndex && urlWithoutIgnoredParams.pathname.endsWith('/')) {\n const directoryURL = new URL(urlWithoutIgnoredParams.href);\n directoryURL.pathname += directoryIndex;\n yield directoryURL.href;\n }\n if (cleanURLs) {\n const cleanURL = new URL(urlWithoutIgnoredParams.href);\n cleanURL.pathname += '.html';\n yield cleanURL.href;\n }\n if (urlManipulation) {\n const additionalURLs = urlManipulation({ url: urlObject });\n for (const urlToAttempt of additionalURLs) {\n yield urlToAttempt.href;\n }\n }\n}\n","/*\n Copyright 2018 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport '../_version.js';\n/**\n * Removes any URL search parameters that should be ignored.\n *\n * @param {URL} urlObject The original URL.\n * @param {Array} ignoreURLParametersMatching RegExps to test against\n * each search parameter name. Matches mean that the search parameter should be\n * ignored.\n * @return {URL} The URL with any ignored search parameters removed.\n *\n * @private\n * @memberof workbox-precaching\n */\nexport function removeIgnoredSearchParams(urlObject, ignoreURLParametersMatching = []) {\n // Convert the iterable into an array at the start of the loop to make sure\n // deletion doesn't mess up iteration.\n for (const paramName of [...urlObject.searchParams.keys()]) {\n if (ignoreURLParametersMatching.some((regExp) => regExp.test(paramName))) {\n urlObject.searchParams.delete(paramName);\n }\n }\n return urlObject;\n}\n","/*\n Copyright 2019 Google LLC\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { registerRoute } from 'workbox-routing/registerRoute.js';\nimport { getOrCreatePrecacheController } from './utils/getOrCreatePrecacheController.js';\nimport { PrecacheRoute } from './PrecacheRoute.js';\nimport './_version.js';\n/**\n * Add a `fetch` listener to the service worker that will\n * respond to\n * [network requests]{@link https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API/Using_Service_Workers#Custom_responses_to_requests}\n * with precached assets.\n *\n * Requests for assets that aren't precached, the `FetchEvent` will not be\n * responded to, allowing the event to fall through to other `fetch` event\n * listeners.\n *\n * @param {Object} [options] See the {@link workbox-precaching.PrecacheRoute}\n * options.\n *\n * @memberof workbox-precaching\n */\nfunction addRoute(options) {\n const precacheController = getOrCreatePrecacheController();\n const precacheRoute = new PrecacheRoute(precacheController, options);\n registerRoute(precacheRoute);\n}\nexport { addRoute };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { logger } from 'workbox-core/_private/logger.js';\nimport { WorkboxError } from 'workbox-core/_private/WorkboxError.js';\nimport { Route } from './Route.js';\nimport { RegExpRoute } from './RegExpRoute.js';\nimport { getOrCreateDefaultRouter } from './utils/getOrCreateDefaultRouter.js';\nimport './_version.js';\n/**\n * Easily register a RegExp, string, or function with a caching\n * strategy to a singleton Router instance.\n *\n * This method will generate a Route for you if needed and\n * call {@link workbox-routing.Router#registerRoute}.\n *\n * @param {RegExp|string|workbox-routing.Route~matchCallback|workbox-routing.Route} capture\n * If the capture param is a `Route`, all other arguments will be ignored.\n * @param {workbox-routing~handlerCallback} [handler] A callback\n * function that returns a Promise resulting in a Response. This parameter\n * is required if `capture` is not a `Route` object.\n * @param {string} [method='GET'] The HTTP method to match the Route\n * against.\n * @return {workbox-routing.Route} The generated `Route`.\n *\n * @memberof workbox-routing\n */\nfunction registerRoute(capture, handler, method) {\n let route;\n if (typeof capture === 'string') {\n const captureUrl = new URL(capture, location.href);\n if (process.env.NODE_ENV !== 'production') {\n if (!(capture.startsWith('/') || capture.startsWith('http'))) {\n throw new WorkboxError('invalid-string', {\n moduleName: 'workbox-routing',\n funcName: 'registerRoute',\n paramName: 'capture',\n });\n }\n // We want to check if Express-style wildcards are in the pathname only.\n // TODO: Remove this log message in v4.\n const valueToCheck = capture.startsWith('http')\n ? captureUrl.pathname\n : capture;\n // See https://github.com/pillarjs/path-to-regexp#parameters\n const wildcards = '[*:?+]';\n if (new RegExp(`${wildcards}`).exec(valueToCheck)) {\n logger.debug(`The '$capture' parameter contains an Express-style wildcard ` +\n `character (${wildcards}). Strings are now always interpreted as ` +\n `exact matches; use a RegExp for partial or wildcard matches.`);\n }\n }\n const matchCallback = ({ url }) => {\n if (process.env.NODE_ENV !== 'production') {\n if (url.pathname === captureUrl.pathname &&\n url.origin !== captureUrl.origin) {\n logger.debug(`${capture} only partially matches the cross-origin URL ` +\n `${url.toString()}. This route will only handle cross-origin requests ` +\n `if they match the entire URL.`);\n }\n }\n return url.href === captureUrl.href;\n };\n // If `capture` is a string then `handler` and `method` must be present.\n route = new Route(matchCallback, handler, method);\n }\n else if (capture instanceof RegExp) {\n // If `capture` is a `RegExp` then `handler` and `method` must be present.\n route = new RegExpRoute(capture, handler, method);\n }\n else if (typeof capture === 'function') {\n // If `capture` is a function then `handler` and `method` must be present.\n route = new Route(capture, handler, method);\n }\n else if (capture instanceof Route) {\n route = capture;\n }\n else {\n throw new WorkboxError('unsupported-route-type', {\n moduleName: 'workbox-routing',\n funcName: 'registerRoute',\n paramName: 'capture',\n });\n }\n const defaultRouter = getOrCreateDefaultRouter();\n defaultRouter.registerRoute(route);\n return route;\n}\nexport { registerRoute };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport './_version.js';\n/**\n * Claim any currently available clients once the service worker\n * becomes active. This is normally used in conjunction with `skipWaiting()`.\n *\n * @memberof workbox-core\n */\nfunction clientsClaim() {\n self.addEventListener('activate', () => self.clients.claim());\n}\nexport { clientsClaim };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { addRoute } from './addRoute.js';\nimport { precache } from './precache.js';\nimport './_version.js';\n/**\n * This method will add entries to the precache list and add a route to\n * respond to fetch events.\n *\n * This is a convenience method that will call\n * {@link workbox-precaching.precache} and\n * {@link workbox-precaching.addRoute} in a single call.\n *\n * @param {Array} entries Array of entries to precache.\n * @param {Object} [options] See the\n * {@link workbox-precaching.PrecacheRoute} options.\n *\n * @memberof workbox-precaching\n */\nfunction precacheAndRoute(entries, options) {\n precache(entries);\n addRoute(options);\n}\nexport { precacheAndRoute };\n","/*\n Copyright 2019 Google LLC\n\n Use of this source code is governed by an MIT-style\n license that can be found in the LICENSE file or at\n https://opensource.org/licenses/MIT.\n*/\nimport { getOrCreatePrecacheController } from './utils/getOrCreatePrecacheController.js';\nimport './_version.js';\n/**\n * Adds items to the precache list, removing any duplicates and\n * stores the files in the\n * {@link workbox-core.cacheNames|\"precache cache\"} when the service\n * worker installs.\n *\n * This method can be called multiple times.\n *\n * Please note: This method **will not** serve any of the cached files for you.\n * It only precaches files. To respond to a network request you call\n * {@link workbox-precaching.addRoute}.\n *\n * If you have a single array of files to precache, you can just call\n * {@link workbox-precaching.precacheAndRoute}.\n *\n * @param {Array} [entries=[]] Array of entries to precache.\n *\n * @memberof workbox-precaching\n */\nfunction precache(entries) {\n const precacheController = getOrCreatePrecacheController();\n precacheController.precache(entries);\n}\nexport { precache };\n"],"names":["self","_","e","messageGenerator","code","args","msg","length","JSON","stringify","WorkboxError","Error","constructor","errorCode","details","super","name","normalizeHandler","handler","handle","Route","match","method","this","setCatchHandler","catchHandler","RegExpRoute","regExp","url","result","exec","href","origin","location","index","slice","Router","_routes","Map","_defaultHandlerMap","routes","addFetchListener","addEventListener","event","request","responsePromise","handleRequest","respondWith","addCacheListener","data","type","payload","requestPromises","Promise","all","urlsToCache","map","entry","Request","waitUntil","ports","then","postMessage","URL","protocol","startsWith","sameOrigin","params","route","findMatchingRoute","has","get","err","reject","_catchHandler","catch","async","catchErr","matchResult","Array","isArray","Object","keys","undefined","setDefaultHandler","set","registerRoute","push","unregisterRoute","routeIndex","indexOf","splice","defaultRouter","_cacheNameDetails","googleAnalytics","precache","prefix","runtime","suffix","registration","scope","_createCacheName","cacheName","filter","value","join","cacheNames","userCacheName","asyncFn","returnPromise","createCacheKey","urlObject","cacheKey","revision","cacheKeyURL","originalURL","searchParams","PrecacheInstallReportPlugin","updatedURLs","notUpdatedURLs","handlerWillStart","state","originalRequest","cachedResponseWillBeUsed","cachedResponse","PrecacheCacheKeyPlugin","precacheController","cacheKeyWillBeUsed","_precacheController","getCacheKeyForURL","headers","supportStatus","copyResponse","response","modifier","clonedResponse","clone","responseInit","Headers","status","statusText","modifiedResponseInit","body","testResponse","Response","error","canConstructResponseFromBodyStream","blob","stripParams","fullURL","ignoreParams","strippedURL","param","delete","Deferred","promise","resolve","quotaErrorCallbacks","Set","toRequest","input","StrategyHandler","strategy","options","_cacheKeys","assign","_strategy","_handlerDeferred","_extendLifetimePromises","_plugins","plugins","_pluginStateMap","plugin","fetch","mode","FetchEvent","preloadResponse","possiblePreloadResponse","hasCallback","cb","iterateCallbacks","thrownErrorMessage","message","pluginFilteredRequest","fetchResponse","fetchOptions","callback","runCallbacks","fetchAndCachePut","responseClone","cachePut","cacheMatch","key","matchOptions","effectiveRequest","getCacheKey","multiMatchOptions","caches","ms","setTimeout","String","replace","RegExp","responseToCache","_ensureResponseSafeToCache","cache","open","hasCacheUpdateCallback","oldResponse","strippedRequestURL","keysOptions","ignoreSearch","cacheKeys","cacheMatchIgnoreParams","put","executeQuotaErrorCallbacks","newResponse","statefulCallback","statefulParam","shift","destroy","pluginsUsed","PrecacheStrategy","responseDone","handleAll","_getResponse","_awaitComplete","_handle","doneWaiting","waitUntilError","_fallbackToNetwork","fallbackToNetwork","copyRedirectedCacheableResponsesPlugin","_handleInstall","_handleFetch","integrityInManifest","integrity","integrityInRequest","noIntegrityConflict","_useDefaultCacheabilityPluginIfNeeded","defaultPluginIndex","cacheWillUpdatePluginCount","entries","defaultPrecacheCacheabilityPlugin","cacheWillUpdate","redirected","PrecacheController","_urlsToCacheKeys","_urlsToCacheModes","_cacheKeysToIntegrities","install","bind","activate","addToCacheList","_installAndActiveListenersAdded","urlsToWarnAbout","cacheMode","firstEntry","secondEntry","warningMessage","console","warn","installReportPlugin","credentials","currentlyCachedRequests","expectedCacheKeys","values","deletedURLs","getURLsToCacheKeys","getCachedURLs","getIntegrityForCacheKey","matchPrecache","createHandlerBoundToURL","getOrCreatePrecacheController","PrecacheRoute","urlsToCacheKeys","possibleURL","ignoreURLParametersMatching","directoryIndex","cleanURLs","urlManipulation","hash","urlWithoutIgnoredParams","paramName","some","test","removeIgnoredSearchParams","pathname","endsWith","directoryURL","cleanURL","additionalURLs","urlToAttempt","generateURLVariations","addRoute","capture","captureUrl","moduleName","funcName","clients","claim"],"mappings":"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"} \ No newline at end of file

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